# 特徴

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

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

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

#### ■ 内蔵周辺機能

- ・独立した前置分周器と比較機能付き1つの8ビットタイマ/カウンタ
- ・独立した前置分周器、比較、捕獲機能付き1つの16ビットタイマ/カウンタ
- ・6または8チャネルの10ビット A/D変換器
- ・主装置/従装置動作SPI直列インターフェース
- ハーイト対応2線直列インターフェース(Philips I<sup>2</sup>C互換)
- ・設定可能な専用発振器付きウォッチドッグ゙タイマ
- ・アナログ比較器
- ・ピン変化での割り込みと起動復帰

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

- ・ ディブック WIRE内蔵ディブック システム
- ・SPIポート経由の実装書き込み(ISP)
- ・電源ONリセット回路と設定可能な低電圧検出器(BOD)
- ・校正可能な内蔵発振器
- ・外部及び内部の割り込み
- ・アイドル、A/D変換雑音低減、パワーダウンの3つの低消費動作
- チップ上の温度感知器

### ■ I/Oと外囲器

- 24ビットの設定可能なI/O
- ・28ピンPDIP、28パットQFN
- 28ビットの設定可能なI/O
- ・32リート、TQFP、32パット、QFN、32球UFBGA

### ■ 動作電圧

• 1.8∼5.5V

### ■ 動作温度

· -40∼85°C

# ■ 動作速度

- $0 \sim 4 \text{MHz} / 1.8 \sim 5.5 \text{V}$
- $\cdot 0 \sim 8 MHz/2.7 \sim 5.5 V$
- $0 \sim 12 MHz/4.5 \sim 5.5 V$

### ■ 代表消費電力

- · 240μA (活動動作、1MHz, 1.8V)
- ・0.1μA (パワーダウン動作)



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

ATtiny48 ATtiny88

Rev. 8008H-04/11, 8008HJ5-04/22





# 1. ピン配置



| 表1- | 表1-1. 32UFBGAL°ン配列 (上面視、190頁参照) |     |     |     |      |     |  |  |  |  |  |
|-----|---------------------------------|-----|-----|-----|------|-----|--|--|--|--|--|
|     | 1                               | 2   | 3   | 4   | 5    | 6   |  |  |  |  |  |
| Α   | PD2                             | PD1 | PC6 | PC4 | PC2  | PC1 |  |  |  |  |  |
| В   | PD3                             | PD4 | PD0 | PC5 | PC3  | PC0 |  |  |  |  |  |
| С   | GND                             | PA2 |     |     | PA1  | GND |  |  |  |  |  |
| D   | VCC                             | PA3 |     |     | PC7  | PA0 |  |  |  |  |  |
| Е   | PB6                             | PD6 | PB0 | PB2 | AVCC | PB5 |  |  |  |  |  |
| F   | PB7                             | PD5 | PD7 | PB1 | PB3  | PB4 |  |  |  |  |  |

# 1.1. ピン概要

#### 1.1.1. VCC

デジタル電源ピン。

#### 1.1.2. AVCC

AVCCは分離I/OピンとA/D変換器用供給電圧(電源)ピンです。例えA/D変換が使われなくても、このピンは外部的にVCCへ接続されるべきです。A/D変換が使われる場合、111頁の「**アナログ雑音低減技術**」で記述されるように、このピンは低域通過濾波器を通してVCCへ接続されることが推奨されます。

PC7,PC5~0と(32ピン外囲器での)PA1~0ピンはそれらの供給電圧をAVCCから受けます。他の全てのI/Oピンはそれらの供給電圧をVCCから取り入れます。

### 1.1.3. GND

接地ピン。

### 1.1.4. PA3~PA0 - (ポートA)

ポートAは32ピンTQFPと32ピンQFN/MLF外囲器での(ビット毎に選択される)内蔵プルアップ抵抗付きの4ビットの双方向入出力ポートです。 PA3~0B出力緩衝部は共に吐き出し/吸い込み能力の対称駆動特性です。入力としてプルアップ抵抗が有効の場合、外部的にLowへ引き込まれたポートAピンには吐き出し電流が流れます。リセット条件が有効になるとき、クロックが動作していなくても、ポートAピンはHi-Zになります。

このポートは32リート、TQFP、32パット、QFN、32球UFBGA外囲器でだけ利用可能です。

### 1.1.5. PB7~PB0 - (ホートB)

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

クロック選択ヒューズ設定に依存し、PB6は内部クロック操作回路の入力として使えます。

ポートBの各特殊機能は43頁の「ホートBの交換機能」で詳しく述べられます。

#### 1.1.6. PC7.PC5~PC0 - (ポートC)

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

### 1.1.7. PC6/RESET

RSTDISBLヒューズがプログラム(0)されると、PC6はI/Oピンとして使われます。PC6の電気的特性がポートCの他のピンのそれらと異なることに注意してください。

RSTDISBLヒュースが非プログラム(1)の場合、PC6はリセット入力として使われます。クロックが動作していなくても、最小パルス幅より長いこのピックのLowレベルはリセットを生成します。最小パルス幅は137頁の表22-3.で与えられます。より短いパルスはリセットの生成が保証されません。ポートCの各特殊機能は45頁の「ポートCの交換機能」で詳しく述べられます。

## 1.1.8. PD7~PD0 - (ポートD)

ポートDは(ビット毎に選択される)内蔵プルアップ抵抗付きの8ビットの双方向入出力ポートです。PD7~4出力緩衝部は共に吐き出し/吸い込み能力の対称駆動特性で、一方PD3~0出力緩衝部は高い吸い込み能力を持ちます。入力としてプルアップ抵抗が有効の場合、外部的にLowへ引き込まれたポートDピンには吐き出し電流が流れます。リセット条件が有効になるとき、クロックが動作していなくても、ポートDピンはHi-Zになります。

ポートDの各特殊機能は47頁の「ホートDの交換機能」で詳しく述べられます。





# 2. 概要

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

## 2.1. 構成図



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

ATtiny48/88は以下の特徴を提供します。

- ・4/8Kバイの実装書き換え可能なフラッシュ メモリ
- 64/64バイトのEEPROM
- 256/512バイトのSRAM
- ・24(28ピン外囲器), 28(32ピン外囲器)本の汎用入出力線
- ・32個の汎用レジスタ
- 比較動作を持つ柔軟な2つのタイマ/カウンタ
- ・内部及び外部割り込み
- ・バイト志向の2線直列インターフェース

- SPI直列ポート
- 6(28ピン外囲器), 8(32ピン外囲器)チャネルの10ビット A/D変換器
- ・設定変更可能な内部発振器付きウォッチドッグタイマ
- ・ソフトウェアで選択できる3つの低消費動作機能

本デバイスは節電用に以下の動作形態を含みます。

- ・アイドル動作: CPUを停止しますが、タイマ/カウンタ、2線直列インターフェース、SPIポート、割り込み機能は有効で動作を継続します。
- ・A/D変換雑音低減動作:A/D変換器を除く周辺機能とCPUを停止し、A/D変換中の切り替え雑音を最小にします。
- ・ パワータ・ウン動作: レシ、スタはそれらの内容を保ち、次の外部割り込みかハート・ウェア リセットまで全てのチップ機能が禁止(無効)されます。

本デ、バイスはAtmelの高密度不揮発性メモリ技術を使って製造されています。内蔵の実装書き換え(ISP)可能なプログラム用フラッシュメモリは規定の不揮発性メモリ書き込み器、SPI直列インターフェース経由、AVRコア上ブートプログラムの実行によって再書き込みができます。プートプログラムはフラッシュメモリ内の応用プログラムの読み込みにどのインターフェースでも使えます。モノリシックチップ上の自己実装書き換え可能なフラッシュメモリと、8ビットRISC型CPUの組み合わせによるAtmel ATtiny48/88は多くの組み込み制御の応用に対して高度な柔軟性と対費用効果をもたらす強力なマイクロコントローラです。

ATtiny48/88 AVRはCコンパイラ、マクロ アセンブラ、デ・ハ・ッカ、シミュレータ、評価キットを含む専用のプログラム及びシステム開発ツールで支援されます。

# 2.2. ATtiny48とATtiny88間の違い

右の表2-1.で要約されるように、ATtiny48とATtiny88はメキモリ容量だけが異なります。

| 表2-1. メモリ容量対比表 |           |        |        |  |  |  |  |  |
|----------------|-----------|--------|--------|--|--|--|--|--|
| デバイス名          | フラッシュ メモリ | EEPROM | SRAM   |  |  |  |  |  |
| ATtiny48       | 4Kバイト     | 64バイト  | 256バイト |  |  |  |  |  |
| ATtiny88       | 8Kバイト     | 64バイト  | 512バイト |  |  |  |  |  |

# 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命令です。

## 3.3. 容量性接触感知

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

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

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

## 3.4. データ保持力

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

### 3.5. お断り

本データシート内で示された代表値はシミュレーションと同じ製法技術で製造された他のAVRマイクロコントローラの特性に基いています。





# 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で実行できます。算術演算操作後、操作結果についての情報を反映するためにステータスレジスタ (SREG)が更新されます。

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

16ビット語(ワード)形式ですが、32ビット命令もあります。いくつかのデバイスが命令一式の部分だけを実装するため、実際の命令一式は変化します。

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

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

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

I/Oメモリ空間は制御レジスタ、SPI、他のI/O機能としてCPU周辺機能用の64アドレスを含みます。I/Oメモリは直接またはレジスタ ファイルの次のデータ空間位置\$20~\$5Fとしてアクセスできます。加えてATtiny48/88にはST/STS/STDとLD/LDS/LDD命令だけ使えるSRAM内の\$60~\$FFに拡張I/O空間があります。

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

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



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

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

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

# 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レシ、スタ(ポーインタ)がレシ、スタファイル内のどのレシ、スタの指示にも設定できるように、このメモリ構成は非常に柔軟なレシ、スタのアクセスを提供します。

|             | 7   | 0 アドレス | 特殊機能レジブスタ                       |
|-------------|-----|--------|---------------------------------|
|             | R0  | \$00   |                                 |
|             | R1  | \$01   |                                 |
|             | R2  | \$02   |                                 |
|             | ?   |        |                                 |
|             | R13 | \$0D   |                                 |
|             | R14 | \$0E   |                                 |
| λн <b>ш</b> | R15 | \$0F   |                                 |
| 汎用<br>レシブスタ | R16 | \$10   |                                 |
| ファイル        | R17 | \$11   |                                 |
| , , (,      | ?   |        |                                 |
|             | R26 | \$1A   | Xレジスタ       下位パイト         上位パイト |
|             | R27 | \$1B   | 上位バイト                           |
|             | R28 | \$1C   | Yレジスタート位バイト                     |
|             | R29 | \$1D   |                                 |
|             | R30 | \$1E   | フレジスター・F位バイ                     |
|             | R31 | \$1F   | 上位が小                            |

## 4.5.1. Xレシ、スタ, Yレシ、スタ, Zレシ、スタ

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

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

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

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

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

スタック ポーインタはサブルーチンや割り込みのスタックが配置されるデータ メモリの領域を指し示します。このスタック空間はサブルーチン呼び出しの実行や割り込みの許可の何れにも先立って、プログラムによって定義されなければなりません。

このポインタはPUSH命令でデータがスタックに置かれる時に-1され、POP命令でデータが取得される時に+1されれます。これはサブルーチン呼び出しや割り込み処理ルーチンへ飛ぶことによって戻りアトレスがスタックに置かれる時に-2され、サブルーチンからの復帰(RET命令)や割り込みからの復帰(RETI命令)によって戻りアトレスががスタックから取得される時に+2されます。

AVRのスタック ポインタは代表的にI/O空間内の2つの8ビット レジスタとして実装されます。スタック ポインタの幅と実装されるビット数はデバイス 依存です。いくつかのAVRデバイスではSPLだけを用いて全てのデータ メモリをアドレス指定することができます。その場合、SPHレジスタは実装されません。

スタック ポインタはI/Oレシ スタ領域(SRAMの最低アトレスである最小値)以上を指示するように設定されなければなりません。11頁の表5-2. をご覧ください。





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

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

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

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





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

AVRは多くの異なる割り込み元を提供します。これらの割り込みと独立したリセット へうタ各々はプログラム メモリ空間内に独立したプログラム へうタを持ちます。全ての割り込みは割り込みを許可するために、ステータス レジスタ(SREG)の全割り込み許可(I)ビットと共に論理1が書かれなければならない個別の許可ビットを割り当てられます。LB2またはLB1施錠ビットがプログラム(0)されると、プログラム カウンタ値によっては割り込みが自動的に禁止されるかもしれません。この特質はソフトウェア保護を改善します。詳細については121頁の「施錠ビット、ヒュース・ビット、デバイス識票」章をご覧ください。

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

割り込みが起こると全割り込み許可(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
           CLI
                                                    ;EEPROM書き込み手順中割り込み禁止
                                                    ;EEPROM主書き込み許可
           SBI
                  EECR, EEMPE
                  EECR, EEPE
                                                    ;EEPROM書き込み開始
           SBT
           OUT
                  SREG, R16
                                                    ;ステータスレジスタを復帰
C言語プログラム例
                                                    /* ステータス レジ スタ保存変数定義 */
           char cSREG;
           cSREG = SREG;
                                                    /* ステータス レシ スタを保存 */
            _disable_interrupt();
                                                   /* EEPROM書き込み手順中割り込み禁止 */
           EECR \mid = (1 << EEMPE);
                                                   /* EEPROM主書き込み許可 */
                                                   /* EEPROM書き込み開始 */
           EECR = (1 < EEPE);
           SREG = cSREG:
                                                   /* ステータス レシ スタを復帰 */
注: 5頁の「コート・例について」をご覧ください。
```

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

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

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

**注**: 5頁の「コード例について」をご覧ください。

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

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

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





# 4.9. コア関係レジスタ

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

| ピット         | 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |     |
|-------------|--------|--------|--------|--------|--------|--------|--------|--------|-----|
| \$3E (\$5E) | _      | -      | -      | -      | -      | -      | (SP9)  | SP8    | SPH |
| Read/Write  | R      | R      | R      | R      | R      | R      | R/W    | R/W    |     |
| 初期値         | RAMEND |     |
| ピット         | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |     |
| \$3D (\$5D) | SP7    | SP6    | SP5    | SP4    | SP3    | SP2    | SP1    | SP0    | SPL |
| Read/Write  | R/W    |     |
| 初期値         | RAMEND |     |
|             |        |        |        |        |        |        |        |        |     |

# 4.9.2. SREG - ステータス レジスタ (Status Register)

| ピット         | 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)を示します。詳細情報については「命令要約」記述をご覧ください。

## **■ L**'y**h**1 - **Z** : **t**'**D** 7ラク (Zero Flag)

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

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

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

(<mark>訳補</mark>) 内蔵SRAMはATtiny48が256バイト(\$0100~\$01FF)、ATtiny88が512バイト(\$0100~\$02FF)です。従ってATtiny48ではSPHの SP9が利用できません。RAMENDはATtiny48が\$01FF(0000 0001 1111 1111)、ATtiny88が\$02FF(0000 0010 1111 1111)になります。

# 5. メモリ

AVR構造は独立したアトレス空間に各々のメモリ形式を配置し、プログラムメモリとデータメモリを区別します。実行可能コートは不揮発性プログラムメモリ(フラッシュ)に配置され、一方データは揮発性(SRAM)または不揮発性(EEPROM)のメモリに置くことができます。右の図5-1.をご覧ください。

全てのメモリ空間は直線的で規則的です。



# 5.1. プログラム メモリ

ATtiny48/88はプログラム保存用に実装書き換え可能な4/8Kバイのフラッシュメモリをチップ上に含みます。フラッシュメモリは不揮発性、換言するとそれらは例え電力がない時でも格納した情報を維持します。

全てのAVR命令が16または32ビット幅のため、このフラッシュメモリは2/4K×16ビットとして構成されます。プログラム カウンタ(PC)は11/12ビット幅で、従って下の表5-1.で説明されるように、2/4Kプログラム メモリ位置のアドレス指定能力があります。

定数表はプログラム メモリのアトレス空間全体に配置できます。「**命令要約**」のLPMと SPMの命令をご覧ください。フラッシュ プログラム メモリは124頁の「**外部プログラミング**」で 記述されるように外部装置からプログラミングすることもできます。

命令の取得と実行のタイミング図は8頁の「**命令実行タイミング**」で示されます。 フラッシュ メモリは最低10,000回の消去/書き込み回数の耐久性があります。

| 表5-1. プログラム メモリの大きさ  |       |               |  |  |  |  |  |  |
|----------------------|-------|---------------|--|--|--|--|--|--|
| デバイス名 フラッシュ容量 アドレス範囲 |       |               |  |  |  |  |  |  |
| ATtiny48             | 4Kバイト | \$0000~\$07FF |  |  |  |  |  |  |
| ATtiny88             | 8Kバイト | \$0000~\$0FFF |  |  |  |  |  |  |

# 5.2. データ メモリ (SRAM)とレジスタ ファイル

表5-2.はATtiny48/88のデータメモリとレジスタファイルがどう構成されるかを示します。これらのメモリは揮発性、換言するとそれらは電力が取り去られた時に情報を保持しません。

| 表5-2    | データ          | オエリア         | レバデスタ | ファイル | の配置 |
|---------|--------------|--------------|-------|------|-----|
| 1X J-Z. | ) — <u>"</u> | <b>レエリ</b> に | レノハブ  | ノバコル |     |

| デバイス名      | メモリ領域           | 大きさ    | 長アドレス (注1)    | 短アト・レス ( <mark>注2</mark> ) |
|------------|-----------------|--------|---------------|----------------------------|
|            | 汎用レジスタファイル      | 32バイト  | \$0000~\$001F | (利用不可)                     |
| ATtiny48   | I/Oレシ スタ ファイル   | 64バイト  | \$0020~\$005F | \$00~\$3F                  |
| AT tilly40 | 拡張I/Oレシブスタ ファイル | 160バイト | \$0060~\$00FF | (利用不可)                     |
|            | データ用SRAM        | 256バイト | \$0100~\$01FF | (利用不可)                     |
|            | 汎用レジスタファイル      | 32バイト  | \$0000~\$001F | (利用不可)                     |
| A T+in00   | I/Oレシ スタ ファイル   | 64バイト  | \$0020~\$005F | \$00~\$3F                  |
| ATtiny88   | 拡張I/Oレシブスタ ファイル | 160バイト | \$0060~\$00FF | (利用不可)                     |
|            | データ用SRAM        | 512バイト | \$0100~\$02FF | (利用不可)                     |

注1: データ アト・レスとしても知られます。このアト・レス指定形態はデータ メモリとレジスタ領域全体を網羅します。アト・レスは2語命令の16ビット領域に含まれます。

**注2**: 直接I/Oアドレスとしても知られます。このアドレス指定形態はレジスタ領域の一部だけを網羅します。アドレスが命令語に組み込まれている命令によって使われます。

512/768メモリ位置は汎用レジスタファイル、I/Oレジスタファイル、拡張I/Oレジスタファイル、内蔵データメモリ(SRAM)を含みます。将来のデバイスとの両立性のため、アクセスされる場合、予約ビットは0を書かれるべきです。予約されたI/Oメモリアドレスは決して書かれるべきではありません。

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

最初の32位置は汎用レジスタファイル用に予約されています。これらのレジスタは7頁の「汎用レジスタファイル」で詳細に記述されます。

### 5.2.2. I/Oレシ スタ ファイル

汎用レシ、スタファイルに後続する、次の64位置はI/Oレシ、スタ用に予約されています。この領域内のレシ、スタは主にデバイスの入出力と周辺機能部との通信に使われます。データはIN,OUT,LD,STとそれらの派生のような命令を用いてI/O空間と汎用レシ、スタファイル間で転送することができます。

この領域内の全てのレジスタはINとOUTの命令でアクセスすることができます。これらのI/O特定命令はI/Oレジスタ領域の最初の位置を \$00、最後を\$3Fとしてアドレス指定します。





下位32個(アドレス範囲\$00~\$1F)のレジスタはいくつかのビット特定命令によってアクセス可能です。これらのレジスタでは、SBIとCBIを用いてビットが容易に設定(1)と解除(0)され、一方ビット条件分岐はSBIC,SBIS,SBRC,SBRS命令を用いて容易く作成されます。

この領域内のレジスタはLD/LDD/LDI/LDSとST/STD/STSの命令でアクセスすることもできます。これらの命令は揮発性メモリ全体を1つのデータ空間として扱い、従ってI/Oレジスタのアドレスは\$20で始まります。

186頁の「命令要約」をご覧ください。

ATtiny48/88はどの情報の格納にも使うことができる3つの汎用I/Oレジスタも含みます。183頁の「**レジスタ要約**」でGPIOR0,GPIOR1, GPIOR2をご覧ください。これらの汎用I/OレジスタはそれらがSBI,CBI,SBIC,SBIS,SBRC,SBRSのようなビット特定命令でアクセス可能なので、特に全体変数や状態フラグの格納に有用です。

### 5.2.3. 拡張I/Oレジスタ ファイル

標準I/Oレジスタファイルに後続する、次の160位置は拡張I/Oレジスタ用に予約されます。ATtiny48/88はINとOUTの命令でアドレス指定することができるよりも多くの周辺機能部を持つ複合マイクロコントローラです。拡張I/O領域内のレジスタはLD/LDD/LDI/LDSとST/STD/STSの命令を用いてアクセスされなければなりません。186頁の「命令要約」をご覧ください。

I/Oレジスタの一覧については183頁の「レジスタ要約」をご覧ください。

### 5.2.4. データ メモリ (SRAM)

汎用レジスタファイルとI/Oレジスタファイルに後続する、残りの256/512位置はデータ用内蔵SRAM用に予約されます。 以下のように利用可能な5つのアドレス指定形態があります。

- ・直接:このアドレス指定の形態はデータ空間全体に届きます。
- 間接:
- ・変位付き間接:このアドレス指定の形態はYまたはZレジスタによって与えられる基準アドレスから63アドレス位置に届きます。
- ・事前減少付き間接:この形態ではアクセスに先立ってアトレスレジスタが自動的に減少(-1)されます。アトレスポインタレジスタ(X,Y,Z)は汎用レジスタファイルのR26~R31に配置されます。7頁の「汎用レジスタファイル」をご覧ください。
- ・事後増加付き間接:この形態ではアクセス後にアトレスレジスタが自動的に増加(+1)されます。アトレスポークタレジスタ(X,Y,Z)は汎用レジスタファイルのR26~R31に配置されます。7頁の「汎用レジスタファイル」をご覧ください。

全てのアドレス指定形態は汎用レジスタ ファイル、I/Oレジスタ ファイル、データ メモリを含み、揮発性メモリ全体に使うことができます。 内蔵SRAMは下の図5-2.で図解されるように2clkcpu周期でアクセスされます。



# 5.3. データ メモリ (EEPROM)

ATtiny48/88は64バイトの不揮発性データ メモリを含みます。このEEPROMは単一バイトで読み書きできる分離したデータ空間として構成されます。全てのアクセス レジスタはI/O空間に配置されます。

表5-3. 不揮発性データ メモリ(EEPROM)の大きさ デバイス名 フラッシュ容量 アドレス範囲 ATtinv48/88 64バイト \$00~\$3F

EEPROM配置は右の表5-3.で要約されます。

EEPROM操作の時間に内蔵8MHz発振器が使われます。この発振器の周波数は20頁の「OSCCAL - 発振校正レジスタ」で記述される必要条件内でなければなりません。

厳重に濾波した電源によって給電される時に電源投入/切断でVCCが緩やかに上昇または下降しそうです。緩やかな上昇と下降の時間はデバイスを指定されたよりも低い供給電圧で走行する状態に置くかもしれません。このような状況での問題を避けるには14頁の「EEPROMデータ化けの防止」をご覧ください。

EEPROMは最低100,000回の消去/書き込み回数の耐久性があります。

## 5.3.1. プログラミング法

EEPROMプログラミングには以下のように2つの方法があります。

- ・非分離バイト プログラミング: これは単一操作で目標位置が消去されて書かれる、単純なプログラミング形態です。この操作形態では書く前に目標が常に消去されることが保証されますが、プログラミング時間がより長くなります。
- ・分離バイトプログラミング: 2つの異なる操作で消去と書き込みの周期を分けることが可能です。これは短いアクセス時間が必要とされるとき、例えば供給電圧が降下する時に有用です。この方法を利用するために、目標位置はそれらへ書く前に消去されなければなりません。

プログラミング法はEEPROM制御レシ、スタ(EECR)のEEPROMプログラミング種別(EEPM1とEEPM0)ビットを用いて選択されます。15頁の表5-4. をご覧ください。書き込みと消去の時間が同じ表で与えられます。

EEPROMプログラミングが或る程度の時間がかかるため、応用は次の(操作)を開始する前に現在の操作の完了を待たなければなりません。これはEEPROM制御レジスタ(EECR)のEEPROMプログラム許可(EEPE)ビットのポーリング、またはEEPROM操作可割り込み経由のどちらかによって行うことができます。EEPROM割り込みはEECRのEEPROM操作可割り込み許可(EERIE)ビットによって制御されます。

### 5.3.2. 読み込み

EEPROM位置を読むには以下の手順に従ってください。

- ・他のEEPROM操作が進行中でないのを確実にするためにEEPROM制御レジスタ(EECR)のEEPROMプログラム許可(EEPE)ビットをポー リングしてください。設定(1)ならば解除(0)を待ってください。
- ・ 目的アドレスをEEPROMアトレス レジスタ(EEARH/EEARL)に書いてください。
- ・EEPROM制御レジスタ(EECR)のEEPROM読み込み許可(EERE)ピットを設定(1)することによって読み込み操作を開始してください。 読み込み動作中、CPUは次の命令を実行する前に4クロック周期間停止されます。
- ・ EEPROMデータ レシブスタ(EEDR)からデータを読んでください。

### 5.3.3. 消去

予期せぬEEPROM書き込みを防ぐために、メモリ位置を消去するのに特別な手順に従わなければなりません。EEPROM位置を消去するには以下の手順に従ってください。

- ・他のEEPROM操作が進行中でないのを確実にするためにEEPROM制御レジスタ(EECR)のEEPROMプログラム許可(EEPE)ビットをポー リングしてください。設定(1)ならば解除(0)を待ってください。
- ・EEPROM制御レジ゙スタ(EECR)のEEPROMプログラミング種別(EEPM1とEEPM0)ビットを書くことによってプログラミング動作形態を消去に設定してください。
- ・ 目的アトレスをEEPROMアトレス レシ スタ(EEARH/EEARL)に書いてください。
- ・EEPROM制御レシ、スタ(EECR)のEEPROM主プログラム許可(EEMPE)を設定(1)することによって消去を許可してください。4クロック周期内にEEPROM制御レシ、スタ(EECR)のEEPROMプログラム許可(EEPE)ビットを設定(1)することによって消去動作を開始してください。消去動作中、CPUは次の命令を実行する前に2クロック周期間停止されます。

EEPEL'ットは消去動作が完了されるまで設定(1)に留まります。デバイスがプログラミング多忙の間、他のどんなEEPROM操作の実行も不可能です。

### 5.3.4. 書き込み

予期せぬEEPROM書き込みを防ぐために、メモリ位置を書くのに特別な手順に従わなければなりません。

EERPOMにデータを書く前に目的位置が消去されなければなりません。これは同一操作で、または分離操作の一部としてのどちらかで行うことができます。未消去EEPROM位置への書き込みは不正なデータに帰着します。

EEPROM位置を書くには以下の手順に従ってください。

- ・他のEEPROM操作が進行中でないのを確実にするためにEEPROM制御レン、スタ(EECR)のEEPROMプログラム許可(EEPE)ヒットをポーリングしてください。設定(1)ならば解除(0)を待ってください。
- ・EEPROM制御レジスタ(EECR)のEEPROMプログラミング種別(EEPM1とEEPM0)ビットを書くことによってプログラミング動作形態を設定してください。2者選択として、1操作でのデータ書き込みか、または消去のみと書き込みのみに分離する書き込み手順にできます。
- ・目的アドレスをEEPROMアトレスレジ、スタ(EEARH/EEARL)に書いてください。
- ・目的データをEEPROMデータレジスタ(EEDR)に書いてください。
- ・EEPROM制御レジ、スタ(EECR)のEEPROM主プログラム許可(EEMPE)を設定(1)することによって書き込みを許可してください。4クロック 周期内にEEPROM制御レジ、スタ(EECR)のEEPROMプログラム許可(EEPE)ヒ、ットを設定(1)することによって書き込み動作を開始してく ださい。書き込み動作中、CPUは次の命令を実行する前に2クロック周期間停止されます。

EEPEビットは書き込み動作が完了されるまで設定(1)に留まります。デバイスがプログラミング多忙の間、他のどんなEEPROM操作の実行も不可能です。





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

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

低供給電圧に於いてEEPROMのデータは以下の2つのように不正にされ得ます。

- その他正当なEEPROMプログラミング手順の正しい操作を維持するために供給電圧が低すぎます。
- ・CPUに対して供給電圧が低すぎで、命令が不正に実行されるかもしれません。

EEPROMデータ化けは不充分な供給電源電圧の期間中、デバイスをリセットに保つことによって避けられます。これは内蔵低電圧検出器 (BOD)を許可することによって容易に行えます。BOD検出レヘルが設計に対して充分でなければ、低VCCに対する外部リセット回路を使うことができます。

供給電圧が充分ならば、例えリセットが起きる時でも、EEPROM書き込み動作は完了されます。

### 5.3.6. プログラム例

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

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

## **注**: 5頁の「コート・例について」をご覧ください。

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

```
アセンブリ言語プログラム例
EEPROM_RD:
           SBIC
                 EECR, EEPE
                                                  ;EEPROMプログラミング完了ならばスキップ
           RJMP
                 EEPROM_RD
                                                  ;以前のEEPROMプログラミング完了まで待機
                                                  ;EEPROMアドレス上位設定
           OUT
                 EEARH, R18
                                                  ;EEPROMアトレス下位設定
           OUT
                 EEARL, R17
           SBI
                 EECR, EERE
                                                  ;EEPROM読み出し開始(読み込み許可ビット設定)
           IN
                 R16, EEDR
                                                  ;EEPROM読み出し値を取得
           RET
                                                  ;呼び出し元へ復帰
C言語プログラム例
unsigned char EEPROM_read(unsigned int ucAddress)
                                                  /* 以前のEEPROMプログラミング完了まで待機 */
   while (EECR & (1<<EPE));
   EEAR = ucAddress;
                                                  /* EEPROMアドレス設定 */
   EECR = (1 < EERE);
                                                  /* EEPROM読み出し開始 */
   return EEDR;
                                                  /* EEPROM読み出し値を取得,復帰 */
注: 5頁の「コード例について」をご覧ください。
```

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

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

| 15 | 14        | 13                | 12                                    | 11                                      | 10                                                                | 9                                       | 8                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----|-----------|-------------------|---------------------------------------|-----------------------------------------|-------------------------------------------------------------------|-----------------------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| _  | -         | -                 | -                                     | -                                       | -                                                                 | -                                       | -                                       | EEARH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| R  | R         | R                 | R                                     | R                                       | R                                                                 | R                                       | R                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0  | 0         | 0                 | 0                                     | 0                                       | 0                                                                 | 0                                       | 0                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7  | 6         | 5                 | 4                                     | 3                                       | 2                                                                 | 1                                       | 0                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| _  | -         | EEAR5             | EEAR4                                 | EEAR3                                   | EEAR2                                                             | EEAR1                                   | EEAR0                                   | EEARL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| R  | R         | R/W               | R/W                                   | R/W                                     | R/W                                                               | R/W                                     | R/W                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0  | 0         | 不定                | 不定                                    | 不定                                      | 不定                                                                | 不定                                      | 不定                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|    | R 0 7 - R | R R 0 0 7 6 R R R | R R R R 0 0 0 0 7 6 5 - EEAR5 R R R/W | R R R R R O O O O O O O O O O O O O O O | R R R R R R 0 0 0 0 0 0 0 7 6 5 4 3 5 EEAR4 EEAR3 R R R/W R/W R/W | R R R R R R R 0 0 0 0 0 0 0 0 0 0 0 0 0 | R R R R R R R R R 0 0 0 0 0 0 0 0 0 0 0 | R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R         R |

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

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

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

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

## 5.4.2. **EEDR** – **EEPROM**データレジスタ (EEPROM Data Register)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     | _    |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|------|
| \$20 (\$40) | (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.4.3. EECR - EEPROM制御レジスタ (EEPROM Control Register)

| \$1F (\$3F) - EEPM1 EEPM0 EERIE EEMF | PE EEPE EER | EECR |
|--------------------------------------|-------------|------|
|                                      |             |      |
| Read/Write R R R/W R/W R/W R/W       | / R/W R/W   |      |
| 初期値 0 0 不定 不定 0 0                    | 不定 0        |      |

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

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

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

EEPROMプログラミング・種別ビットはEEPROMプログラミン 表5-4 FFPROMプログラミング・種別ビットとプログラミング・時間 グ許可(EEPE)が書かれた時に起動される活動を定 義します。データは新しい値が書かれる前に直前の 値が自動的に消去される単一非分離操作でプログ ラミングすることができ、または消去と書き込みを2つ の異なる操作に分離することができます。各動作に 対するプログラミング時間は表5-4.で示されます。

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

EEPEが設定(1)されていると、EEPMnへのどの書き 込みも無視されます。

リセット中、EEPMntiットはEEPROMがプログラミング多忙中を除いて'00'にリセットされます。

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

このビットの1書き込みがEEPROM操作可割り込みを許可します。 ステータス レジスタ(SREG)の全割り込み許可(J)ビットが設定(1)されている なら、不揮発性メモリがプログラミングに対して準備可の時にEEPROM操作可割り込みが起動されます。

このビットの0書き込みはEEPROM操作可割り込みを禁止します。

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

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

EEMPEが設定(1)されて4クロック周期内にEEPEが設定(1)されると、選択したアトレスのEEPROMがプログラムされます。4クロック周期後にハー ト'ウェアがこのビットをOに解除します。





EEMPEがOなら、EEPE設定(1)は無効です。

# ■ ビット1 - EEPE: EEPROMプログラム許可(EEPROM Program Enable)(訳注:本文を修正)

EEPROMプログラム許可信号(EEPE)はEEPROMへのプログラミング許可信号です。EEPEが(1を)書かれると、EEPROMはEEPMnビット設定に従ってプログラムされます。論理1がEEPEへ書かれる前にEEPROM主プログラム許可(EEMPE)ビットは1を書かれなければならず、さもなければEEPROM書き込み(消去)は行われません。EEPROMを書くとき、次の手順に従うべきです(手順3.と4.の順番は重要ではありません)。

- 1. EEPROMプログラム許可(EEPE)ビットがOになるまで待ちます。
- 2. SPM制御/状態レシスタ(SPMCSR)の自己プログラミング許可(SELFPRGEN)ビットが0になるまで待ちます。
- 3. 今回のEEPROMアドレスをEEPROMアドレス レジスタ(EEAR)に書きます。(任意)
- 4. 今回のEEPROMデータをEEPROMデータレシブスタ(EEDR)に書きます。(任意)
- 5. EEPROM制御レジスタ(EECR)のEEPROM主プログラム許可(EEMPE)ビットに1を、EEPROMプログラム許可(EEPE)ビットに0を同時に書きます。
- 6. EEMPEビット設定後4クロック周期内にEEPROMプ゚ログラム許可(EEPE)ビットへ論理1を書きます。

CPUがフラッシュ メモリ書き込み中、EEPROMはプログラム(書き込みが)できません。ソフトウェアは新規EEPROM書き込みを始める前にフラッシュ メモリのプログラミングが完了されていることを検査しなければなりません。フラッシュ メモリが決してCPUによって更新されないなら、2.は省略できます。

警告: 手順5.と6.間の割り込みはEEPROM主プログラム許可が時間超過するため、書き込み周期失敗になります。EEPROMをアクセスする割り込みルーチンが他のEEPROMアクセスを中断し、EEARかEEDRが変更されると、中断したEEPROMアクセスを失敗させます。これらの問題を避けるため、全ての手順中、ステータスレジ、スタ(SREG)の全割り込み許可(I)ビットは解除(0)されていることが推奨されます。

書き込み(プログラミング)アクセス時間が経過されると、EEPROMプログラム許可(EEPE)ビットはハードウェアによって解除(0)されます。EEPEが設定(1)されてしまうと、次の命令が実行される前にCPUは2周期停止されます。

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

これはEEPROMの読み込みストローブです。目的アドレスがEEARに構成設定されると、EEPROM読み出しを起動するためにEEREビットは1を書かれなければなりません。

EEPROM読み出しアクセスは(その)1命令で行われ、要求したデータは直ちに利用できます。EEPROMが読まれる時に次の命令が実行される前にCPUは4周期停止されます。

使用者は読み込み操作を始める前にEEPEビットをポーリングすべきです。書き込み(プログラム)操作実行中の場合、EEPROMアドレス レジスタ(EEAR)の変更もEEPROM読み込みもできません。

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

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |        |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|--------|
| \$2B (\$4B) | (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.4.5. GPIOR1 - 汎用I/Oレジスタ1 (General Purpose I/O Register 1)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |        |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|--------|
| \$2A (\$4A) | (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.4.6. GPIORO - 汎用I/OレジスタO (General Purpose I/O Register 0)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |        |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|--------|
| \$1E (\$3E) | (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.はAVR内の主要なクロック系統とその配給を示します。全てのクロックが与えられた時間有効である必要はありません。消費電力低減のため、21頁の「電力管理と休止形態」で記述される各種休止形態の使用によって、使われない部分のクロックを停止することができます。クロック系統は以下で詳細に示されます。



# 6.1. クロック副系統

クロック副系統が以下の項で詳述されます。

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

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

### 6.1.2. I/O วิตุงว - clk<sub>I/O</sub>

I/Oクロックはタイマ/カウンタ、直列周辺インターフェース、外部割り込み部のようなI/O部の大部分で使われます。いくつかの外部割り込みは例えI/Oクロックが停止されてもそれらが認証されることを意味する、非同期論理回路によって検知されることに注意してください。2線インターフェースの開始条件検出が(例えclkɪ/oが停止されている時でも)全休止形態でのTWIアドレス認証動作を意味する非同期であることに注意してください。

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

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

### 6.1.4. A/D変換クロック - clkaDC

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

## 6.1.5. 高速TWIクロック - clk<sub>TWIHS</sub>

このTWIクロックは高速動作で操作される時の2線インターフェース部の動作を制御します。実際問題として、このクロックはディーイスのクロック源と同じです。87頁の「ビット速度発生器」をご覧ください。

# 6.2. クロック元

デバイスはシステム クロックに以下の供給元のどれかを使う ことができます。

- ・外部クロック信号(18頁をご覧ください。)
- ・校正付き内蔵8MHz発振器(18頁をご覧ください。)
- ・内部128kHz発振器 (18頁をご覧ください。)

クロック元はCKSELヒューズを用いて選択されます。**表6-1**. をご覧ください。

ヒュース ビットのより多くの情報については122頁の「ヒュース ビット」をご覧ください。

| 表6-1. デバイ | ス クロックイ | 壬意選択 |
|-----------|---------|------|
|-----------|---------|------|

| CKSEL1,0 (注1)     | デバイス クロック任意選択    | 周波数                |  |  |  |  |  |  |
|-------------------|------------------|--------------------|--|--|--|--|--|--|
| 0 0               | 外部クロック信号         | 0∼12MHz            |  |  |  |  |  |  |
| 0 1               | (予約)             | -                  |  |  |  |  |  |  |
| 1 0 ( <b>注2</b> ) | 校正付き内蔵発振器        | 8MHz ( <b>注3</b> ) |  |  |  |  |  |  |
| 1 1               | 128kHz内部(WDT)発振器 | 128kHz             |  |  |  |  |  |  |

注1: 全ヒューズに対し、"1"は非プログラム、"0"はプログラムを意味します。

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

注3: 周波数8MHzが(VCCに依存して)デバイスの仕様を超える場合、内部 周波数を8分周するのにCKDIV8ヒュース・をプログラム(0)にできます。





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

外部クロック元からデバイスを駆動するにはCLKIが**図6-2**.で示されるように駆動されるべきです。このクロック元が選択されると、起動時間は**表6-2**.で示されるようにSUTヒュースによって決定されます。



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

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

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

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

## 6.2.2. 校正付き内蔵8MHz発振器

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

選択したなら、外部部品なしで動作します。リセット中、ハート・ウェアが発振校正(OSCCAL)ルジスタに予めプログラムされた校正値バイトを設定し、これによって発振器を自動的に校正します。この校正の精度は表22-1.で工場校正として示されます。

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

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

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

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

| SUT1,0  | パワーダウンからの<br>起動遅延時間 | リセットからの付加遅延<br>時間 (VCC=5.0V) | 電力条件             |  |  |  |  |  |  |
|---------|---------------------|------------------------------|------------------|--|--|--|--|--|--|
| 0 0     | 6×CK                | 14×CK ( <b>注1</b> )          | 低電圧検出リセット(BOD)許可 |  |  |  |  |  |  |
| 0 1     | 6×CK                | 14×CK+4ms                    | 高速上昇電源           |  |  |  |  |  |  |
| 10 (注2) | 6×CK                | 14×CK+64ms                   | 低速上昇電源           |  |  |  |  |  |  |
| 11      |                     | (予約)                         |                  |  |  |  |  |  |  |

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

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

# 6.2.3. 128kHz内部発振器

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

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

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

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

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

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

このディイスは8.0MHzの校正付き内蔵発振器でCKDIV8ヒューズがプログラム(0)され、結果として1.0MHzのシステム クロックで出荷されます。 起動時間は計時完了周期が許可され、最大に設定されます。(CKSEL=10, SUT=10, CKDIV8=プログラム(0)) この既定設定は全ての使用者が利用可能なプログラシング インターフェースを用いて、それらを希望したクロック元設定にできることを保証します。

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

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

### 6.3.1. 前置分周器設定切り替え

前置分周器設定間を切り替えるとき、システム クロック前置分周器は中間(経過途中)の周波数が直前の設定に対応するクロック周波数または新規設定に対応するクロック周波数のどちらよりも高くなく、クロック系で不具合が起きないことを保証します。前置分周器として実行するリプル カウンタは分周されないクロック周波数で走行し、CPUのクロック周波数より速いかもしれません。従って例え(カウンタ値が)読めるとしても、前置分周器の状態を決めることはできず、1から他へのクロック分周値切り替えを行う正確な時間は必ずしも予測できません。CLKPS値が書かれる時から新規クロック周波数が活性(有効)になる前にT1+T2~T1+2×T2間かかります。この間で2つの有効なクロック端が生成されます。ここでのT1は直前のクロック周期、T2は新規前置分周器設定に対応する周期です。

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

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

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

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

このデ、バイスはシステム クロックをCLKOピンに出力できます。本出力を許可するにはCKOUTヒュース、がプログラム(0)されなければなりません。この動作はチップのクロックがシステム上の他の回路を駆動する時用です。このヒュース、がプログラム(0)されると、I/Oピンの標準動作は無視され、このクロックはリセット中も出力されます。CLKOがクロック出力を扱うとき、校正付き内蔵発振器を含む何れのクロック元も選択できます。システム クロック前置分周器が使われた場合、分周されたシステム クロックが出力されます。

# 6.5. クロック起動手順

何れのクロック元も発振を開始するための充分なVCCと、それが安定であると考えられるのに先立って最低発振周期数が必要です。

充分なVCCを保証するためにその他全てのリセット元によってデバイスリセットが開放された後、デバイスは起動遅延時間(t<sub>TOUT</sub>)の内部リセットを発生します。25頁からの「システム制御とリセット」はこの内部リセットに対する起動条件を記述します。この遅延(t<sub>TOUT</sub>)はウォッチトック発振器で計時され、遅延周期数はSUTとCKSELのヒュースによって設定されます。選択可能な遅延は表6-5.で示されます。161頁の「ウォッチトック・発振器周波数対動作電圧」と162頁の「ウォッチトック・発振器周波数対動作電圧」と162系振器の周波数は電圧に依存します。

| 表6-5. 始動手順時間長                                  |        |           |        |  |  |  |  |  |  |
|------------------------------------------------|--------|-----------|--------|--|--|--|--|--|--|
| CKSEL1,0                                       | SUT1,0 | WDT周期数    | 代表経過時間 |  |  |  |  |  |  |
| 0.0                                            | 0 0    | 0         | 0 ms   |  |  |  |  |  |  |
| $\begin{bmatrix} 0 & 0 \\ 1 & 0 \end{bmatrix}$ | 0 1    | 4K (4096) | 4ms    |  |  |  |  |  |  |
| 1 1                                            | 1 0    | 8K (8192) | 64ms   |  |  |  |  |  |  |
| 1 1                                            | 1 1    | (予約)      | (予約)   |  |  |  |  |  |  |
| 0 1                                            | хх     | (予約)      | (予約)   |  |  |  |  |  |  |

遅延の主な目的はAVRが最小VCCを印加されるまでAVRをリセットに保つことです。この遅延は実電圧を監視しないので、VCC上昇時間よりも長い遅延を選ぶことが必要とされるべきです。これが不可能な場合、内部または外部の低電圧検出回路(BOD)が使われるべきです。BOD回路がリセットを開放する前に充分なVCCを保証するでしょうから、起動遅延時間は禁止され得ます。低電圧検出回路(BOD)なしでの起動遅延時間の禁止は推奨されません。

この発振器はクロックが安定と考えられるのに先立って最低クロック数を発振することを必要とされます。内部リプル カウンタは発振器の出力 クロックを監視し、与えられたクロック周期数に対して内部リセットを活性(有効)に保ちます。このリセットはその後に開放され、デバイスが実行を開始します。

クロックについての起動手順は計時完了遅延とデバイスがリセットから起動する時の起動時間の両方を含みます。パワーダウンから起動する時にVCCは充分な電圧であると認識され、起動時間だけが含められます。





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

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

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

発振校正レジスタは発振器周波数の偏差処理を省くための内蔵発振器の調整に使われます。チップのリセット中、136頁の表22-1.で指定されるように工場で校正された周波数を与える、予めプログラムされた値が本レジスタへ自動的に書かれます。

応用ソフトウェアは発振器周波数を変更するためにOSCCALレシ、スタへ書くことができます。この発振器は**表22-1**.で指定される周波数に校正できます。この範囲外への校正は推奨されません。

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

全てのレシ、スタ ビットが周波数用に使います。\$00設定が最低周波数、\$FF設定が最高周波数を生じます。

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

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

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

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

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

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

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

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

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

# 表6-6. クロック前置分周器選択

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

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

休止形態は応用でMCU内の未使用部を一時停止することを可能にし、それによって節電します。AVRは応用で必要な消費電力に 仕立てることを使用者に許す様々な休止形態を提供します。

許可したなら、低電圧検出器(BOD)は休止期間中、電源電圧を積極的に監視します。更なる節電のため、いくつかの休止形態種別でBODを禁止することが可能です。より多くの詳細については次頁の「ソフトウェア低電圧検出器(BOD)禁止」をご覧ください。

## 7.1. 休止形態種別

17頁の図6-1.はATtiny48/88の各種クロック系統とその配給を示します。本図は適切な休止形態を選択する助けになります。表7-1.は各種休止形態、それらの起動元とBOD禁止の可能性を示します。

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

|           | 動化     | 作クロ      | ラク軍   | 色囲     | 動作発振器     |                      | 復帰            | 起動要因(         | 割り込み)       |           |            |
|-----------|--------|----------|-------|--------|-----------|----------------------|---------------|---------------|-------------|-----------|------------|
| 休止形態      | clkcpu | clkflash | clkio | clkadc | 主クロック 供給元 | INT1<br>INT0<br>ピン変化 | TWI<br>アドレス一致 | EEPROM<br>操作可 | A/D変換<br>完了 | ウォッチト゛ック゛ | その他<br>I/O |
| アイドル      |        |          | 0     | 0      | 0         | 0                    | 0             | 0             | 0           | 0         | 0          |
| A/D変換雑音低減 |        |          |       | 0      | 0         | 1                    | 0             | 0             | 0           | 0         |            |
| ハ゜ワータ゛ウン  |        |          |       |        |           | 1                    | 0             |               |             | 0         |            |

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

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

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

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

## 7.1.1. アイドル動作

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

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

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

休止種別選択(SM1,0)ビットが'01'を書かれると、SLEEP命令はMCUをA/D変換雑音低減動作へ移行させ、CPUを停止しますが、A/D変換器、外部割り込み、2線直列インターフェースのアドレス監視、ウォッチドッグの(許可されていれば)継続動作を許します。この休止形態は基本的にclkg/O, clkCPU, clkFLASHを停止する一方、他のクロックに走行を許します。

これはA/D変換に対する雑音環境を改善し、より高い分解能の測定を可能にします。A/D変換器が許可されている場合、本動作に移行すると、変換が自動的に始まります。A/D変換完了割り込みからの他、外部リセット、ウォッチト、ッグ・システム リセット、ウォッチト、ッグ・割り込み、低電圧検出(BOD)リセット、2線直列インターフェースのアトンス一致割り込み、EEPROM操作可割り込み、INTOまたはINT1の外部レベル割り込み、ピン変化割り込みだけが、A/D変換雑音低減動作からMCUを起動できます。

## 7.1.3. パワーダウン動作

休止種別選択(SM1,0)ビットが、10'を書かれるとき、SLEEP命令はMCUをパワーダウン動作へ移行させます。この動作では外部発振器が停止される一方、外部割り込み、2線直列インターフェースのアドレス監視、ウォッチドッグ機能は(許可されていれば)継続して動作します。外部リセット、ウォッチ ドッグ システム リセット、ウォッチドッグ割り込み、低電圧検出(BOD)リセット、2線直列インターフェースのアドレス一致割り込み、INTOまたはINT1の外部レベル割り込み、ピン変化割り込みだけがMCUを起動できます。この休止形態は基本的に生成した全てのクロックを停止し、非同期部の動作だけを許します。

レヘ・ルで起動した割り込みがパワーダウン動作からの復帰に使われる場合、MCUを起動するためには変更したレヘ・ルが一定時間保持されなければならないことに注意してください。詳細については32頁の「外部割り込み」を参照してください。

パワーダウン動作から起動するとき、起動条件が起きてから起動の効果が現れるまで遅延があります。これは停止されてしまっている後の再始動と安定になることをクロックに許します。この起動(遅延)時間は17頁の「**クロック元**」で記述されるように、リセット付加遅延時間を定義するのと同じCKSELヒューズによって定義されます。





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

低電圧検出器(BOD)が122頁の表20-4.のBODLEVELtュースによって許可されていると、BODは休止期間中に電源電圧を活発に監視します。節電のため、休止形態のいくつかに対してソフトウェアによってBODを禁止することが可能です。表7-1.をご覧ください。この休止形態電力消費はBODがtュースによって全面的に禁止される時と同じ水準になるでしょう。BODがソフトウェアで禁止される場合、BOD機能は休止形態移行後、直ちにOFFされます。休止からの起動復帰でBODは再び自動的に許可されます。これは休止期間中にVCCレヘルが落ちた場合の安全な動作を保証します。

BODが禁止されてしまうと、MCUがコードの実行を継続する前にBODが正しく動作することを保証するために、休止形態からの起動時間は概ね60μsになります。

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

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

# 7.3. 消費電力の最小化

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

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

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

## 7.3.2. アナログ比較器

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

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

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

# 7.3.4. 内部基準電圧

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

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

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

### 7.3.6. ポート ピン

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

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

### 7.3.7. 内蔵デバッグ機能 (dW)

内蔵デバッグ機能がDWENヒュースによって許可され、チップが休止形態へ移行すると、主クロック元は許可に留まり、従って常に電力を消費します。これはより深い休止形態での総消費電流にとって重要な一因になります。

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

# 7.4.1. SMCR - 休止形態制御レジスタ (Sleep Mode Control Register)

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

| ピット         | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0   | _    |
|-------------|---|---|---|---|---|-----|-----|-----|------|
| \$33 (\$53) | _ | - | - | - | - | SM1 | SM0 | SE  | SMCR |
| Read/Write  | R | R | R | R | R | R/W | R/W | R/W |      |
| 初期値         | 0 | 0 | 0 | 0 | 0 | 0   | 0   | 0   |      |

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

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

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

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

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

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

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

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

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

### ■ ビット6 - BODS: BOD休止 (BOD Sleep)

休止間にBODをOFFにするために、BODSビットは論理1を書かれなければなりません。21頁の表7-1.をご覧ください。BODSビットの書き込みはMCUCRのBOD休止許可(BODSE)ビットと時間制限手順によって制御されます。関連する休止形態でBODを禁止するには最初にBODSとBODSEの両方が1に設定されなければなりません。その後BODS ビットを設定するためにBODSが1に設定され、そして4クロック周期内にBODSEが0に設定されなければなりません。

BODSビットはそれが設定された後の3クロック周期間活性(有効)です。SLEEP命令は実際の休止形態に対してBODをOFFにするために、BODSが活性(有効)の間に実行されなければなりません。BODSビットは3クロック周期後、自動的に解除(0)されます。

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

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





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

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

周辺機能部の停止は全体に亘る重要な消費電力の削減のために活動動作とアイドル動作で使えます。その他の休止形態ではクロックが予め停止されます。

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

## ■ ビット7 - PRTWI: 2線直列インターフェース電力削減 (Power Reduction TWI)

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

■ ビット6,4,1 - Res: 予約 (Reserved)

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

■ ビット5 - PRTIMO: タイマ/カウンタ0電力削減 (Power Reduction Timer/Counter0)

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

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

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

■ ビット2 - PRSPI: 直列周辺インターフェース電力削減 (Power Reduction Serial Peripheral Interface)

デバック、WIRE内蔵デバッグ機能を使うなら、このビットは1を書かれるべきではありません。

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

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

このビットへの1書き込みはA/D変換器(ADC)を停止します。A/D変換器は停止前に禁止されなければなりません。A/D変換器停止時、アナログ比較器はADC入力切替器を使えません。

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

# 8.1. AVRのリセット

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



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

### 8.2. リセット元

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

- ・電源ONJセット・・・・・供給電圧が電源ONJセット閾値電圧(VPOT)以下、または供給電圧の急激な低下時にMCUがJセットされます。
- ・外部リセット・・・・・・・RESETビングがパルス幅必要条件以上Lowレベルに保たれると、MCUがリセットされます。
- ・ウォッチト、ック、リセット・・・ウォッチト、ック、システム リセット動作が許可され、ウォッチト、ック、タイマが終了すると、MCUがリセットされます。
- ・低電圧リセット・・・・・低電圧検出が許可され、供給電圧(VCC)が低電圧検出電圧(VBOT)以下でMCUがリセットされます。





## 8.2.1. 電源ONリセット

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

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

図8-2. 内蔵電源ONリセット(RESETはVCCに接続)





### 8.2.2. 外部リセット

外部リセットはRESETt°ンのLowレヘルによって生成されます。クロックが動いていなくても、最小ハペルス幅(137頁の表22-3.参照)以上のリセットハペルスはリセットを生成します。短すぎるハペルスはリセット生成が保証されません。印加された信号の上昇がリセット閾値電圧(VRST)に達すると(遅延タイマを起動し)、遅延タイマは遅延時間(tTOUT)経過後にMCUを始動します。外部リセットはRSTDISBLヒュースでよって禁止できます。122頁の表20-4.をご覧ください。



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

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

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



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

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

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



# 8.3. 内部基準電圧

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

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

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

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

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

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

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

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



ウォッチト、ック、常時ON(WDTON)ヒュース、のプログラム(0)はウォッチト、ック、タイマをシステム リセット動作種別に強制します。このヒュース、のプログラム(0)でシステム リセット動作(WDE)ヒ、ットと割り込み動作(WDIE)ヒ、ットは各々、'1'と'0'に固定されます。

更にプログラム保護を保証するためにウォッチト、ッグ設定の変更は時間制限手順に従わなければなりません。システム リセット許可(WDE)の解除と計時完了時間設定の変更についての手順は次のとおりです。

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





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

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

## 注: 5頁の「コート・例について」をご覧ください。

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

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

```
アセンブリ言語プログラム例
WDT_PRS:
            CLT
                                                      ;全割り込み禁止
            WDR
                                                      ;ウォッチト、ック、タイマ リセット
            LDS
                  R16, WDTCSR
                                                      ;現WDTCSR値を取得(他ビット保護用)
            ORI
                  R16, (1<<WDCE) | (1<<WDE)
                                                      ;WDCEとWDE論理1値を設定
                                                      ;WDCEとWDEに論理1書き込み
                  WDTCSR, R16
            STS
                  R16, (1<<WDE) | (1<<WDP2) | (1<<WDP0)
            LDI
                                                      ;WDE=1,計時間隔=0.5s値を取得
            STS
                  WDTCSR, R16
                                                      ;0.5s監視間隔リセット動作開始
            SEI
                                                      ;全割り込み許可
                                                      ;呼び出し元へ復帰
            RET
C言語プログラム例
void WDT_off(void)
     _disable_interrupt();
                                                      /* 全割り込み禁止 */
                                                      /* ウォッチト・ック・タイマ リセット */
     _watchdog_reset();
    WDTCSR |= (1<<WDCE) | (1<<WDE);
                                                      /* WDCEとWDEに論理1書き込み */
    WDTCSR = (1 << WDE) | (1 << WDP2) | (1 << WDP0);
                                                      /* 0.5s 監視間隔リセット動作開始 */
                                                      /* 全割り込み許可 */
    __enable_interrupt();
注: 5頁の「コート・例について」をご覧ください。
```

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

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

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

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

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

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

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

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

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

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

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

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

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





# 8.5.2. WDTCSR - ウォッチトック、タイマ制御レジスタ (Watchdog Timer Control Register)

| ピット        | 7    | 6    | 5    | 4    | 3   | 2    | 1    | 0    | _      |
|------------|------|------|------|------|-----|------|------|------|--------|
| (\$60)     | WDIF | WDIE | WDP3 | WDCE | WDE | WDP2 | WDP1 | WDP0 | WDTCSR |
| 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)されると、ウォッチドッグ割り込みが許可されます。この設定(=1)との組み合わせでウォッチドッグ リセット許可(WDE)ビットが解除(0)されると、割り込み動作種別になり、ウォッチドッグ タイマで計時完了が起こると、対応する割り込みが実行されます。

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

| 表8-1. ウォ | <del>ト</del> ッチドック゛ タ | イマ設定 |                |                      |
|----------|-----------------------|------|----------------|----------------------|
| WDTON    | WDE                   | WDIE | 動作種別           | 計時完了での動作             |
| 1        | 0                     | 0    | 停止             | なし                   |
| 1        | 0                     | 1    | 割り込み           | 割り込み                 |
| 1        | 1                     | 0    | システム リセット      | リセット                 |
| 1        | 1                     | 1    | 割り込み及びシステムリセット | 割り込み、その後システムリセット動作種別 |
| 0        | v                     | v    | システム リセット      | リナット                 |

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

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

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

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

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

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

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

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

| Hymaxo 2. Cheaver)    |          |                                                               |    |       |     |     |       |      |      |       |   |   |   |   |   |   |
|-----------------------|----------|---------------------------------------------------------------|----|-------|-----|-----|-------|------|------|-------|---|---|---|---|---|---|
| 表8-2. ウォッチドッグ前置分周器選択  |          |                                                               |    |       |     |     |       |      |      |       |   |   |   |   |   |   |
| WDP3                  | WDP3 0 1 |                                                               |    |       |     |     |       |      |      |       |   |   |   |   |   |   |
| WDP2                  |          | 0 1 0 1                                                       |    |       |     |     |       |      |      |       |   |   |   |   |   |   |
| WDP1                  | (        | )                                                             |    | 1     | (   | )   |       | [    | (    | )     |   | 1 | ( | 0 |   | 1 |
| WDP0                  | 0        | 1                                                             | 0  | 1     | 0   | 1   | 0     | 1    | 0    | 1     | 0 | 1 | 0 | 1 | 0 | 1 |
| WDT発振周期数              | 2k       | 4k                                                            | 8k | 16k   | 32k | 64k | 128k  | 256k | 512k | 1024k |   |   |   |   |   |   |
| 代表的計時完了<br>周期(VCC=5V) | 16ms     | 16ms 32ms 64ms 0.125s 0.25s 0.5s 1.0s 2.0s 4.0s 8.0s (予約) (注) |    |       |     |     |       |      |      |       |   |   |   |   |   |   |
| ) JEE LED 3: LEE A    |          | NII. 1                                                        |    | H . I |     |     | 1.2.2 | 2 2  |      |       |   |   |   |   |   |   |

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

# 9. 割り込み

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

# 9.1. 割り込みべかり

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

| ベクタ番号 | プログラム アドレス | 発生元              | 備考                     |
|-------|------------|------------------|------------------------|
| 1     | \$0000     | リセット             | 電源ON, WDT, BOD等の各種リセット |
| 2     | \$0001     | INT0             | 外部割り込み要求0              |
| 3     | \$0002     | INT1             | 外部割り込み要求1              |
| 4     | \$0003     | PCINTO (PCIO)    | ピン変化0群割り込み要求           |
| 5     | \$0004     | PCINT1 (PCI1)    | ピン変化1群割り込み要求           |
| 6     | \$0005     | PCINT2 (PCI2)    | ピン変化2群割り込み要求           |
| 7     | \$0006     | PCINT3 (PCI3)    | ピン変化3群割り込み要求           |
| 8     | \$0007     | ウォッチドック゛WDT      | ウォッチドッグ計時完了            |
| 9     | \$0008     | タイマ/カウンタ1 CAPT   | タイマ/カウンタ1捕獲発生          |
| 10    | \$0009     | タイマ/カウンタ1 COMPA  | タイマ/カウンタ1比較A一致         |
| 11    | \$000A     | タイマ/カウンタ1 COMPB  | タイマ/カウンタ1比較B一致         |
| 12    | \$000B     | タイマ/カウンタ1 OVF    | タイマ/カウンタ1溢れ            |
| 13    | \$000C     | タイマ/カウンタ0 COMPA  | タイマ/カウンタ0比較A一致         |
| 14    | \$000D     | タイマ/カウンタ0 COMPB  | タイマ/カウンタ0比較B一致         |
| 15    | \$000E     | タイマ/カウンタ0 OVF    | タイマ/カウンタ0溢れ            |
| 16    | \$000F     | SPI STC          | SPI 転送完了               |
| 17    | \$0010     | A/D変換器 ADC       | A/D変換完了                |
| 18    | \$0011     | EEPROM EE_RDY    | EEPROM 操作可             |
| 19    | \$0012     | アナログ比較器 ANA_COMP | アナログ比較器出力遷移            |
| 20    | \$0013     | 2線直列インターフェース TWI | 2線直列インターフェース状態変化       |

プログラムが決して割り込み元を許可しない場合、割り込みへ、クタは使われず、その結果としてそれらの場所に通常のプログラムコードを置くことができます。

ATtiny48/88での代表的で一般的な割り込みベクタ アドレス構成設定が次のプログラム例で示されます。





| アセンブリ言語プ           | ログラム例      |            |                      |
|--------------------|------------|------------|----------------------|
| \$0000             | ORG        | \$0000     | ;プログラム用フラッシュ メモリ先頭位置 |
|                    |            |            |                      |
| \$0000             | RJMP       | RESET      | ;各種リセット              |
| \$0001             | RJMP       | EXT_INTO   | ;外部割り込み要求0           |
| \$0002             | RJMP       | EXT_INT1   | ;外部割り込み要求1           |
| \$0003             | RJMP       | PCINTO     | ;ピン変化0群割り込み要求        |
| \$0004             | RJMP       | PCINT1     | ;ピン変化1群割り込み要求        |
| \$0005             | RJMP       | PCINT2     | ;ピン変化2群割り込み要求        |
| \$0006             | RJMP       | PCINT3     | ;ピン変化3群割り込み要求        |
| \$0007             | RJMP       | WDT_OVF    | ;ウォッチドッグ計時完了         |
| \$0008             | RJMP       | TIM1_CAPT  | ;タイマ/カウンタ1捕獲発生       |
| \$0009             | RJMP       | TIM1_COMPA | ;タイマ/カウンタ1比較A一致      |
| \$000A             | RJMP       | TIM1_COMPB | ;タイマ/カウンタ1比較B一致      |
| \$000B             | RJMP       | TIM1_OVF   | ;タイマ/カウンタ1溢れ         |
| \$000C             | RJMP       | TIMO_COMPA | ;タイマ/カウンタ0比較A一致      |
| \$000D             | RJMP       | TIMO_COMPB | ;タイマ/カウンタ0比較B一致      |
| \$000E             | RJMP       | TIMO_OVF   | ;タイマ/カウンタ0溢れ         |
| \$000F             | RJMP       | SPI_STC    | ;SPI転送完了             |
| \$0010             | RJMP       | ADC        | ;ADC変換完了             |
| \$0011             | RJMP       | EE_RDY     | ;EEPROM操作可           |
| \$0012             | RJMP       | ANA_COMP   | ;アナログ比較器出力遷移         |
| \$0013             | RJMP       | TWI        | ;2線直列インターフェース状態変化    |
| ;                  |            |            |                      |
| \$0014 RE          | ESET: "命令" |            | ;主プログラム開始            |
| <b>汁</b> . 5百の「¬-L | 「個について」をデ  | 些ノゼキい      |                      |

注: 5頁の「**コード例について**」をご覧ください。

## 9.2. 外部割り込み

外部割り込みはINT0,INT1ピンまたはPCINT0~27ピンの何れかによって起動されます。許可したなら、例えINT0,1またはPCINT0~27 ピンが出力として設定されても、割り込みが起動することに注目してください。この特徴は以下のようなソフトウェア割り込みを生成する方法を提供します。

- ・PCI3t°ン変化割り込みは許可したPCINT24~27t°ンの何れかが切り替わると起動します。
- ・PCI2tン変化割り込みは許可したPCINT16~23tシの何れかが切り替わると起動します。
- ・PCI1ピン変化割り込みは許可したPCINT8~15ピンの何れかが切り替わると起動します。
- ・PCIOtシ変化割り込みは許可したPCINTO~7tシの何れかが切り替わると起動します。

ピン変化割り込み許可レジスタn(PCMSK0,PCMSK1,PCMSK2,PCMSK3)は、どのピンがピン変化割り込み要因となるかを制御します。PCI NTO~27でのピン変化割り込みは非同期に検知されます。これはそれらの割り込みがアイドル動作以外の休止形態からもデバイスを起動するのに使えることを意味します。

INT0とINT1割り込みは上昇端または下降端(含む両端)、またはLowレヘルによって起動できます。これは外部割り込み制御レジスタA (EICRA)で記述されるように構成設定されます。INT0またはINT1割り込みがレヘル起動として設定、そして許可されると、そのピンが Lowに保持される限り、割り込みは(継続的に)起動します。INT0またはINT1の上昇端や下降端割り込みの認知は17頁の「I/Oクロック - clk<sub>I/O</sub>」で記述されるI/Oクロックの存在を必要とすることに注意してください。

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

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





## 9.2.2. Lowレヘ ル割り込み

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

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

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

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

### 9.3.1. EICRA - 外部割り込み制御レジスタA (External Interrupt Control Register A)

外部割り込み制御レシ、スタAは割り込み条件制御ビットを含みます。

| ピット<br>(\$69)     | 7 | 6 | 5<br>- | 4 | 3<br>ISC11 | 2<br>ISC10 | 1<br>ISC01 | 0<br>ISC00 | EICRA |
|-------------------|---|---|--------|---|------------|------------|------------|------------|-------|
| Read/Write<br>初期値 | R | R | R      | R | R/W        | R/W        | R/W        | R/W        |       |

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

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

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

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

| 表9-2. ダ | 小部割り  | 込み1(INT1)割り込み条件   |
|---------|-------|-------------------|
| ISC11   | ISC10 | 割り込み発生条件          |
| 0       | 0     | INT1ピンがLowレベルで発生。 |
| 0       | 1     | INT1ピンの論理変化(両端)。  |
| 1       | 0     | INT1ピンの下降端で発生。    |
| 1       | 1     | INT1ピンの上昇端で発生。    |

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

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

表9-3. 外部割り込み0(INT0)割り込み条件ISC01 ISC00 割り込み発生条件0 0 INT0ピンがLowレベルで発生。0 1 INT0ピンの論理変化(両端)。1 0 INT0ピンの下降端で発生。1 1 INT0ピンの上昇端で発生。





# 9.3.2. EIMSK - 外部割り込み許可レジスタ (External Interrupt Mask Register)

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

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

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

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

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

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

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

# 9.3.3. EIFR - 外部割り込み要求フラク・レシ、スタ (External Interrupt Flag Register)

| ピット         | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0     |      |
|-------------|---|---|---|---|---|---|-------|-------|------|
| \$1C (\$3C) | - | - | - | - | - | - | INTF1 | INTF0 | EIFR |
| Read/Write  | R | R | R | R | R | R | R/W   | R/W   |      |
| 初期値         | 0 | 0 | 0 | 0 | 0 | 0 | 0     | 0     |      |

### ■ L'ット7~2 - Res: 予約 (Reserved)

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

## ■ ビット1 - INTF1:外部割り込み1要求フラグ(External Interrupt Flag 1)

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

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

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

# 9.3.4. PCICR - ピン変化割り込み制御レジスタ (Pin Change Interrupt Control Register) (訳注:次頁下段参照)

| ピット        | 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     | _     |
|------------|---|---|---|---|-------|-------|-------|-------|-------|
| (\$68)     | - | - | - | - | PCIE3 | PCIE2 | PCIE1 | PCIE0 | PCICR |
| 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 - PCIE3: ピン変化3群割り込み許可 (Pin Change Interrupt Enable 3)

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

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

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

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

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

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

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

# 9.3.5. PCIFR - ピン変化割り込み要求フラク・レシィスタ (Pin Change Interrupt Flag Register) (訳注:次頁下段参照)

| ピット         | 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     | _     |
|-------------|---|---|---|---|-------|-------|-------|-------|-------|
| \$1B (\$3B) | _ | - | - | - | PCIF3 | PCIF2 | PCIF1 | PCIF0 | PCIFR |
| Read/Write  | R | R | R | R | R/W   | R/W   | R/W   | R/W   |       |
| 初期値         | 0 | 0 | 0 | 0 | 0     | 0     | 0     | 0     |       |

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

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

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

PCINT24~27ピンの何れかの論理変化が割り込み要求を起動すると、PCIF3が設定(1)になります。ステータスレジスタ(SREG)の全割り込み許可(I)ビットとピン変化割り込み制御レシ、スタ(PCICR)のピン変化3群割り込み許可(PCIE3)ビットが設定(1)なら、MCUは対応する割り込みへ、クタへ飛びます。このフラケ、は割り込み処理ルーチンが開始されると解除(0)されます。代わりにこのフラケ、は論理1を書くことによっても解除(0)できます。

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

PCINT16~23ピンの何れかの論理変化が割り込み要求を起動すると、PCIF2が設定(1)になります。ステータスレジスタ(SREG)の全割り込み許可(I)ビットとピン変化割り込み制御レシ、スタ(PCICR)のピン変化2群割り込み許可(PCIE2)ビットが設定(1)なら、MCUは対応する割り込みへ、クタへ飛びます。このフラケ、は割り込み処理ルーチンが開始されると解除(0)されます。代わりにこのフラケ、は論理1を書くことによっても解除(0)できます。

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

PCINT8~14ピンの何れかの論理変化が割り込み要求を起動すると、PCIF1が設定(1)になります。ステータスレジ、スタ(SREG)の全割り込み許可(I)ビットとピン変化割り込み制御レジ、スタ(PCICR)のピン変化1群割り込み許可(PCIE1)ビットが設定(1)なら、MCUは対応する割り込みへ、クタへ飛びます。このフラケは割り込み処理ルーチンが開始されると解除(0)されます。代わりにこのフラケは論理1を書くことによっても解除(0)できます。

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

PCINT0~7ピンの何れかの論理変化が割り込み要求を起動すると、PCIF0が設定(1)になります。ステータスレジスタ(SREG)の全割り込み許可(I)ビットとピン変化割り込み制御レジスタ(PCICR)のピン変化0群割り込み許可(PCIE0)ビットが設定(1)なら、MCUは対応する割り込み ^  $^1$ クタへ飛びます。このフラク は割り込み処理ルーチンが開始されると解除(0)されます。代わりにこのフラク は論理1を書くことによっても解除(0)できます。





## 9.3.6. PCMSK3 - ピン変化割り込み許可レジスタ3 (Pin Change Enable Mask 24~27) (訳注:頁下段参照)

| ピット        | 7 | 6 | 5 | 4 | 3       | 2       | 1       | 0       |        |
|------------|---|---|---|---|---------|---------|---------|---------|--------|
| (\$6A)     | - | - | - | - | PCINT27 | PCINT26 | PCINT25 | PCINT24 | PCMSK3 |
| 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~0 - PCINT27~PCINT24: ピン変化割り込み27~24許可 (Pin Change Enable Mask 27~24)

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

## 9.3.7. PCMSK2 - ピン変化割り込み許可レジスタ2 (Pin Change Enable Mask 16~23)

| ピット        | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |        |
|------------|---------|---------|---------|---------|---------|---------|---------|---------|--------|
| (\$6D)     | PCINT23 | PCINT22 | PCINT21 | PCINT20 | PCINT19 | PCINT18 | PCINT17 | PCINT16 | PCMSK2 |
| Read/Write | R/W     |        |
| 初期値        | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |        |

### ■ ビット7~0 - PCINT23~PCINT16: ピン変化割り込み23~16許可 (Pin Change Enable Mask 23~16)

各PCINT16~23ビットは対応するI/Oピンでピン変化割り込みが許可されるかどうかを選びます。PCINT16~23とピン変化割り込み制御 ν ŷ ' x β (PCICR) の PCIE2が設定(1)なら、対応するI/Oピンのピン変化割り込みが許可されます。PCINT16~23が解除(0)されると、対応するI/Oピンのピン変化割り込みは禁止されます。

# 9.3.8. PCMSK1 - ピン変化割り込み許可レジスタ1 (Pin Change Enable Mask 8~14)

| ピット        | 7       | 6       | 5       | 4       | 3       | 2       | 1      | 0      |        |
|------------|---------|---------|---------|---------|---------|---------|--------|--------|--------|
| (\$6C)     | PCINT15 | PCINT14 | PCINT13 | PCINT12 | PCINT11 | PCINT10 | PCINT9 | PCINT8 | PCMSK1 |
| 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 - PCINT15~PCINT8: ピン変化割り込み15~8許可 (Pin Change Enable Mask 15~8)

各PCINT8~15ビットは対応するI/Oピンでピン変化割り込みが許可されるかどうかを選びます。PCINT8~15とピン変化割り込み制御レジスタ(PCICR)のPCIE1が設定(1)なら、対応するI/Oピンのピン変化割り込みが許可されます。PCINT8~15が解除( $\frac{0}{0}$ )されると、対応するI/Oピンのピン変化割り込みは禁止されます。

## 9.3.9. PCMSKO - ピン変化割り込み許可レジスタO (Pin Change Enable Mask 0~7)

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

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

各PCINT0~7ビットは対応するI/Oピンでピン変化割り込みが許可されるかどうかを選びます。PCINT0~7とピン変化割り込み制御レジス f(PCICR)のPCIE0が設定(1)なら、対応するI/Oピンのピン変化割り込みが許可されます。PCINT0~7が解除( $\frac{0}{0}$ )されると、対応するI/Oピンのピン変化割り込みは禁止されます。

(<mark>訳補</mark>)28ピン外囲器にはPCINT24~27が存在しないため、PCIE3,PCIF3ビット及びPCMSK3レジスタが利用できません。

# 10. 入出力ポート

# 10.1. 序説

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

本項内の全てのレシ、スタとビットの参照は一般形で記されます。小文字の'x'はポート番号文字、小文字の'n'はビット番号を表します。けれどもプログラム内でレシ、スタやビット定



義に使うとき、正確な形式(例えば、ここで一般に記されたPORTxnがポートBのビット3に対してはPORTB3)が使われなければなりません。物理的なI/Oレジスタとビット位置は49頁の「I/Oポート用レジスタ」で一覧されます。

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

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

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

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

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





### 10.2.1. ピンの設定

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

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

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

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

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

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

# 10.2.3. 接続前切断(Break-Before-Make)切り替え

接続前切断動作ではDDRxnを入力から出力へ切り換える時に1システム クロック持続する隣接Hi-Z区間が**図10-3**.で示されるように導入されます。例えば、システム クロックが4MHzでDDRxnが出力にするように書かれた場合、PORTxnの値がホート ピンで見える前に250nsの隣接Hi-Z区間が導入されます。異常を避けるため、DDRxn最大切り替え周波数は2システム クロックが推奨されます。この接続前切断はポート単位動作で、ホート単位の接続前切断許可(BBMx)ピットによって活性にされます。BBMxピットの詳細については49頁の「PORTCR - ホート制御レジスタ」をご覧ください。DDRxnピットを出力から入力に切り替える時に隣接Hi-Z区間は導入されません。



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

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.はピン値に対する制御信号の一覧を示します。

| 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.5. ピン値の読み込み

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

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

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





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

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

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





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

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

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

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

### 10.2.7. 未接続ピン

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

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

# 10.3. 交換ポート機能

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



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

| 11 > 100 10 11 11 | りつ扱品のです。              |                                                                                                     |  |  |  |
|-------------------|-----------------------|-----------------------------------------------------------------------------------------------------|--|--|--|
| 表10-2. 交          | 表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. ホートAの交換機能

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

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

| ホ°ート ヒ°ン | 交換機能                                          |
|----------|-----------------------------------------------|
| PA3      | PCINT27 (ピン変化割り込み27入力)                        |
| PA2      | PCINT26 (ピン変化割り込み26入力)                        |
| PA1      | ADC7 (A/D変換チャネル7入力)<br>PCINT25 (ピン変化割り込み25入力) |
| PA0      | ADC6 (A/D変換チャネル6入力)<br>PCINT4 (ピン変化割り込み4入力)   |

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

• PCINT27 - π°-トΑ Ľット3 : PA3

PCINT27: ピン変化割り込み27入力。

**PCINT26**: ピン変化割り込み26入力。

• ADC7/PCINT25 - ホートA ビット1: PA1

ADC7: PA1はA/D変換チャネル7入力として使えます。

PCINT25: ピン変化割り込み25入力。

• ADC6/PCINT24 - ポートA ビット0: PA0

ADC6: PA0はA/D変換チャネル6入力として使えます。

PCINT24: ピン変化割り込み24入力。

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

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

| 信号名   | PA3/PCINT27     | PA2/PCINT26     | PA1/PCINT25     | PA0/PCINT24     |
|-------|-----------------|-----------------|-----------------|-----------------|
| PUOE  | 0               | 0               | 0               | 0               |
| PUOV  | 0               | 0               | 0               | 0               |
| DDOE  | 0               | 0               | 0               | 0               |
| DDOV  | 0               | 0               | 0               | 0               |
| PVOE  | 0               | 0               | 0               | 0               |
| PVOV  | 0               | 0               | 0               | 0               |
| PTOE  | -               | _               | -               | _               |
| DIEOE | PCINT27 • PCIE3 | PCINT26 · PCIE3 | PCINT25 • PCIE3 | PCINT24 · PCIE3 |
| DIEOV | 1               | 1               | 1               | 1               |
| DI    | PCINT27入力       | PCINT26入力       | PCINT25入力       | PCINT24入力       |
| AIO   | -               | _               | ADC7入力          | ADC6入力          |

### 10.3.2. ホートBの交換機能

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

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

| ポート ピン | 交換機能                                                                  |
|--------|-----------------------------------------------------------------------|
| PB7    | PCINT7 (ピン変化割り込み7入力)                                                  |
| PB6    | CLKI (外部クロック信号入力)<br>PCINT6 (ピン変化割り込み6入力)                             |
| PB5    | SCK (SPI 直列クロック 主装置側出力/従装置側入力)<br>PCINT5 (ピン変化割り込み5入力)                |
| PB4    | MISO (SPI 主装置側データ入力/従装置側データ出力)<br>PCINT4 (ピン変化割り込み4入力)                |
| PB3    | MOSI (SPI 主装置側データ出力/従装置側データ入力)<br>PCINT3 (ピン変化割り込み3入力)                |
| PB2    | SS (SPI 従装置選択入力)<br>OC1B (タイマ/カウンタ1 比較B一致出力)<br>PCINT2 (ピン変化割り込み2入力)  |
| PB1    | OC1A (タイマ/カウンタ1 比較A一致出力)<br>PCINT1 (ピン変化割り込み1入力)                      |
| PB0    | ICP1 (タイマ/カウンタ1 捕獲起動入力)<br>CLKO (システム クロック出力)<br>PCINTO (ピン変化割り込み0入力) |

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

• PCINT7 – π°-トΒ ビット7 : PB7

PCINT7: ピン変化割り込み7入力。PB7ピンは外部割り込み元としても扱えます。

• CLKI/PCINT6 - π°-\B L\*y\6 : PB6

CLKI:外部クロック信号入力。クロック ピンとして使われると、このピンはI/Oピンとして使えません。

PCINT6: ピン変化割り込み6入力。PB6ピンは外部割り込み元としても扱えます。 PB6がクロック ピンとして使われると、PORTB6, DDB6, PINB6は全て0を読みます。

• SCK/PCINT5 - ポートB ビット5 : PB5

SCK: SPIチャネル用の主装置クロック出力、従装置クロック入力。SPIが従装置として許可されると、本ピンはポートB方向レジスタ(DDRB)の DDB5設定に拘らず、入力として設定されます。SPIが主装置として許可されると、本ピンのデータ方向はDDB5で制御されます。このピンがSPIによって入力を強制されるとき、プルアップは未だポートB出力レジスタ(PORTB)のPORTB5で制御できます。

PCINT5: ピン変化割り込み5入力。PB5ピンは外部割り込み元としても扱えます。

• MISO/PCINT4 - ポートB ビット4 : PB4

MISO: SPIチャネル用の主装置データ入力、従装置データ出力。SPIが主装置として許可されると、本ピンはポートB方向レシ、スタ(DDRB)のDDB4の設定に拘らず、入力として設定されます。SPIが従装置として許可されると、本ピンのデータ方向はDDB4で制御されます。このピンがSPIによって入力を強制されるとき、プルアップは未だポートB出力レシ、スタ(PORTB)のPORTB4で制御できます。

PCINT4: ピン変化割り込み4入力。PB4ピンは外部割り込み元としても扱えます。

• MOSI/PCINT3 - ホ°ートB ビット3 : PB3

MOSI: SPIチャネル用の主装置データ出力、従装置データ入力。SPIが従装置として許可されると、本ピンはポートB方向レジスタ(DDRB)のDDB3設定に拘らず、入力として設定されます。SPIが主装置として許可されると、本ピンのデータ方向はDDB3で制御されます。このピンがSPIによって入力を強制されるとき、プルアップは未だポートB出力レジスタ(PORTB)のPORTB3で制御できます。

PCINT3: ピン変化割り込み3入力。PB3ピンは外部割り込み元としても扱えます。

• SS/OC1B/PCINT2 - ホートB ビット2: PB2

SS: SPI従装置選択入力。SPIが従装置として許可されると、本ピンはポートB方向レジスタ(DDRB)のDDB2の設定に拘らず、入力として設定されます。従装置としてこのピンがLowに駆動されるとSPI(機能)が活性化(有効に)されます。SPIが主装置として許可されると、このピンのデータ方向はDDB2で制御されます。このピンがSPIによって入力を強制されるとき、プルアップは未だポートB出力レジスタ(PORTB)のPORTB2で制御できます。

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

PCINT2: ピン変化割り込み2入力。PB2ピンは外部割り込み元としても扱えます。





### • OC1A/PCINT1 - ポートB ビット1 : PB1

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

PCINT1: ピン変化割り込み1入力。PB1ピンは外部割り込み元としても扱えます。

# • ICP1/CLKO/PCINT0 - ホートB ビット0: PB0

ICP1: タイマ/カウンタ1の捕獲起動入力。PB0ピンはタイマ/カウンタ1用捕獲起動入力ピンとして動作できます。

CLKO: システム クロック出力。分周したシステム クロックがPBOピンに出力できます。分周したシステム クロックはCKOUTヒューズがプログラム(0)され

ると、PORTB0とDDB0設定に拘らず、出力されます。これはリセット中にも出力されます。

PCINTO: ピン変化割り込み0入力。PBOピンは外部割り込み元としても扱えます。

表10-6.と表10-7.はポートBの交換機能を41頁の図10-6.で示される交換信号に関連付けます。SPI主装置入力とSPI従装置出力がMISOを構成し、一方MOSIはSPI主装置出力とSPI従装置入力に分けられます。

#### 表10-6. ポートB7~4の交換機能用交換信号

| 信号名   | PB7/PCINT7     | PB6/CLKI/PCINT6     | PB5/SCK/PCINT5 | PB4/MISO/PCINT4 |
|-------|----------------|---------------------|----------------|-----------------|
| PUOE  | 0              | INTOSC              | SPE•MSTR       | SPE•MSTR        |
| PUOV  | 0              | 0                   | PORTB5•PUD     | PORTB4•PUD      |
| DDOE  | 0              | INTOSC              | SPE•MSTR       | SPE•MSTR        |
| DDOV  | 0              | 0                   | 0              | 0               |
| PVOE  | 0              | 0                   | SPE•MSTR       | SPE•MSTR        |
| PVOV  | 0              | 0                   | SCK出力          | SPI従装置出力        |
| PTOE  | -              | _                   | -              | _               |
| DIEOE | PCINT7 · PCIE0 | INTOSC+PCINT6.PCIE0 | PCINT5.PCIE0   | PCINT4.PCIE0    |
| DIEOV | 1              | INTRC               | 1              | 1               |
| DI    | PCINT7入力       | PCINT6入力            | SCK/PCINT5入力   | SPI主装置/PCINT4入力 |
| AIO   | -              | クロック入力              | -              | -               |

注: INTOSCは校正付き内蔵発振器が(CKSELヒューズ)によって)選択されることを意味します。

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

| 信号名   | PB3/MOSI/PCINT3 | PB2/SS/OC1B/PCINT2 | PB1/OC1A/PCINT1 | PB0/ICP1/CLKO/PCINT0 |
|-------|-----------------|--------------------|-----------------|----------------------|
| PUOE  | SPE•MSTR        | SPE•MSTR           | 0               | 0                    |
| PUOV  | PORTB3•PUD      | PORTB2•PUD         | 0               | 0                    |
| DDOE  | SPE•MSTR        | SPE•MSTR           | 0               | 0                    |
| DDOV  | 0               | 0                  | 0               | 0                    |
| PVOE  | SPE•MSTR        | OC1B許可             | OC1A許可          | 0                    |
| PVOV  | SPI主装置出力        | OC1B               | OC1A            | 0                    |
| PTOE  | -               | -                  | -               | _                    |
| DIEOE | PCINT3 · PCIE0  | PCINT2 · PCIE0     | PCINT1.PCIE0    | PCINTO · PCIE0       |
| DIEOV | 1               | 1                  | 1               | 1                    |
| DI    | SPI従装置/PCINT3入力 | SPI SS/PCINT2入力    | PCINT1入力        | ICP1/PCINT0入力        |
| AIO   | -               | -                  | -               | -                    |

### 10.3.3. ポートCの交換機能

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

### 表10-8. ポートCピンの交換機能

| <u> </u>                           | 10 6. 小 下のこの交換版化                                                     |                                    |                                             |  |  |  |  |
|------------------------------------|----------------------------------------------------------------------|------------------------------------|---------------------------------------------|--|--|--|--|
| ホ <sup>°</sup> ート ヒ <sup>°</sup> ン | 交換機能                                                                 | ホ <sup>°</sup> ート ヒ <sup>°</sup> ン | 交換機能                                        |  |  |  |  |
| PC7                                | PCINT15(ピン変化割り込み15入力)                                                | PC3                                | ADC3 (A/D変換チャネル3入力)                         |  |  |  |  |
| PC6                                | RESET (リセット ピン)                                                      | PC3                                | PCINT11 (ピン変化割り込み11入力)                      |  |  |  |  |
|                                    | PCINT14 (ピン変化割り込み14入力)                                               |                                    | ADC2 (A/D変換チャネル2入力)                         |  |  |  |  |
| PC5                                | ADC5 (A/D変換チャネル5入力)<br>SCL (2線直列バスクロック入出力)<br>PCINT13 (ピン変化割り込み13入力) | PC2                                | PCINT10 (ピン変化割り込み10入力)                      |  |  |  |  |
| 1 05                               |                                                                      | PC1                                | ADC1 (A/D変換チャネル1入力)                         |  |  |  |  |
|                                    | ADC4 (A/D変換チャネル4入力)                                                  | 1 01                               | PCINT9 (ピン変化割り込み9入力)                        |  |  |  |  |
| PC4                                | SDA (2線直列バスデータ入出力)<br>PCINT12 (ピン変化割り込み12入力)                         | PC0                                | ADC0 (A/D変換チャネル0入力)<br>PCINT8 (ピン変化割り込み8入力) |  |  |  |  |

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

• PCINT15 - ポートC ビット7 : PC7

PCINT15: ピン変化割り込み15入力。PC7ピンは外部割り込み元としても扱えます。

• RESET/PCINT14 - π°-LC L'yL6 : PC6

RESET: リセット ピン。RSTDISBLヒュースがプログラム(O)されると、このピンは標準のI/Oピンとして機能し、デバイスはリセット元として電源ON リセットと低電圧リセットに頼らなければなりません。RSTDISBLヒュースが非プログラム(1)にされると、このピンにリセット回路が接続され、このピンはI/Oピンとして使えません。

PC6がリセット ピンとして使われると、PORTC6, DDC6, PINC6は全て0を読みます。

PCINT14: ピン変化割り込み14入力。PC6ピンは外部割り込み元としても扱えます。

• SCL/ADC5/PCINT13 - ホートC ビット5: PC5

SCL: 2線直列インターフェース クロック。2線直列インターフェースを許可するために2線直列インターフェース制御レシ、スタ(TWCR)の2線直列インターフェース動作許可(TWEN)ビットが設定(1)されると、PC5は(標準の)ポートから切り離されて、2線直列インターフェース用直列クロック入出力ピッとになります。この動作では入力信号上の50nsより短いスパイク(瞬間雑音)を消去するためのスパイク除去器があり、スリューレート(上昇/下降速度)制限付きオープントレイン駆動部によって駆動されます。

ADC5: PC5はA/D変換チャネル5入力としても使えます。この入力はデジタル電源を使うことに注意してください。

PCINT13: ピン変化割り込み13入力。PC5ピンは外部割り込み元としても扱えます。

• SDA/ADC4/PCINT12 - ホートC ビット4: PC4

SDA: 2線直列インターフェースデータ。2線直列インターフェースを許可するために2線直列インターフェース制御レジスタ(TWCR)の2線直列インターフェース動作許可(TWEN)ビットが設定(1)されると、PC4は(標準の)ポートから切り離されて、2線直列インターフェース用直列データ入出力ピッンになります。この動作では入力信号上の50nsより短いスパイク(瞬間雑音)を消去するためのスパイク除去器があり、スリューレート(上昇/下降速度)制限付きオープントレイン駆動部によって駆動されます。

ADC4: PC4はA/D変換チャネル4入力としても使えます。この入力はデジタル電源を使うことに注意してください。

PCINT12: ピン変化割り込み12入力。PC4ピンは外部割り込み元としても扱えます。

• ADC3/PCINT11 - π°-FC Ε΄νF3 : PC3

ADC3: PC3はA/D変換チャネル3入力としても使えます。この入力はアナログ電源を使うことに注意してください。PCINT11: ピン変化割り込み11入力。PC3ピンは外部割り込み元としても扱えます。

• ADC2/PCINT10 - π°-FC Ε΄νF2 : PC2

ADC2: PC2はA/D変換チャネル2入力としても使えます。この入力はアナログ電源を使うことに注意してください。 PCINT10: ピン変化割り込み10入力。PC2ピンは外部割り込み元としても扱えます。

• ADC1/PCINT9 - ポ-トC ビット1 : PC1

ADC1: PC1はA/D変換チャネル1入力としても使えます。この入力はアナログ電源を使うことに注意してください。 PCINT9: ピン変化割り込み9入力。PC1ピンは外部割り込み元としても扱えます。

• ADC0/PCINT8 – π°-トC ビット0 : PC0

ADC0: PC0はA/D変換チャネル0入力としても使えます。この入力はアナログ電源を使うことに注意してください。 PCINT8: ピン変化割り込み8入力。PC0ピンは外部割り込み元としても扱えます。





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

# 表10-9. ポートC7~4の交換機能用交換信号

| 信号名   | PC7/PCINT15   | PC6/RESET/PCINT14          | PC5/SCL/ADC5/PCINT13 | PC4/SDA/ADC4/PCINT12 |
|-------|---------------|----------------------------|----------------------|----------------------|
| PUOE  | 0             | RSTDISBL                   | TWEN                 | TWEN                 |
| PUOV  | 0             | 1                          | PORTC5•PUD           | PORTC4•PUD           |
| DDOE  | 0             | RSTDISBL                   | TWEN                 | TWEN                 |
| DDOV  | 0             | 0                          | SCL出力                | SDA出力                |
| PVOE  | 0             | 0                          | TWEN                 | TWEN                 |
| PVOV  | 0             | 0                          | 0                    | 0                    |
| PTOE  | 1             | -                          | _                    | _                    |
| DIEOE | PCINT15•PCIE1 | RSTDISBL+PCINT14•<br>PCIE1 | ADC5D+PCINT13•PCIE1  | ADC4D+PCINT12•PCIE1  |
| DIEOV | 1             | RSTDISBL                   | PCINT13.PCIE1        | PCINT12•PCIE1        |
| DI    | PCINT15入力     | PCINT14入力                  | PCINT13入力            | PCINT12入力            |
| AIO   | -             | リセット入力                     | ADC5入力/SCL入力         | ADC4入力/SDA入力         |

注: 許可されると、2線直列インターフェースはPC4とPC5ピン出力のスリューレート制御を許可します。これは図で示されていません。加えて、ポート図で示されるAIO出力と2線直列インターフェース(TWI)部間にスパイク除去器が接続されます。

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

| 信号名   | PC3/ADC3/PCINT11    | PC2/ADC2/PCINT10    | PC1/ADC1/PCINT9    | PC0/ADC0/PCINT8    |
|-------|---------------------|---------------------|--------------------|--------------------|
| PUOE  | 0                   | 0                   | 0                  | 0                  |
| PUOV  | 0                   | 0                   | 0                  | 0                  |
| DDOE  | 0                   | 0                   | 0                  | 0                  |
| DDOV  | 0                   | 0                   | 0                  | 0                  |
| PVOE  | 0                   | 0                   | 0                  | 0                  |
| PVOV  | 0                   | 0                   | 0                  | 0                  |
| PTOE  | -                   | -                   | -                  | _                  |
| DIEOE | ADC3D+PCINT11•PCIE1 | ADC2D+PCINT10•PCIE1 | ADC1D+PCINT9•PCIE1 | ADC0D+PCINT8•PCIE1 |
| DIEOV | PCINT11.PCIE1       | PCINT10 • PCIE1     | PCINT9.PCIE1       | PCINT8 • PCIE1     |
| DI    | PCINT11入力           | PCINT10入力           | PCINT9入力           | PCINT8入力           |
| AIO   | ADC3入力              | ADC2入力              | ADC1入力             | ADC0入力             |

### 10.3.4. ポートDの交換機能

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

### 表10-11 ポートDピンの交換機能

| 五10 11. 小                          | DC 700 关 100 C 10 |        |                                             |  |  |  |
|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------|--|--|--|
| ホ <sup>°</sup> ート ヒ <sup>°</sup> ン | 交換機能                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ポート ピン | 交換機能                                        |  |  |  |
| PD7                                | AIN1 (アナログ 比較器反転入力)<br>PCINT23 (ピン変化割り込み23入力)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PD3    | INT1 (外部割り込み1入力)<br>PCINT19 (ピン変化割り込み19入力)  |  |  |  |
| PD6                                | AIN0 (アナログ比較器非反転入力)<br>PCINT22 (ピン変化割り込み22入力)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PD2    | INT0 (外部割り込み0 入力)<br>PCINT18 (ピン変化割り込み18入力) |  |  |  |
| PD5                                | T1 (タイマ/カウンタ1 外部クロック入力)<br>PCINT21 (ピン変化割り込み21入力)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | PD1    | PCINT17 (ピン変化割り込み17入力)                      |  |  |  |
| PD4                                | T0 (タイマ/カウンタ0 外部クロック入力)<br>PCINT20 (ピン変化割り込み20入力)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | PD0    | PCINT16(ピン変化割り込み16入力)                       |  |  |  |

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

• AIN1/PCINT23 - ホートロ ビット7: PD7

AIN1: アナログ比較器反転入力。アナログ比較器機能を邪魔するデジタルポート機能を無効とするために、内部プルアップがOFFにされた 入力としてポート ピンを設定してください。

PCINT23: ピン変化割り込み23入力。PD7ピンは外部割り込み元としても扱えます。

AINO: アナログ比較器非反転入力。アナログ比較器機能を邪魔するデジタルポート機能を無効とするために、内部プルアップがOFFにされた入力としてポート ピンを設定してください。

PCINT22: ピン変化割り込み22入力。PD6ピンは外部割り込み元としても扱えます。

• T1/PCINT21 - ホートD ビット5: PD5

T1: タイマ/カウンタ1の外部クロック入力ピンです。

PCINT21: ピン変化割り込み21入力。PD5ピンは外部割り込み元としても扱えます。

• T0/PCINT20 - ホートD ビット4: PD4

TO: タイマ/カウンタ0の外部クロック入力ピンです。

PCINT20: ピン変化割り込み20入力。PD4ピンは外部割り込み元としても扱えます。

• INT1/PCINT19 - ホートロ ビット3: PD3

INT1:外部割り込み1入力。PD3ピンは外部割り込み元として扱えます。

PCINT19: ピン変化割り込み19入力。PD3ピンは外部割り込み元としても扱えます。

• INT0/PCINT18 - ホ°ートD ビット2 : PD2

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

PCINT18: ピン変化割り込み18入力。PD2ピンは外部割り込み元としても扱えます。

• PCINT17 - ホートD ビット1: PD1

PCINT17: ピン変化割り込み17入力。PD1ピンは外部割り込み元としても扱えます。

• PCINT16 - ポ-トD ビット0 : PD0

PCINT1: ピン変化割り込み16入力。PDOピンは外部割り込み元としても扱えます。





表10-12.と表10-13.はポートDの交換機能を41頁の図10-6.で示される交換信号に関連付けます。

# 表10-12. ポートD7~4の交換機能用交換信号

| 信号名   | PD7/AIN1/PCINT23 | PD6/AIN0/PCINT22 | PD5/T1/PCINT21  | PD4/T0/PCINT20  |
|-------|------------------|------------------|-----------------|-----------------|
| PUOE  | 0                | 0                | 0               | 0               |
| PUOV  | 0                | 0                | 0               | 0               |
| DDOE  | 0                | 0                | 0               | 0               |
| DDOV  | 0                | 0                | 0               | 0               |
| PVOE  | 0                | 0                | 0               | 0               |
| PVOV  | 0                | 0                | 0               | 0               |
| PTOE  | _                | -                | _               | -               |
| DIEOE | PCINT23 · PCIE2  | PCINT22 • PCIE2  | PCINT21 • PCIE2 | PCINT20 • PCIE2 |
| DIEOV | 1                | 1                | 1               | 1               |
| DI    | PCINT23入力        | PCINT22入力        | T1/PCINT21入力    | T0/PCINT20入力    |
| AIO   | AIN1入力           | AIN0入力           | <u>-</u>        | _               |

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

| 信号名   | PD3/INT1/PCINT19     | PD2/INT0/PCINT18     | PD1/PCINT17     | PD0/PCINT16     |
|-------|----------------------|----------------------|-----------------|-----------------|
| PUOE  | 0                    | 0                    | 0               | 0               |
| PUOV  | 0                    | 0                    | 0               | 0               |
| DDOE  | 0                    | 0                    | 0               | 0               |
| DDOV  | 0                    | 0                    | 0               | 0               |
| PVOE  | 0                    | 0                    | 0               | 0               |
| PVOV  | 0                    | 0                    | 0               | 0               |
| PTOE  | -                    | -                    | -               | _               |
| DIEOE | INT1許可+PCINT19·PCIE2 | INT0許可+PCINT18・PCIE2 | PCINT17 · PCIE2 | PCINT16 • PCIE2 |
| DIEOV | 1                    | 1                    | 1               | 1               |
| DI    | INT1/PCINT19入力       | INTO/PCINT18入力       | PCINT17入力       | RXD/PCINT16入力   |
| AIO   | _                    | _                    |                 | _               |

# 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 | BODSE | PUD | - | - | - | - | MCUCR |
| Read/Write  | R | R/W  | R/W   | R/W | R | R | R | R |       |
| 初期値         | 0 | 0    | 0     | 0   | 0 | 0 | 0 | 0 |       |

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

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

# 10.4.2. PORTCR - ホート制御レジスタ (Port Control Register)

| ピット         | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    | _      |
|-------------|------|------|------|------|------|------|------|------|--------|
| \$12 (\$32) | BBMD | BBMC | BBMB | BBMA | PUDD | PUDC | PUDB | PUDA | PORTCR |
| Read/Write  | R/W  |        |
| 初期値         | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |        |

### ■ ビット7~4 - BBMx:接続前切断動作許可 (Break-Before-Make Mode Enable)

これらのビットが1を書かれると、ポート単位の接続前切断動作が活性(有効)にされます。そして出力にするためのDDRxn書き込み時に仲介Hi-Z周期が挿入されます。更なる情報については38頁の「接続前切断切り替え」をご覧ください。

#### ■ ビット3~0 - PUDx: ポート単位プルアップ禁止 (Port-Wise Pull-up Disable)

これらのビットが1を書かれると、例えDDxnとPORTxnレジスタがプルアップを許可(DDxn=0, PORTxn=1)に設定されていても、定義された 入出力ポートでポート単位のプルアップが禁止されます。これらのポート単位プルアップ禁止ビットはMCU制御レジスタ(MCUCR)の全プルアップ禁止(PUD)ビットと論理和(OR)されます。この特徴についてより多くの詳細に関しては38頁の「ピンの設定」をご覧ください。

### 10.4.3. PORTA - ホートA出力レシ、スタ (Port A Data Register) (訳注:頁下段参照)

| ピット         | 7 | 6 | 5 | 4 | 3      | 2      | 1      | 0      |       |
|-------------|---|---|---|---|--------|--------|--------|--------|-------|
| \$0E (\$2E) | _ | - | - | - | PORTA3 | PORTA2 | PORTA1 | PORTA0 | PORTA |
| Read/Write  | R | R | R | R | R/W    | R/W    | R/W    | R/W    |       |
| 初期値         | 0 | 0 | 0 | 0 | 0      | 0      | 0      | 0      |       |

### 10.4.4. DDRA - ポートA方向レジスタ (Port A Data Direction Register) (訳注:頁下段参照)

| ピット         | 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    | _    |
|-------------|---|---|---|---|------|------|------|------|------|
| \$0D (\$2D) | _ | - | - | - | DDA3 | DDA2 | DDA1 | DDA0 | DDRA |
| Read/Write  | R | R | R | R | R/W  | R/W  | R/W  | R/W  |      |
| 初期値         | 0 | 0 | 0 | 0 | 0    | 0    | 0    | 0    |      |

#### 10.4.5. PINA - ポートA入力レジスタ (Port A Input Address) (訳注:頁下段参照)

| ピット         | 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     |      |
|-------------|---|---|---|---|-------|-------|-------|-------|------|
| \$0C (\$2C) | _ | - | - | - | PINA3 | PINA2 | PINA1 | PINA0 | PINA |
| Read/Write  | R | R | R | R | R/W   | R/W   | R/W   | R/W   |      |
| 初期値         | 0 | 0 | 0 | 0 | 不定    | 不定    | 不定    | 不定    |      |

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

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

(<mark>訳補</mark>) 28ピン外囲器にはPA3~0が存在しないため、PORTA,DDRA,PINAレシブスタは利用できません。





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

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

# 10.4.8. PINB - ポートB入力レジスタ (Port B Input Address)

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

# 10.4.9. PORTC - ホートC出力レジスタ (Port C Data Register)

| ピット         | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |       |
|-------------|--------|--------|--------|--------|--------|--------|--------|--------|-------|
| \$08 (\$28) | PORTC7 | PORTC6 | PORTC5 | PORTC4 | PORTC3 | PORTC2 | PORTC1 | PORTC0 | PORTC |
| Read/Write  | R/W    |       |
| 初期値         | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |       |

# 10.4.10. DDRC - ポートC方向レジスタ (Port C Data Direction Register)

| ピット         | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    | _    |
|-------------|------|------|------|------|------|------|------|------|------|
| \$07 (\$27) | DDC7 | DDC6 | DDC5 | DDC4 | DDC3 | DDC2 | DDC1 | DDC0 | DDRC |
| Read/Write  | R/W  |      |
| 初期値         | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |      |

# 10.4.11. PINC - ポートC入力レジスタ (Port C Input Address)

| ピット         | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |      |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|------|
| \$06 (\$26) | PINC7 | PINC6 | PINC5 | PINC4 | PINC3 | PINC2 | PINC1 | PINC0 | PINC |
| Read/Write  | R/W   |      |
| 初期値         | 不定    |      |

# 10.4.12. PORTD - ホートD出力レジスタ (Port D Data Register)

| <b>ビット</b>  | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |       |
|-------------|--------|--------|--------|--------|--------|--------|--------|--------|-------|
| \$0B (\$2B) | PORTD7 | PORTD6 | PORTD5 | PORTD4 | PORTD3 | PORTD2 | PORTD1 | PORTD0 | PORTD |
| Read/Write  | R/W    |       |
| 初期値         | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |       |

# 10.4.13. DDRD - ポートD方向レジスタ (Port D Data Direction Register)

|      |        |      |      |      |      | _    |      |      |      |      |
|------|--------|------|------|------|------|------|------|------|------|------|
| ť    | ゛ット    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    | _    |
| \$0A | (\$2A) | DDD7 | DDD6 | DDD5 | DDD4 | DDD3 | DDD2 | DDD1 | DDD0 | DDRD |
| Read | /Write | R/W  |      |
| 初    | 期値     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |      |

# 10.4.14. PIND - ポートD入力レジスタ (Port D Input Address)

| ピット         | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     | _    |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|------|
| \$09 (\$29) | PIND7 | PIND6 | PIND5 | PIND4 | PIND3 | PIND2 | PIND1 | PIND0 | PIND |
| Read/Write  | R/W   |      |
| 初期値         | 不定    |      |

# 11. 8ビット タイマ/カウンタ0

# 11.1. 特徴

- 2つの独立した比較出力部
- 比較一致でのタイマ/カウンタ解除(自動再設定)
- 3つの独立した割り込み (TOV0,OCF0A,OCF0B)

#### 11.2. 概要

タイマ/カウンタのは2つの独立した比較出力部付きの汎用8ビット タイマ/カウンタ部です。それは正確なプログラム実行タイミング(事象管理)、波形生成を許します。この8ビット タイマ/カウンタの簡単化した構成図は図11-1.で示されます。I/Oピンの実際の配置については2頁の「ピン配置」を参照してください。CPUがアクセス可能な(I/OビットとI/Oピンを含む)I/Oレジスタは赤文字(訳注:原文は太字)で示されます。デバイス仕様のI/Oレジスタとビット位置は55頁の「8ビット タイマ/カウンタ0用レジスタ」で一覧されます。

24頁の「PRR - 電力削減レジスタ」のPRTIMOビットはタイマ/カウンタ0部を許可するために0を書かれなければなりません。



# 11.2.1. 関係レジスタ

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

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

比較レジスタ(OCR0AとOCR0B)はタイマ/カウンタ値と常に比較されます。この比較一致発生は比較一致割り込み要求の発生に使える比較一致割り込み要求フラグ(OCF0AとOCF0B)も設定(1)します。

### 11.2.2. 定義

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

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

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





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

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

# 11.4. 計数器部

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



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

計数順序(方法)はタイマ/カウンタ制御レシ、スタA(TCCR0A)に配置された比較一致解除許可(CTC0)ビットの設定によって決定されます。進化した計数順序についてのより多くの詳細に関しては53頁の「動作種別」をご覧ください。

タイマ/カウンタ溢れ(TOV0)フラグはCTC0ビットによって選択された動作種別に従って設定(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)できます。

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



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

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

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

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

# 11.6. 動作種別

動作種別、換言するとタイマ/カウンタと比較出力の動作は比較一致解除許可(CTC0)ビットによって定義されます。 タイミング情報の詳細については54頁の「**タイマ/カウンタ0のタイミング**」を参照してください。

#### 11.6.1. 標準動作

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

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

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

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



(訳注) 本図内の周期はOCFnx割り込み時に値反転を行った場合のそれに対する周期で、参考の意味だけです。

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

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





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

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



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



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



図11-8.はOCROAがTOPのCTC動作でのTCNT0の解除とOCF0Aの設定を示します。



# 11.8. 8ビット タイマ/カウンタ用レシ、スタ

# 11.8.1. TCCR0A - タイマ/カウンタ制御レシ、スタA (Timer/Counter 0 Control Register A)

| ピット         | 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    | _      |
|-------------|---|---|---|---|------|------|------|------|--------|
| \$25 (\$45) | _ | - | - | - | CTC0 | CS02 | CS01 | CS00 | TCCR0A |
| 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 - CTC0: 比較一致解除許可 (Clear Timer on Compare Match Mode)

このビットはカウンタの計数手順、最大カウンタ(TOP)値の供給元を制御します。表11-2.をご覧ください。タイマ/カウンタ部によって支援される動作種別は標準動作(カウンタ)、比較一致タイマ/カウンタ解除(CTC)動作です。53頁の「動作種別」をご覧ください。

#### 表11-2. CTC動作Linh内容

| 番 | 号 | CTC0 | タイマ/カウンタ動作種別          | TOP値  | OCR0x更新時 | TOV0設定時 |
|---|---|------|-----------------------|-------|----------|---------|
|   | 0 | 0    | 標準動作                  | \$FF  | 即時       | MAX     |
|   | 1 | 1    | 比較一致タイマ/カウンタ解除(CTC)動作 | OCR0A | 即時       | MAX     |

#### 注: MAX=\$FFです。

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

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

#### 表11-3. タイマ/カウンタ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.8.2. TCNT0 - タイマ/カウンタ (Timer/Counter 0)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |       |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$26 (\$46) | (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.8.3. OCR0A - タイマ/カウンタ 比較Aレシ スタ (Timer/Counter 0 Output Compare A Register)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |       |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$27 (\$47) | (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ビットの値を含みます。一致は比較一致割り込みを生成するのに使えます。





### 11.8.4. OCR0B - タイマ/カウンタ 比較Bレシ、スタ (Timer/Counter 0 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ビットの値を含みます。一致は比較一致割り込みを生成するのに使えます。

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

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

#### ■ L'ット7~3 - Res: 予約 (Reserved)

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

55頁の表11-2.「CTC動作ビット内容」をご覧ください。

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

# 12.1. 特徴

- 真の16ビット設計(換言すれば16ビットPWMの許容)
- 2つの独立した比較出力部
- 2重緩衝の比較レジスタ
- •1つの捕獲入力部
- 捕獲入力雜音消去器
- 比較一致でのタイマ/カウンタ解除(自動再設定)
- 不具合なしで正しい位相のパルス幅変調器 (PWM)
- 可変PWM周期
- 周波数発生器
- 外部事象計数器
- 4つの独立した割り込み (TOV1,OCF1A,OCF1B,ICF1)

# 12.2. 概要

本資料でのレシ、スタとビット参照の多くは一般形で書かれ、ここで小文字の'n'はタイマ/カウンタ番号、小文字の'x'は比較出力部の置き換えです。けれどもプログラムでレシ、スタまたはビット定義に使う時は正確な形式が使われなければなりません(例えばタイマ/カウンタ1のカウンタ値に対するアクセスのTCNT1のように)。

この16ビット タイマ/カウンタ部は正確なプログラム実行タイミング(事象管理)、波形生成、信号タイミング計測を許します。この16ビット タイマ/カウンタの簡単化した構成図は図12-1.で示されます。



てください。 実際のI/Oピンの配置については2頁の「**ピン配置**」を参照してください。CPUがアクセス可能な(I/OビットとI/Oピンを含む)I/Oレジスタは<mark>赤</mark>

文字(訳注: 原文太字)で示されます。デバイス仕様のI/Oレジスタとピット位置は71頁の「16ピットタイマ/カウンタ1用レジスタ」で示されます。

24頁の「PRR - 電力削減レジスタ」のPRTIM1ビットはタイマ/カウンタ1部を許可するために0を書かれなければなりません。





### 12.2.1. 関係レジスタ

gイマ/カウンタ(TCNT1)、比較レシ、スタ(OCR1A,OCR1B)、捕獲レシ、スタ(ICR1)は全て16ビットレジ、スタです。16ビットレジ、スタをアクセスするとき、特別な手順に従わなければなりません。これらの手順は59頁の「16ビットレジ、スタのアクセス」項で記述されます。タイマ/カウンタ1制御レジ、スタ(TCCR1A,TCCR1B,TCCR1C)は8ビットレジ、スタで、CPUアクセスの制限はありません。割り込み要求信号はタイマ/カウンタ1割り込み要求レジ、スタ(TIFR1)で全て見えます。全ての割り込みはタイマ/カウンタ1割り込み許可レジ、スタ(TIMSK1)で個別に遮蔽(禁止)されます。TIFR1とTIMSK1はこの図で示されません。

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

2重緩衝化した比較レジスタ(OCR1A,OCR1B)はタイマ/カウンタ値と常に比較されます。この比較結果は比較出力(OC1A,OC1B)ピンでPW Mまたは可変周波数出力を生成するための波形生成器によって使えます。63頁の「**比較出力部**」をご覧ください。この比較一致発生は比較出力割り込み要求の発生に使える比較一致割り込み要求フラグ(OCF1A,OCF1B)も設定(1)します。

捕獲レジスタ(ICR1)は捕獲起動(ICP1)ピンまたはアナログ比較器出力(105頁の「**アナログ比較器**」参照)のどちらかの外部(エッジで起動された)事象でタイマ/カウンタ値を捕獲(複写)できます。捕獲入力部はスパイク雑音を捕らえる機会を軽減するためにデジタレ濾波器(雑音消去器)を含みます。

TOP値または最大タイマ/カウンタ値は、いくつかの動作種別でOCR1A、ICR1、または一群の固定値の何れかによって定義できます。 PWM動作でTOP値としてOCR1Aを使うと、OCR1AはPWM出力生成用に使えません。 けれどもこの場合、TOP値は動作中に変更されることをTOP値に許す2重緩衝化します。 固定的なTOP値が必要とされる場合、ICR1が代わりに使え、PWM出力として使われるべきOCR1Aを開放します。

### 12.2.2. 定義

次の定義は本資料を通じて広範囲に使われます。

| 表12-1. 用語定義 |                                                                                                             |  |  |  |  |  |  |
|-------------|-------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 用語          | 意味                                                                                                          |  |  |  |  |  |  |
| BOTTOM      | 計数器が\$0000に到達した時。                                                                                           |  |  |  |  |  |  |
| MAX         | 計数器が\$FFFF(65535)に到達した時。                                                                                    |  |  |  |  |  |  |
| ТОР         | 計数器がTOP値に到達した時(計数動作での最大値と等しくなった時)。TOP値は固定値(\$00FF,\$01FF,\$03FF)、OCR1A値、ICR1値の何れか1つを指定できます。この指定は動作種別に依存します。 |  |  |  |  |  |  |

# 12.3. 16ビットレジスタのアクセス

TCNT1,OCR1A,OCR1B,ICR1は8ビット バス経由でAVR CPUによってアクセスできる16ビット レジスタです。この16ビット レジスタは2回の読みまたは書き操作を使ってバイト アクセスされなければなりません。16ビット タイマ/カウンタは16ビット アクセスの上位バイトの一時保存用に1つの8 ビット レジスタを持ちます。16ビット タイマ/カウンタ内の全ての16ビット レジスタ間で、この同じ一時レジスタが共用されます。下位バイト アクセスが16ビット読み書き動作を起動します。16ビット レジスタの下位バイトがCPUによって書かれると、一時レジスタに保存した上位バイトと書かれた下位バイトは同じクロック周期で16ビット レジスタに両方が複写されます。16ビット レジスタの下位バイトがCPUによって読まれると、16ビット レジスタの上位バイトは下位バイトが読まれるのと同じクロック周期で一時レジスタに複写されます。

全ての16ビットアクセスが上位バイトに対して一時レジスタを使う訳ではありません。OCR1AとOCR1Bの16ビットレジスタ読み込みは一時レジスタの使用に関係しません。

16ビット書き込みを行うために、上位バイトは下位バイトに先立って書かれなければなりません。16ビット読み込みについては下位バイトが上位バイトの前に読まれなければなりません。

次のコート・例は割り込みが一時レシ、スタを更新しないことが前提の16ビットタイマ/カウンタレジ、スタのアクセス法を示します。OCR1A, OCR1B, ICR1レジ、スタのアクセスに対して同じ原理が直接的に使えます。C言語を使う時はコンパイラが16ビットアクセスを扱うことに注意してください。



アセンブリ言語コート・例はR17:R16レジスタ対にTCNT1値を戻します。

16ビット レジスタ アクセスが非分断操作であるのに注意することが重要です。16ビット レジスタをアクセスする2命令間で割り込みが起き、割り込みコードがその16ビット タイマ/カウンタ レジスタの同じ若しくは他の何れかをアクセスすることによって一時レジスタを更新する場合、割り込み外のその後のアクセス結果は不正にされます。従って主コードと割り込みコードの両方が一時レジスタを更新するとき、主コードは16ビット アクセス中の割り込みを禁止しなければなりません。





次のコード例はTCNT1レジスタ内容の非分断読み込み法を示します。同じ原理を使うことにより、OCR1A,OCR1B,ICR1のどの読み込みも行えます。

```
アセンブリ言語プログラム例
RD_TCNT1:
                                                  ;現全割り込み許可フラグ(I)を保存
           IN
                 R18, SREG
           CLI
                                                  ;全割り込み禁止
                                                  ;TCNT1下位バイト取得(上位バイト⇒一時レジスタ)
                 R16, TCNT1L
           ΙN
                 R17, TCNT1H
                                                  ;TCNT1上位バイ取得(一時レジスタ)
           ΤN
           OUT
                 SREG, R18
                                                  ;全割り込み許可フラグ(I)を復帰
           RET
                                                  ;呼び出し元へ復帰
C言語プログラム例
unsigned int TIM16_Read_TCNT1(void)
   unsigned char sreg;
                                                  /* ステータス レシブスター時保存変数定義 */
   unsigned int i;
                                                  /* TCNT1読み出し変数定義 */
   sreg = SREG;
                                                  /* 現全割り込み許可フラグ(I)を保存 */
                                                  /* 全割り込み禁止 */
   __disable_interrupt();
   i = TCNT1;
                                                  /* TCNT1値を取得 */
                                                  /* 全割り込み許可フラグ(I)を復帰 */
   SREG = sreg;
   return i;
                                                  /* TCNT1値で呼び出し元へ復帰 */
```

### 注: 5頁の「コート・例について」をご覧ください。

アセンブリ言語コート・例はR17:R16レシブスタ対にTCNT1値を戻します。

次のコート・例はTCNT1レシ、スタ内容の非分断書き込み法を示します。同じ原理を使うことにより、OCR1A,OCR1B,ICR1のどの書き込みも行えます。

```
アセンブリ言語プログラム例
WR TCNT1:
           IN
                 R18, SREG
                                                   ;現全割り込み許可フラグ(I)を保存
                                                   ;全割り込み禁止
           CLI
                                                   ;TCNT1上位バイ設定(一時レジスタ)
           OUT
                 TCNT1H, R17
           OUT
                 TCNT1L, R16
                                                   ;TCNT1下位バイト設定(一時レジスタ⇒上位バイト)
           OUT
                 SREG, R18
                                                   ;全割り込み許可フラグ(I)を復帰
           RET
                                                   ;呼び出し元へ復帰
C言語プログラム例
void TIM16_Write_TCNT1(unsigned int i)
                                                  /* ステータス レシブスター時保存変数定義 */
   unsigned char sreg;
   unsigned int i;
                                                  /* TCNT1書き込み変数定義 */
   sreg = SREG;
                                                  /* 現全割り込み許可フラグ(I)を保存 */
    __disable_interrupt();
                                                  /* 全割り込み禁止 */
                                                  /* TCNT1値を設定 */
   TCNT1 = i;
                                                  /* 全割り込み許可フラグ(I)を復帰 */
   SREG = sreg;
```

#### **注**: 5頁の「**コート 例について**」をご覧ください。

アセンブリ言語コート、例はR17:R16レジスタ対がTCNT1へ書かれるべき値を含むことが必要です。

#### 12.3.1. 上位バイー時レジスタの再使用

書かれる全レジスタについて上位バイトが同じ複数16ビット レジスタ書き込みなら、上位バイトは1度書かれることだけが必要です。けれども直前で記述した非分断操作の同じ規則がこの場合にも適用されることに注意してください。

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

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

# 12.5. 計数器部

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



この16ビット カウンタはカウンタの上位8ビットを含むカウンタ上位(TCNT1H)と下位8ビットを含むカウンタ下位(TCNT1L)の2つの8ビット I/Oメモリ位置に配置されます。TCNT1HレジスタはCPUによって間接的なアクセスのみできます。CPUがTCNT1H I/O位置をアクセスする時にCPUは上位ハイトー時レジスタ(TEMP)をアクセスします。この一時レジスタはTCNT1Lが読まれる時にTCNT1H値で更新され、TCNT1Lが書かれる時にTCNT1Hは一時レジスタ値で更新されます。これは8ビットデータハス経由で1クロック周期内での16ビットカウンタ値全体の読み書きをCPUに許します。予測不能な結果を与える、カウンタが計数中の時のTCNT1書き込みの特別な場合に注意することが重要です。この特別な場合はそれらが重要となる項で記述されます。

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

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

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





# 12.6. 捕獲入力部

タイマ/カウンタは外部の出来事を捕獲でき、発生時間を示す時間印(タイマ/カウンタ値)を与える捕獲入力部と合体します。出来事または複数の出来事を示す外部信号はICP1ピンまたは代わりにアナロケ、比較器部経由で印加できます。時間印はその後、周波数、デューティ比、印加された信号の他の特徴の計算に使えます。代わりに時間印は出来事の記録作成にも使えます。

捕獲入力部は**図12-3**.で示される構成図によって図解されます。直接的な捕獲入力部の部分でない構成図の要素は青枠(<mark>訳注</mark>:原文は灰色背景)で示されます。レジスタとビット名での小文字の'n'はタイマ/カウンク番号を示します。



捕獲起動入力(ICP1)ピン若しくは代わりにアナログ比較器出力(ACO)で論理レヘブルの変化(出来事)が起き、その変化がエッジ検出器の設定を追認すると、捕獲が起動されます。捕獲が起動されると、カウンタ(TCNT1)の16ピット値が捕獲レジスタ(ICR1)に書かれます。捕獲割り込み要求フラグ(ICF1)はTCNT1値がICR1に複写されるのと同じシステムクロックで設定(1)されます。許可(I=1, ICIE1=1)ならば捕獲割り込み要求フラグは捕獲割り込みを発生します。ICF1は割り込みが実行されると自動的に解除(0)されます。代わりにこのI/O ビット位置に論理1を書くことによってソフトウェアで解除(0)できます。

捕獲レジスタ(ICR1)の16ビット値読み込みは初めに下位バイト(ICR1L)、その後に上位バイト(ICR1H)を読むことによって行われます。下位 バイトが読まれる時に上位バイトが上位バイト一時レジスタ(TEMP)に複写されます。 CPUがICR1H I/O位置を読むと、この一時レジスタをアクセスします。

ICR1はカウンタのTOP値定義にICR1を利用する波形生成種別を使う時だけ書けます。これらの場合、TOP値がICR1に書かれるであろう前に波形生成種別(WGM13~0)ビットが設定されなければなりません。ICR1に書くとき、下位バイトがICR1Lに書かれる前に上位バイトがICR1H I/O位置に書かれなければなりません。

16ビット レジスタ アクセス法のより多くの情報については59頁の「16ビット レジスタのアクセス」を参照してください。

### 12.6.1. 捕獲起動元

捕獲入力部用の主な起動元は捕獲起動入力(ICP1)ピンです。タイマ/カウンタ1は捕獲入力部用起動元としてアナログ比較器出力を代わりに使えます。アナログ比較器はアナログ比較器制御/状態レシ、スタ(ACSR)のアナログ比較器捕獲起動許可(ACIC)ピットの設定(1)によって起動元として選択されます。起動元を変更することが捕獲を起動し得ることに気付いてください。従って捕獲割り込み要求フラグ(ICF1)はその変更後に解除(0)されなければなりません。

捕獲起動入力(ICP1)ピンとアナログ比較器出力(ACO)の両入力はT1ピン(76頁の図13-1.参照)についてと同じ技法を使って採取されます。エッジ検出器も全く同じです。けれども雑音消去が許可されると、付加論理回路がエッジ検出器の前に挿入され、そして遅延を4システムクロック周期増やします。タイマ/カウンタがTOP値定義にICR1を使う波形生成種別に設定されないなら、雑音消去器とエッジ検出器の入力は常に許可されることに注意してください。

捕獲入力はICP1ピンのポートを制御することによってソフトウェアで起動できます。

# 12.6.2. 雑音消去器

雑音消去器は簡単なデジタル濾波器機構を使うことによって雑音耐性を改善します。雑緒音消去器の入力は4採取に渡って監視され、エッジ検出器によって使われる方向転換となる出力を変更するためには4回全てが同じでなければなりません。

雑音消去器はタイマ/カウンタ制御レジスタB(TCCR1B)の捕獲入力雑音消去許可(ICNC1)ビットの設定(1)によって許可されます。許可した時に雑音消去器は入力に印加した変更からICR1の更新までに4システム クロック周期の追加遅延をもたらします。雑音消去器はシステム クロックを使い、従って前置分周器によって影響されません。

### 12.6.3. 捕獲入力の使用

捕獲入力機能を使う主な要求(目的)は入って来る出来事に対して充分なプロセッサ能力を当てがうことです。2つの出来事間の時間が際どいとします。次の出来事が起こる前に捕獲した捕獲レジスタ(ICR1)の値をプロセッサが読めなかった場合、ICR1は新しい値で上書きされます。この場合、捕獲の結果は不正にされます。

捕獲割り込みを使う時にICR1は割り込み処理ルーチンで可能な限り早く読まれるべきです。捕獲割り込みが相対的に高い優先順位であっても、最大割り込み応答時間は他の割り込み要求の何れかを扱うために必要とされる最大クロック周期数に依存します。

動作中にTOP値(分解能)が積極的に変更されるとき、どの動作種別での捕獲入力部の使用も推奨されません。

外部信号のデューティ比測定は各捕獲後に起動端が変更されることを必要とします。検出端の変更はICR1が読まれてしまった後に可能な限り早く行われなければなりません。エッシ、の変更後、捕獲割り込み要求フラケ(ICF1)はソフトウェア(I/Oビット位置への論理1書き込み)によって解除(0)されなければなりません(訳補:エッシ・変更によってICF1が設定(1)されることを想定)。周波数のみの測定については(割り込み処理が使われる場合)ICF1の解除(0)は必要とされません。

## 12.7. 比較出力部

この16ピット比較器はTCNT1と比較レジスタ(OCR1x)を継続的に比較します。TCNT1とOCR1xが等しければ比較器が一致を指示します。この一致は次のタイマ/カウンタ クロック周期で比較割り込み要求フラグ(OCF1x)を設定(1)します。許可(I=1,OCIE1x=1)なら、この比較割り込み要求フラグが比較割り込みを発生します。OCF1xは割り込みが実行されると自動的に解除(0)されます。代わりにOCF1xはこのI/Oビット位置に論理1を書くことによってソフトウェアで解除(0)できます。波形生成器は波形生成種別(WGM13~0)ビットと比較出力選択(COM1x1,0)ビットによって設定された動作種別に従った出力を生成するのにこの一致信号を使います。TOPとBOTTOM信号は動作種別(66頁の「動作種別」参照)のいくつかで両端値の特別な場合を扱うため、波形生成器によって使われます。

比較A出力部の特殊な特性はタイマ/カウンタのTOP値(換言するとカウンタの分解能)定義を許します。カウンタの分解能に加え、TOP値は波形生成器によって生成された波形の周期時間を定義します。

図12-4.は比較出力部の構成図を示します。レジスタとビット名での小文字の'n'はタイマ/カウンタ番号(タイマ/カウンタ1に対してはn=1)、小文字の'x'は比較出力部(AまたはB)を表します。直接的な比較出力部の部分でない構成図の要素は青枠(訳注:原文は灰色背景)で示されます。







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

OCR1xのアクセスは複雑なように思えますが決してそんなことはありません。2重緩衝動作が許可されるとCPUはOCR1x緩衝部をアクセスし、禁止されるとOCR1xレジ、スタを直接アクセスします。OCR1x(緩衝部またはレジ、スタ)の内容は書き込み操作によってのみ変更されます(タイマ/カウンタはTCNT1やICR1のようにOCR1xを自動的に更新しません)。従ってOCR1xは上位パイトー時レジ、スタ(TEMP)経由で読まれません。けれども他の16ピット レジ、スタをアクセスする時のように下位パイトを先に読むのは良い習慣です。OCR1x書き込みは16ピット全ての比較が継続的に行われるため、一時レジ、スタ経由で行われなければなりません。上位パイト(OCR1xH)は先に書かれなければなりません。上位パイト(OCR1xH)は先に書かれなければなりません。上位パイト(OCR1xH)はたに書かれなければなりません。上位パイト(OCR1xH)が下位8t゚ットを書かれると、(一時レジ、スタ内の)上位パイトは(下位パイト書き込みと)同じシステムクロック周期でOCR1x緩衝部またはOCR1xレジ、スタのどちらかに複写されます。

16ビット レジスタ アクセス法のより多くの情報については59頁の「16ビット レジスタのアクセス」を参照してください。

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

## 12.7.1. 強制比較出力

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

### 12.7.2. TCNT1書き込みによる比較一致妨害

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

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

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

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

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

# 12.8. 比較一致出力部

比較出力選択(COM1x1,0)と、かは2つの機能を持ちます。波形生成器は次の比較一致での比較出力(OC1x)状態の定義にCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、かにCOM1x1,0と、のにCOM1x1,0と、かにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、かにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM1x1,0と、のにCOM



COM1x1,0ビットのどちらかが設定(1)されると、標準I/Oポート機能は波形生成器からの比較出力(OC1x)によって無効にされます。けれどもOC1xピンの方向(入出力)はポート ピンに対するポート方向レジスタ(DDR)によって未だ制御されます。OC1xピンに対するポート方向レジスタのビット(DDR\_OC1x)はOC1x値がピンで見えるのに先立って出力として設定されなければなりません。このポートの交換機能は一般的に波形生成種別と無関係ですがいくつかの例外があります。詳細については、表12-2、表12-3、表12-4、を参照してください。

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

COM1x1.0ビットは捕獲入力部での何の効果もありません。

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

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

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





## 12.9. 動作種別

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

タイミング情報の詳細については70頁の「タイマ/カウンタ1のタイミング」を参照してください。

### 12.9.1. 標準動作

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

捕獲入力部は標準動作で使用が容易です。けれども外部の事象間の最大間隔がタイマ/カウンタの分解能(16ビット長)を越えてはならないことに気付いてください。事象間の間隔が長すぎる場合、捕獲部に対して分解能を拡張するためにタイマ/カウンタ溢れ割り込みまたは前置分周器が使われなければなりません。

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

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

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

CTC動作に関するタイミング図は**図12-6**.で示されます。カウンタ(TCNT1)値はOCR1AまたはICR1のどちらかで比較一致が起こるまで増加し、そしてその後カウンタ(TCNT1)は解除(\$0000)されます。



TOP値を定義するのに使われるレジスタに対してOCF1AまたはICF1のどちらかを使うことにより、カウンタ値がTOP値に到達する時毎に割り込みが生成できます。割り込みが許可されるなら、割り込み処理ルーチンはTOP値を更新するのに使えます。けれども前置分周なしまたは低い前置分周値でカウンタが走行している時にBOTTOMと近い値にTOPを変更することは、CTC動作が2重緩衝機能を持たないために注意して行わなければなりません。OCR1AまたはICR1に書かれた新しい値がTCNT1の現在値より低い(小さい)場合、カウンタは(その回の)比較一致を失います。その後カウンタは比較一致が起こせるのに先立って最大値(\$FFFF)へそして次に\$0000から始める計数をしなければならないでしょう。多くの場合でこの特性は好ましくありません。OCR1Aが2重緩衝されるので、代替はTOPを定義するのにOCR1Aを使う高速PWM動作(WGM13~0=1111)を使うことでしょう。

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

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

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

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

## 12.9.3. 高速PWM動作

高速 $\ref{n}$ %ルス幅変調(PWM)動作(WGM13 $\ref{n}$ 0=0101,0110,0111,1110,1111)は高周波数PWM波形生成選択を提供します。高速PWMはそれが単一傾斜(鋸波)動作であることによって他のPWM動作と異なります。カウンタはBOTTOMからTOPまで計数し、その後BOTTOMから再び始めます。非反転比較出力動作(COM1x1,0=10)での比較出力(OC1x)はTCNT1とOCR1x間の比較一致で解除(0)され、TOPで設定(1)されます。反転出力動作(COM1x1,0=11)の出力は比較一致で設定(1)され、TOPで解除(0)されます。単一傾斜動作のため、高速PWM動作の動作周波数は両傾斜(三角波)動作を使う位相基準や位相/周波数基準PWM動作よりも2倍高くできます。この高い周波数は電力調節、整流、D/A変換に対して高速PWM動作を都合よく適合させます。高い周波数は物理的に小さな外部部品(コイルやコンデンナ)を許し、従ってシステム総費用を削減します。

高速PWMのPWM分解能は8,9,10ピットに固定、またはOCR1AかICR1のどちらかによって定義できます。 許された最小分解能は2ビット(OCR1AまたはICR1が\$0003設定)、最大分解能は16ビット(OCR1AまたはICR1がMAX設定)です。ビットでのPWM分解能は次(右)式を使うことによって計算できます。

$$R_{\text{FPWM}} = \frac{\log (\text{TOP} + 1)}{\log 2}$$

高速PWM動作でのカウンタはカウンタ値が固定値\$00FF,\$01FF,\$03FF(WGM13~0=0101,0110,0111)、ICR1値(WGM13~0=1110)またはOCR1A値(WGM13~0=1111)の何れかと一致するまで増加されます。そしてカウンタは(一致の)次のタイマ/カウンタ クロック周期で解除(\$0000)されます。高速PWM動作のタイミング図は図12-7.で示されます。本図はOCR1AかICR1がTOPを定義するのに使われる時の高速PWM動作を示します。TCNT1値はタイミング図で単一傾斜動作(鋸波)を表す折れ線グラフとして示されます。本図は非反転と反転のPWM出力を含みます。細い赤線はOCR1x値を示し、TCNT1値との交点(接点)がTCNT1とOCR1x間の比較一致を示します(訳注:図補正に伴い本行若干変更)。比較割り込み要求フラグ(OCF1x)は比較一致が起こると設定(1)されます。

タイマ/カウンタ溢れ割り込み要求(TOV1)フラグはカウンタがTOPに到達する時毎に設定(1)されます。加えて、OCR1AかICR1のどちらかがTOP値を定義するのに使われる時にOCF1AまたはICF1割り込み要求フラグはTOV1が設定(1)されるのと同じタイマ/カウンタクロック周期で設定(1)されます。これらの割り込みの1つが許可されるなら、その割り込み処理ルーチンはTOPと比較値を更新するのに使えます。

TOP値を変更するとき、プログラムは新TOP値が全ての比較レジスタ値と等しいか大きいことを保証しなければなりません。TOP値が何れかの比較レジスタより小さな場合、TCNT1とそのOCR1x間で比較一致は決して起きません。固定TOP値を使う



場合、どのOCR1xが書かれる時も、未使用ビットが0で隠(に置換)されることに注意してください。

ICR1がTOP値を定義するのに使われるとき、ICR1を更新する手順はOCR1Aの更新と異なります。ICR1は2重緩衝されません。これは前置分周なし、または低い前置分周値でカウンタが走行している時にICR1が小さな値に変更される場合、書かれた新しいICR1値がTCNT1の現在値より小さくなる危険を意味します。その後の結果はカウンタが(その回の)TOP値での比較一致を失うことです。その後カウンタは比較一致を起こせるのに先立ってMAX値(\$FFFF)へそして次に\$0000から始める計数をしなければならないでしょう。しかし、OCR1Aは2重緩衝されます。この特徴は何時でも書かれることをOCR1AのI/O位置に許します。OCR1A I/O位置が書かれると、書かれた値はOCR1A緩衝部に置かれます。OCR1A(比較)レシ、スタはその後にTCNT1がTOPと一致した次のタイマ/カウンタ クロック周期にOCR1A緩衝部の値で更新されます。この更新はTCNT1の解除(\$0000)やTOV1の設定(1)と同じタイマ/カウンタ クロック周期で行われます。

TOPを定義するのにICR1を使うことは決まったTOP値を使う時に上手くいきます。ICR1を使うことにより、OC1AでのPWM出力を生成するためにOCR1Aが自由に使えます。けれども基準PWM周波数が(TOP値を変更することによって)動的に変更される場合、OCR1Aが2重緩衝機能のため、TOPとしてOCR1Aを使うことは明らかに良い選択です。

高速PWM動作での比較部はOC1xt°ンでのPWM波形の生成を許します。COM1x1,0t'ットを'10'に設定することは非反転PWM出力を作成し、反転PWM出力はCOM1x1,0を'11'に設定することで生成できます。71頁の表12-3.をご覧ください。実際のOC1x値はそのポート t°ンに対するデータ方向が出力(DDR\_OC1x=1)として設定される場合だけ見えるでしょう。PWM波形はTCNT1とOCR1x間の比較一致でOC1x(内部)レジスタを設定(1)(または解除(0))と、カウンタが解除(\$0000、TOPからBOTTOMへ変更)されるタイマ/カウンタ クロック周期でのOC1xレジスタを解除(0)(または設定(1))することによって生成されます。

PWM出力周波数は次式によって計算できます。変数Nは前置分周数(1,8,64,256,1024)を表します。 OCR1xの両端値は高速PWM動作でPWM波形出力を生成する時の特別な場合にあたります。 OCR1xがBOTTOM(\$0000)に等しく設定されると、出力はTOP+1 タイマ/カクンタ クロック周期毎の狭いス

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

パイク(パルス)になるでしょう。OCR1xがTOPに等しく設定されると、(COM1x1,0ビットによって設定される出力極性に依存して)定常的なLowまたはHigh出力に終わるでしょう。

高速PWM動作で(デューティ比50%)周波数の波形出力は比較一致毎に論理反転するOC1A設定(COM1A1,0=01)によって達成できます。これはTOP値を定義するのにOCR1Aが使われる(WGM13~0=1111)の場合にだけ適用されます。生成された波形はOCR1Aが0 (\$0000)に設定される時に $f_{\rm OC1A}=f_{\rm clk\_I/O}/2$ の最大周波数でしょう。この特性は高速PWM動作で比較出力部の2重緩衝機能が許可されることを除いて、CTC動作でのOC1A交互出力(COM1A1,0=01)と同じです。





## 12.9.4. 位相基準PWM動作

位相基準パルス幅変調(PWM)動作(WGM13~0=0001,0010,0011,1010,1011)は高分解能で正しい位相のPWM波形生成選択を提供します。位相基準PWM動作は両傾斜(三角波)動作を基準とした位相/周波数基準PWMと似ています。カウンタはBOTTOM(\$0000)からTOPへ、そしてその後TOPからBOTTOMへを繰り返し計数します。非反転比較出力動作(COM1x1,0=10)での比較出力(OC1x)は上昇計数中のTCNT1とOCR1x間の比較一致で解除(0)され、下降計数中の比較一致で設定(1)されます。反転出力動作(COM1x1,0=11)での動作は逆にされます。両傾斜(三角波)動作は単一傾斜(鋸波)動作より低い最大動作周波数になります。けれども両傾斜(三角波)PWM動作の対称特性のため、これらの動作種別は電動機制御の応用に好まれます。

位相基準PWM動作のPWM分解能は8,9,10ビットに固定、若しくはOCR1AかICR1のどちらかによって定義できます。許された最小分解能は2ビット(OCR1AまたはICR1が\$0003設定)、最大分解能は16ビット(OCR1AまたはICR1がMAX設定)です。ビットでのPWM分解能は次式を使うことによって計算できます。

$$R_{\text{PCPWM}} = \frac{\log (\text{TOP} + 1)}{\log 2}$$

位相基準PWM動作でのカウンタはカウンタ値が固定値\$00FF,\$01FF,\$03FF(WGM13~0=0001,0010,0011)、ICR1値(WGM13~0=1010)またはOCR1A値(WGM13~0=1011)の何れかと一致するまで増加されます。カウンタはTOPに到達したその時に計数方向を変更します。このTCNT1値は1タイマ/カウンタクロッ

ク周期間TOPと等しくなります。位相基準PWM動作のタイング図は図12-8.で示されます。この図はOCR1AかICR1がTOPを定義するのに使われる時の位相基準PWM動作を示します。TCNT1値はタイング図で両傾斜動作(三角波)を表す折れ線グラフとして示されます。この図は非反転と反転のPWM出力を含みます。細い赤線はOCR1x値を示し、TCNT1値との交点(接点)がTCNT1とOCR1x間の比較一致を示します(訳注:図補正に伴い本行若干変更)。比較割り込み要求フラグ(OCF1x)は比較一致が起こると設定(1)されます。



タイマ/カウンタ溢れ(TOV1)フラグ はカウンタがBOTTOMに到達する時毎に設定(1)されます。OCR1AかICR1のどちらかがTOP値を定義するのに使われるとき、OCF1AまたはICF1割り込み要求フラグ はOCR1xレジスタが(TOPに於いて)2重緩衝値で更新されるのと同じタイマ/カウンタ クロック周期によって設定(1)されます。これらの割り込み要求フラグ はカウンタがTOPまたはBOTTOM値に到達する毎に割り込みを発生するのに使えます。

TOP値を変更する時にプログラムは新TOP値が全ての比較レジスタ値と等しいか大きいことを保証しなければなりません。TOP値が何れかの比較レジスタより小さな場合、TCNT1とそのOCR1x間で比較一致は決して起きません。固定TOP値を使う場合、どのOCR1xが書かれる時も、未使用ビットがOで隠(に置換)されることに注意してください。図12-8.で示される第3周期が図解するようにタイマ/カウンタが位相基準PWM動作で走行中にTOPを積極的に変更することは非対称出力で終わることが有り得ます。これに対する理由はOCR1xレジスタの更新時に見出せます。OCR1x更新はTOPで起きるので、PWM周期はTOPで始まりそして終わります。これは下降傾斜長が直前のTOP値によって決定され、一方上昇傾斜長は新しいTOP値で決定されることを意味します。これら2つの値(TOP)が違うとき、その周期の2つの傾斜長は異なるでしょう。この長さの相違が出力での非対称な結果を生じます。

タイマ/カウンタが走行中にTOP値を変更する場合、位相基準PWM動作の代わりに位相/周波数基準PWM動作を使うことが推奨されます。一定のTOP値を使うとき、2つの動作種別間に現実的な違いはありません。

位相基準PWM動作での比較部はOC1xピンでのPWM波形の生成を許します。COM1x1,0ビットを'10'に設定することは非反転PWM出力を作成し、反転PWM出力はCOM1x1,0を'11'に設定することで生成できます(71頁の表12-4.をご覧ください)。実際のOC1x値はそのポート ピンに対するデータ方向が出力(DDR\_OC1x=1)として設定される場合だけ見えるでしょう。PWM波形はカウンタが増加する時のTCNT1とOCR1x間の比較一致でOC1x(内部)レジスタを設定(1)(または解除(0))と、カウンタが減少する時のTCNT1とOCR1x間の比較一致でOC1xレジスタを解除(0)(または設定(1))することによって生成されます。

位相基準PWMを使う時の出力に対するPWM周波数は次式によって計算できます。変数Nは前置 分周数(1,8,64,256,1024)を表します。

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

OCR1xの両端値は位相基準PWM動作でPWM波形出力を生成する時の特別な場合にあたります。非反転PWM動作ではOCR1xがBOTTOMに等しく設定されると出力は定常的なLow、TOPに等しく設定されると定常的なHighになるでしょう。反転PWMに対する出力は逆の論理値になります。TOP値定義にOCR1Aが使われ(WGM13~0=1011)、COM1A1,0=01なら、OC1A出力はデューティ比50%で交互に変化します。

## 12.9.5. 位相/周波数基準PWM動作

位相/周波数基準パルス幅変調(PWM)動作(WGM13~0=1000,1001)は高分解能で正しい位相と周波数のPWM波形生成選択を提供します。位相/周波数基準PWM動作は両傾斜(三角波)動作を基準とした位相基準PWMと似ています。カウンタはBOTTOM(\$0000)からTOPへ、そしてその後TOPからBOTTOMへを繰り返し計数します。非反転比較出力動作(COM1x1,0=10)での比較出力(OC1x)は上昇計数中のTCNT1とOCR1x間の比較一致で解除(0)され、下降計数中の比較一致で設定(1)されます。反転出力動作(COM1x1,0=11)での動作は逆にされます。両傾斜(三角波)動作は単一傾斜(鋸波)動作より低い最大動作周波数になります。けれども両傾斜(三角波)PWM動作の対称特性のため、これらの動作種別は電動機制御の応用に好まれます。

位相基準と位相/周波数基準PWM動作間の主な違いはOCR1xレジスタがOCR1x緩衝部によって更新される時(<mark>訳補</mark>:TOPとBOTTO M)です(図12-8.と図12-9.参照)。

位相/周波数基準PWM動作のPWM分解能はOCR1AかICR1のどちらかで定義できます。許された最小分解能は2ビット(OCR1AまたはICR1が\$0003設定)、最大分解能は16ビット(OCR1AまたはICR1がMAX設定)です。ビットでのPWM分解能は次式を使うことによって計算できます。

$$R_{\rm PFCPWM} = \frac{\log (\text{TOP} + 1)}{\log 2}$$

位相/周波数基準PWM動作でのタイマ/カウンタはタイマ/カウンタ値がICR1値(WGM13~0=1000)かOCR1A値(WGM13~0=1001)のどちらかと一致するまで増加されます。カウンタはTOPに到達したその時に計数方向を変更します。このTCNT1値は1タイマ/カウンタクロック周期間TOPと等しくなります。位相/周波数基

準PWM動作のタイシクで図は**図12-9**.で示されます。この図はOCR1AかICR1がTOPを定義するのに使われる時の位相/周波数基準PWM動作を示します。TCNT1値はタイシクで図で両傾斜動作(三角波)を表す折れ線グラフとして示されます。この図は非反転と反転のPWM出力を含みます。細い赤線はOCR1x値を示し、TCNT1値との交点(接点)がTCNT1とOCR1x間の比較一致を示します(訳注:図補正に伴い本行若干変更)。比較割り込み要求フラグ(OCF1x)は比較一致が起こると設定(1)されます。



タイマ/カウンタ溢れ(TOV1)フラク はOCR1xレシ スタが(BOTTOMに於いて)2重緩衝値で更新されるのと同じタイマ/カウンタ クロック周期で設定(1)されます。OCR1AかICR1のどちらかがTOP値を定義するのに使われるとき、OCF1AまたはICF1割り込み要求フラク はタイマ/カウンタがTOPに到達する時毎に設定(1)されます。これらの割り込み要求フラク はカウンタがTOPまたはBOTTOM値に到達する毎に割り込みを発生するのに使えます。

TOP値を変更する時にプログラムは新TOP値が全ての比較レジスタ値と等しいか大きいことを保証しなければなりません。TOP値が何れかの比較レジスタより小さな場合、TCNT1とそのOCR1x間で比較一致は決して起きません。

図12-9.が示すように生成された出力は位相基準PWM動作と異なり、全ての周期で対称です。OCR1xレジスタがBOTTOMで更新されるため、上昇と下降の傾斜長は常に等しくなります。これが対称出力パルス、従って正しい周波数を与えます。

TOPを定義するのにICR1を使うことは決まったTOP値を使う時に上手くいきます。ICR1を使うことにより、OC1AでのPWM出力を生成するためにOCR1Aが自由に使えます。けれども基準PWM周波数が(TOP値を変更することによって)動的に変更される場合、OCR1Aが2重緩衝機能のため、TOPとしてOCR1Aを使うことは明らかに良い選択です。

位相/周波数基準PWM動作での比較部はOC1xピンでのPWM波形の生成を許します。COM1x1,0ビットを'10'に設定することは非反転 PWM出力を作成し、反転PWM出力はCOM1x1,0を'11'に設定することで生成できます(71頁の表12-4.をご覧ください)。実際のOC1x 値はそのポート ピンに対するデータ方向が出力(DDR\_OC1x=1)として設定される場合だけ見えるでしょう。PWM波形はカウンタが増加する 時のTCNT1とOCR1x間の比較一致でOC1x(内部)レジスタを設定(1)(または解除(0))と、カウンタが減少する時のTCNT1とOCR1x間の比較一致でOC1xレジ、スタを解除(0)(または設定(1))することによって生成されます。

位相/周波数基準PWMを使う時の出力に対するPWM周波数は次式によって計算できます。変数 Nは前置分周数(1,8,64,256,1024)を表します。  $f_{\text{OCnxPFCPWM}} = \frac{f_{\text{clk\_I/O}}}{2 \times N \times \text{TOP}}$ 

OCR1xの両端値は位相/周波数基準PWM動作でPWM波形出力を生成する時の特別な場合にあたります。非反転PWM動作ではOCR1xがBOTTOMに等しく設定されると出力は定常的なLow、TOPに等しく設定されると定常的なHighになるでしょう。反転PWMに対する出力は逆の論理値になります。TOP値定義にOCR1Aが使われ(WGM13 $\sim$ 0 =1001)、COM1A1,0=01なら、OC1A出力はデューティ比50%で交互に変化します。





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

このタイマ/カウンタは同期設計で、従ってタイマ/カウンタ クロック(clkT1)が下図のクロック許可信号として示されます。この図は割り込みフラグが設定(1)される時、そしてOCR1xレシ、スタがOCR1x緩衝値で更新される時(2重緩衝を使う種別のみ)の情報を含みます。図12-10.はOCF1xの設定に関するタイミング図を示します。



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



図12-12.は各動作種別でのTOP近辺の計数手順を示します。位相/周波数基準PWM動作使用時のOCR1xレジスタはBOTTOMで更新されます。タイミング図は同じになりますが、当然TOPはBOTTOM、TOP-1はBOTTOM+1などのように置き換えられます。BOTTOMでTOV1を設定(1)する動作種別についても、同様な名称変更が適用されます。



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



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

# 12.11.1. TCCR1A - タイマ/カウンタ1制御レジスタA (Timer/Counter1 Control Register A)

| ピット        | 7      | 6      | 5      | 4      | 3 | 2 | 1     | 0     |        |
|------------|--------|--------|--------|--------|---|---|-------|-------|--------|
| (\$80)     | COM1A1 | COM1A0 | COM1B1 | COM1B0 | - | - | WGM11 | WGM10 | TCCR1A |
| 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 COM1A1,0: 比較1A出力選択 (Compare Output Mode1A bit 1 and 0)
- ビット5,4 COM1B1,0: 比較1B出力選択 (Compare Output Mode1B bit 1 and 0)

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

OC1AまたはOC1Bがピンに接続されるとき、COM1x1,0ビットの機能はWGM13~0ビット設定に依存します。**表12-2.**はWGM13~0ビットが標準動作またはCTC動作(つまり非PWM)に設定される時のCOM1x1,0ビット機能を示します。

表12-2. 非PWM動作での比較出力選択 (注: xはAまたはB)

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

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

表12-3. 高速PWM動作での比較出力選択(注: xはAまたはB, Xは0または1)

| COM1x1 | COM1x0 | 意味                                                                                       |
|--------|--------|------------------------------------------------------------------------------------------|
| 0      | 0      | 標準ポート動作(OC1x切断)                                                                          |
| 0      | 1      | WGM13~0=111X : 比較一致でOC1Aピン トグル(交互)出力、OC1Bは標準ポート動作(OC1B切断)<br>WGM13~0上記以外:標準ポート動作(OC1x切断) |
| 1      | 0      | 比較一致でLow、TOPでHighをOC1xt°ンへ出力(非反転動作)                                                      |
| 1      | 1      | 比較一致でHigh、TOPでLowをOC1xt°ンへ出力(反転動作)                                                       |

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

表12-4.はWGM13~0ビットが位相基準または位相/周波数基準PWM動作に設定される時のCOM1x1,0ビット機能を示します。

表12-4. 位相基準または位相/周波数基準PWM動作での比較出力選択(注: xはAまたはB, Xは0または1)

| COM1x1 | COM1x0 | 意味                                                                                       |
|--------|--------|------------------------------------------------------------------------------------------|
| 0      | 0      | 標準ポート動作(OC1x切断)                                                                          |
| 0      | 1      | WGM13~0=10XX : 比較一致でOC1Aピン トグル(交互)出力、OC1Bは標準ポート動作(OC1B切断)<br>WGM13~0上記以外:標準ポート動作(OC1x切断) |
| 1      | 0      | 上昇計数時の比較一致でLow、下降計数時の比較一致でHighをOC1xt°ンへ出力                                                |
| 1      | 1      | 上昇計数時の比較一致でHigh、下降計数時の比較一致でLowをOC1xピンへ出力                                                 |

注: COM1x1が設定(1)され、OCR1xがTOPと等しい時に特別な状態が起きます。より多くの詳細については68頁の「位相基準 PWM動作」をご覧ください。

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

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





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

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

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

| 番号 | WGM13 | WGM12<br>(CTC1) | WGM11<br>(PWM11) | WGM10<br>(PWM10) | タイマ/カウンタ動作種別          | TOP値   | OCR1x<br>更新時 | TOV1<br>設定時 |
|----|-------|-----------------|------------------|------------------|-----------------------|--------|--------------|-------------|
| 0  | 0     | 0               | 0                | 0                | 標準動作                  | \$FFFF | 即値           | MAX         |
| 1  | 0     | 0               | 0                | 1                | 8ビット位相基準PWM動作         | \$00FF | TOP          | ВОТТОМ      |
| 2  | 0     | 0               | 1                | 0                | 9ビット位相基準PWM動作         | \$01FF | TOP          | ВОТТОМ      |
| 3  | 0     | 0               | 1                | 1                | 10ビット位相基準PWM動作        | \$03FF | TOP          | BOTTOM      |
| 4  | 0     | 1               | 0                | 0                | 比較一致タイマ/カウンタ解除(CTC)動作 | OCR1A  | 即値           | MAX         |
| 5  | 0     | 1               | 0                | 1                | 8ビット高速PWM動作           | \$00FF | TOP          | TOP         |
| 6  | 0     | 1               | 1                | 0                | 9ビット高速PWM動作           | \$01FF | TOP          | TOP         |
| 7  | 0     | 1               | 1                | 1                | 10ビット高速PWM動作          | \$03FF | TOP          | TOP         |
| 8  | 1     | 0               | 0                | 0                | 位相/周波数基準PWM動作         | ICR1   | BOTTOM       | BOTTOM      |
| 9  | 1     | 0               | 0                | 1                | 位相/周波数基準PWM動作         | OCR1A  | BOTTOM       | BOTTOM      |
| 10 | 1     | 0               | 1                | 0                | 位相基準PWM動作             | ICR1   | TOP          | BOTTOM      |
| 11 | 1     | 0               | 1                | 1                | 位相基準PWM動作             | OCR1A  | TOP          | BOTTOM      |
| 12 | 1     | 1               | 0                | 0                | 比較一致タイマ/カウンタ解除(CTC)動作 | ICR1   | 即値           | MAX         |
| 13 | 1     | 1               | 0                | 1                | (予約)                  |        | _            | _           |
| 14 | 1     | 1               | 1                | 0                | 高速PWM動作               | ICR1   | TOP          | TOP         |
| 15 | 1     | 1               | 1                | 1                | 高速PWM動作               | OCR1A  | TOP          | TOP         |

### 12.11.2. TCCR1B - タイマ/カウンタ1制御レジスタB (Timer/Counter1 Control Register B)

| ピット        | 7     | 6     | 5 | 4     | 3     | 2    | 1    | 0    |        |
|------------|-------|-------|---|-------|-------|------|------|------|--------|
| (\$81)     | ICNC1 | ICES1 | - | WGM13 | WGM12 | CS12 | CS11 | CS10 | TCCR1B |
| Read/Write | R/W   | R/W   | R | R/W   | R/W   | R/W  | R/W  | R/W  |        |
| 初期値        | 0     | 0     | 0 | 0     | 0     | 0    | 0    | 0    |        |

### ■ ビット7 - ICNC1: 捕獲起動入力1雑音消去許可 (Input Capture1 Noise Canceler)

このビットを(1に)設定することは捕獲起動入力雑音消去器を活性(有効)にします。雑音消去器が有効にされると、捕獲起動入力 (ICP1)ピンからの入力が濾波されます。この濾波器機能はそれが出力を更新することに対して連続4回等しく評価されたICP1ピンの採取を必要とします。雑音消去器が許可されると、捕獲入力はこれによって4発振器(システム クロック)周期遅らされます。

### ■ ビット6 - ICES1: 捕獲起動入力端選択 (Input Capture1 Edge Select)

このビットは出来事での捕獲を起動するために使われる捕獲起動入力(ICP1)ピンのどちらかのエッジを選択します。ICES1ビットが0を書かれると起動動作として下降(負)端が使われ、ICES1ビットが1を書かれると上昇(正)端が捕獲を起動します。

捕獲がICES1設定に従って起動されると、カウンタ値が捕獲レシ、スタ(ICR1)に複写されます。この出来事は捕獲入力割り込み要求フラク (ICF1)も設定(1)し、そしてこれはこの割り込みが許可されていれば捕獲入力割り込みを起こすのに使えます。

ICR1がTOP値として使われると(TCCR1AとTCCR1Bに配置されたWGM13~0ビットの記述をご覧ください)、ICP1が切り離され、従って捕獲入力機能は禁止されます。

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

このビットは将来の使用に対して予約されています。将来のデバイスとの共通性を保つため、TCCR1Bが書かれるとき、このビットは<mark>0</mark>を書かれなければなりません。

# ■ ビット4,3 - WGM13,2:波形生成種別 (Waveform Generation Mode bit 3 and 2)

TCCR1AのWGM11,0ビット記述をご覧ください。

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

この3つのクロック選択ビットはタイマ/カウンタ(TCNT1)によって使われるべきクロック元を選択します。図12-10.と図12-11.をご覧ください。

表12-6. タイマ/カウンタ1 入力クロック選択

| CS12 | CS11 | CS10 | 意味                                |
|------|------|------|-----------------------------------|
| 0    | 0    | 0    | 停止(タイマ/カウンタ1動作停止)                 |
| 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    | T1ピンの下降端 (外部クロック)                 |
| 1    | 1    | 1    | T1ピンの上昇端 (外部クロック)                 |

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

### 12.11.3. TCCR1C - タイマ/カウンタ1制御レジスタC (Timer/Counter1 Control Register C)

| ピット        | 7     | 6     | 5 | 4 | 3 | 2 | 1 | 0 |        |
|------------|-------|-------|---|---|---|---|---|---|--------|
| (\$82)     | FOC1A | FOC1B | - | - | - | - | - | - | TCCR1C |
| Read/Write | W     | W     | R | R | R | R | R | R |        |
| 初期値        | 0     | 0     | 0 | 0 | 0 | 0 | 0 | 0 |        |

- ビット7 FOC1A: OC1A強制変更 (Force Output Compare 1A)
- ビット6 FOC1B: OC1B強制変更 (Force Output Compare 1B)

FOC1A/FOC1BビットはWGM13~0ビットが非PWM動作を指示する時だけ有効です。けれども、将来のデバイスとの共通性を保証するため、PWM動作時にTCCR1Cが書かれるとき、これらのビットは0を設定されなければなりません。FOC1A/FOC1Bビットに論理1を書くと、波形生成部で直ちに比較一致が強制されます。OC1x出力はCOM1x1,0ビット設定に従って変更されます。FOC1A/FOC1Bビットがストロープとして実行されることに注意してください。それによって強制された比較の効果を決めるのはCOM1x1,0ビットに存在する値です。

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

FOC1A/FOC1Bビットは常に0として読まれます。

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

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

### 12.11.4. TCNT1H,TCNT1L (TCNT1) - タイマ/カウンタ1 (Timer/Counter1)

| ビット<br>(\$85)  | 15<br>(MSB) | 14  | 13  | 12  | 11  | 10  | 9   | 8          | TCNT1H |
|----------------|-------------|-----|-----|-----|-----|-----|-----|------------|--------|
| 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          |        |
| ヒ`ット<br>(\$84) | 7           | 6   | 5   | 4   | 3   | 2   | 1   | 0<br>(LSB) | TCNT1L |
| 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          |        |

この2つのタイマ/カウンタ I/O位置(TCNT1HとTCNT1Lを合わせたTCNT1)は読み書き両方についてタイマ/カウンタ部の16ビット カウンタに直接アクセスします。CPUがこれらのレジ、スタをアクセスする時に上位と下位の両バイトが同時に読み書きされるのを保証するため、このアクセスは8ビット上位バイトー時レジ、スタ(TEMP)を使って実行されます。この一時レジ、スタは他の全ての16ビットレジ、スタによって共用されます。59頁の「16ビットレジ、スタのアクセス」をご覧ください。

カウンタ走行中にカウンタ(TCNT1)を変更することはOCR1xの1つとTCNT1間の比較一致消失の危険を誘発します。

TCNT1への書き込みは全ての比較部に対して次のタイマ/カウンタ クロックでの比較一致を妨害(除去)します。





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

| ピット        | 15    | 14  | 13  | 12  | 11  | 10  | 9   | 8     | _      |
|------------|-------|-----|-----|-----|-----|-----|-----|-------|--------|
| (\$89)     | (MSB) |     |     |     |     |     |     |       | OCR1AH |
| 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     | 6   | 5   | 4   | 3   | 2   | 1   | 0     | _      |
| (\$88)     |       |     |     |     |     |     |     | (LSB) | OCR1AL |
| 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     |        |
|            |       |     |     |     |     |     |     |       |        |

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

| ビット<br>(\$8B) | 15<br>(MSB) | 14  | 13  | 12  | 11  | 10  | 9   | 8          | OCR1BH |
|---------------|-------------|-----|-----|-----|-----|-----|-----|------------|--------|
| 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          |        |
| ピット<br>(\$8A) | 7           | 6   | 5   | 4   | 3   | 2   | 1   | 0<br>(LSB) | OCR1BL |
| 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          |        |

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

この比較レジスタは容量が16ビットです。CPUがこれらのレジスタへ書く時に上位と下位の両バイが同時に書かれるのを保証するため、このアクセスは8ビット上位バイト一時レジスタ(TEMP)を使って実行されます。この一時レジスタは他の全ての16ビット レジスタによって共用されます。59頁の「16ビット レジスタのアクセス」をご覧ください。

## 12.11.7. ICR1H,ICR1L (ICR1) - タイマ/カウンタ1 捕獲レジスタ (Timer/Counter1 Input Capture Register)

|            |       |     |     |     |     | -   | -   | _     |       |
|------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| ピット        | 15    | 14  | 13  | 12  | 11  | 10  | 9   | 8     |       |
| (\$87)     | (MSB) |     |     |     |     |     |     |       | ICR1H |
| 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     | 6   | 5   | 4   | 3   | 2   | 1   | 0     | _     |
| (\$86)     |       |     |     |     |     |     |     | (LSB) | ICR1L |
| 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     |       |
|            |       |     |     |     |     |     |     |       |       |

この捕獲レジスタはICP1ピン(またはタイマ/カウンタ1については任意のアナログ比較器出力)で出来事が起こる毎にカウンタ(TCNT1)値で更新されます。この捕獲レジスタはタイマ/カウンタのTOP値を定義するのに使えます。

この捕獲レシ、スタは容量が16ビットです。CPUがこれらのレシ、スタをアクセスする時に上位と下位の両ハ、イトが同時に読まれることを保証するため、このアクセスは8ビット上位ハ、イト一時レシ、スタ(TEMP)を使って実行されます。この一時レシ、スタは他の全ての16ビット レシ、スタのアクセス」をご覧ください。

### 12.11.8. TIMSK1 - タイマ/カウンタ1割り込み許可レジスタ (Timer/Counterl Interrupt Mask Register)

| ピット        | 7 | 6 | 5     | 4 | 3 | 2      | 1      | 0     | _      |
|------------|---|---|-------|---|---|--------|--------|-------|--------|
| (\$6F)     | _ | - | ICIE1 | - | - | OCIE1B | OCIE1A | TOIE1 | TIMSK1 |
| Read/Write | R | R | R/W   | R | R | R/W    | R/W    | R/W   |        |
| 初期値        | 0 | 0 | 0     | 0 | 0 | 0      | 0      | 0     |        |

### ■ ビット5 - ICIE1: タイマ/カウンタ1捕獲割り込み許可 (Timer/Counter1 Input Capture Interrupt Enable)

このビットが1を書かれて、ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されると、タイマ/カウンタ1捕獲割り込みが許可されます。タイマ/カウンタ1割り込み要求フラグレジスタ(TIFR1)に配置された捕獲割り込み要求フラグ(ICF1)が設定(1)されると、対応する割り込み  $^{\prime}$ 0 $^{\prime}$ 0 $^{\prime}$ 11頁の「割り込み」参照)が実行されます。

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

このビットが1を書かれて、ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されると、タイマ/カウンタ1比較B一致割り込みが許可されます。タイマ/カウンタ1割り込み要求フラグレジスタ(TIFR1)に配置された比較1B割り込み要求フラグ(OCF1B)が設定(1)されると、対応する割り込みベクタ(31頁の「割り込み」参照)が実行されます。

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

このビットが1を書かれて、ステーータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されると、タイマ/カウンタ1比較A一致割り込みが許可されます。タイマ/カウンタ1割り込み要求フラグレジスタ(TIFR1)に配置された比較1A割り込み要求フラグ(OCF1A)が設定(1)されると、対応する割り込みベクタ(31頁の「割り込み」参照)が実行されます。

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

このビットが1を書かれて、ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されると、タイマ/カウンタ1溢れ割り込みが許可されます。タイマ/カウンタ1割り込み要求フラグレジスタ(TIFR1)に配置されたタイマ/カウンタ1溢れ割り込み要求フラグ(TOV1)が設定(1)されると、対応する割り込みベクタ(31頁の「割り込み」参照)が実行されます。

### 12.11.9. TIFR1 - タイマ/カウンタ1割り込み要求フラグレジスタ (Timer/Counter1 Interrupt Flag Register)

| ピット         | 7 | 6 | 5    | 4 | 3 | 2     | 1     | 0    |       |
|-------------|---|---|------|---|---|-------|-------|------|-------|
| \$16 (\$36) | _ | - | ICF1 | - | - | OCF1B | OCF1A | TOV1 | TIFR1 |
| Read/Write  | R | R | R/W  | R | R | R/W   | R/W   | R/W  |       |
| 初期値         | 0 | 0 | 0    | 0 | 0 | 0     | 0     | 0    |       |

### ■ ビット5 - ICF1: タイマ/カウンタ1捕獲割り込み要求フラグ(Timer/Conterl, Input Capture Flag)

ICP1ピンに捕獲の事象が起こると、このフラケが設定(1)されます。捕獲レシ、スタ(ICR1)が $WGM13\sim0$ によってTOP値として設定されると、ICF1フラケルカウンタがTOP値に到達する時に設定(1)されます。

捕獲割り込み ペクタが実行されると、ICF1は自動的に解除(0)されます。代わりにこのビット位置へ論理1を書くことによってもICF1は解除(0)できます。

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

このフラグはカウンタ(TCNT1)値が比較Bレジスタ(OCR1B)と一致した後(次)のタイマ/カウンタ クロック周期で設定(1)されます。

強制的な比較出力(FOC1B)ストローブがOCF1Bフラグを設定(1)しないことに注意してください。

比較B一致割り込みへ、クタが実行されると、OCF1Bは自動的に解除(0)されます。代わりにこのビット位置へ論理1を書くことによってもOCF1Bは解除(0)できます。

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

このフラグはカウンタ(TCNT1)値が比較Aレジスタ(OCR1A)と一致した後(次)のタイマ/カウンタ クロック周期で設定(1)されます。

強制的な比較出力(FOC1A)ストローブがOCF1Aフラグを設定(1)しないことに注意してください。

比較A一致割り込み ベクタが実行されると、OCF1Aは自動的に解除( $\frac{0}{0}$ )されます。代わりにこのビット位置へ論理1を書くことによってもOCF1Aは解除( $\frac{0}{0}$ )できます。

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

このフラグの設定(1)はWGM13~0ビット設定に依存します。標準またはCTC動作でのTOV1フラグはタイマ/カウンタ1溢れ時に設定(1)されます。他のWGM13~0ビット設定を使う時のTOV1フラグ動作については72頁の**表12-5**.を参照してください。

タイマ/カウンタ1溢れ割り込みベウタが実行されると、TOV1は自動的に解除(0)されます。代わりにこのビット位置へ論理1を書くことによってもTOV1は解除(0)できます。

(注) 本頁レジスタ内のビット7,6,4,3は予約されており、常に0として読まれます。





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

51頁の「8ビット タイマ/カウンタ0」と57頁の「16ビット タイマ/カウンタ1(PWM付き)」は同じ前置分周器部を共用しますが、タイマ/カウンタは異なる前置分周器設定ができます。以下の記述はタイマ/カウンタ0とタイマ/カウンタ1の両方に適用されます。

### 13.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$ の何れかの周波数です。

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

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

プログラム実行にタイマ/カウンタを同期することに対して前置分周器リセットを使うことが可能です。しかし、同じ前置分周器を共用する他のタイマ/カウンタも前置分周を使う場合、注意が必要とされなければなりません。前置分周器リセットはそれが接続される全タイマ/カウンタに関する前置分周器周期に影響を及ぼします。

## 13.3. 外部クロック元

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

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



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

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

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

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



注: 入力ピン(T0/T1)の同期化/エッシ 検出論理回路は図13-1.で示されます。

## 13.4. タイマ/カウンタ前置分周器制御関係レジスタ

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

| ピット         | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0       |       |
|-------------|-----|---|---|---|---|---|---|---------|-------|
| \$23 (\$43) | TSM | - | - | - | _ | - | _ | PSRSYNC | GTCCR |
| Read/Write  | R/W | R | R | R | R | R | R | R/W     |       |
| 初期値         | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0       |       |

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

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

#### ■ L'ット6~1 - Res: 予約 (Reserved)

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

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

このビットが1のとき、タイマ/カウンタ0とタイマ/カウンタ1の前置分周器はリセットします。TSMビットが設定(1)されている場合を除き、通常、このビッ トはハート・ウェアによって直ちに解除(0)されます。タイマ/カウンタ0とタイマ/カウンタ1は同じ前置分周器を共用し、この前置分周器のリセットが両 方のタイマ/カウンタに影響を及ぼすことに注意してください。





## 14. 直列周辺インターフェース (SPI: Serial Peripheral Interface)

### 14.1. 特徴

- 全二重3線同期データ転送
- 主装置/従装置動作
- LSB/MSB先行データ転送
- ・設定変更可能な7つのビット速度
- 送信完了割り込み要求フラグ
- ・送信上書きフラグ保護
- アイドル動作からの起動
- 倍速(CK/2)主装置SPI動作

#### 14.2. 概要

直列周辺インターフェースはATtiny44/48 と様々なAVRデバイスや周辺デバイス間 の高速同期データ転送を許します。

24頁の「PRR - 電力削減レジスタ」での PRSPIビットはSPI部を許可するために0 を書かれなければなりません。

SPIでの主装置と従装置のCPU間相 互連結は図14-2.で示されます。この システムは2つの移動レジスタと主装置ク ロック発生器から成ります。SPI主装置 は希望した従装置のSS(従装置選択)



注: SPIピン配置については2頁の「ピン配置」と43頁の表10-5.を参照してください。

ピンをLowへ引き込む時に一群の通信を開始します。主装置と従装置は各々の移動レジスタに送出すべきデータを用意し、主装置はデータを交換するために必要なクロック パルスをSCK信号線に生成します。データは常にMOSI(Master Out Slave In)信号線を主装置から従装置へ、MISO(Master In Slave Out)信号線を従装置から主装置へ移動されます。各データ パケット後、主装置はSS(従装置選択)ピンをHighへ引き上げることによって従装置と同期を取ります。

主装置として設定されると、SPIインターフェースにはSS信号線の自動制御がありません。これは通信が開始できるのに先立って使用者ソフトウェアによって操作されなければなりません。これが行われると、SPIデータレジスタ(SPDR)へのハ・(小書き込みがSPIクロック発生器を始動し、ハート・ウェアが従装置内へ8ピットを移動します。1ハ・(小の移動後、SPIクロック発生器は停止し、SPI状態レジスタ(SPSR)の転送完了フラケッ(SPIF)を設定(1)します。SPI制御レジスタ(SPCR)でSPI割り込み許可(SPIE)ピットが設定(1)されていれば割り込みが要求されます。主装置はSPDR内へ次ハ・(小を書くことによって次ハ・(小の移動を継続、またはSS(従装置選択)信号線をHighへ引き上げることによってハ・ケットの終了を指示することができます。最後の到着ハ・(小はその後の使用のため、緩衝レジスタ内に保持されます。

従装置として設定されると、SPIインターフェースはSSピンがHighに駆動される限り、MISOをHi-Zにした休止状態に留まります。この状態でプログラムはSPIデータレジスタ(SPDR)の内容を更新できますが、そのデータはSSピンがLowに駆動されるまでSCKピンでの到着クロック パルスによって移動出力されません。1バイトが完全に移動されてしまうと転送完了フラグ(SPIF)が設定(1)されます。SPCRでSPI割り込み許可(SPIE)ビットが設定(1)されていれば割り込みが要求されます。従装置は受信データを読む前にSPDR内へ送られるべき次のデータの配置を続けられます。最後の到着バイトはその後の使用のため、緩衝レジスタ内に保持されます。

このシステムは送信側単一緩衝、受信側2重緩衝です。これは一連の移動全体が完了される前に送信されるべきが介がSPIデータレジ、スタ(SPDR)へ書けないことを意味します。けれども、データを受信するとき、次のデータが完全に移動入力される前に受信したデータがSPIデータレジ、スタ(SPDR)から読まれなければなりません。さもなければ始めのバイが失われます。

SPI従装置動作では制御論理回路がSCKピンの到着信号を採取します。このクロック信号の正しい採取を保証するため、High/Lowの最小時間は各々2CPUクロック周期より長くあるべきです。

SPIが許可されると、MOSI, MISO, SCK, SSピンの データ方向は表14-1.に従って無視されます。自動的なポート無視のより多くの詳細については41頁の「交換ポート機能」を参照してください。

#### 図14-2. SPI主装置/従装置の連結 MSB 主装置 従装置 LSB MSB LSB MISO MISO 8ビット移動レジスタ 8ビット移動レジスタ MOSI MOSI. SCK SCK SS SS 移動許可 **→**⊙ クロック回路

| の方向規定       |
|-------------|
|             |
| スタ(DDRB)の指定 |
|             |
|             |
|             |

注: 使用者定義SPIピンの方向定義方法の詳細記述については43頁の「ポートBの交換機能」を参照してください。

次のコート例は主装置としてSPIを初期化する方法と簡単な送信を実行する方法を示します。例でのDDR\_SPIはSPIピンを制御する実際のポート方向レジスタに置き換えられなければなりません。DD\_MOSI, DD\_MISO, DD\_SCKはこれらのピンに対する実際のポート方向ビットに置き換えられなければなりません。例えばMOSIがPB5ピンに配置されるなら、DD\_MOSIはDDB5、DDR\_SPIはDDRBに置き換えます。

```
アセンブリ言語プログラム例
SPI_M_Init: LDI
                   R17, (1<<DD_MOSI) | (1<<DD_SCK)
                                                      ;MOSI, SCK=出力、他は入力値を取得
                   DDR_SPI, R17
                                                      ;MOSI, SCK=出力、他は入力に設定
            OUT
                   R17, (1<<SPE) | (1<<MSTR) | (1<<SPRO)
                                                      ;SPI許可、主装置、16分周値を取得
            LDI
            OUT
                   SPCR, R17
                                                      ;SPI許可、主装置、16分周に設定
            RET
                                                      ;呼び出し元へ復帰
SPI_M_Tx:
                                                      ; データ(R16) 送信開始
           OUT
                  SPDR, R16
SPI_M_Tx_W: SBIS
                                                      ;転送完了ならばスキップ
                  SPSR, SPIF
                                                      ;転送完了まで待機
            RJMP
                  SPI_M_Tx_W
                                                      ;呼び出し元へ復帰
            RET
C言語プログラム例
void SPI_MasterInit(void)
    DDR\_SPI = (1 << DD\_MOSI) | (1 << DD\_SCK);
                                                      /* MOSI, SCK=出力、他は入力に設定 */
    SPCR = (1 << SPE) \mid (1 << MSTR) \mid (1 << SPRO);
                                                      /* SPI許可、主装置、16分周に設定 */
void SPI_MasterTransmit(char cData)
                                                      /* データ送信開始 */
    SPDR = cData;
    while(!(SPSR & (1<<SPIF)));
                                                      /* 転送完了まで待機 */
```

### **注**: 5頁の「コート・例について」をご覧ください。

次のコート・例は従装置としてSPIを初期化する方法と簡単な受信を実行する方法を示します。

```
アセンブリ言語プログラム例
SPI_S_Init: LDI
                 R17, (1<<DD_MISO)
                                                   ;MISO出力、他は入力値を取得
                                                   ;MISO出力、他は入力に設定
           OUT
                 DDR_SPI, R17
           LDI
                 R17, (1<<SPE)
                                                   ;SPI許可値を取得
           OUT
                 SPCR, R17
                                                   ;SPI許可設定
                                                   ;呼び出し元へ復帰
           RET
SPI_S_Rx:
           SBIS
                 SPSR, SPIF
                                                   ;受信(転送)完了ならばスキップ
                                                   ;受信(転送)完了まで待機
           RJMP
                 SPI_S_Rx
           IN
                 R16, SPDR
                                                   ;受信データを取得
                                                   ;呼び出し元へ復帰
           RET
C言語プログラム例
void SPI_SlaveInit(void)
   DDR SPI = (1 << DD MISO);
                                                   /* MISO出力、他は入力に設定 */
   SPCR = (1 << SPE);
                                                   /* SPI許可設定 */
char SPI_SlaveReceive(void)
   while(!(SPSR & (1<<SPIF)));
                                                   /* 受信(転送)完了まで待機 */
   return SPDR;
                                                   /* 受信データと共に復帰 */
注: 5頁の「コード例について」をご覧ください。
```



## 14.3. SSt<sup>2</sup>ンの機能

### 14.3.1. 従装置動作

SPIが従装置として設定されると、従装置選択(SS)ピンは常に入力です。SSがLowに保たれるとSPIは活性に(作動)され、使用者によってそのように設定されていればMISOが出力になります。他の全てのピンは入力です。SSがHighに駆動されると、出力として使用者設定され得るMISOを除く全てのピンは入力、SPIは非活動で、それは到着データを受信しないことを意味します。SPI論理回路は一旦SSピンがHighに駆動されると、リセットすることに注意してください。

このSSピンはパケット/バイト同期に対して、従装置ビット カウンタが主装置クロック発生器との同期を保つのに有用です。SSピンがHighに駆動されると、SPI従装置は直ちに送受信論理回路をリセットし、それは移動レジスタ内で部分的に受信したどのデータも取り落とします。

#### 14.3.2. 主装置動作

SPIが主装置(SPI制御レジスタ(SPCR)の主装置許可(MSTR)ビット=1)として設定されると、SSピンの方向は使用者が決められます。

SSが出力として設定されると、このピンはSPIシステムに影響を及ぼされない標準出力ピンです。代表的にはこのピンがSPI従装置のSSピンを駆動するでしょう。

SSが入力として設定されると、SPI主装置動作を保証するためにそれはHighに保持されなければなりません。SSピンが入力として定義されたSPI主装置として設定されるとき、周辺回路によってSSピンがLowに駆動されると、SPIシステムは他の主装置が従装置として選択してデータ送信を始めると解釈します。パスの衝突を避けるためにSPIシステムは次の動作を行います。

- 1. SPCRで主装置許可(MSTR)ビットが解除(0)され、SPIシステムは従装置になります。SPIシステムが従装置になる結果としてMOSIとSCK ピンが入力になります。
- 2. SPI状態レジスタ(SPSR)でSPI割り込み要求フラグ(SPIF)が設定(1)され、そしてSPI割り込みが許可(SPCRのSPIE=1)され、且つステータスレジスタ(SREG)の全割り込み許可(I)ビットが設定(1)なら、割り込みルーチンが実行されます。

従って割り込み駆動SPI送信が主装置動作で使われ、SSがLowに駆動される可能性があるとき、その割り込み(処理)はMSTRビットが未だ設定(1)されているのを常に検査すべきです。MSTRビットが従装置選択によって解除(0)されてしまっていると、それはSPI主装置動作を再び許可するため、使用者によって設定(1)されなければなりません。

## 14.4. データ転送形式

直列データに関してはSPI制御レジスタ(SPCR)のSCK位相(CPHA)とSCK極性(CPOL)制御ビットによって決定されるSCK位相と極性で4つの組み合わせがあります。このSPIデータ転送形式は図14-3.と図14-4.で示されます。





データ ビットは安定のためデータ信号に対して充分な時間を保証するSCK信号の反対端で移動出力と(入力)ラッチが行われます。これは**表14-2**.で行われるように表14-3.と表14-4.を要約することによって明解にされます。

表14-2. CPOL,CPHA機能動作 SPI動作種別番号 CPOL CPHA SCK先行端 SCK後行端 0 入力採取/上昇端 出力設定/下降端 0 0 出力設定/上昇端 入力採取/下降端 0 1 2 入力採取/下降端 出力設定/上昇端 0 出力設定/下降端 入力採取/上昇端 3





## 14.5. SPI用レジスタ

## 14.5.1. SPCR - SPI制御レジスタ (SPI Control Register)

| ピット         | 7    | 6   | 5    | 4    | 3    | 2    | 1    | 0    |      |
|-------------|------|-----|------|------|------|------|------|------|------|
| \$2C (\$4C) | SPIE | SPE | DORD | MSTR | CPOL | CPHA | SPR1 | SPR0 | SPCR |
| 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 - SPIE: SPI割り込み許可(SPI Interrupt Enable)

ステータス レシ、スタ(SREG)の全割り込み許可(I)ビットが設定(1)されて、SPI状態レシ、スタ(SPSR)でSPI割り込み要求フラグ(SPIF)が設定(1)されると、このビットがSPI割り込みを実行させます。

#### ■ ビット6 - SPE: SPI許可 (SPI Enable)

SPEビットが1を書かれるとSPIが許可されます。どのSPI操作を許可するにも、このビットが設定(1)されなければなりません。

#### ■ ビット5 - DORD: データ順選択(Data Order)

DORDビットが1を書かれるとデータ語のLSBが最初に転送されます。DORDビットが0を書かれるとMSBが最初に転送されます。

#### ■ ビット4 - MSTR: 主装置/従装置選択 (Master/Slave Select)

このビットは1を書かれると主装置動作、論理0を書かれると従装置動作を選択します。 $\overline{SS}$ が入力として設定され、MSTRが設定(1)の間にLowへ駆動されると、MSTRが解除(0)されてSPI状態レジスタ(SPSR)でSPI割り込み要求フラグ(SPIF)が設定(1)になります。その後使用者はSPI主装置動作を再び許可するためにMSTRを設定(1)しなければなりません。

#### ■ ビット3 - CPOL: SCK極性選択 (Clock Polarity)

このビットが1を書かれると、アイドル時にSCKはHighです。CPOLが0を書かれると、アイドル時にSCKはLowです。例については図14-3.と図14-4.を参照してください。CPOL機能は右で要約されます。

| 表14-3. | 表14-3. CPOL機能動作 |        |  |  |  |  |  |  |  |
|--------|-----------------|--------|--|--|--|--|--|--|--|
| CPOL   | SCK先行端          | SCK後行端 |  |  |  |  |  |  |  |
| 0      | 上昇端             | 下降端    |  |  |  |  |  |  |  |
| 1      | 下降端             | 上昇端    |  |  |  |  |  |  |  |

#### ■ ビット2 - CPHA: SCK位相選択 (Clock Phase)

このSCK位相選択(CPHA)ビットの設定はデータがSCKの先行(先)端または後行(後)端で採取/(設定)されるかを決めます。例については図14-3.と図14-4.を参照してください。CPHA機能は右で要約されます。

| 表14-4. | 表14-4. CPHA機能動作 |        |  |  |  |  |  |  |  |
|--------|-----------------|--------|--|--|--|--|--|--|--|
| CPHA   | SCK先行端          | SCK後行端 |  |  |  |  |  |  |  |
| 0      | 入力採取            | 出力設定   |  |  |  |  |  |  |  |
| 1      | 出力設定            | 入力採取   |  |  |  |  |  |  |  |

#### ■ ビット1,0 - SPR1,0: SPIクロック選択 (SPI Clock Rate Select 1 and 0)

これら2ビットは主装置として設定されたデバイスのSCK速度を制御します。従装置でのSPR1とSPR0は無効です。SCKと(システム)発振器クロック周波数fosc間の関連は次表で示されます。

| 表14-5. SCK速度選択(fosc=CPUクロック周波数) |        |        |        |         |         |      |      |          |
|---------------------------------|--------|--------|--------|---------|---------|------|------|----------|
| SPR1                            | 0      |        | 0      |         | 1       |      | 1    |          |
| SPR0                            | (      | )      | 1      |         | 0       |      | 1    |          |
| SPI2X                           | 1      | 0      | 1      | 0       | 1       | 0    | 1    | 0        |
| SCK周波数                          | fosc/2 | fosc/4 | fosc/8 | fosc/16 | fosc/32 | foso | c/64 | fosc/128 |

#### 14.5.2. SPSR - SPI状態レジスタ (SPI Status Register)

| ピット         | 7    | 6    | 5 | 4 | 3 | 2 | 1 | 0     |      |
|-------------|------|------|---|---|---|---|---|-------|------|
| \$2D (\$4D) | SPIF | WCOL | - | - | - | - | - | SPI2X | SPSR |
| Read/Write  | R    | R    | R | R | R | R | R | R/W   |      |
| 初期値         | 0    | 0    | 0 | 0 | 0 | 0 | 0 | 0     |      |

### ■ ビット7 - SPIF: SPI割り込み要求フラグ(SPI Interrupt Flag)

直列転送が完了すると、このSPIFフラグが設定(1)されます。全割り込みが許可(ステータスレジスタ(SREG)の全割り込み許可(I)ビット=1)されて、SPI制御レジスタ(SPCR)でSPI割り込み許可(SPIE)ビットが設定(1)されるなら、割り込みが生成されます。SPIが主装置動作の時にSS ピンが入力でLowに駆動されるなら、これもこのSPIFフラグを同様に設定(1)します。対応する割り込み処理へクタを実行するとき、SPIFはハートヴェアによって解除(0)されます。代わりにSPIFが設定(1)されたSPI状態レジスタ(SPSR)を始めに読み、その後にSPIデータレジスタ (SPDR)をアクセスすることによっても、SPIFフラグは解除(0)されます。

### ■ ビット6 - WCOL: 上書き発生フラグ (Write Collision Flag)

データ転送中にSPIデータレシ、スタ(SPDR)が書かれると、このWCOLビットが設定(1)されます。WCOLビット(とSPIFビット)はWCOLが設定(1)されたSPI状態レシ、スタ(SPSR)を始めに読み、その後にSPIデータレシ、スタ(SPDR)をアクセスすることによって解除(0)されます。

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

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

### ■ ビット0 - SPI2X : SPI倍速許可 (Double SPI Speed Bit)

このビットが論理1を書かれると、SCK速度(SCK周波数)はSPIが主装置動作のとき、倍にされます(表14-5.参照)。これは最小SCK周期が2CPUクロック周期であることを意味します。SPIが従装置として設定されるとき、SPIはfosc(CPUクロック周波数)/4またはそれ以下での動作のみ保証されます。

ATtiny48/88のSPIインターフェースはフラッシュ メモリやEEPROMの書き換え(読み書き)にも使われます。直列プログラミングと照合については131頁をご覧ください。

## 14.5.3. SPDR - SPIデータレジスタ (SPI Data Register)

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

SPIデータレジスタはSPI移動レジスタとレジスタファイル(汎用レジスタ)間のデータ転送に使われる読み書き可能なレジスタです。このレジスタへの書き込みはデータ送信を開始します。このレジスタの読み込みは移動レジスタの受信緩衝部読み出しを引き起こします。





## 15. 2線インターフェース (TWI:Two Wire Interface)

## 15.1. 特徴

- Phillips社I<sup>2</sup>C適合
- SMBus**適合**(条件付)
- 2本のバス信号線のみ必要な、単純ながら強力で柔軟な通信インターフェース
- 主装置動作と従装置動作の両方を支援
- 送信装置または受信装置として動作可能
- アビットのアドレス空間が128までの異なる従装置アドレスを許容
- 複数主装置の調停支援
- 従装置動作で400kHzまでのデータ転送速度
- 上昇/下降(スリューレート)制限された出力駆動回路
- バス信号線のスパイクを排除する雑音消去回路
- 一斉呼び出しを含む完全に設定変更可能な従装置アドレスの支援
- AVRが休止形態の時にアドレス認証(一致)が起動

24頁の「PRR-電力削減レシ、スタ」のPRTWIL「ットは2線直列インターフェース部を許可するために0を書かれなければなりません。

#### 15.2. 概要

2線インターフェース(TWI)は2線だけを使う双方向バス通信です。TWIはI<sup>2</sup>Cと条件付でSMBusに適合します(101頁の「**SMB**us**との適合性**」をご覧ください)。

ハ、スに接続されたデ、バイスは主装置または従装置として動作しなければなりません。主装置はバス上の従装置をアドレス指定することによってデータ転送処理を始め、データの送信または受信のどちらを望むかを知らせます。1つのバスは多数の主装置を持て、そして同時に2つ以上の主装置が送信を試みる場合の優先権を調停手順が取り扱います。

#### 15.3. バス定義

2線直列インターフェース(TWI)は代表的なマイクロ コントローラ応用に対して理想的に適応されています。TWI通信規約は2本の双方向バス信号線、データ用1本(SDA)とクロック用1本(SCL)だけを使って128個までの異なる装置の相互接続をシステム設計者に許します。バスを実現するために必要とされる外部ハードウェアはTWIバス信号線各々に1本づつのプルアップ抵抗だけです。バスに接続した全ての装置は個別のアドレスを持ち、バス衝突を解決する機構は本質的にTWI通信規約で行います。



## 15.3.1. TWI用語定義

次の定義は本項で度々使われます。

| 表15-1. TWI用語定義 |                                 |  |  |  |  |  |  |
|----------------|---------------------------------|--|--|--|--|--|--|
| 用語             | 意味                              |  |  |  |  |  |  |
| 主装置            | 送信の開始と終了する装置。主装置はSCLクロックも生成します。 |  |  |  |  |  |  |
| 従装置            | 主装置によって指定された装置。                 |  |  |  |  |  |  |
| 送信装置           | バス上にデータを送り出す装置。                 |  |  |  |  |  |  |
| 受信装置           | バスからデータを読み込む装置。                 |  |  |  |  |  |  |

### 15.3.2. 電気的な相互接続

図15-1.で描かれたように両バス信号線はプルアップ抵抗を通して正供給電圧に接続されます。全てのTWI準拠装置のバス駆動部はオープント・レインかオープショレクタです。これはインターフェースの動作のために重要なワイアードAND機能を実現します。TWIバス信号線のLowレベルは1つまたはより多くのTWI装置の0出力時に生成されます。Highレベルは全TWI装置がHi-Z出力時の出力で、プルアップ抵抗で信号線をHighへ引き上げさせます。TWIバスに接続した全てのAVRデ゙バイスはどんなバス動作も許すために電源が供給されなければならないことに注意してください。

このバスに接続できる装置数はアビットの従装置アドレス空間と400pFのバス容量制限によってのみ制限されます。TWIの電気的特性の詳細仕様は139頁の「**2線直列インターフェース特性**」で与えられます。そこで与えられる2組の異なる仕様は1つがバス速度100kHz以下に関するもので、もう1つはバス速度400kHzまでに関して有効です。

## 15.4. データ転送とフレーム形式

#### 15.4.1. ビット転送

TWIn'スに転送される各データ ビットはクロック信号線のパルスを伴います。データ信号線のレヘールはクロック信号線がHighの時に安定していなければなりません。この規則の例外は開始条件と停止条件の生成だけです。



#### 15.4.2. 開始条件と停止条件

主装置がデータ転送の開始と終了を行います。転送は主装置がバスに開始条件を起こすと開始され、主装置が停止条件を起こすと終了されます。開始条件と停止条件間はバスが使用中と考えられ、他の主装置はバスの制御獲得を試みるべきではありません。開始条件と停止条件間で新規開始条件が起こされると特別な状態が起きます。これは再送開始条件として引用され、主装置がバスの制御を手放さずに新規転送を始めたい時に使われます。再送開始条件後、バスは次の停止条件まで使用中と考えられます。これは開始動作に関して全く同じで、従って特記事項を除いて本データシートの残りに対して開始条件と再送開始条件の両方の記述に開始条件が使われます。下で描かれるように開始条件と停止条件はSCL信号線がHighの時のSDA信号線のレベル変更によって指示されます。



#### 15.4.3. アトレス ハゲット形式

TWIn'スに送信した全てのアドレス パケットはアビットのアドレス ビット、1ビットの方向(Read/Write)制御ビット、1ビットの応答ビットから成る9ビットです。方向(R/W)ビットが設定(1)されると読み出し操作が実行され、さもなければ書き込み操作が実行されるべきです。従装置がアドレス指定されたことを認証すると、9番目のSCL(ACK)周期でSDAをLowへ引くことによって確認応答すべきです。アドレス指定された従装置が忙しいまたはその他の理由で主装置の要求を扱えない場合、確認応答(ACK)クロック周期でSDA信号線をHighのままにすべきです。主装置はその後に停止条件または新規転送を始めるために再送開始条件を送出できます。従装置アドレスと方向(R/W)ビットから成るアドレス パケットは各々SLA+RまたはSLA+Wと呼ばれます。

アト・レス ビットの最上位ビット(MSB)が最初に送信されます。従装置アト・レスは設計者によって自由に割り当てられますが、アト・レス0000000は一斉呼び出し用に予約されています。

一斉呼び出しが起こされると、全従装置は確認応答(ACK)周期でSDA信号線をLowにすることによって応答すべきです。一斉呼び出しは主装置がシステム内のそれぞれの従装置に同じ通信内容を送信したい時に使われます。一斉呼び出しアドレスに



続きW(方向が書き込み)ビットがバスに送信されると、一斉呼び出しに応答する設定の全ての従装置はACK周期でSDA信号線をLowに引き込みます。そして後続のデータ パケットは一斉呼び出しに確認応答した全従装置によって受信されます。一斉呼び出しアドレスに続くR(方向が読み出し)ビットの送信は、従装置それぞれが異なるデータの送信を始める場合の衝突の原因となるので意味がないことに注意してください。

1111 xxx形式の全アドレスは将来の目的のために予約されるべきです(訳補: I<sup>2</sup>C規格のアドレス拡張他)。

#### 15.4.4. データ パケット形式

TWIハスに送信した全てのデータハットがいは1ハイのデータと1ビットの応答ビットから成る9ビットです。データ転送中、主装置はクロックと開始条件、停止条件を生成し、一方受信装置は受信に応答する責任があります。確認応答(ACK)は受信装置が9番目のSCL周期中にSDA信号線をLowに引き込むことによって示されます。受信装置がSDA信号線をHighのままにするとNACKを示します。受信装置が最終ハイトを受信したとき、または何らかの理由でこれ以上のハイトを受信ができないとき、最終ハイト後にNACKを送ることによって送信装置へ通知すべきです。データハイトの最上位(MSB)ビットが最初に送信されます。







### 15.4.5. 転送内でのアドレス パケットとデータ パケットの組み合わせ

転送は基本的に開始条件、SLA+R/W、1つ以上のデータ パケット、停止条件から成ります。開始条件に続く停止条件から成る空の通信 内容は規則違反です。SCL信号線のワイアート、ANDが主装置と従装置間のハント、シェークに使えることに注目してください。従装置はSCL 信号線をLowに引き込むことによってSCLのLow期間を引き伸ばせます。これは主装置が従装置に対して速すぎるクロック速度設定、または従装置がデータ送信間の処理に追加時間を必要とする場合に有用です。従装置がSCLのLow期間を延長することは主装置によって決められるSCLのHigh期間に影響しません。同様に従装置はSCLのデューティ比(Low期間)を延長することによってTWIデータ転送速度を落とせます。

図15-6.は代表的なデータ転送を示します。様々なデータは応用ソフトウェアによって実装されたソフトウェア規約に依存し、SLA+R/Wと停止条件間に送信できることに注意してください。



## 15.5. 複数主装置バス システムの調停と同期

TWI規約は多数主装置のバス システムを許します。例え2つ以上の主装置が同時に送信を始めても、送信が通常のように続行することを保証するために特別な手段が講じられます。複数主装置のシステムでは2つの問題が起こります。

- ・送信を完了するために1つの主装置だけを許す方法が実現されなければなりません。他の全ての主装置は(自身が行っている従 装置)選択手順を失った(失敗した)ことに気付く時、送信を止めるべきです。この選択手順は調停(アピトレーション)と呼ばれます。 競 合する主装置は調停(従装置選択)手順を失ったことに気付くと、勝ち残った主装置によってアドレス指定されるかどうかを調べるた め、直ちに従装置動作へ切り替えるべきです。 複数の主装置が同時に送信を始めた事実は従装置で検知できるべきではありま せん。 換言すると、パスに転送されているデータが不正にされてはなりません。
- ・違う主装置が異なるSCL周波数を使うかもしれません。同期確定手順で送信が続行するために、全主装置からの直列クロックを同期化する方法が考案されなければなりません。これは調停手順を容易にします。

ハス信号線のワイアー・ANDはこれらの問題の両方の解決に用いられます。全ての主装置からの直列クロックはワイアー・ANDされ、最短High期間の主装置の1つからに等しいHigh期間の合成クロックを生成します。合成クロックのLow期間は最長Low期間の主装置のLow期間に等しくなります。全ての主装置がSCL信号線を監視する、実際には合成SCL信号線がHighまたはLowになるとき、各々SCLのHighとLow経過時間の計時を始めることに注意してください。

調停は全ての主装置がデータ出力後にSDA信号線を継続的に監視することによって実行されます。SDA信号線から読んだ値がその主装置の出力した値と一致しない場合、調停に敗れます。主装置がSDAにHigh値を出力し、同時に他の主装置がLow値を出力する時のみ調停に敗れるかもしれないことに注意してください。敗れた主装置は直ちに従装置動作へ移行し、勝ち残った主装置によってアトレス指定されるかを検査すべきです。SDA信号線はHighのままにすべきですが、敗れた主装置は現在のデータ若しくはアトレスハプケットの最後までクロック信号を生成することを許されます。調停は唯一の主装置が残るまで継続され、多くのビットを必要とするかもしれません。多くの主装置が同じ従装置をアトレス指定しようとすると、調停はデータハプケットへ続くでしょう。





調停が次の状態間で許されないことに注意してください。

- ・再送開始条件とデータビット間
- ・停止条件とデータビット間
- 再送開始条件と停止条件間

これらの違法な調停状態を決して起こさないよう保証するのは使用者ソフトウェアの責任です。これは複数主装置システムでの全てのデータ 転送は同じ構成、SLA+R/Wとデータ パケットを使われなければならないことを意味します。言葉を変えると、全ての送信は同じデータ パケット数を含まなければならず、さもなければ調停の結果は不定にされます。

## 15.6. TWI部の概要

図15-9.で示されるようにTWI部は様々な部分から成ります。赤文字で示された(訳注:原文は太線で描かれた)全てのレシ、スタはAVR データ バスを通してアクセス可能です。



#### 15.6.1. SCLとSDAL°ン

これらのピンはAVR TWIをMCUシステムのその他とインターフェースします。出力駆動部はTWI仕様に適合させるためのスリューレート(上昇/下降)制限器を含みます。入力段は50nsよりも短いスパーイクを除去するスパーイク消去部を含みます。「入出力ポート」章で説明したようにAVR パット・の内部プルアップはSCLとSDAピンに対応するポートのビットを設定(1)することによって許可できることに注目してください。内部プルアップはいくつかのシステムで外部抵抗の必要をなくせます。

## 15.6.2. ビット速度発生器

この部分は主装置動作で動く時のSCL周期を制御します。SCL周期はTWIビット速度レジスタ(TWBR)とTWI状態レジスタ(TWSR)の前置分周器ビットの設定によって制御されます。従装置動作はビット速度や前置分周器設定と関係ありませんが、従装置でのCPUクロック周波数はSCL周波数よりも最低16倍高くなければなりません。従装置がSCLのLow期間を延長するかもしれず、これによって平均TWI バス クロック周波数が減少することに注意してください。

TWIは104頁の「TWIHSR - TWI高速レジスタ」で記述されるように、高速動作で動くように設定することができます。高速動作ではTWI がシステム クロックを使い、一方標準動作では同じシステム クロックの前置分周版に頼ります。使うクロック信号に依存してSCL周波数は次式の1つに従って生成されます。

標準動作SCL周波数 = clk<sub>I/O</sub> : 前置分周されたシステム クロック(17頁の**図6-1**.参照)

16+2×(TWBR)×前置分周値 clkTWIHS : システム クロック(17頁の図6-1.参照)

高速動作SCL周波数 = clkTWIHS TWBR : TWILL, TWILL,

注: TWI主装置動作ではTWBRが10またはそれ以上でなければなりません。

### 15.6.3. バス インターフェース部

この部分はデータとアト・レスの移動レシ、スタ(TWDR)、開始条件/停止条件制御器、調停検出回路を含みます。TWDRは送信されるべきアト・レスまたはデータ ハ・イト、若しくは受信したアト・レスまたはデータ ハ・イトを含みます。8ビットのTWDRに加えハ、スインターフェース部は送信されるべきまたは受信した(N)ACKヒ・ットを含むレシ、スタも含みます。この(N)ACKレシ、スタは応用ソフトウェアによって直接的にアクセスできません。けれどもTWI制御レシ、スタ(TWCR)を操作することにより、受信時に設定(1)または解除(0)できます。送信装置動作時、受信した(N)ACKヒ・ットの値はTWSRの値によって判定できます。

開始条件/停止条件制御器は開始条件、再送開始条件、停止条件の生成と検出に対して責任があります。開始条件/停止条件制御器はAVR MCUが主装置によってアドレス指定されるとMCUを起動できる休止形態の1つの時でも、開始条件または停止条件を検出できます。

TWIが主装置として送信を始められると、調停検出ハードウェアは調停が進行中かを決めるために送信の試行を継続的に監視します。 TWIが調停に敗れた場合、制御部に通知されます。その後に正しい処置が行われ、適切な状態符号が生成されます。





### 15.6.4. アドレス一致部

アト・レス一致部は受信したアト・レス ハ・仆がTWIアト・レス レシ・スタ(TWAR)の7ビット アト・レスと一致するかを検査します。TWARで一斉呼び出し検出許可(TWGCE)ビットが1を書かれると、全ての到着アト・レス ビットは一斉呼び出しアト・レスに対しても比較されます。アト・レス一致を制御部は通知され、正しい処置を行うことを許します。TWIはTWI制御レシ・スタ(TWCR)の設定によってそのアト・レスへの応答をするかもしれないし、しないかもしれません。アト・レス一致部はAVR MCUが主装置によってアト・レス指定されるとMCUを起動できる休止形態の1つの時でもアト・レスを比較できます。TWIがパワータ・ウン動作でのアト・レス一致でCPUを起動中に他の割り込み(例えばINTO)が起こると、TWIは動作を停止してアイト・ル状態で復帰します。これが何らかの問題の原因なら、パワータ・ウン動作へ移行する時にTWIアト・レス一致だけが割り込みを許可されることを保証してください。

#### 15.6.5. 制御部

制御部はTWIハ、スを監視し、TWI制御レシ、スタ(TWCR)の設定に従った応答を生成します。応用に注意を要求する事象がTWIハ、スで起こると、TWI割り込み要求フラケ、(TWINT)が有効にされます。次のクロック周期でTWI状態レシ、スタ(TWSR)は事象を示す状態符号で更新されます。TWI割り込み要求フラケが有効にされる時にだけ、TWSRは適切な状態情報を含みます。他の全ての時でTWSRは適切な状態情報が利用できないことを示す特別な状態符号を含みます。TWINTフラケが設定(1)されている限り、SCL信号線はLowに保たれます。これは続くTWI送信を許す前に(現状)処理完了を応用ソフトウェアに許します。

TWI割り込み要求フラグ(TWINT)は次の場合に設定(1)されます。

- 開始条件または再送開始条件送信後
- · SLA+R/W送信後
- ・アドレス バイト送信後
- ・調停に敗れた後
- ・自身の従装置アドレスまたは一斉呼び出しによってアドレス指定された後
- ・データバ小受信後
- ・従装置として未だアドレス指定されている間の停止条件または再送開始条件受信後
- ・不正な開始条件または停止条件のためバス異常が起きた時

### 15.7. TWIの使用法

AVR TWIは小・小志向で割り込みが基本です。割り込みは小・小の受信や開始条件の送出のような全てのハ・スの事象後に起こります。 TWIは割り込みが基本のため、応用ソフトウェアはTWIハ・・小転送中に他の操作を続行するために開放されます。 ステータス レシ・スタ(SREG)の全割り込み許可(I)ヒ・ットと共にTWI制御レシ・スタ(TWCR)のTWI割り込み許可(TWIE)ヒ・ットは、TWCRのTWI割り込み要求フラク・(TWINT)の設定(1)が割り込み要求を発生すべきかどうか決めることを応用(ソフトウェア)に許します。 TWIE ヒ・ットが解除(0)されると、応用(ソフトウェア)はTWIハ・スの動きを検知するためにTWINTフラグ・をポーリングしなければなりません。

TWINTフラグが設定(1)されると、TWIは動作を終え、応用(ソフトウェア)の応答を待ちます。この場合、TWI状態レジスタ(TWSR)はTWIハスの現在の状態を示す値を含みます。そして応用ソフトウェアはTWCRとTWDRの操作により、TWIが次のTWIハス周期で何を行うべきかを決定できます。

図15-10.は応用(ソフトウェア)がTWIハードウェアにどうインターフェースできるかの簡単な例です。この例では主装置が単一データ バイトを従装置に送信しようします。この内容はかなり大雑把ですので、より詳細な説明が本項の後に続きます。希望した動きを実現する簡単なコート例も示されます。



- 1. TWI送信の最初の段階は<mark>開始条件</mark>を送出することです。これはTWIハードウェアに開始条件送出を命じる特別な値をTWCR内に書くことによって行います。どんな値を書くかは後で記述されます。けれども、書かれる値でTWINTビットが設定(1)されることが重要です。TWINTへの1書き込みは、このフラケを解除(0)します。TWCRでTWINTビットが設定(1)されている限り、TWIはどんな動作も始めません。応用(ソフトウェア)がTWINTを解除(0)した後、TWIは直ちに開始条件の送出を始めます。
- 2. 開始条件が送出されてしまうと、TWCRでTWINTフラグが設定(1)され、TWSRは<mark>開始条件</mark>が正常に送出されてしまったことを示す 状態符号に更新されます。
- 3. 応用ソフトウェアは開始条件が正常に送信されたのを確認するためにTWSRの値を直ぐに検査すべきです。TWSRがその他を示している場合、応用ソフトウェアは異常ルーチンを呼び出すような或る特別な動きを講じるかもしれません。期待した状態符号だと仮定すると、応用(ソフトウェア)はTWDRにSLA+Wを設定しなければなりません。TWDRがアトレスとデータの両方に使われることを思い出してください。TWDRが希望したSLA+Wに設定されてしまった後、TWDRにあるSLA+Wの送信をTWIハートウェアへ命じる特別な値がTWCRに書かれなければなりません。どんな値を書くかは後で記述されます。けれども書かれる値でTWINTビットが設定(1)されることが重要です。TWINTへの1書き込みがこのフラグを解除(0)します。TWCRでTWINTビットが設定(1)されている限り、TWIはどんな動作も始めません。応用(ソフトウェア)がTWINTを解除(0)した後、TWIは直ちにアトレス パケットの送信を始めます。
- 4. アトンス パケットが送信されてしまうと、TWCRでTWINTフラグが設定(1)され、TWSRはアトンス パケットが正常に送信されたことを示す状態符号に更新されます。この状態符号は従装置がパケットに応答したかどうかも反映します。
- 5. 応用ソフトウェアはアドレス パケットが正常に送信され、期待されたACKビット値であるのを確認するためにTWSRの値を直ぐに検査すべきです。TWSRが他を示している場合、応用ソフトウェアは異常ルーチンを呼び出すような或る特別な動きを講じるかもしれません。期待した状態符号だと仮定すると、応用(ソフトウェア)はTWDRにデータを設定しなければなりません。その後、TWDRにあるデータ パケットの送信をTWIハードウェアへ命じる特別な値がTWCRに書かれなければなりません。どんな値を書くかは後で記述されます。けれども書かれる値でTWINTビットが設定(1)されることが重要です。TWINTへの1書き込みがこのフラグを解除(0)します。TWCRでTWINTビットが設定(1)されている限り、TWIはどんな動作も始めません。応用(ソフトウェア)がTWINTを解除(0)した後、TWIは直ちにデータ パケットの送信を始めます。
- 6. データ パケットが送信されてしまうと、TWCR内のTWINTフラグが設定(1)され、TWSRはデータ パケットが正常に送信されたことを示す状態符号に更新されます。この状態符号は従装置がパケットに応答したかどうかも反映します。
- 7. 応用ソフトウェアはデータ パケットが正常に送信され、期待されたACKビットの値であるのを確認するためにTWSRの値を直ぐに検査すべきです。TWSRが他を示している場合、応用ソフトウェアは異常ルーチンを呼び出すような或る特別な動きを講じるかもしれません。期待した状態符号だと仮定すると、応用(ソフトウェア)は停止条件の送出をTWIハート・ウェアへ命じる特別な値をTWCRに書かなければなりません。どんな値を書くかは後で記述されます。けれども書かれる値でTWINTビットが設定(1)されることが重要です。TWINTへの1書き込みがこのフラク・を解除(0)します。TWCRでTWINTビットが設定(1)されている限り、TWIはどんな動作も始めません。応用(ソフトウェア)がTWINTを解除(0)した後、TWIは直ちに停止条件の送出を始めます。停止条件が送出されてしまった後にTWINTが設定(1)されないことに注意してください。





この例は簡単とはいえ、全てのTWI送信に関係した原理を示しています。これらは次のように要約できます。

- ・TWIが動作を終了して応用(ソフトウェア)の反応を予想する時にTWINTフラグが設定(1)されます。SCL信号線はTWINTが解除(0)されるまでLowに引き込まれます。
- ・TWINTフラグが設定(1)されたなら、使用者は次のTWIバス周期に関連した値で(必要な)全てのTWIレジスタを更新しなければなりません。例で示されるようにTWDRは次のTWIバス周期で送信されるべき値を設定されなければなりません。
- ・(必要な)全てのTWIレジスタを更新し、その他保留中の応用ソフトウェアの処理が完了されてしまった後にTWCRが書かれます。TWCR 書き込み時、TWINTビットが設定(1)されるべきです。TWINTへの1書き込みはこのフラグを解除(0)します。TWCR設定によってどの動作が指定されても、TWIはその(TWINT=0)後に実行を始めます。

次にアセンブリ言語とC言語の実装例が与えられます。以下のコートは例えばインクルート、ファイルの使用により、様々な定義が作成されてしまっている前提であることに注意してください。

|    | アセ                        | ンフ゛リ言語プログラム例                                                                           | C言語プログラム例                                                                                                                          | 注釈                                                               |
|----|---------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|
| 1. | LDI<br>OUT                | R16, (1< <twint) (1<<twsta)<br=""  ="">  (1&lt;<twen)<br>TWCR, R16</twen)<br></twint)> | TWCR = (1< <twint) (1<<twsta)<br=""  ="">  (1&lt;<twen);< td=""><td>;開始条件送出</td></twen);<></twint)>                                | ;開始条件送出                                                          |
| 2. | WAIT1: IN<br>SBRS<br>RJMP | R16, TWCR<br>R16, TWINT<br>WAIT1                                                       | while (!(TWCR & (1< <twint)));< td=""><td>;TWINT=1まで待機<br/>;(開始条件送出完了待機)</td></twint)));<>                                         | ;TWINT=1まで待機<br>;(開始条件送出完了待機)                                    |
|    | IN<br>ANDI<br>CPI<br>BRNE | R16, TWSR<br>R16, \$F8<br>R16, START<br>ERROR                                          | if ((TWSR & 0xF8) != START) ERROR();                                                                                               | ;TWI状態レジスタ値検査<br>;前置分周選択ビットの遮蔽<br>;STARTと異なる状態符号で<br>;異常処理へ      |
| 3. | LDI<br>OUT<br>LDI<br>OUT  | R16, SLA_W<br>TWDR, R16<br>R16, (1< <twint) (1<<twen)<br=""  ="">TWCR, R16</twint)>    | TWDR = SLA_W;  TWCR = (1< <twint) (1<<twen);<="" td=""  =""><td>;TWDRにSLA+W設定<br/>;アドレス送信開始のため<br/>;TWCRのTWINTを解除(0)</td></twint)> | ;TWDRにSLA+W設定<br>;アドレス送信開始のため<br>;TWCRのTWINTを解除(0)               |
| 4. | WAIT2: IN<br>SBRS<br>RJMP | R16, TWCR<br>R16, TWINT<br>WAIT2                                                       | while (!(TWCR & (1< <twint)));< td=""><td>;TWINT=1まで待機<br/>;(SLA+W送出完了と<br/>;ACK/NACK受信完了待機)</td></twint)));<>                     | ;TWINT=1まで待機<br>;(SLA+W送出完了と<br>;ACK/NACK受信完了待機)                 |
| 5. | IN<br>ANDI<br>CPI<br>BRNE | R16, TWSR<br>R16, \$F8<br>R16, MT_SLA_ACK<br>ERROR                                     | if ((TWSR & 0xF8) != MT_SLA_ACK) ERROR();                                                                                          | ;TWI状態レジスタ値検査<br>;前置分周選択ビットの遮蔽<br>;MT_SLA_ACKと違う状態符号で<br>;異常処理へ  |
| 5. | LDI<br>OUT<br>LDI<br>OUT  | R16, DATA<br>TWDR, R16<br>R16, (1< <twint) (1<<twen)<br=""  ="">TWCR, R16</twint)>     | TWDR = DATA;  TWCR = (1< <twint) (1<<twen);<="" td=""  =""><td>;TWDRにデータ設定<br/>;データ送信開始のため<br/>;TWCRのTWINTを解除(0)</td></twint)>     | ;TWDRにデータ設定<br>;データ送信開始のため<br>;TWCRのTWINTを解除(0)                  |
| 6. | WAIT3: IN<br>SBRS<br>RJMP | R16, TWCR<br>R16, TWINT<br>WAIT3                                                       | while (!(TWCR & (1< <twint)));< td=""><td>;TWINT=1まで待機<br/>;(データ送出完了と<br/>;ACK/NACK受信完了待機)</td></twint)));<>                       | ;TWINT=1まで待機<br>;(データ送出完了と<br>;ACK/NACK受信完了待機)                   |
| 7. | IN<br>ANDI<br>CPI<br>BRNE | R16, TWSR<br>R16, \$F8<br>R16, MT_DATA_ACK<br>ERROR                                    | if ((TWSR & 0xF8) != MT_DATA_ACK) ERROR();                                                                                         | ;TWI状態レジスタ値検査<br>;前置分周選択ビットの遮蔽<br>;MT_DATA_ACKと違う状態符号で<br>;異常処理へ |
|    | LDI<br>OUT                | R16, (1< <twint) (1<<twsto)<br=""  ="">  (1&lt;<twen)<br>TWCR, R16</twen)<br></twint)> | TWCR = (1< <twint) (1<<twsto)<br=""  ="">  (1&lt;<twen);< td=""><td>;停止条件送出</td></twen);<></twint)>                                | ;停止条件送出                                                          |

注: 5頁の「コート・例について」をご覧ください。

## 15.8. 転送種別

TWIは4つの主な動作種別の1つで動けます。これらは送信主装置(MT)、受信主装置(MR)、送信従装置(ST)、受信従装置(SR)と名付けられます。これら種別の多くは同じ応用に使えます。例えば、TWI方式のEEPROM内にデータを書くのにTWIはMT動作を、EEPR OMからデータを読み戻すのにMR動作を使えます。システム内に他の主装置が存在する場合、それらのいくつかがTWIにデータを送信するかもしれず、するとSR動作が使われるでしょう。どの動作種別が適正かを決めるのは応用ソフトウェアです。

次項はこれら動作種別の各々を記述します。起こり得る状態符号は各動作種別のデータ伝送詳細図に沿って示されます。これらの図は次の略号を含みます。

- S 開始(START)条件
- Rs 再送開始(REPEATED START)条件
- R 読み出し指定ビット (SDA=High)
- W 書き込み指定ビット(SDA=Low)
- A 確認応答(ACK)ビット(SDA=Low)
- A 非確認応答(NACK)ビット(SDA=High)
- Data 8ビットデータハイト
- P 停止(STOP)条件
- SLA 従装置アドレス

図15-12.~18.内の楕円(<mark>訳注</mark>:原文は円)はTWI制御レシブスタ(TWCR)のTWI割り込み要求フラケ(TWINT)が設定(1)されたことを示すのに使われます。この楕円内の番号は前置分周選択ビットが0で遮蔽されたTWI状態レシブスタ(TWSR)に保持した状態符号を表します。これら位置での動きはTWI転送の継続または完了が応用(ソフトウェア)によって行われなければなりません。TWI転送はソフトウェアによってTWINTフラケが解除(0)されるまで一時停止されます。

TWI割り込み要求フラグ(TWINT)が設定(1)される時のTWI状態レジスタ(TWSR)の状態符号は適切なソフトウェア動作を決めるのに使われます。各状態符号に対する必要なソフトウェア動作や後続の直列転送の詳細は表15-2.~5.で与えられます。これらの表に於いて前置分周選択ビットが0で遮蔽されていることに注意してください。





## 15.8.1. 送信主装置動作

送信主装置動作では何バーかのデータが受信従装置へ送信されます(図15-11.参照)。主装置動作へ移行するには開始条件が送出されなければなりません。それに続くアドレスパーケットの形式が送信主装置または受信主装置のどちらへ移行すべきかを決めます。 SLA+Wが送信されると送信主装置(MT)へ移行し、SLA+Rが送信されると受信主装置(MR)へ移行します。本項で言及する全ての状態符号は前置分周選択ビットがのか、または0で遮蔽されることが前提です。



開始条件はTWCRに次の値を書くことによって送出されます。

| ピット  | 7     | 6    | 5     | 4     | 3    | 2    | 1 | 0    |
|------|-------|------|-------|-------|------|------|---|------|
| TWCR | TWINT | TWEA | TWSTA | TWSTO | TWWC | TWEN | - | TWIE |
| 設定値  | 1     | X    | 1     | 0     | X    | 1    | 0 | X    |

TWENは2線直列インターフェース(TWI)を許可するために設定(1)されなければなりません。TWSTAは開始条件を送出するために1を書かれねばならず、TWINTはTWINTフラグを解除(0)するために1を書かれなければなりません。そしてTWIは2線直列バスを検査し、バスが開放になると直ぐに開始条件を生成します。開始条件が送出されてしまった後、TWINTフラグがハードウェアによって設定(1)され、TWSRの状態符号が\$08(表15-2.参照)になります。送信主装置へ移行するにはSLA+Wが送信されなければなりません。これはTWDRにSLA+Wを書くことによって行います。その後、転送を継続するためにTWINTビットは(1の書き込みによって)解除(0)されるべきです。これはTWCRに次の値を書くことによって成し遂げられます。

| ピット  | 7     | 6    | 5     | 4     | 3    | 2    | 1 | 0    |
|------|-------|------|-------|-------|------|------|---|------|
| TWCR | TWINT | TWEA | TWSTA | TWSTO | TWWC | TWEN | - | TWIE |
| 設定値  | 1     | X    | 0     | 0     | X    | 1    | 0 | X    |

SLA+Wが送信されて応答ビットが受信されてしまうと、TWINTが再び設定(1)され、TWSRの状態符号の数値が利用可能になります。主装置動作で可能性のある状態符号は\$18,\$20,\$38です。これら状態符号の各々に対する適切な動作は $\mathbf{表}15-2$ .で詳述されます。 SLA+Wが正常に送信されてしまうと、データ パケットが送信されるべきです。これはTWDRにデータ バイトを書くことによって行われます。 TWDRはTWINTが1の時にだけ書かれなければなりません。さもなければ、そのアクセスは破棄され、TWCRで上書き発生(TWWC)フラケが設定(1)されます。 TWDR更新後、転送を継続するためにTWINTビットは(1の書き込みによって)解除( $\mathbf{0}$ )されるべきです。これは TWCRに次の値を書くことによって成し遂げられます。

| ピット  | 7     | 6    | 5     | 4     | 3    | 2    | 1 | 0    |
|------|-------|------|-------|-------|------|------|---|------|
| TWCR | TWINT | TWEA | TWSTA | TWSTO | TWWC | TWEN | - | TWIE |
| 設定値  | 1     | X    | 0     | 0     | X    | 1    | 0 | X    |

最後のバイトが送られてしまうまでこの手順が繰り返され、この転送は停止条件または再送開始条件を生成することによって終了されます。停止条件はTWCRに次の値を書くことによって生成されます。

| ピット  | 7     | 6    | 5     | 4     | 3    | 2    | 1 | 0    |
|------|-------|------|-------|-------|------|------|---|------|
| TWCR | TWINT | TWEA | TWSTA | TWSTO | TWWC | TWEN | 1 | TWIE |
| 設定値  | 1     | X    | 0     | 1     | Χ    | 1    | 0 | X    |

再送開始条件はTWCRに次の値を書くことによって生成されます。

| ピット  | 7     | 6    | 5     | 4     | 3    | 2    | 1 | 0    |
|------|-------|------|-------|-------|------|------|---|------|
| TWCR | TWINT | TWEA | TWSTA | TWSTO | TWWC | TWEN | - | TWIE |
| 設定値  | 1     | X    | 1     | 0     | X    | 1    | 0 | X    |

再送開始条件(状態符号\$10)後、2線直列インターフェースは停止条件を送出せずに再び同じ従装置または新しい従装置にアクセスできます。再送開始条件は主装置がバスの制御を失わずに送信主装置、受信主装置間の切り替えを可能にします(訳注:原文では従装置も含まれていますが、基本動作に対して不適切なため削除しました)。

| 表15-2 送信主装置動作の状態符号()        | E: TWSRの前置分周選択ビットは0の前提)                                                       |
|-----------------------------|-------------------------------------------------------------------------------|
| X 10 4. 应旧工农但到1FV77,芯竹 7 (/ | L. I WUNV2月11日 月 /日   201/10 / 1 (より) / 1   1   1   1   1   1   1   1   1   1 |

| 小台的            | 古前の動作し            |             | ソフトウ  | ェアの対応 | <u>,</u> |      |                                   |
|----------------|-------------------|-------------|-------|-------|----------|------|-----------------------------------|
| 状態符号<br>(TWSR) | 直前の動作と<br>バスの状態   | TWDR操作      |       | TWCF  | R設定      |      | TWCR設定によるハードウェア動作                 |
| (1 WSIV)       | ハハの水路             | TWDN(未)下    | TWSTA | TWSTO | TWINT    | TWEA |                                   |
| \$08           | 開始条件送信            | SLA+W設定     | 0     | 0     | 1        | X    | SLA+W送信、ACKかNACK受信                |
| \$10           | 再送開始条件送信          | SLA+W設定     | 0     | 0     | 1        | X    | SLA+W送信、ACKかNACK受信                |
| φ10            | 丹及開始未件及信          | SLA+R設定     | 0     | 0     | 1        | X    | SLA+R送信、受信主装置動作へ移行                |
|                |                   | データ設定       | 0     | 0     | 1        | X    | データ送信、ACKかNACK受信                  |
| \$18           | SLA+W送信           |             | 1     | 0     | 1        | X    | 再送開始条件送信                          |
| \$10           | ACK受信             | なし          | 0     | 1     | 1        | X    | 停止条件送信、TWSTO=0                    |
|                |                   |             | 1     | 1     | 1        | X    | 停止条件→開始条件送信、TWSTO=0               |
|                |                   | データ設定       | 0     | 0     | 1        | X    | データ送信、ACKかNACK受信                  |
| \$20           | SLA+W送信<br>NACK受信 |             | 1     | 0     | 1        | X    | 再送開始条件送信                          |
| <b>Φ</b> Δ0    |                   | なし          | 0     | 1     | 1        | X    | 停止条件送信、TWSTO=0                    |
|                |                   |             | 1     | 1     | 1        | X    | 停止条件→開始条件送信、TWSTO=0               |
|                |                   | データ設定       | 0     | 0     | 1        | X    | データ送信、ACKかNACK受信                  |
| \$28           | データ バイ送信          |             | 1     | 0     | 1        | X    | 再送開始条件送信                          |
| <b>Φ</b> ΔΟ    | ACK受信             | なし          | 0     | 1     | 1        | X    | 停止条件送信、TWSTO=0                    |
|                |                   |             | 1     | 1     | 1        | X    | 停止条件→開始条件送信、TWSTO= <mark>0</mark> |
|                |                   | データ設定       | 0     | 0     | 1        | X    | データ送信、ACKかNACK受信                  |
| \$30           | データバイ送信           |             | 1     | 0     | 1        | X    | 再送開始条件送信                          |
| φ3U            | NACK受信            | なし          | 0     | 1     | 1        | X    | 停止条件送信、TWSTO=0                    |
|                |                   |             | 1     | 1     | 1        | X    | 停止条件→開始条件送信、TWSTO=0               |
| \$38           | SLA+W, データ バイトで   | なし          | 0     | 0     | 1        | X    | バス開放、未指定従装置動作へ移行                  |
| φοο            | バス競合調停敗退          | <b>/</b> よし | 1     | 0     | 1        | X    | n'a開放時に開始条件送信                     |







### 15.8.2. 受信主装置動作

受信主装置動作では何バイかのデータが送信従装置から受信されます(図15-13.参照)。主装置動作へ移行するには開始条件が送出されなければなりません。それに続くアドレスパケットの形式が送信主装置または受信主装置のどちらへ移行すべきかを決めます。 SLA+Wが送信されると送信主装置(MT)へ移行し、SLA+Rが送信されると受信主装置(MR)へ移行します。本項で言及する全ての状態符号は前置分周選択ビットがのか、または0で遮蔽されることが前提です。



開始条件はTWCRに次の値を書くことによって送出されます。



TWENは2線直列インターフェース(TWI)を許可するために設定(1)されなければなりません。TWSTAは開始条件を送出するために1を書かれねばならず、TWINTはTWINTフラグを解除(0)するために1を書かれなければなりません。そしてTWIは2線直列バスを検査し、バスが開放になると直ぐに開始条件を生成します。開始条件が送出されてしまった後、TWINTフラグがハードウェアによって設定(1)され、TWSRの状態符号が\$08(表15-3.参照)になります。受信主装置へ移行するにはSLA+Rが送信されなければなりません。これはTWDRにSLA+Rを書くことによって行います。その後、転送を継続するためにTWINTビットは(1の書き込みによって)解除(0)されるべきです。これはTWCRに次の値を書くことによって成し遂げられます。

| ピット  | 7     | 6    | 5     | 4     | 3    | 2    | 1 | 0    |
|------|-------|------|-------|-------|------|------|---|------|
| TWCR | TWINT | TWEA | TWSTA | TWSTO | TWWC | TWEN | - | TWIE |
| 設定値  | 1     | X    | 0     | 0     | X    | 1    | 0 | X    |

SLA+Rが送信されて応答ビットが受信されてしまうと、TWINTが再び設定(1)され、TWSRの状態符号の数値が利用可能になります。主装置動作で可能性のある状態符号は\$38,\$40,\$48です。これら状態符号の各々に対する適切な動作は表15-3.で詳述されます。

ハードウェアによってTWINTフラグが設定(1)されると、受信したデータがTWDRから読めます。この手順は最後のバイが受信されてしまうまで繰り返されます。最後のバイトが受信されてしまった後、受信主装置は最後に受信したデータバイ後のNACK送信によって送信従装置へ通知すべきです。この転送は停止条件または再送開始条件を生成することによって終了されます。停止条件はTWCRに次の値を書くことによって生成されます。

| ピット  | 7     | 6    | 5     | 4     | 3    | 2    | 1 | 0    |
|------|-------|------|-------|-------|------|------|---|------|
| TWCR | TWINT | TWEA | TWSTA | TWSTO | TWWC | TWEN | - | TWIE |
| 設定値  | 1     | X    | 0     | 1     | X    | 1    | 0 | X    |

再送開始条件はTWCRに次の値を書くことによって生成されます。

| ピット  | 7     | 6    | 5     | 4     | 3    | 2    | 1 | 0    |
|------|-------|------|-------|-------|------|------|---|------|
| TWCR | TWINT | TWEA | TWSTA | TWSTO | TWWC | TWEN | - | TWIE |
| 設定値  | 1     | X    | 1     | 0     | X    | 1    | 0 | X    |

再送開始条件(状態符号\$10)後、2線直列インターフェースは停止条件を送出せずに再び同じ従装置または新しい従装置にアクセスできます。再送開始条件は主装置がバスの制御を失わずに送信主装置、受信主装置間の切り替えを可能にします(訳注:原文では従装置も含まれていますが、基本動作に対して不適切なため削除しました)。

| 表15-3 | 受信主装置動作の状態符号   | (注: TWSRの前置分周選択ビットは0の前提                             | 를) |
|-------|----------------|-----------------------------------------------------|----|
| 120 0 | ,又旧土农邑到15岁八心门了 | \ <mark>/                                   </mark> | _/ |

|                | 本並の私作し              |            | ソフトウ  | ェアの対応 | -<br>> |      |                     |
|----------------|---------------------|------------|-------|-------|--------|------|---------------------|
| 状態符号<br>(TWSR) | 直前の動作と<br>バスの状態     | TWDR操作     |       | TWCF  | R設定    |      | TWCR設定によるハードウェア動作   |
| (1 77511)      | バスの大窓               | I WDN(未) F | TWSTA | TWSTO | TWINT  | TWEA |                     |
| \$08           | 開始条件送信              | SLA+R設定    | 0     | 0     | 1      | X    | SLA+R送信、ACKかNACK受信  |
| \$10           | 再送開始条件送信            | SLA+R設定    | 0     | 0     | 1      | X    | SLA+R送信、ACKかNACK受信  |
| \$10           | 丹区開始未件区信            | SLA+W設定    | 0     | 0     | 1      | X    | SLA+W送信、送信主装置動作へ移行  |
| \$38           | SLA+Rで調停敗退          | なし         | 0     | 0     | 1      | X    | バス開放、未指定従装置動作へ移行    |
| <b>န</b> ၁ဝ    | またはNACK受信           | /4 C       | 1     | 0     | 1      | X    | バス開放時に開始条件送信        |
| \$40           | SLA+R送信             | なし         | 0     | 0     | 1      | 0    | データ受信、NACK応答        |
| <b>Φ4</b> 0    | ACK受信               | /4 C       | 0     | 0     | 1      | 1    | データ受信、ACK応答         |
|                | CL A LD)光层          |            | 1     | 0     | 1      | X    | 再送開始条件送信            |
| \$48           | SLA+R送信<br>NACK受信   | なし         | 0     | 1     | 1      | X    | 停止条件送信、TWSTO=0      |
|                | NACKXIII            |            | 1     | 1     | 1      | X    | 停止条件→開始条件送信、TWSTO=0 |
| \$50           | データバイ受信             | データ取得      | 0     | 0     | 1      | 0    | データ受信、NACK応答        |
| φ50<br>        | ACK応答               | / 一ク取得     | 0     | 0     | 1      | 1    | データ受信、ACK応答         |
|                | 二九八五日               |            | 1     | 0     | 1      | X    | 再送開始条件送信            |
| \$58           | データ バイト受信<br>NACK応答 | データ取得      | 0     | 1     | 1      | X    | 停止条件送信、TWSTO=0      |
|                | TW CIT/UVE          |            | 1     | 1     | 1      | X    | 停止条件→開始条件送信、TWSTO=0 |







### 15.8.3. 受信従装置動作

受信従装置動作では何バイトかのデータが送信主装置から受信されます(図15-15.参照)。本項で言及する全ての状態符号は前置分周選択ビットが0か、または0で遮蔽されることが前提です。



受信従装置動作を始めるにはTWARとTWCRが次のように初期化されなければなりません。

| ピット  | 7            | 6    | 5    | 4    | 3    | 2    | 1    | 0     |  |  |
|------|--------------|------|------|------|------|------|------|-------|--|--|
| TWAR | TWA6         | TWA5 | TWA4 | TWA3 | TWA2 | TWA1 | TWA0 | TWGCE |  |  |
| 設定値  | 装置自身の従装置アドレス |      |      |      |      |      |      |       |  |  |

上位7ビットは主装置によってアドレス指定される時に2線直列インターフェースが応答するアドレスです。最下位(TWGCE)ビットが設定(1)されるなら、TWIは一斉呼び出し(\$00)に応答し、さもなければ一斉呼び出しアドレスを無視します。

| ピット  | 7     | 6    | 5     | 4     | 3    | 2    | 1 | 0    |
|------|-------|------|-------|-------|------|------|---|------|
| TWCR | TWINT | TWEA | TWSTA | TWSTO | TWWC | TWEN | _ | TWIE |
| 設定値  | 0     | 1    | 0     | 0     | 0    | 1    | 0 | X    |

TWENは2線直列インターフェース(TWI)を許可するために1を書かれなければなりません。TWEAは装置自身の従装置アドレスまたは一斉呼び出しアドレスの確認応答(ACK)を許可するために1を書かれなければなりません。TWSTAとTWSTOは0を書かれなければなりません。

TWARとTWCRが初期化されてしまうと、TWIは自身の従装置アトンス(または許可なら、一斉呼び出しアトンス)とそれに続くデータ方向ビットによってアトンス指定されるまで待ちます。方向ビットが0(W)ならばTWIは受信従装置で動作し、さもなくば(1(R)ならば)送信従装置へ移行されます。自身の従装置アトンスとWビットが受信されてしまった後にTWINTフラグが設定(1)され、TWSRから有効な状態符号が読めます。この状態符号は適切なソフトウェア動作を決めるのに使われます。各状態符号に対して行うべき適切な動作は表15-4.で詳述されます。受信従装置動作はTWIが主装置動作の間で調停に敗れた場合にも移行されるかもしれません。(状態符号\$68,\$78参照)

転送中にTWEAビットがリセット(0)されると、TWIは次に受信したデータ バイト後のSDAに非確認応答(NACK)(SDA=High)を返します。これは従装置がこれ以上受信できないことを示すのに使えます。TWEAが0の間中、TWIは自身の従装置アドレスに応答しませんが、2線直列バスは未だ監視され、アドレス認証はTWEAの設定(1)によって何時でも再開できます。これはTWEAビットがTWIを2線直列バスから一時的に隔離するのに使えることを意味します。

アイドル動作を除く休止形態ではTWIへのクロック系がOFFにされます。TWEAt'ットが設定(1)されていると、このインターフェースはクロック元として2線直列パスクロック(SCL)を使うことにより、自身の従装置アドレスと一斉呼び出しに未だ確認応答できます。その後デバイスが休止形態から起動し、TWIは起動中からTWINTフラケが(1書き込みによって)解除(0)されるまでSCLクロックをLowに保ちます。その後のデータ受信はAVRクロックが通常通り走行することで通常通りに行われます。AVRが長い起動時間に設定されていると、SCL信号線が長時間Lowに保持され、他のデータ送信を阻止するかもしれないことに気付いてください。

これらの(アイドル動作を除く)休止形態から起動すると、2線直列インターフェース データ レジスタ(TWDR)がバスで渡す最後のバイトを反映しないことに注意してください。

| 表15-4. 受信従装置動作の状態符号(注: 7 | 「WSRの前置分周選択ビットは0の前提) |
|--------------------------|----------------------|
|--------------------------|----------------------|

| 状態符号   | 語位装直動作の状態符<br>直前の動作と        |         |       | ェアの応答 | F     |      |                                 |
|--------|-----------------------------|---------|-------|-------|-------|------|---------------------------------|
| (TWSR) | がるの状態                       | TWDR操作  |       | TWCF  |       |      | TWCR設定によるハードウェア動作               |
| (TWSK) | - · · ·                     | IWDN採IF | TWSTA | TWSTO | TWINT | TWEA |                                 |
| \$60   | 自宛SLA+W受信                   | なし      | X     | 0     | 1     | 0    | データ受信、NACK応答                    |
| ΨΟΟ    | ACK応答                       | , 40    | X     | 0     | 1     | 1    | データ受信、ACK応答                     |
| \$68   | 主装置のSLA+R/Wで<br>調停敗退/自宛SLA+ | なし      | X     | 0     | 1     | 0    | データ受信、NACK応答                    |
| ,      | W受信/ACK応答                   | 0.0     | X     | 0     | 1     | 1    | データ受信、ACK応答                     |
| \$70   | 一斉呼び出し受信                    | なし      | X     | 0     | 1     | 0    | データ受信、NACK応答                    |
| φισ    | ACK応答                       | , 4 C   | X     | 0     | 1     | 1    | データ受信、ACK応答                     |
| \$78   | 主装置のSLA+R/Wで<br>調停敗退/一斉呼び   | なし      | X     | 0     | 1     | 0    | データ受信、NACK応答                    |
| Ψισ    | 出し受信/ACK応答                  | 1.40    | X     | 0     | 1     | 1    | データ受信、ACK応答                     |
| \$80   | 自宛データバ小受信                   | データ取得   | X     | 0     | 1     | 0    | データ受信、NACK応答                    |
| φου    | ACK応答                       | ノーク収付   | X     | 0     | 1     | 1    | データ受信、ACK応答                     |
|        |                             |         | 0     | 0     | 1     | 0    | 未指定従装置動作へ移行、応答禁止                |
|        |                             |         | 0     | 0     | 1     | 1    | 未指定従装置動作へ移行、応答対応                |
| \$88   | 自宛データ バイト受信<br>NACK応答       | データ取得   | 1     | 0     | 1     | 0    | 未指定従装置動作へ移行、応答禁止<br>バス開放で開始条件送信 |
|        |                             |         | 1     | 0     | 1     | 1    | 未指定従装置動作へ移行、応答対応<br>バス開放で開始条件送信 |
| \$90   | 一斉呼び出しのデータ                  | データ取得   | X     | 0     | 1     | 0    | データ受信、NACK応答                    |
| \$90   | バイ受信/ACK応答                  | / 一ク取得  | X     | 0     | 1     | 1    | データ受信、ACK応答                     |
|        |                             |         | 0     | 0     | 1     | 0    | 未指定従装置動作へ移行、応答禁止                |
|        | 一斉呼び出しのデータ                  |         | 0     | 0     | 1     | 1    | 未指定従装置動作へ移行、応答対応                |
| \$98   | バイ受信<br>NACK応答              | データ取得   | 1     | 0     | 1     | 0    | 未指定従装置動作へ移行、応答禁止<br>バス開放で開始条件送信 |
|        | NACK心合                      |         | 1     | 0     | 1     | 1    | 未指定従装置動作へ移行、応答対応<br>バス開放で開始条件送信 |
|        |                             |         | 0     | 0     | 1     | 0    | 未指定従装置動作へ移行、応答禁止                |
|        | 自指定中の                       |         | 0     | 0     | 1     | 1    | 未指定従装置動作へ移行、応答対応                |
| \$A0   | 停止条件または                     | なし      | 1     | 0     | 1     | 0    | 未指定従装置動作へ移行、応答禁止<br>バス開放で開始条件送信 |
|        | 再送開始条件検出                    |         | 1     | 0     | 1     | 1    | 未指定従装置動作へ移行、応答対応<br>バス開放で開始条件送信 |

#### 図15-16. 受信従装置動作の形式と状態 S SLA W Data A P/S 自宛データ受信確認応答 Α Α Data 60 80 A0 (80) 最終バイ非確認応答 Ā P/S 88 主装置で調停敗退自アドレス検出 Α 68 ·斉呼出 Data 一斉呼び出しでのデータ受信 Data 90 A0 70 90 P/S 最終バイ非確認応答 Ā 98 主装置で調停敗退一斉呼び出し検出 Α



Data A 何組かのデータと確認応答 (nn) 16進状態符号(TWSR)

従装置⇒主装置

主装置⇒従装置



### 15.8.4. 送信従装置動作

送信従装置動作では何バイトかのデータが送信主装置へ送信されます(図15-17.参照)。本項で言及する全ての状態符号は前置分周選択ビットが0か、または0で遮蔽されることが前提です。



送信従装置動作を始めるにはTWARとTWCRが次のように初期化されなければなりません。

| ピット  | 7            | 6    | 5    | 4    | 3    | 2    | 1    | 0     |  |  |
|------|--------------|------|------|------|------|------|------|-------|--|--|
| TWAR | TWA6         | TWA5 | TWA4 | TWA3 | TWA2 | TWA1 | TWA0 | TWGCE |  |  |
| 設定値  | 装置自身の従装置アドレス |      |      |      |      |      |      |       |  |  |

上位7ビットは主装置によってアドレス指定される時に2線直列インターフェースが応答するアドレスです。最下位(TWGCE)ビットが設定(1)されるなら、TWIは一斉呼び出し(\$00)に応答し、さもなければ一斉呼び出しアドレスを無視します。

| ピット  | 7     | 6    | 5     | 4     | 3    | 2    | 1 | 0    |
|------|-------|------|-------|-------|------|------|---|------|
| TWCR | TWINT | TWEA | TWSTA | TWSTO | TWWC | TWEN | - | TWIE |
| 設定値  | 0     | 1    | 0     | 0     | 0    | 1    | 0 | X    |

TWENは2線直列インターフェース(TWI)を許可するために1を書かれなければなりません。TWEAは装置自身の従装置アドレスまたは一斉呼び出しアドレスの確認応答(ACK)を許可するために1を書かれなければなりません。TWSTAとTWSTOは0を書かれなければなりません。

TWARとTWCRが初期化されてしまうと、TWIは自身の従装置アト・レス(または許可ならば一斉呼び出しアト・レス)とそれに続くデータ方向 ヒ・ットによってアト・レス指定されるまで待機します。方向ヒ・ットが1(R)ならばTWIは送信従装置で動作し、さもなくば(O(W)ならば)受信従装 置へ移行されます。自身の従装置アト・レスとRヒ・ットが受信されてしまった後、TWINTフラケが設定(1)され、TWSRから有効な状態符号が 読めます。この状態符号は適切なソフトウェア動作を決めるのに使われます。各状態符号に対して行うべき適切な動作は表15-5.で詳述 されます。送信従装置動作はTWIが主装置動作の間で調停に敗れた場合にも移行されるかもしれません。(状態符号80参照)

転送中にTWEAビットが0を書かれると、TWIは転送の最後のバイトを送信します。受信主装置が最終バイト後にACKまたはNACKのどちらを送信するかによって状態\$C0か\$C8へ移行します。TWIはアドレス指定されていない従装置動作に切り替えられ、主装置が転送を続ける場合、その主装置を無視します。従って受信主装置は直列データとして全て1を受信します。従装置が最後のバイトを送信(TWEAが0で主装置からのNACKを予測)したとしても、主装置が(ACK送信によって)追加データ バイトを要求すると状態\$C8へ移行します。

TWEAが0の間中、TWIは自身の従装置アドレスに応答しませんが、2線直列バスは未だ監視され、アドレス認証はTWEAの設定(1)によって何時でも再開できます。これはTWEAビットがTWIを2線直列バスから一時的に隔離するのに使えることを意味します。

アイドル動作を除く休止形態ではTWIへのクロック系がOFFにされます。TWEAt'ットが設定(1)されていると、このインターフェースはクロック元として2線直列バスクロック(SCL)を使うことにより、自身の従装置アドレスと一斉呼び出しに未だ確認応答できます。その後デバイスが休止形態から起動し、TWIは起動中からTWINTフラケが(1書き込みによって)解除(0)されるまでSCLクロックをLowに保ちます。その後のデータ受信はAVRクロックが通常通り走行することで通常通りに行われます。AVRが長い起動時間に設定されていると、SCL信号線が長時間Lowに保持され、他のデータ送信を阻止するかもしれないことに気付いてください。

これらの(アイト・ル動作を除く)休止形態から起動すると、2線直列インターフェース データ レジスタ(TWDR)がバスで渡す最後のバイトを反映しないことに注意してください。

| 表15-5 | 送信従装置動作の状態符号 | (注: TWSRの前置分周選択ビットは0の前提)                            |
|-------|--------------|-----------------------------------------------------|
| 120 0 | · 处 id 此     | \ <mark>/                                   </mark> |

|                | 古並の針 佐し                     |          | ソフトウ  | ェアの応答 | F     |      |                                 |
|----------------|-----------------------------|----------|-------|-------|-------|------|---------------------------------|
| 状態符号<br>(TWSR) | 直前の動作と<br>がるの状態             | TWDR操作   |       | TWCF  | R設定   |      | TWCR設定によるハードウェア動作               |
| (1 \\ \\ \)    | ハスの八忠                       | TWDN(末TF | TWSTA | TWSTO | TWINT | TWEA |                                 |
| \$A8           | 自宛SLA+R受信                   | データ設定    | X     | 0     | 1     | 0    | 最終データハイト送信、NACK受信予定             |
| φΛΟ            | ACK応答                       | 7 7 段足   | X     | 0     | 1     | 1    | データバイル送信、ACK受信予定                |
| \$B0           | 主装置のSLA+R/Wで<br>調停財法/自家SLA+ | データ設定    | X     | 0     | 1     | 0    | 最終データハー・小送信、NACK受信予定            |
| φυθ            | 調停敗退/自宛SLA+<br>R受信/ACK応答    | アが民      | X     | 0     | 1     | 1    | データハー・小送信、ACK受信予定               |
| \$B8           | データバイト送信                    | データ設定    | X     | 0     | 1     | 0    | 最終データハー・小送信、NACK受信予定            |
| фДО            | ACK受信                       | 7一分政化    | X     | 0     | 1     | 1    | データ バイト送信、ACK受信予定               |
|                |                             |          | 0     | 0     | 1     | 0    | 未指定従装置動作へ移行、応答禁止                |
|                |                             | なし       | 0     | 0     | 1     | 1    | 未指定従装置動作へ移行、応答対応                |
| \$C0           | データ バイト送信<br>NACK受信         |          | 1     | 0     | 1     | 0    | 未指定従装置動作へ移行、応答禁止<br>バス開放で開始条件送信 |
|                |                             |          | 1     | 0     | 1     | 1    | 未指定従装置動作へ移行、応答対応<br>バス開放で開始条件送信 |
|                |                             |          | 0     | 0     | 1     | 0    | 未指定従装置動作へ移行、応答禁止                |
|                | 最終データバイ送信                   |          | 0     | 0     | 1     | 1    | 未指定従装置動作へ移行、応答対応                |
| \$C8           | (TWEA=0)<br>ACK受信           | なし       | 1     | 0     | 1     | 0    | 未指定従装置動作へ移行、応答禁止<br>バス開放で開始条件送信 |
|                | TONXIII                     |          | 1     | 0     | 1     | 1    | 未指定従装置動作へ移行、応答対応<br>バス開放で開始条件送信 |



## 15.8.5. その他の状態

定義したTWI状態に従わない2つの状態符号があります。表15-6.をご覧ください。

状態\$F8はTWI割り込み要求フラグ(TWINT)が設定(1)されないので適切な情報が利用できないことを示します。これは他の状態間でTWIが直列転送に関係しない時に起きます。

状態\$00は2線直列バス転送中にバス異常が起きたことを示します。バス異常はフレーム形式の不正な位置で開始(START)条件または停止(STOP)条件が起きる時に起きます。このような不正位置の例はアドレス バイト、データ バイト、確認応答(ACK)ビットの直列転送中です。 バス異常が起きるとTWINTが設定(1)されます。バス異常から回復するには停止(STOP)条件生成許可(TWSTO)ビットが設定(1)され、TWINTが論理1書き込みによって解除(0)されなければなりません。これはTWIをアドレス指定されていない従装置動作にさせ、TWST Oビットを解除(0)させます(TWCRの他のビットは影響されません)。SDAとSCL信号進は開放され、停止条件は送出されません。

表15-6. その他の状態符号(注: TWSRの前置分周選択ビットは0の前提)

|                | 古並の計 <i>作</i> し                    |          | ソフトウ  | エアの応答 |       |      |                            |
|----------------|------------------------------------|----------|-------|-------|-------|------|----------------------------|
| 状態符号<br>(TWSR) | 直前の動作と がるの状態                       | TWDR操作   |       | TWCF  | R設定   |      | TWCR設定によるハードウェア動作          |
| (1 77511)      | ハスの水流                              | I WUR探IF | TWSTA | TWSTO | TWINT | TWEA |                            |
| \$F8           | 適切な状態情報なし<br>TWINT= <mark>0</mark> | なし       | -     | -     | -     | -    | 待機または現在の転送続行               |
| \$00           | 不正な開始条件/停<br>止条件でのバス異常             | なし       | 0     | 1     | 1     | X    | 停止条件を送出せずにバスを開放<br>TWSTO=0 |





### 15.8.6. 各種TWI動作種別の組み合わせ

いくつかの場合で望んだ動作を満たすために各々のTWI動作種別は組み合わされなければなりません。例えば直列EEPROMからのデータ読み出しを考えてください。一般的にこのような転送は次の段階を含みます。

- 1. 転送が開始されなければなりません。
- 2. EEPROMは読み出すべき場所を指示されなければなりません。
- 3. 読み出しが実行されなければなりません。
- 4. 転送が終了されなければなりません。

データが主装置から従装置へとその逆の両方向へ転送されることに注意してください。主装置はどの場所を読みたいかを従装置に指示しなければならず、送信主装置動作の使用を必要とします。その後にデータを従装置から読まねばならず、受信主装置動作の使用を意味します。その後にデータを従装置から読まねばならず、受信主装置動作の使用を意味します。従って転送方向が切り替えられなければなりません。主装置はこれら全ての段階中にバスの制御を保持しなければならず、この手順は排他的(非分断)操作として行われるべきです。複数主装置システムでこの原則に違反すると、他の主装置が②と③段階間でEEPROM内のデータ ポーインタを変更するかもしれず、(元の)主装置は不正なデータ位置を読むでしょう。このような転送方向の切り替えはアトンス バーイの送信とデータの受信間で再送開始条件を送出することによって成し遂げられます。再送開始条件後も主装置はバスの占有権を保持します。次の図はこの転送の流れを示します。



## 15.9. 複数主装置システムでのバス競合と調停

複数の主装置が同じバスに接続されると、それらの1つまたはそれ以上によって同時に送信が開始されるかもしれません。TWIは主装置の1つが転送を続けることを許され、手順内でデータが失われないような方法でこのような状態が扱われることを標準で保証します。2つの主装置が受信従装置へデータを送信することを試みる場合の調停状況の例は以下で図示されます。



以下で示されるように様々な異なる状況が調停中に起こるかもしれません。

- ・複数の主装置が同じ従装置に全く同じ通信を実行する場合。この場合、主/従装置のどれもがバスの衝突について知りません。
- ・複数の主装置が異なるデータまたは方向ビット(R/W)で同じ従装置をアクセスする場合。この場合、R/Wビットまたはデータ ビットのどちらかで調停が起きます。他の主装置がSDAに0を出力する間に1を出力しようとする主装置が調停に敗れます。 敗れた主装置は応用ソフトウェアの処置によって未指定従装置動作に切り替えるか、またはバスが開放になるまで待って新規開始条件を送出します。
- ・複数の主装置が異なる従装置をアクセスする場合。この場合、SLAビット内で調停が起きます。他の主装置がSDAに0を出力する間に1を出力しようとする主装置が調停に敗れます。SLA内で調停に敗れた主装置は勝った主装置によってアドレス指定されるかを検査するために従装置動作へ切り替えます。アドレス指定されると、R/Wビットの値によって受信従装置(SR)動作または送信従装置(ST)動作へ切り替えます。アドレス指定されないなら、応用ソフトウェアの処置によって未指定従装置動作に切り替えるか、またはバスが開放になるまで待って新規開始条件を送出します。

これは**図15-21**.で要約されます。利用可能な状態符号は楕円(<mark>訳注</mark>:原文は円)で与えられます。



## 15.10. SMBusとの適合性

他のどのI<sup>2</sup>C適合インターフェースとでも既知の互換性の問題があるため、設計者はTWIデバイスをSMBusデバイスへ接続する前に知るべきです。SMBus環境での使用に関して以下が注意されるべきです。

- ・2線インターフェースのそれらを含むAVRの全ての入出力ピンは供給電圧とGNDの両方に保護ダイオードを持ちます。37頁の図10-1.をご覧ください。これはSMBus仕様の必要条件と矛盾します。結果として、供給電圧はAVRから取り除かれてはならず、さもなければ保護ダイオードがバス線を引き下げるでしょう。パワーダウンと休止形態は供給電圧が残っているなら問題ありません。
- ・TWIのデータ保持時間はSMBusに対する指定よりも小さくなっています。
- ・SMBusは低速限度を持ち、一方はI<sup>2</sup>C持ちません。SMBus環境での主装置の時に、より遅いバス速度がSMBus従装置で時間超過を起動するため、AVRはバス速度が仕様以下に低下しないことを確実にしなければなりません。AVRが従装置に構成設定された場合、TWI単位部が時間超過を識別しないため、バス固定化の可能性があります。





## 15.11. TWI用レジスタ

### 15.11.1. TWBR - TWIL ット速度レジスタ (TWI Bit Rate Register)

| ピット        | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |      |
|------------|-------|-------|-------|-------|-------|-------|-------|-------|------|
| (\$B8)     | TWBR7 | TWBR6 | TWBR5 | TWBR4 | TWBR3 | TWBR2 | TWBR1 | TWBR0 | TWBR |
| Read/Write | R/W   |      |
| 初期値        | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |      |

#### ■ ビット7~0 - TWBR7~0: TWI ビット速度選択 (TWI Bit Rate Register)

TWBRはビット速度発生器用の分周値を選びます。ビット速度発生器は主装置動作でのSCLクロック周波数を生成する周波数分周器です。ビット速度の計算については87頁の「ビット速度発生器」をご覧ください。

TWIが主装置動作で動く場合、TWBRは10またはそれ以上でなければなりません。

### 15.11.2. TWCR - TWI制御レジスタ (TWI Control Register)

| ピット        | 7     | 6    | 5     | 4     | 3    | 2    | 1 | 0    |      |
|------------|-------|------|-------|-------|------|------|---|------|------|
| (\$BC)     | TWINT | TWEA | TWSTA | TWSTO | TWWC | TWEN | - | TWIE | TWCR |
| Read/Write | R/W   | R/W  | R/W   | R/W   | R    | R/W  | R | R/W  |      |
| 初期値        | 0     | 0    | 0     | 0     | 0    | 0    | 0 | 0    |      |

TWCRはTWI動作の制御に使われます。TWIの許可、バス上に<mark>開始条件を印加することによる主装置のアクセス開始、受信装置の応答生成、停止条件</mark>の生成、バスにデータを送出するためのTWIデータレジ、スタ(TWDR)への書き込み中のバスの一時停止制御に使われます。TWDRがアクセス不能の間にTWDRへ書き込もうとする場合の上書き発生も示します。

### ■ ビット7 - TWINT: TWI割り込み要求フラグ(TWI Interrupt Flag)

このビットはTWIが現在の作業を終了し、応用ソフトウェアの応答が予測されるとき、ハートウェアによって設定(1)されます。TWI制御レジスタ (TWCR)のTWI割り込み許可(TWIE)ビットとステータスレジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されていると、MCUはTWI割り込みへつりないます。TWINTフラウが設定(1)の間、SCLのLow期間は引き伸ばされます。TWINTフラウンはソフトウェアによる論理1書き込みによって解除(0)されなければなりません。このフラウンが割り込みルーチンを実行する時に自動的に解除(0)されないことに注意してください。このフラケの解除(0)がTWIの動作を始めるので、このフラケンの解除(0)前にTWIアトンスレジスタ(TWAR)、TWIデータレジスタ(TWDR)、TWI状態レジスタ(TWSR)への全てのアクセスが完了していなければならないことにも注意してください。

#### ■ ビット6 - TWEA:確認応答(ACK)許可 (TWI Enable Acknowledge Bit)

TWEAビットは確認応答(ACKパルス)の生成を制御します。TWEAビットが1を書かれ、次の条件に合致すると、TWIバスにACKパルスが生成されます。

- 装置が自分用の従装置アドレスを受信した場合。
- ・TWIアドレスレジスタ(TWAR)の一斉呼び出し検出許可(TWGCE)ビットが設定(1)されている時に一斉呼び出しを受信した場合。
- ・主受信装置または従受信装置動作でデータバイを受信した場合。

TWEAビットに0を書くことにより、一時的且つ仮想的に装置を2線直列バスから切り離せます。アドレス認証はその後に再びTWEAビットへ1を書くことによって再開できます。

#### ■ ビット5 - TWSTA: 開始(START)条件生成許可 (TWI START Condition Bit)

2線直列バスの主装置になるのを欲する時に応用はTWSTAビットに1を書きます。TWIハードウェアはバスが利用可能かを検査し、開放ならばバスに開始条件を生成します。しかし、バスが未開放の場合、TWIは停止条件が検出されるまで待ち、その後にバス所有権を要求する新規開始条件を生成します。TWSTAは開始条件が送出されてしまった時にソフトウェアで解除(0)されなければなりません。

#### ■ ビット4 - TWSTO: 停止(STOP)条件生成許可 (TWI STOP Condition Bit)

主装置動作でTWSTOビットに1を書くことが2線直列バスに停止条件を生成します。停止条件がバスで実行されると、TWSTOビットは自動的に解除(0)されます。従装置動作でのTWSTOビットの設定(1)は異常状態からの回復に使えます。これは停止条件を生成しませんが、TWIは明確に指定されていない従装置動作に戻り、SCL、SDA信号線をHi-Z状態に開放します。

#### ■ ビット3 - TWWC: TWI上書き発生フラグ (TWI Write Collision Flag)

TWI割り込み要求フラク (TWINT)が0の時にTWIデータレン、スタ(TWDR)への書き込みを試みると、このTWWCフラク が設定(1)されます。このフラク はTWINTが1の時のTWDR書き込みによって解除(0)されます。

#### ■ ビット2 - TWEN: TWI動作許可(TWI Enable Bit)

TWENビットはTWI動作を許可し、TWIインターフェースを活性(有効)にします。TWENが1を書かれると、TWIはSCL、SDAピンに接続した I/Oピンを制御できるようになり、スパ゚イク濾波器とスリューレート制限器を許可します。このビットが0を書かれると、TWIがOFFにされ、どんな 進行中の動作にも関係なく、全てのTWI送信が終了されます。

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

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

#### ■ ビット0 - TWIE: TWI割り込み許可 (TWI Interrupt Enable)

このビットが1を書かれ、ステーータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されていると、TWI割り込み要求フラグ(TWINT)が1である限り、TWI割り込み要求が活性に(発生)されます。

#### 15.11.3. TWSR - TWI 状態レジスタ (TWI Status Register)

| ピット<br>(\$B9) | 7<br>TWS7 | 6<br>TWS6 | 5<br>TWS5 | 4<br>TWS4 | 3<br>TWS3 | 2 | 1<br>TWPS1 | 0<br>TWPS0 | TWSR |
|---------------|-----------|-----------|-----------|-----------|-----------|---|------------|------------|------|
| Read/Write    | R         | R         | R         | R         | R         | R | R/W        | R/W        |      |
| 初期値           | 1         | 1         | 1         | 1         | 1         | 0 | 0          | 0          |      |

### ■ ビット7~3 - TWS7~3: TWI状態 (TWI Status)

これら5ビットはTWI論理回路と2線直列バスの状態を反映します。各種状態符号は91頁の「転送種別」で記述されます。TWSRから読む値が5ビットの状態符号と2ビットの前置分周値の両方を含むことに注意してください。応用設計者は状態ビットを検査する時に前置分周器ビットを0で隠すべきです。これは前置分周器設定に関係なく状態検査を行います。この手法は特記事項を除いてこのデータシート内で使われます。

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

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

#### ■ ビット1,0 - TWPS1,0: TWI前置分周器選択 (TWI Prescaler Bits)

これらのビットは読み書きでき、ビット速度の前置分周器を制御します。

ビット速度を計算するには87頁の「**ビット速度発生器**」をご覧ください。TWPS1,0の値はこの式で使われます。

| 表15-7. TWIL ット速度前置分周器選択 |   |   |    |    |  |  |  |  |  |
|-------------------------|---|---|----|----|--|--|--|--|--|
| TWPS1                   | 0 | 0 | 1  | 1  |  |  |  |  |  |
| TWPS0                   | 0 | 1 | 0  | 1  |  |  |  |  |  |
| 分周値                     | 1 | 4 | 16 | 64 |  |  |  |  |  |

## 15.11.4. TWDR - TWIデータレジスタ (TWI Data Register)

| ピット        | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |      |
|------------|------|------|------|------|------|------|------|------|------|
| (\$BB)     | TWD7 | TWD6 | TWD5 | TWD4 | TWD3 | TWD2 | TWD1 | TWD0 | TWDR |
| Read/Write | R/W  |      |
| 初期値        | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    |      |

送信動作でのTWDRは送信されるべき次小小を含みます。受信動作でのTWDRは最後に受信した小小を含みます。TWDRはTWIがハートを移動する手順でない間に書き込み可能です。これはTWI制御レジスタ(TWCR)のTWI割り込み要求フラグ(TWINT)がハートウェアによって設定(1)されると起きます。最初のTWI割り込みが起こる前にデータレジスタ(TWDR)は使用者によって初期化できないことに注意してください。TWDRのデータはTWINTが安定して設定(1)されている限り存続します。データが移動出力される間、ハスのデータが同時に移動入力されます。TWI割り込みによる休止形態からの起動後を除いて、TWDRは常にハスに現れる最後のハートを含みます。この例外の場合のTWDRの内容は不定です。ハス調停に敗れた場合の主装置から従装置への移行でもデータは失われません。確認応答(ACK)ビットの扱いはTWI論理回路によって自動的に制御され、CPUはACKビットを直接的にアクセスできません。

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

これら8ビットは送信されるべき次のデータバイト、または2線直列バスで最後に受信したデータバイトを構成します。

### 15.11.5. TWAR - TWI(従装置)アトレス レジスタ (TWI (Slave) Address Register)

| ピット        | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0     |      |
|------------|------|------|------|------|------|------|------|-------|------|
| (\$BA)     | TWA6 | TWA5 | TWA4 | TWA3 | TWA2 | TWA1 | TWA0 | TWGCE | TWAR |
| Read/Write | R/W   |      |
| 初期値        | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 0     |      |

TWARは従装置の送受信装置として設定した時にTWIが応答する7ビット従装置アドレスを(TWAR上位7ビットに)設定されるべきで、主装置動作では必要とされません。複数主装置のシステムでは、他の主装置によって従装置としてアドレス指定され得る主装置に於いて、TWARは設定されなければなりません。

TWARの最下位ビット(TWGCE)は一斉呼び出しアドレス(\$00)認証の許可に使われます。これらは受信した直列アドレスで従装置アドレス(と許可ならば一斉呼び出しアドレス)を捜す関連アドレス比較器です。一致が見つかると割り込み要求が生成されます。

#### ■ ビット7~1 - TWA6~0: TWI 従装置アドレス (TWI (Slave) Address)

これら7ビットはTWI部の従装置アドレスを構成します。

## ■ ビット0 - TWGCE: 一斉呼び出し検出許可 (TWI General Call Recognition Enable Bit)

設定(1)なら、このビットは2線直列バスを伝って与えられる一斉呼び出しの認証(検出)を許可します。





### 15.11.6. TWAMR - TWI(従装置)アトレス遮蔽レシ、スタ (TWI (Slave) Address Mask Register)

| ピット        | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0 |       |
|------------|-------|-------|-------|-------|-------|-------|-------|---|-------|
| (\$BD)     | TWAM6 | TWAM5 | TWAM4 | TWAM3 | TWAM2 | TWAM1 | TWAM0 | - | TWAMR |
| Read/Write | R/W   | R |       |
| 初期値        | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0 |       |

#### ■ ビット7~1 - TWAM6~0: TWI従装置アトレス遮蔽 (TWI (Slave) Address Mask)

TWAMRは7ビットの従装置アドレス遮蔽値を格納できます。TWAM R内の各ビットはTWI(従装置)アドレス レジスタ(TWAR)内の対応する アドレス ビットを遮蔽(禁止)します。遮蔽ビットが1に設定されると、その後のアドレス一致論理回路は到着アドレス ビットとTWAR内の対応ビット間の比較を無視します。図15-22.はアドレス一致論理回路を詳細に示します。



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

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

### 15.11.7. TWHSR - TWI 高速レジスタ (TWI High Speed Register)

| ピット        | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |       |
|------------|---|---|---|---|---|---|---|------|-------|
| (\$BE)     | _ | - | - | - | - | - | - | TWHS | TWHSR |
| Read/Write | R | R | R | R | R | R | R | R/W  |       |
| 初期値        | 0 | Λ | Λ | Λ | Λ | Λ | 0 | Λ    |       |

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

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

### ■ ビット0 - TWHS: TWI高速許可(TWI High Speed Enable)

このビットに1を書くことによってTWI高速動作が許可されます。この動作ではTWIクロックとして分周されないシステム クロックが選ばれます。17頁の図6-1.をご覧ください。

TWI高速動作はI/Oクロック周波数(clk<sub>I/O</sub>)よりも正確に2倍高い高速クロック(clk<sub>TWIHS</sub>)を必要とします。これは2倍低く前置分周される I/Oクロック周波数(clk<sub>I/O</sub>)を使用者が保証しなければなりません。例えば、供給元クロックして8MHz発振器が選択された場合、使用者はシステム クロック(従って、とI/Oクロック)を4MHzに下げる尺度で前置分周器を設定しなければなりません。クロック系統についてのより多くの情報に関しては17頁の「クロック体系」をご覧ください。

## 16. アナログ比較器

アナログ比較器は非反転入力AINOピンと反転入力AIN1ピンの入力値を比較します。非反転AINOピンの電圧が反転AIN1ピンの電圧よりも高い時にACSRのアナログ比較器出力(ACO)ビットが設定(1)されます。この比較器の出力はタイマ/カウンタ1捕獲機能を起動するように設定することができます。加えて、この比較器はアナログ比較器専用の独立した割り込みを起動できます。使用者は比較器出力の上昇端、下降端、またはその両方で割り込み起動を選べます。この比較器とその周辺論理回路の構成図は図16-1.で示されます。

ADC入力多重器を使うにはADC電力削減(PRADC)ビットが禁止されなければなりません。これは電力削減レジスタ(PRR)のPRADCビットを解除することによって行われます。より多くの詳細については24頁の「PRR - 電力削減レジスタ」をご覧ください。



注: A/D多重器出力については**表16-1**.をご覧ください。 アナロが比較器のピン配置については2頁の「ピン配置」と47頁の**表10-**11.を参照してください。

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

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

表16-1. アナログ比較器反転入力選択

| ACME | ADEN | MUX2~0 | アナログ比較器反転入力 | 備考              |
|------|------|--------|-------------|-----------------|
| 0    | X    | ххх    | AIN1        |                 |
|      | 1    | ххх    | AIINI       |                 |
|      |      | 0 0 0  | ADC0        |                 |
|      |      | 0 0 1  | ADC1        |                 |
|      |      | 0 1 0  | ADC2        |                 |
| 1    | 0    | 0 1 1  | ADC3        |                 |
|      | U    | 100    | ADC4        |                 |
|      |      | 1 0 1  | ADC5        |                 |
|      |      | 1 1 0  | ADC6        | TQFP, QFN/MLF32 |
|      |      | 111    | ADC7        | 外囲器のみ           |

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

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

| (\$7B)            | 7 | 6<br>ACME | 5<br>- | 4 | 3 | 2<br>ADTS2 | ADTS1 | 0<br>ADTS0 | ADCSRB      |
|-------------------|---|-----------|--------|---|---|------------|-------|------------|-------------|
| Read/Write<br>初期値 | R | R/W       | R      | R | R | R/W        | R/W   | R/W        | 7,2 2 3,1,2 |

### ■ ビット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     |      |
|-------------|-----|------|-----|-----|------|------|-------|-------|------|
| \$30 (\$50) | ACD | ACBG | ACO | ACI | ACIE | ACIC | ACIS1 | ACIS0 | ACSR |
| Read/Write  | R/W | R/W  | R   | R/W | R/W  | R/W  | 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)されると、AINOがアナログ比較器の非反転入力に印加されます。内部基準電圧がアナログ比較器入力として使われるとき、電圧の安定に一定時間を必要とします。安定(待機を)しない場合、最初は不正値を与えるかもしれません。27頁の「内部基準電圧」をご覧ください。

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

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

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

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

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

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

#### ■ ビット2 - ACIC: アナログ比較器捕獲起動許可 (Analog Comparator Input Capture Enable)

論理1を書かれると、このビットはアナログ比較器によって起動されるタイマ/カウンタ1の捕獲機能を許可します。この場合、比較器出力は比較器にタイマ/カウンタ1捕獲割り込みの雑音消去機能とエッジ選択機能を利用させる捕獲入力前置論理回路へ直接的に接続されます。 論理0を書かれると、アナログ比較器と捕獲機能間の接続は存在しません。比較器がタイマ/カウンタ1捕獲割り込みを起動するには、タイマ/カウンタ1割り込み許可レジスタ(TIMSK1)の捕獲割り込み許可(ICIE1)ビットが設定(1)されなければなりません。

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

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

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

| 表16-2. アナログ比較器割り込み条件選択 |       |              |  |  |  |  |
|------------------------|-------|--------------|--|--|--|--|
| ACIS1                  | ACIS0 | 割り込み発生条件     |  |  |  |  |
| 0                      | 0     | 比較器出力の変移(両端) |  |  |  |  |
| 0                      | 1     | (予約)         |  |  |  |  |
| 1                      | 0     | 比較器出力の下降端    |  |  |  |  |
| 1                      | 1     | 比較器出力の上昇端    |  |  |  |  |

### 16.2.3. DIDR1 - デッタル入力禁止レジスタ1 (Digital Input Disable Register 1)

| (e7E)            |     |   |       |       |       |
|------------------|-----|---|-------|-------|-------|
| (\$7F)           |     | - | AIN1D | AIN0D | DIDR1 |
| Read/Write R R R | R R | R | R/W   | R/W   |       |
| 初期値 0 0 0        | 0 0 | 0 | 0     | 0     |       |

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

これらのビットは予約されており、常に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ビット分解能
- 積分非直線性誤差1LSB
- 絶対精度±2LSB
- 14µsの変換時間
- 最大分解能で15kSPS(採取/s)
- 6チャネルのシングルエンド入力多重器内蔵
  - ・32リート、TQFP、32パット、QFN、32球UFBGAでの2つの追加入力
- 温度感知器入力チャネル
- A/D変換結果読み出しに対する任意の左揃え
- 0~VCC A/D変換入力電圧範囲
- 選択可能な1.1V A/D変換基準電圧
- 連続と単独の変換動作
- ・割り込み元の自動起動によるA/D変換開始
- A/D変換完了割り込み
- 休止形態雑音低減機能

#### 17.2. 概要

ATtiny48/88は10ビット逐次比較A/D変換器(ADC)が特徴です。ADCは6つ(または32リード/パット・/球の外囲器では8つ)のシングルエント、入力ピンと、内部温度感知器から来るシングルエント、電圧チャネルの1つの内部からの電圧測定をADCに許す9チャネルのアナログ多重器に配線されています。シングルエント、電圧入力は0V(GND)が基準です。

このA/D変換器はA/D変換器への入力電圧が変換中に一定の値で保持されることを保証する採取&保持(S/H)回路を含みます。 A/D変換部の構成図は**図17-1**.で示されます。

ADC用に独立したアナログ電圧供給ピン(AVCC)があります。VCCとAVCCの電圧供給ピン間の電圧差は0.3Vを越えてはいけません。アナログ電圧供給ピンの接続方法は111頁の「**雑音低減技術**」項をご覧ください。

公称1.1Vの内部基準電圧がチップ上で提供されます。代わりに基準電圧としてAVCCを使うことができます。







## 17.3. 操作

A/D変換部を使えるようにするため、ADC電力削減(PRADC)ビットが禁止されなければなりません。これは電力削減レジスタ(PRR)のPRADCビットを解除することによって行われます。より多くの詳細については24頁の「PRR - 電力削減レジスタ」をご覧ください。

A/D変換部は逐次比較を通してアナログ入力電圧を10ビットのデジタル値に変換します。最小値はGNDを表し、最大値は基準電圧を表します。A/D変換器基準電圧はA/D多重器選択レジスタ(ADMUX)の基準電圧選択(REFS0)ビット書き込みによって選択されます。選択はAVCC供給ピンと1.1V内部基準電圧です。

アナログ入力チャネルはA/D多重器選択(ADMUX)レジスタのチャネル選択(MUX3~0)ビットへの書き込みによって選択されます。GNDと固定基準電圧(1.1V内蔵基準電圧(VBG))だけでなく、どのADC入力ピン(ADC7~0)もA/D変換器のシングルエンド入力として選択できます。

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

A/D変換部はA/Dデータ レジスタ(ADCH,ADCL)で示される10ビットの結果を生成します。既定では、この結果は右揃え(16ビットのビットの側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. 変換の開始

電力削減レジスタ(PRR)のA/D変換電力削減(PRADC)ビットを解除(0)することによってADCが給電されることを保証してください(24頁の「PRR - 電力削減レジスタ」をご覧ください)。単独変換はADCSRAで変換開始(ADSC)ビットに論理1を書くことによって開始されます。このビットは変換が進行中である限り1に留まり、変換が完了される時にハートウェアによって解除(0)されます。変換が進行中に違う入力チャネルが選択されると、A/D変換部はそのチャネル変更を実行する前に現在の変換を済ませます。

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



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

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

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

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

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

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

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

通常の変換は13変換クロック周期で行われます。下の図17-4.で示されるように、A/D

変換部がONされる(ADCSRAのADEN=1)後の最初の変換はアナログ回路を初期化するために25変換クロック周期で行われます。





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





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



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



| 表17-1. A/D変換時間 |      |      |
|----------------|------|------|
| 変換種別           | 保持点  | 変換時間 |
| 初回変換           | 13.5 | 25   |
| シングルエント、入力通常変換 | 1.5  | 13   |
| 自動起動変換         | 2    | 13.5 |
| 連続変換           | 2.5  | 14   |

注: 変換時間を除く各値は変換開始からの変換クロック数です。

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

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

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

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

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

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

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

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

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

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

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

このA/D変換基準電圧(VREF)はA/D変換に対する変換範囲を示します。VREFを越えるシングルエンド入力チャネルは\$3FFで打ち切る符号に帰着します。VREFはVCC、1.1V内部基準電圧、外部AREFtプンのどれかとして選択できます。1.1V内部基準電圧は内部増幅器を通して内部パンドキャップ基準電圧(VBG)から生成されます。

基準電圧源切り替え後の最初のA/D変換結果は不正確かもしれず、使用者はこの結果を破棄することが推奨されます。

### 17.7. 雜音低減機能

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

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

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

# 17.8. アナログ入力回路

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

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

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



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

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

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

- ・アナログ信号経路を可能な限り最短にしてください。
- ・アナログ信号経路がアナログGND面上を走ることを確認してください。
- アナログ信号経路を高速切り替えデジタル信号線から充分離すことを守ってください。
- ・何れかのADCポートピンがデジタル出力として使われる場合、これらを変換進行中に決して切り替えてはなりません。
- ・アナログ電圧供給(AVCC)ピンは図17-9.で示されるようにLC濾波器を経由してデジタル供給電圧(VCC)に接続されるべきです。

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

(訳注)図17-9.は原図に対し修正され、ピン名は部分的に省略されています。







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

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

#### • オフセット誤差 - 図17-10.

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

#### • 利得誤差 - 図17-11.

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

#### • 積分非直線性誤差 (INL) - 図17-12.

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

#### • 微分非直線性誤差 (DNL) - 図17-13.

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

#### • 量子化誤差

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

#### • 絶対精度

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









# 17.11. A/D変換の結果

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

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

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

# 17.12. 温度測定

温度測定はシンケルエント、ADC8チャネルに連結されるチップ・上の温度感知器に基きます。A/D多重器選択(ADMUX)レジスタのチャネル選択 (MUX3~0)ビットへの'1000'書き込みによるADC8チャネル選択がこの温度感知器を許可します。温度感知器測定に対する推奨A/D変換器基準電圧源は1.1V内部基準電圧です。温度感知器が許可されると、A/D変換器は温度感知器上の電圧測定を単独変換動作 (ADATE=0)で使うことができます。

測定した電圧は表17-2.で記述されたように温度に対して直線的関係を持ちます。 感度は概ね $1LSB/\mathbb{C}$ で、精度は使用者校正に依存します。代表的には、室温校正 との仮定で、1点温度校正後の測定精度は $\pm 10\mathbb{C}$ です。より良い精度は校正に対し て2つの温度点を使うことで達せられます。

| 表17-2. 温度対感知器出力電圧(代表値)_ |                         |  |  |  |  |  |  |  |  |  |  |
|-------------------------|-------------------------|--|--|--|--|--|--|--|--|--|--|
| 温度(℃)                   |                         |  |  |  |  |  |  |  |  |  |  |
| A/D変換値(LSB)             | A/D変換値(LSB) 230 300 370 |  |  |  |  |  |  |  |  |  |  |
|                         |                         |  |  |  |  |  |  |  |  |  |  |

表17-2.に記載した値は代表値です。然しながら製法変化のため、温度感知器出力電圧は或るチップと別のチップで変化します。より正確な結果達成を可能とするために、温度測定は応用ソフトウェアで校正できます。校正ソフトウェアは次式を使って行なえます。

#### $T(温度)=k\times(ADCH<<8|ADCL)-TOS$

ここでADCH:ADCLはA/D変換器データレジスタ、kは固定傾斜係数、TOSは温度感知器オフセット値です。代表的に係数kは1.0に大変近く、1点校正ではこの係数を省略できるかもしれません。高精度が要求される場合、傾斜係数は2つ温度での測定を基に評価されるべきです。

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

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

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

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

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

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

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

| 表17-3. A/  | 表17-3. A/D変換部の基準電圧選択 |  |  |  |  |  |  |  |  |
|------------|----------------------|--|--|--|--|--|--|--|--|
| REFS0 基準電圧 |                      |  |  |  |  |  |  |  |  |
| 0          | 内部1.1V基準電圧           |  |  |  |  |  |  |  |  |
| 1          | AVCC其準電圧             |  |  |  |  |  |  |  |  |

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

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

#### ■ ビット3~0 - MUX3~0: A/Dチャネル選択 (Analog Channel Select Bits 3~0)

これらのビットの値はA/D変換器に接続されるアナログ入力を選びます。シングルエンド チャネル ADC8選択は温度測定を許可します。詳細については表17-4.をご覧ください。これらのビットが変換中に変更される場合、その変更はこの変換が完了する(ADCSRAのADIF=1)まで実施しません。

#### 表17-4. アナログ入力チャネル選択

| MUX3~0     | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110   | 0111   | 1000  | 1001~1101 | 1110                            | 1111 |
|------------|------|------|------|------|------|------|--------|--------|-------|-----------|---------------------------------|------|
| アナログ入力チャネル | ADC0 | ADC1 | ADC2 | ADC3 | ADC4 | ADC5 | (ADC6) | (ADC7) | ADC8  | (予約)      | 1.1V                            | 0V   |
| 備考         | PC0  | PC1  | PC2  | PC3  | PC4  | PC5  | PA0    | PA1    | 温度(1) |           | V <sub>B</sub> G <sup>(2)</sup> | GND  |

注1: 温度測定については112頁の「温度測定」をご覧ください。

注2: 内部基準電圧切り替え後、A/D変換器は測定が安定するのに先立って1msの安定時間が必要です。これに先立つ変換開始は信頼できないかもしれません。A/D変換器はこの安定時間中に許可されなければなりません。

(訳注) PDIPとQFN/MLF28外囲器は6チャネルのため、ADC6,7はありません。

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

| ヒ`ット       | 7    | 6    | 5     | 4    | 3    | 2     | 1     | 0     | _      |
|------------|------|------|-------|------|------|-------|-------|-------|--------|
| (\$7A)     | 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\sim0$ )ビット設定によって選択されます。





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

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

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

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

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

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

| 表17-5. 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     |        |
|------------|---|------|---|---|---|-------|-------|-------|--------|
| (\$7B)     | - | ACME | - | - | - | ADTS2 | ADTS1 | ADTS0 | ADCSRB |
| Read/Write | R | R/W  | R | R | R | R/W   | R/W   | R/W   |        |
| 初期値        | 0 | 0    | 0 | 0 | 0 | 0     | 0     | 0     |        |

#### ■ ビット7.5~3 - Res: 予約 (Reserved Bits)

これらのビットは将来の使用に対して予約されています。将来のデバイスとの共通性のため、ADCSRBが書かれるとき、これらのビットはのが書かれなければなりません。

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

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

表17-6. A/D変換自動起動元選択

| 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     | タイマ/カウンタ1比較B一致 |
| 1     | 1     | 0     | タイマ/カウンタ1溢れ    |
| 1     | 1     | 1     | タイマ/カウンタ1捕獲要求  |

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

|            | ADLAR=0 | 時    |      |      |      |      |      |      |      |
|------------|---------|------|------|------|------|------|------|------|------|
| ピット        | 15      | 14   | 13   | 12   | 11   | 10   | 9    | 8    |      |
| (\$79)     | _       | -    | -    | -    | -    | -    | 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    |      |
| (\$78)     | 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 |
|            |         |      |      |      |      |      |      |      |      |

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

これらのビットは112頁の「A/D変換の結果」で詳述されるように変換での結果を表します。A/D変換が完了すると、その結果がこれら2つのレジスタで得られます。

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

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

| ピット        | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |       |
|------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| (\$7E)     | ADC7D | ADC6D | ADC5D | ADC4D | ADC3D | ADC2D | ADC1D | ADC0D | DIDR0 |
| Read/Write | R/W   |       |
| 初期値        | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |       |

### ■ ビット7~0 - ADC7D~ADC0D: ADC7~0 デジタル入力禁止 (ADC7~0 Digital Input Disable)

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





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

### 18.1. 特徴

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

#### 18.2. 概要

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

### 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

  dW(RESET)

  GND
- ・dW/(RESET)線のプルアップ抵抗は10kΩよりも小さくてはなりません。この抵抗はデバックWIRE機能の必要条件ではありません。
- ・RESETピンのVCCへの直接的な接続では動作しません。
- ・RESETピンに挿入したコンデンサはデバッグWIRE使用時、切断されなければなりません。
- ・全ての外部リセット元は切断されなければなりません。

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

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

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

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

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

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

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

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

# 18.6. デバッグWIRE用レジスタ

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



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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

へージ書き込みを行うにはZポインタにアドレスを設定してSPMCSRに'00000101'を書いて、SPMCSR書き込み後4クロック周期内にSPM命令を実行してください。R1とR0のデータは無視されます。ページ アドレスは(Zポインタの)PCPAGEに書かれなければなりません。この操作の間、Zポインタの他のビットは0を書かれなければなりません。

ページ書き込み中、CPUは停止されます。

# 19.1. 自己プログラミング中のフラッシュ メモリのアトレス指定

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 |

フラッシュ メモリがヘーシ で構成されるため(124頁の「メモリ ハーラメータ」参照)、プログラム カウンタ(アト・レス ポーインタ)は2つの違う領域を持つように扱われます。1つの領域は下位側ビットから成り、ヘーシ 内の語(ワート・)をアト・レス指定し、一方上位側ビットはそのヘーシをアト・レス指定します。これは次頁の図19-1.で示されます。ヘーシ 消去とヘーシ 書き込み操作が個別にアト・レス指定されることに注意してください。従ってソフトウェアはヘーン 消去とヘーン 書き込み操作の両方で同じヘーン をアト・レス指定することが最も重要です。

LPM命令はアドレスを格納するのにZポインタを使います。この命令はフラッシュメモリのバイト単位をアドレス指定するので、Zポインタの最下位ビット(Z0)も使われます。







# 19.1.1. SPM命令での書き込み時のEEPROM書き込みによる妨害

EEPROM書き込み動作がフラッシュ メモリへの全ソフトウェア プログラミングを妨げることに注意してください。ソフトウェアからのヒューズと施錠ビット読み出しもEEPROM書き込み動作中に妨げられます。使用者はEEPROM制御レジスタ(EECR)のEEPROMプログラム許可(EEPE)ビットを検査し、SPM命令制御/状態レジスタ(SPMCSR)へ書く前にこのビットが解除(0)されているのを確認することが推奨されます。

### 19.1.2. ソフトウェアからのヒュース ビットと施錠ビットの読み出し

ソフトウェアからヒュース、と施錠ビットの両方を読むことが可能です。施錠ビットを読むにはZポインタに \$0001を設定し、SPMCSRのSELFPRGEN とヒュース、/施錠ビット読み込み(RFLB)ビットを設定(1)してください。SELFPRGENとRFLBビットがSPMCSRに設定された後3CPU周期内にLPM命令が実行されると、施錠ビットの値が転送先レジスタに格納されます。SELFPRGENとRFLBビットは施錠ビット読み出しの完了で、または3CPU周期内にLPM命令が実行されないか、または4CPU周期内にSPM命令が実行されない場合、自動的に解除(0)されます。SELFPRGENとRFLBビットが解除(0)されると、LPMは命令一式手引書で記述されるように動作します。

| ピット | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0   |
|-----|---|---|---|---|---|---|-----|-----|
| Rd  | _ | _ | _ | _ | _ | _ | LB2 | LB1 |

ヒュース、下位バイを読む手順は上記の施錠ビット読み出しと同様です。ヒュース、下位ビットを読み出すにはZポインタに \$0000を設定してSPM CSRのSELFPRGENとRFLBビットを設定(1)してください。SELFPRGENとRFLBビットがSPMCSRに設定された後3CPU周期内にLPM命令が実行されると、以下で示されるようにヒュース、下位バイト(FLB)の値が転送先レジスタに格納されます。ヒュース、下位バイトの配置と詳細な記述については122頁の表20-5.を参照してください。

| ピット | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|------|------|------|------|------|------|------|------|
| Rd  | FLB7 | FLB6 | FLB5 | FLB4 | FLB3 | FLB2 | FLB1 | FLB0 |

同様に、ヒュース・上位バイトを読むにはZポインタに\$0003を設定してください。SELFPRGENとRFLBビットがSPMCSRで設定(1)された後3周期内にLPM命令が実行されると、以下で示されるようにヒュース・上位バイト(FHB)の値が転送先レジスタに格納されます。ヒュース・上位バイトの配置と詳細な記述については122頁の表20-4.を参照してください。

| ピット | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|------|------|------|------|------|------|------|------|
| Rd  | FHB7 | FHB6 | FHB5 | FHB4 | FHB3 | FHB2 | FHB1 | FHB0 |

ヒュース、拡張ハ、イトはZポインタに \$0002を設定することによって読むことができます。SELFPRGENとRFLBビットがSPMCSRで設定(1)された後3周期内にLPM命令が実行されると、以下で示されるようにヒュース、拡張ハイト(FEB)の値が転送先レジスタに格納されます。ヒュース、拡張ハイトの配置と詳細な記述については122頁の表20-3.を参照してください。

| ピット | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|-----|---|---|---|---|---|---|---|------|
| Rd  | _ | _ | _ | _ | _ | _ | _ | EFB0 |

プログラム(0)されたヒュースと施錠ビットは0として読めます。非プログラム(1)にされたヒュースと施錠ビットは1として読めます。

### 19.1.3. フラッシュ メモリ データ化けの防止

低VCCの期間中、CPUとフラッシュメモリの正しい動作に対して供給電圧が低すぎるためにフラッシュメモリのプログラムが不正にされ得ます。これらの問題はフラッシュメモリを使う基板段階の装置と同じで、同じ設計上の解決策が適用されるべきです。

フラッシュ メモリのプログラム化けは電圧が低すぎる時の2つの状態によって起こされます。1つ目として、フラッシュ メモリへの通常の書き込み手順は正しく動作するための最低電圧が必要です。2つ目として、供給電圧が低すぎると、CPU自身が命令を誤って実行し得ます。 フラッシュ メモリ化けは次の推奨設計によって容易に避けられます(1つは必須)。

- ・不十分な供給電源電圧の期間中、AVR RESETを活性(Low)に保ってください。これは動作電圧が検出電圧と一致するなら、内部 低電圧検出器(BOD)を許可することによって行えます。そうでなければ外部低VCCリセット保護回路が使えます。書き込み操作進 行中にリセットが起こると、その書き込み動作は供給電源電圧が充分であれば完了されます。
- ・低VCCの期間中、AVRコアをパワーダウン休止動作に保ってください。これはCPUが命令の復号と実行を試みるのを防ぎ、SPMCSR 従ってフラッシュ メモリを予期せぬ書き込みから効果的に保護します。

# 19.1.4. SPM命令使用時のフラッシュ メモリ用プログラミング(書き込み)時間

校正された内蔵発振器がフラッシュ メモリ アクセス時間に使われます。表19-1.はCPUからのフラッシュ メモリ アクセスに対する代表的なプログラミング時間を示します。

| 主10_1     | 1수숙MQ2 | トスフラッシュ  | メモリのプログラミング時間        |
|-----------|--------|----------|----------------------|
| 75 I 9- I |        | トの ノフツソコ | メナリひょ ノ ロソ フミノソ ロチロー |

| 項目                                         | 最小    | 最大    |
|--------------------------------------------|-------|-------|
| SPM命令によるフラッシュ書き込み(ページ消去、ページ書き込み、施錠ビット書き込み) | 3.7ms | 4.5ms |

注: 最小と最大の時間は(項目の)個別操作毎に対してです。





# 19.2. 自己プログラミング 用レジ スタ

### 19.2.1. SPMCSR - SPM命令制御/状態レジスタ (Store Program Memory Control and Status Register)

このレジスタはプログラムメモリ操作を制御するために必要とする制御ビットを含みます。

| ピット         | 7 | 6     | 5 | 4    | 3    | 2     | 1     | 0         |        |
|-------------|---|-------|---|------|------|-------|-------|-----------|--------|
| \$37 (\$57) | _ | RWWSB | - | CTPB | RFLB | PGWRT | PGERS | SELFPRGEN | SPMCSR |
| Read/Write  | R | R     | R | R/W  | R/W  | R/W   | R/W   | R/W       |        |
| 初期値         | 0 | 0     | 0 | 0    | 0    | 0     | 0     | 0         |        |

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

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

#### ■ ビット6 - RWWSB: RWW領域多忙 (Read-While-Write Section Busy)

このビットは書き中読み可(Read-While-Write)を支援するデバイスとの互換用です。ATtiny48/88では常に0として読みます。

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

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

#### ■ ビット4 - CTPB : ペ-ジ一時緩衝部消去 (Clear Temporary Page Buffer)

へーシー時緩衝部を満たしている間にCTPBビットが1を書かれると、ヘーシー時緩衝部は消去され、データが失われます。

#### ■ ビット3 - RFLB: ヒューズ/施錠ビット読み込み (Read Fuse and Lock Bits)

SPMCSRでRFLBとSELFPRGENが設定(1)された後の3クロック周期内のLPM命令は(ZポインタのZ0によって)ヒュース゛ビットまたは施錠ビットのどちらかを転送先レジスタに読みます。詳細については118頁の「ソフトウェアからのヒュース゛ビットと施錠ビットの読み出し」をご覧ください。

#### ■ ビット2 - PGWRT : ページ書き込み (Page Write)

このビットがSELFPRGENと同時に1を書かれると、次の4クロック周期内のSPM命令は一時緩衝部に格納したデータでページ書き込みを実行します。ページアドレスはZポインタの上位部から取得されます。R1とR0のデータは無視されます。PGWRTビットはページ書き込みの完了で、または4クロック周期内にSPM命令が実行されない場合、自動的に解除(0)されます。ペーシ´全体の書き込み動作中、CPUは停止されます。

# ■ ビット1 - PGERS : ページ消去 (Page Erase)

このビットがSELFPRGENと同時に1を書かれると、次の4クロック周期内のSPM命令はページ消去を実行します。 ページアドレスはZポインタの上位部から取得されます。R1とR0のデータは無視されます。PGERSビットはページ消去の完了で、または4クロック周期内にSPM命令が実行されない場合、自動的に解除(0)されます。 ページ全体の消去中、CPUは停止されます。

### ■ ビット0 - SELFPRGEN: 自己プログラミング許可 (Self Programming Enable)

このビットは次の4クロック周期間SPM命令を許可します。このビットがCTPB,RFLB,PGWRT,PGERSのどれかと共に1を書かれると、続くSPM命令は特別な意味を持ちます(上の記述をご覧ください)。SELFPRGENだけが書かれると、続くSPM命令はZポインタでアドレス指定したページ一時緩衝部へR1:R0の値を格納します。Zレジスタの最下位ビットは無視されます。SELFPRGENビットはSPM命令の完了で、または4クロック周期内にSPM命令が実行されないと自動的に解除(0)されます。ページ消去とページ書き込み中、SELFPRGENビットはその動作が完了されるまで1に留まります。

下位5ビットに10001, 01001, 00101, 00011, 00001以外のどんな組み合わせを書いても無効です。

(訳注) ビット0の名称SELFPRGENはヒューズ ビットに同一名が存在します。状況によっては不都合かもしれません。この名称重複が存在 する他のデバイスと異なり、AVR Studio 4.16でのデバイス定義インクルード ファイルではヒューズ ビットのSELFPRGEN定義が注釈になっています。故にこの名称を使う場合は充分な注意と確認が必要です。

# 20. 施錠ビット、ヒューズビット、デバイス識票

# 20.1. 施錠ビット

ATtiny48/88は表20-1.で一覧にされるプログラムとデータのメモリ施錠ビットを提供します。

表20-1. 施錠ビット バ 仆の内容

| 名称  | ビット番号 | 意味                                           | 既定値(注)     |
|-----|-------|----------------------------------------------|------------|
| _   | 7     |                                              | 1(非プログラム)  |
| _   | 6     |                                              | 1 (非プログラム) |
| _   | 5     |                                              | 1 (非プログラム) |
| _   | 4     |                                              | 1 (非プログラム) |
| _   | 3     |                                              | 1 (非プログラム) |
| _   | 2     |                                              | 1 (非プログラム) |
| LB2 | 1     | フラッシュとEEPROMメモリに対する一般保護用施錠ビット                | 1 (非プログラム) |
| LB1 | 0     | ノノツンユCDDFROIVI/TTY(CX) y の   加文 木護用地鉄ビッド<br> | 1 (非プログラム) |

注: 0はプログラム、1は非プログラムを意味します。

施錠ビットは非プログラム(1)のままか、または表20-2.で一覧される付加機能を得るためにプログラム(0)にすることができます。

表20-2. 施錠ビットの保護種別

|       | メモリ施錠ビット | •   | 保護種別                                                                              |
|-------|----------|-----|-----------------------------------------------------------------------------------|
| LB 種別 | LB2      | LB1 | 直列、並列、またはデバッグWIRE経由プログラミングに対する保護                                                  |
| 1     | 1        | 1   | メモリ施錠機能は機能しません。                                                                   |
| 2     | 1        | 0   | フラッシュ、EEPROMの更なるプログラミング(書き込み)が禁止されます。 ヒューズ ビットが固定されます。 ( <mark>注1</mark> )        |
| 3     | 0        | 0   | フラッシュ、EEPROMの更なるプログラミング(書き込み)と照合(読み出し)が禁止されます。ヒュース・ヒットが固定されます。( <mark>注1</mark> ) |

注1: 施錠ビットを書く前にヒューズビットを書いてください。

注2: 0はプログラム、1は非プログラムを意味します。

施錠ビットはチップ消去指令でのみ1に消去することができます。

ATtiny48/88は独立したブートローゲ領域を持ちません。SELFPRGENヒューズがプログラム(0)されると、SPM命令はフラッシュ メモリ全体に対して許可され、さもなければ禁止されます。





# 20.2. ヒュース゛ヒ゛ット

ATtiny48/88には3つのヒュース゛バイトがあります。**表20-3**.~5.は全てのヒュース゛の概略機能とヒュース゛バイト内でどのように配置されるかを示します。ヒュース゛はプログラムされると、論理0として読まれることに注意してください。

#### 表20-3. ヒュース 拡張バイト一覧

| 名称        | ピット          | 意味                  | 既定値                     |
|-----------|--------------|---------------------|-------------------------|
| _         | 7 <b>~</b> 1 |                     | 1 (非プログラム)              |
| SELFPRGEN | 0            | 自己プログラミング機能許可。 (注1) | 1 (非プログラム) 自己プログラミング不許可 |

注1: SPM命令許可。117頁の「フラッシュの自己プログラミング」をご覧ください。

#### 表20-4. ヒューズ上位バイト一覧

| 名称        | ピット | 意味                                | 既定値                        |
|-----------|-----|-----------------------------------|----------------------------|
| RSTDISBL  | 7   | PC6がI/OピンかまたはRESETピンかを選択します。(注1,2 | ) 1 (非プログラム) PC6はRESETピン   |
| DWEN      | 6   | デバックWIRE機能許可。 (注2                 | ) 1 (非プログラム) ディブック WIRE不許可 |
| SPIEN     | 5   | 直列プログラミング許可。(注3                   | ) 0 (プログラム) 直列プログラミング許可    |
| WDTON     | 4   | ウォッチドッグタイマ常時有効。 (注4               | ) 1 (非プログラム) WDTはWDTCSRで許可 |
| EESAVE    | 3   | チップ消去からEEPROM内容を保護。               | 1 (非プログラム) EEPROMは未保護      |
| BODLEVEL2 | 2   |                                   | 1 (非プログラム)                 |
| BODLEVEL1 | 1   | 低電圧検出(BOD)リセットの制御と検出電圧選択。 (注:     | ) 1 (非プログラム)               |
| BODLEVEL0 | 0   |                                   | 1 (非プログラム)                 |

注1: RSTDISBLヒューズの記述については45頁の「ポートCの交換機能」をご覧ください。

**注2**: このヒュース、ビットのプログラム(0)はRESETピンの機能を変更し、直列インターフェース経由での更なるプログラミングを不可能にします。 ヒュース、ビットは並列プログラミング法を使って非プログラム(1)にできます。

注3: SPIENヒュース は直列プログラミングでアクセスできません。

注4: 詳細については30頁の「WDTCSR - ウォッチト、ック、タイマ制御レジスタ」をご覧ください。

注5: BODLEVELtュース、の符号化については137頁の表22-4.をご覧ください。

### 表20-5. ヒューズ下位バイト一覧

| 名称     | ピット | 意味                                   | 既定值                                                |
|--------|-----|--------------------------------------|----------------------------------------------------|
| CKDIV8 | 7   | システム クロック 8分周選択。 ( <mark>注4</mark> ) | 0 (プログラム) 8分周                                      |
| CKOUT  | 6   | システム クロック出力許可。 (注3)                  | 1 (非プログラム) 不許可                                     |
| SUT1   | 5   | 起動時間選択。 (注1)                         | 1 (非プログラム)                                         |
| SUT0   | 4   | <b>应</b> 期时间进 <u>价。</u> (注1)         | <mark>0</mark> (プ <sup>°</sup> ロク <sup>*</sup> ラム) |
| -      | 3   |                                      | 1 (非プログラム)                                         |
| -      | 2   |                                      | 1 (非プログラム)                                         |
| CKSEL1 | 1   | クロック種別選択。 (注2)                       | 1 (非プログラム)                                         |
| CKSEL0 | 0   | プログノ1里が1月251八。<br>                   | <mark>0</mark> (プ <sup>°</sup> ロク <sup>*</sup> ラム) |

注1: SUT1,0の既定値は最大起動時間になります。詳細については18頁の表6-3.をご覧ください。

注2: CKSEL1,0の既定設定は8MHz校正付き内蔵発振器になります。詳細については17頁の表6-1.をご覧ください。

注3: CKOUTはポートBOに出力するのをシステム クロックに許します。詳細については19頁の「クロック出力緩衝部」をご覧ください。

**注4**: 詳細については19頁の「システム クロック前置分周器」をご覧ください。

ヒューズ ビットの状態はチップ消去によって影響されません。施錠ビット1(LB1)がプログラム(<mark>0</mark>)されると、ヒューズ ビットが固定されることに注意してください。施錠ビットをプログラム(<mark>0</mark>)する前にヒューズ ビットをプログラミング(書き込み)してください。

#### **20.2.1**. ヒュース のラッチ

ヒュース<sup>\*</sup>値はデ、バイスがプログラミング動作へ移行する時にラッチされ、ヒュース<sup>\*</sup>値の変更はデ、バイスがプログラミング動作を去るまで無効です。これは一旦プログラム(0)されると直ぐに効果があるEESAVEヒュース<sup>\*</sup>には適用されません。ヒュース<sup>\*</sup>は通常動作での電源投入でもラッチされます。

# 20.3. 識票バイ

全てのAtmel マイクロコントローラはデバイスを識別する3バイトの識票符号を持ちます。この符号は直列と並列の両プログラミング動作で、またデバイスが施錠されても読めます。この3バイトは分離された空間に存在します。ATtiny48/88用の識票バイトは表20-6.で与えられます。

| 表20-6. デバイスの識別番号(ID) |            |        |        |  |  |
|----------------------|------------|--------|--------|--|--|
| 部品番号                 | 識票バイト アドレス |        |        |  |  |
| 中四田石                 | \$0000     | \$0001 | \$0002 |  |  |
| ATtiny48             | \$1E       | \$92   | \$09   |  |  |
| ATtinv88             | \$1E       | \$93   | \$11   |  |  |

# 20.4. 校正バイ

ATtiny48/88は内蔵発振器用に1バイトの校正値を持ちます。このバイトは識票アドレス空間でアドレス\$0000の上位バイトにあります。リセット中、校正付き内蔵発振器の正しい周波数を保証するために、このバイトが発振校正(OSCCAL)レジスタへ自動的に書かれます。





# 21. 外部プログラミング

本章はATtiny48/88のフラッシュメモリ、EEPROM、施錠ビット、ヒューズ、ビットのプログラミングと照合の方法を記述します。

# 21.1. メモリ ハ<sup>°</sup>ラメータ

フラッシュ メモリのハプラメータは下の表21-1.で要約されます。

表21-1. フラッシュ メモリのヘージ 数とヘージの語数

| <b>デバイ</b> ス | 全容量        | ページ容量 | PCWORD | ページ数 | PCPAGE | PCMSB |
|--------------|------------|-------|--------|------|--------|-------|
| ATtiny48     | 2K語(4Kバイト) | 32語   | PC4∼0  | 64   | PC10∼5 | 10    |
| ATtiny88     | 4K語(8Kバイト) | 32語   | PC4~0  | 128  | PC11~5 | 11    |

EEPROMのパラメータは下の表21-2.で要約されます。

表21-2. EEPROMメモリのページ数とページの語数

| <b>デバイス</b> | 全容量   | ページ容量 | PCWORD | ページ数 | PCPAGE | EEAMSB |
|-------------|-------|-------|--------|------|--------|--------|
| ATtiny48    | 64バイト | 4バイト  | EEA1∼0 | 16   | EEA5∼2 | 5      |
| ATtiny88    | 64バイト | 4バイト  | EEA1∼0 | 16   | EEA5∼2 | 5      |

# 21.2. 並列プログラミング

並列プログラミング信号と接続は右の図21-1.で図解されます。



信号は下の表21-3.で記述されます。下表で示されないピンはピン名によって参照されます。

表21-3. 信号名とピン名の関係

| 信号名     | ピン名         | 入出力 | 機能                                                       |
|---------|-------------|-----|----------------------------------------------------------|
| RDY/BSY | PD1         | 出力  | <b>0</b> (Low): 多忙(プログラミング中) <b>1</b> (High): 準備可(指令受付可) |
| ŌĒ      | PD2         | 入力  | 出力許可(負論理)                                                |
| WR      | PD3         | 入力  | 書き込みパルス(負論理)                                             |
| BS1     | PD4         | 入力  | 上位/下位バイ選択1 (0:下位, 1:上位) (一般用)                            |
| XA0     | PD5         | 入力  | CLKI動作ビット0                                               |
| XA1     | PD6         | 入力  | CLKI動作ビット1                                               |
| PAGEL   | PD7         | 入力  | プログラム メモリとEEPROMデータをヘーシー 時緩衝部に設定                         |
| BS2     | PC2         | 入力  | 上位/下位バイト選択2 (0:下位, 1:上位) (ヒュース゛ビット用)                     |
| DATA    | PC1,0:PB5∼0 | 入出力 | 双方向データ バス (OE=Low時出力)                                    |

**注**: VCC-0.3V<AVCC<VCC+0.3Vですが、AVCCは常に4.5~5.5V内にすべきです。 特記事項を除いて、パルス幅は最低250nsと仮定されます。

表21-4. プログラミング動作移行時のピン値

| ピン名   | シンホ゛ル          | 値 |
|-------|----------------|---|
| PAGEL | Prog_enable[3] | 0 |
| XA1   | Prog_enable[2] | 0 |
| XA0   | Prog_enable[1] | 0 |
| BS1   | Prog_enable[0] | 0 |

XA0とXA1ピンはCLKIピンが正パルスを与えられる時に実行される動作を決めます。このビット符号化は表21-5.で示されます。

| 表21-5      | XA0とXA1の符号化(機 | 台)           |
|------------|---------------|--------------|
| 70 / I -:) |               | <b>B</b> F / |

| XA1 | XA0 | CLKIパルス時の動作                         |
|-----|-----|-------------------------------------|
| 0   | 0   | フラッシュまたはEEPROMのアトレス設定(上位/下位はBS1で指定) |
| 0   | 1   | テータ設定 (フラッシュの上位/下位はBS1で指定)          |
| 1   | 0   | 指令設定                                |
| 1   | 1   | アイドル (動作なし)                         |

WRまたはOEパルスを送るとき、設定した指令が実行される動作を決めます。各種指令は表21-6.で示されます。

#### 表21-6. 指令バイのビット符号化

|   | 指令バイト            | 指令の機能         | 指令バイト            | 指令の機能             |
|---|------------------|---------------|------------------|-------------------|
|   | \$80 (1000 0000) | チップ消去         | \$08 (0000 1000) | 識票バイト、校正バイト読み出し   |
|   | \$40 (0100 0000) | ヒューズビット書き込み   | \$04 (0000 0100) | ヒューズビット、施錠ビット読み出し |
| I | \$20 (0010 0000) | 施錠ビット書き込み     | \$02 (0000 0010) | フラッシュ メモリ読み出し     |
|   | \$10 (0001 0000) | フラッシュ メモリ書き込み | \$03 (0000 0011) | EEPROM読み出し        |
|   | \$11 (0001 0001) | EEPROM書き込み    |                  |                   |

#### 21.2.1. 並列プログラミング動作への移行

次に示す方法がデバイスを(高電圧)並列プログラミング動作にします。

- ① VCCをOV、RESET ピンをOV、124頁の表21-4.で一覧されるProg\_enableピンを全てLow(0)に設定します。
- ② VCCとGND間に4.5~5.5Vを印加します。それから20µs以内にVCCが最低1.8Vに達することを保証してください。
- ③ 20~60µs待ち、RESETに11.5~12.5Vを印加します。
- ④ Prog\_enable識別のラッチを確実にするため、高電圧が印加されてしまった後、最低10µs、Prog\_enableピンを無変化に保ちます。
- 5 如何なる並列プログラミング指令を与えるのにも先立って少なくとも300us間待ちます。
- ⑥ デバイスの電源を落とすか、RESETピンを0Vに持ってくることによってプログラミング動作を抜けます。

VCCの上昇時間が上で示した必要条件を完全に満たせない場合、次の代替手順が使えます。

- ① VCCを0V、RESET ピンを0V、124頁の表21-4.で一覧されるProg\_enablet゚ンを全てLow(0)に設定します。
- ② VCCとGND間に4.5~5.5Vを印加します。
- ③ VCCを監視し、0.9~1.1Vに達したら直ぐ、REESTに11.5~12.5Vを印加します。
- 4 Prog\_enable識別のラッチを確実にするため、高電圧が印加されてしまった後、最低10µs、Prog\_enableピンを無変化に保ちます。
- ⑤ 如何なる並列プログラミング指令を与えるのにも先立ってVCCが実際に4.5~5.5Vに達するまで待ちます。
- ⑥ デバイスの電源を落とすか、RESETピンを0Vに持ってくることによってプログラミング動作を抜けます。

# 21.2.2. 効率的なプログラミングへの考慮

設定した指令とアドレスはプログラミング中、維持されます。効率的なプログラミングを行うために次を考慮すべきです。

- ・複数のメモリ領域を読み書きする時に指令設定は一度だけ必要です。
- ・チップ消去後のフラッシュ メモリと(EESAVEヒューズがプロケラム(0)されている場合を除き)EEPROM全体の内容は\$FFなので、値が\$FFの データ書き込みを飛ばします。
- ・アドレス上位バイトはフラッシュメモリで新規256語(ワード)枠、EEPROMで新規256バイト枠の読み書き前に一度だけ必要です。この考慮は識票バイト読み出しにも適用されます。

### 21.2.3. チップ消去

チップ消去はフラッシュ メモリやEEPROMが再書き込みされる前に実行されなければなりません。チップ消去はフラッシュ メモリ、EEPROM、施錠ビットの全てを消去します。EESAVEヒューズがプログラム(0)されている場合、EEPROMは消去されません。

施錠ビットはプログラム メモリが完全に消去されてしまうまでリセット(消去)されません。ヒューズビットは変更されません。

「チップ消去」指令は以下のように設定されます。

- ① XA1をHigh(1)、XA0をLow(0)に設定します。これは指令設定を許可します。
- ② BS1をLow(0)に設定します。
- ③ DATAを\$80(1000 0000)に設定します。これはチップ消去指令です。
- ④ CLKIに正パルスを与えます。これはチップ消去指令を設定します。
- ⑤ WRに負パルスを与えます。これはチップ消去を開始します。RDY/BSYがLow(0)になります。
- ⑥ 次の指令を設定する前にRDY/BSYがHigh(1)になるまで待ちます。





# 21.2.4. フラッシュ メモリ書き込み (次頁の図21-3.タイミングを参照)

フラッシュ メモリはヘージで構成されます(124頁の表21-1.参照)。フラッシュ メモリへ書く時にプログラム データはヘージ 緩衝部にラッチされます。これは同時に書かれることをプログラム データの1ヘージに許します。 次の手順は完全なフラッシュ メモリの書き込み方法を記述します。

#### A. 「フラッシュ メモリ書き込み」指令設定

- ① XA1をHigh(1)、XA0をLow(0)に設定します。これは指令設定を許可します。
- ② BS1をLow(0)に設定します。
- ③ DATAを\$10(0001 0000)に設定します。これはフラッシュ メモリ書き込み指令です。
- ④ CLKIに正パルスを与えます。これはフラッシュ メモリ書き込み指令を設定します。

#### B. アドレス下位バイト設定

- ① XA1をLow(0)、XA0をLow(0)に設定します。これはアドレス設定を許可します。
- ② BS1をLow(0)に設定します。これは下位アドレス(バイト)を選択します。
- ③ DATAにアドレス下位ハイハ(\$00~\$FF)を設定します。
- ④ CLKIに正パルスを与えます。これはアドレス下位バイを設定します。

#### C. データ下位バイト設定

- (1) XA1をLow(0)、XA0をHigh(1)に設定します。これはデータ設定を許可します。
- ② DATAにデータ下位バイト(\$00~\$FF)を設定します。
- ③ CLKIに正パルスを与えます。これはデータ下位バイを設定します。

#### D. データ上位バイ設定

- ① BS1をHigh(1)に設定します。これは上位バイを選択します。
- ② XA1をLow(0)、XA0をHigh(1)に設定します。これはデータ設定を許可します。
- ③ DATAにデータ上位ハーイト(\$00~\$FF)を設定します。
- ④ CLKIに正パルスを与えます。これはデータ上位バイを設定します。

### E. 語(ワート)データをヘーン一時緩衝部に設定

- ① BS1をHigh(1)にします。これは上位ハイトを選択します。
- ② PAGELに正パルスを与えます。これは語データをページー時緩衝部にラッチ(設定)します。
- F. 緩衝部全体が満たされるか、または(必要な)全てのデータが緩衝部内に設定されるまで、B~Eを繰り返し

アト・レス内の下位ビットがページ内の語(ワード)位置を指示する一方、上位ビットがフラッシュ メモリ内のページをアドレス指定します。これは図21-2.で図示されます。 ページ内の語アドレスに8ビット未満が必要とされる場合(ページ容量<256)、アドレス下位バイトの最上位(側)ビットがページ書き込み実行時のページアドレスに使われることに注意してください。

#### G. アトレス上位バイ設定

- ① XA1をLow(0)、XA0をLow(0)に設定します。これはアドレス設定を許可します。
- ② BS1をHigh(1)に設定します。これは上位アドレス(バイト)を選択します。
- ③ DATAにアドレス上位ハイト(\$00~\$07/\$0F)を設定します。
- ④ CLKIに正パルスを与えます。これはアドレス上位バイトを設定します。

# H. ページ書き込み

- ① BS1をLow(0)に設定します。
- ② WRに負パルスを与えます。これはデータのページ全体の書き込みを開始します。RDY/BSYがLow(0)になります。
- ③ RDY/BSYがHigh(1)になるまで待ちます。
- I. フラッシュ メモリ全部が書かれるか、または(必要な)全データが書かれてしまうまで、B~Hを繰り返し
- J. ページ書き込み終了
  - ① XA1をHigh(1)、XA0をLow(0)に設定します。これは指令設定を許可します。
  - ② DATAを\$00(0000 0000)にします。これは無操作指令です。
  - ③ CLKIに正パルスを与えます。これは無操作指令を設定し、内部書き込み信号がリセットされます。

フラッシュ ペーシ のアト レス指定は下の**図21-2**.で図解されます。使われるシンボルは124頁の**表21-1**.で記述されます。



フラッシュ プログラミング 波形は**図21-3**.で図解され、そこでのxxは"無関係"を意味し、文字は先に記述されたプログラミング 段階を参照します。







### 21.2.5. EEPROM書き込み

EEPROMはヘーシで構成されます(124頁の表21-2.参照)。EEPROMを書く時にデータはヘーシ、緩衝部にラッチされます。これは同時に書かれることをデータの1ヘーシに許します。データ用EEPROMメモリの書き込み方法は次のとおりです。(指令、アトレス、データ設定の詳細については126頁の「フラッシュ メモリの書き込み」を参照。図21-4.タイミング参照。)

- 1. EEPROM書き込み指令\$11(0001 0001)を設定します。(「フラッシュ メモリ書き込み」のAを参照)
- 2. アドレス上位ハイト(\$00)を設定します。(「フラッシュ メモリ書き込み」のGを参照)
- 3. アドレス下位バイ(\$00~\$3F)を設定します。(「フラッシュ メモリ書き込み」のBを参照)
- 4. データ バイト(\$00~\$FF)を設定します。(「フラッシュ メモリ書き込み」のCを参照)
- 5. データをラッチします(PAGELに正パルスを与えます)。(「フラッシュ メモリ書き込み」のEを参照)
- K. 緩衝部全体が満たされるまで3~5を繰り返します。
- L. EEPROMページ書き込み
  - ① BS1をLow(0)に設定します。
  - ② WRに負パルスを与えます。これはEEPROMページ書き込みを開始します。RDY/BSYがLow(0)になります。
  - ③ 次のヘージを書く前に、RDY/BSYがHigh(1)になるまで待ちます。

EEPROMプログラミング波形は図21-4.で図解され、そこでのxxは″無関係″を意味し、文字は先に記述されたプログラミング段階を参照します。



### 21.2.6. フラッシュ メモリ読み出し

フラッシュ メモリの読み出し方法は次のとおりです。(指令とアドレス設定の詳細については126頁の「**フラッシュ メモリの書き込み**」を参照)

- 1. フラッシュ メモリ読み出し指令\$02(0000 0010)を設定します。(「フラッシュ メモリ書き込み」のAを参照)
- 2. アドレス上位バイト(\$00~\$07/\$0F)を設定します。(「フラッシュ メモリ書き込み」のGを参照)
- 3. アドレス下位バイト(\$00~\$FF)を設定します。(「**フラッシュ メモリ書き込み**」の**B**を参照)
- 4. BS1をLow(0)、OEをLow(0)に設定します。フラッシュ メモリ語(ワート)の下位バイが直ぐにDATAで読めます。
- 5. BS1をHigh(1)に設定します。フラッシュ メモリ語(ワート)の上位バイが直ぐにDATAで読めます。
- 6. OEをHigh(1)に設定します。DATAはHi-Zになります。

### 21.2.7. EEPROM読み出し

データ用EEPROMの読み出し方法は次のとおりです。(指令とアドレス設定の詳細については126頁の「フラッシュ メモリの書き込み」を参照)

- 1. EEPROM読み出し指令\$03(0000 0011)を設定します。(「フラッシュ メモリ書き込み」のAを参照)
- 2. アドレス上位ハイト(\$00)を設定します。(「フラッシュ メモリ書き込み」のGを参照)
- 3. アドレス下位バイト(\$00~\$3F)を設定します。(「**フラッシュ メモリ書き込み**」のBを参照)
- **4.** BS1をLow(0)、OEをLow(0)に設定します。EEPROMのバイトデータが直ぐにDATAで読めます。
- 5. OEをHigh(1)に設定します。DATAはHi-Zになります。

#### **21.2.8. ヒュース ビット書き込み (訳注:**原書での拡張/上位/下位ヒュース 項を1つに纏めました。)

各ヒューズバイトの書き込み方法は次のとおりです。(指令とデータ設定の詳細については126頁の「フラッシュ メモリの書き込み」を参照)

- 1. ヒューズ ビット書き込み指令\$40(0100 0000)を設定します。(「**フラッシュ メモリ書き込み**」の**A**を参照)
- 2. データ下位バイトを設定します。0=プログラム,1=非プログラム(消去)です。(「フラッシュ メモリ書き込み」のCを参照)
- 3. BS1とBS2を右表の目的バイトに対応する設定にします。
- 4. WRに負パルスを与え、RDY/BSYがHighになるまで待ちます。
- 5. 3.でHighに設定したBS1、BS2をLow(0)に戻します。これはデータ下位バイを選択します。

| 表A. ヒューズ バイト | 表A. ヒューズバ仆対応BS1,BS2設定 |         |  |  |  |
|--------------|-----------------------|---------|--|--|--|
| ヒュース゛ハ゛イト    | BS1                   | BS2     |  |  |  |
| 拡張バイト        | Low(0)                | High(1) |  |  |  |
| 上位バイト        | High(1)               | Low(0)  |  |  |  |
| 下位バイト        | Low(0)                | Low(0)  |  |  |  |

ヒュース、のプログラミング波形は図21-5.で図解され、そこでのxxは、無関係、を意味し、文字は先に記述されたプログラミング、段階を参照します。





### 21.2.9. 施錠ビット書き込み

施錠ビットの書き込み方法は次のとおりです。(指令とデータ設定の詳細については126頁の「フラッシュ メモリの書き込み」を参照)

- 1. 施錠ビット書き込み指令\$20(0010 0000)を設定します。(「フラッシュ メモリの書き込み」のAを参照)
- 2. データ下位ハイト(としてデータ)を設定します。 0=プログラム,1=無変化です。 LB保護種別3が設定(LB1とLB2がプログラム(0))されると、どの外部的なプログラミング動作種別によっても施錠ビットはプログラミングできません。 (「フラッシュ メモリの書き込み」の Cを参照)
- 3. WRに負パルスを与え、RDY/BSYがHighになるまで待ちます。

施錠ビットはチップ消去の実行によってのみ解除(1)できます。

#### 21.2.10. ヒューズ ビットと施錠ビットの読み出し

ヒュース、ビットと施錠ビットの読み出し方法は次のとおりです。(指令設定の詳細については126頁の「フラッシュ メモリの書き込み」を参照)

- 1. ヒュース ビットと施錠ビットの読み出し指令\$04(0000 0100)を設定します。(「フラッシュ メモリの書き込み」のAを参照)
- 2. BS1とBS2をLow(0)、OEをLow(0)に設定します。ヒュース・下位ビットの状態が直ぐにDATAで読めます。(0=プログラム)
- 3. BS1とBS2をHigh(1)、OEをLow(0)に設定します。ヒュース、上位ビットの状態が直ぐにDATAで読めます。(0=プログラム)
- 4. BS1をLow(0)、BS2をHigh(1)、OEをLow(0)に設定します。拡張ヒュース、ビットの状態が直ぐにDATAで読めます。(0=プログラム)
- 5. BS1をhigh(1)、BS2をLow(0)、OEをLow(0)に設定します。施錠ビットの状態が直ぐにDATAで読めます。(0=プログラム)
- 6. OEをHigh(1)に設定します。DATAはHi-Zになります。

ヒューズと施錠ビットの割り当ては下の図21-6.で図解されます。



### 21.2.11. 識票バ 小読み出し

識票バイトの読み出し方法は次のとおりです。(指令とアドレス設定の詳細については126頁の「**フラッシュ メモリの書き込み**」を参照)

- 1. 識票バイト読み出し指令\$08(0000 1000)を設定します。(「フラッシュ メモリの書き込み」のAを参照)
- 2. アトレス下位バイト(\$00~\$02)を設定します。(「フラッシュ メモリの書き込み」のBを参照)
- 3. BS1をLow(0)、○EをLow(0)に設定します。選択した識票バイが直ぐにDATAで読めます。
- 4. OEをHigh(1)に設定します。DATAはHi-Zになります。

# 21.2.12. 校正バ 小読み出し

校正バイの読み出し方法は次のとおりです。(指令とアドレス設定の詳細については126頁の「フラッシュ メモリの書き込み」を参照)

- 1. 校正バイト読み出し指令\$08(0000 1000)を設定します。(「フラッシュ メモリの書き込み」のAを参照)
- 2. アドンス下位バイトに\$00を設定します。(「フラッシュ メモリの書き込み」のBを参照)
- 3. BS1をHigh(1)、OEをLow(0)に設定します。校正バイが直ぐにDATAで読めます。
- 4. OEをHigh(1)に設定します。DATAはHi-Zになります。

# 21.3. 直列プログラミング

フラッシュ メモリとEEPROMの両方はRESETがGNDに引かれている間に直列SPIハ、スを使ってプログラミングできます。この直列インターフェースはSCK入力、MOSI入力、MISO出力から成ります。RESETがLowに設定された後、書き込み/消去操作が実行され得るのに先立ってプログラミング許可命令が初めに実行されることを必要とします。

直列プログラミング信号と接続は右の図21-7.で図解されます。ピン割り当ては表21-7.で図解されます。

EEPROMをプログラミングする時に自動消去期間が自動書き込み動作内に組み入れられるので(直列プログラミングのみ)、チップ消去命令を初めに実行する必要がありません。

チップ消去操作はプログラム(フラッシュ メモリ)とEEPROM両方の全てのメモリ位置の内容を\$FFにします。

CKSELヒュース による有効なクロックが与えられなければなりません。直列クロック(SCK)入力のLowとHighの区間の最小値は次のように定義されます。



注1: デバイスが内蔵発振器で動作する場合、CLKIピンに クロック元を接続する必要はありません。

**注2**: VCC-0.3V〈AVCC〈VCC+0.3Vですが、AVCCは常に1.8~5.5V内にすべきです。

 $f_{\rm CK} < 12$ MHz: Low区間>2CPUクロック周期  $f_{\rm CK} < 12$ MHz: High区間>2CPUクロック周期  $f_{\rm CK} \ge 12$ MHz: High区間>3CPUクロック周期  $f_{\rm CK} \ge 12$ MHz: High区間>3CPUクロック周期

### 21.3.1. ピン配置

ピン割り当ては表21-7.で一覧にされます。

| 表21-7. 直列プログラミング用ピン配置 |     |     |         |  |  |
|-----------------------|-----|-----|---------|--|--|
| 信号名                   | ピン名 | 入出力 | 機能      |  |  |
| MOSI                  | PB3 | 入力  | 直列データ入力 |  |  |
| MISO                  | PB4 | 出力  | 直列データ出力 |  |  |
| SCK                   | PB5 | 入力  | 直列クロック  |  |  |

### 21.3.2. プログラミング手順

ATtiny48/88への直列データ書き込み時、データはSCKの上昇端でクロック駆動されます。ATtiny48/88からのデータ読み込み時、データはSCKの下降端でクロック駆動されます。タイミングの詳細については143頁の**図22-9**.と**図22-10**.をご覧ください。

直列プログラミング動作でのATtiny48/88のプログラミングと照合は次手順が推奨されます(表21-8.の命令一式参照)。

- 1. 電源投入手順: RESETとSCKがLow(0)に設定されている間にVCCとGND間へ電源を印加してください。
  - ・いくつかのシステムで電源投入中、SCKがLowに保持されるのを書き込み器が保証できません。この場合、SCKがLow(0)に設定されてしまった後、RESETは正パルスを与えられなければなりません。パルスの幅は最低tRST+2CPUクロック周期でなければなりません。RESETピンの最小パルス幅の定義については137頁の表22-3.をご覧ください。
- 2. 最低20ms待ち、MOSIピンにプログラミング許可命令を送ることによって直列プログラミングを許可してください。
- 3. 通信が同期を外していると、直列プログラミング命令は動作しません。同期していると、プログラミング許可命令の第3小イト送出時に第2 バイト(\$53)が戻ります。
  - ・この戻りが正しいかどうかによらず命令の4小か全てが送信されなければなりません。
  - ・ \$53が戻らない場合、RESETに正パルスを与え、新規プログラミング許可命令を行ってください。
- - ・ ペーシ が正しく設定されるのを保証するため、与えられたアドレスにデータ上位バイトが適用される前にデータ下位バイトが設定され なければなりません。
  - ・プログラム メモリのページはアトレスの上位6/7ビットを含むページ書き込み命令の設定によって(フラッシュ メモリに)格納されます。
  - ・ポーリング(BSY/RDY)が使われない場合、使用者は次のページを行う前に最低twp\_FLASH(表21-9.参照)待たねばなりません。 フラッシュ書き込み操作完了前の(ポーリング以外の)直列プログラミング インターフェースでのアクセスは不正な書き込み結果になり得ます。
- 5. EEPROMはペーシー単位かハイト単位のどちらかでプログラミングできます。

**バイト単位**: EEPROMは適切なEEPROM書き込み命令と共にアドレスとデータを供給することによって1バイト単位で書かれます。EEP ROMのメモリ位置は新規データが書かれるのに先立って始めで自動的に消去されます。ポーリング(BSY/RDY)が使われない場合、次のバイトを行う前に最低twp\_eeprom(表21-9.参照)待たなければなりません。





**ページ単位**: EEPROMの1ぺージはEEPROMぺージ設定命令と共にアドレスの下位2ビットとデータを供給することによって1バイトづつ設定れます。EEPROMぺージはアドレスの上位4/4ビットを含むEEPROMぺージ書き込み命令によって(EEPROMに)格納されます。EE PROMぺージアクセz使用時、EEPROMぺージ設定命令で設定したバイト位置だけが変更されます。残り位置は無変化で留まります。ポーリング(BSY/ $\overline{RDY}$ )が使われない場合、次ぺージ( $\overline{\textbf{$\bf 821-2}}$ 。参照)を行う前に最低twp\_eeprom( $\overline{\textbf{$\bf 821-9}}$ 。参照)待たなければなりません。チップ消去されたデ゙バイスでの $\overline{\textbf{$\bf 821-9}}$ に書かれる必要がありません。

- 6. どのメモリ位置も選択したアドレスの内容を直列出力MISOに読み戻す読み出し命令を使うことによって照合できます。
- 7. プログラミング作業終了時、RESETは通常動作を開始するため、High(1)に設定できます。
- 8. 電源OFF手順(必要とされるならば): RESETをHigh(1)に設定してください。VCC電源をOFFにしてください。

### 21.3.3. 直列プログラミング命令一式

表21-8.と次頁の図21-8.は命令一式を記述します。

表21-8. 直列プログラミング命令一式

| <b>^</b>              | 命令形式  |        |        |         | / <b>#</b> <del>*</del>              |
|-----------------------|-------|--------|--------|---------|--------------------------------------|
| 命令                    | 第1バイト | 第2バイト  | 第3バイト  | 第4バイト   | 備考                                   |
| プログラミング許可             | \$AC  | \$53   | \$00   | \$00    |                                      |
| チップ。消去                | \$AC  | \$80   | \$00   | \$00    |                                      |
| 多忙/準備可検査              | \$F0  | \$00   | \$00   | 状態値     | 最下位ビットが多忙フラグ。                        |
| 設定系命令                 |       |        |        |         |                                      |
| 拡張アドレス設定( <b>注1</b> ) | \$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   | 校正バイ    |                                      |
| 書き込み命令                |       |        |        |         |                                      |
| フラッシュヘージ書き込み          | \$4C  | アドレス上位 | アドレス下位 | \$00    |                                      |
| EEPROMバイト書き込み         | \$C0  | アドレス上位 | アドレス下位 | バイト     |                                      |
| EEPROMページ書き込み         | \$C2  | アドレス上位 | アドレス下位 | \$00    | 注:ページ指示以外のアドレス ビットは <mark>0</mark> 。 |
| 施錠ビット書き込み             | \$AC  | \$E0   | \$00   | 施錠ビット値  |                                      |
| ヒューズ下位ビット書き込み         | \$AC  | \$A0   | \$00   | ヒュース・下位 |                                      |
| ヒューズ上位ビット書き込み         | \$AC  | \$A8   | \$00   | ヒュース・上位 |                                      |
| ヒューズ拡張ビット書き込み         | \$AC  | \$A4   | \$00   | ヒュースが拡張 |                                      |

注1:全命令が全デバイスで利用可能な訳ではありません。

**注**:・施錠ビットとヒューズ値はプログラムが0、非プログラムが1です。将来との互換性のため、未使用のヒューズと施錠ビットは非プログラム(1)にすべきです。

- ・ヒュース、施錠ビット、識票バイト、校正バイト、ページ容量については対応項を参照してください。
- ・プログラミングと書き込み器に関する応用記述については http://www.atmel.com/avr をご覧ください。
- ・第4バイトの赤背景はホスト読み込み(デバイス出力)を示します。

多忙/準備可検査バイト データ出力のLSBが1なら、プログラミング操作が未だ保留(動作中)です。次の命令が実行される前に本ビットがのに戻るまで待ってください。

同じへージ内で、下位へ、イテータは上位へ、イテータに先行して格納されなければなりません。

データがページ、緩衝部に格納された後にEEPROMページをプログラムしてください。次頁の図21-8.をご覧ください。



(<mark>訳補</mark>) フラッシュ メモリ、EEPROM、ペーシ、緩衝部内のアトレス(位置)指定に使われるビットはメモリ容量とページ、構成に依存します。ATtiny48/88でのこれらの指定方法は次表で要約されます。

表B. アドレス(第2,3バイト)指定法

| 命令              | 第2バイト                  | 第3バイト                  | 備考                                                         |
|-----------------|------------------------|------------------------|------------------------------------------------------------|
| 拡張アドレス設定        |                        |                        | 該当命令なし                                                     |
| フラッシュページ内バイ設定   | 0000 0000              | 000L LLLL              | ATtiny48/88 : L=PC4~0                                      |
| EEPROMページ内バイ設定  | 0000 0000              | 0000 00LL              | ATtiny48/88 : L=EEA1∼0                                     |
| フラッシュ メモリ読み出し   | 0000 0HHH<br>0000 HHHH | LLLL LLLL              | ATtiny48 : H=PC10~8,L=PC7~0<br>ATtiny88 : H=PC11~8,L=PC7~0 |
| EEPROM読み出し      | 0000 0000              | OOLL LLLL              | ATtiny48/88 : L=EEA5∼0                                     |
| フラッシュ ヘ゜ーシ゛書き込み | 0000 0HHH<br>0000 HHHH | LLL0 0000<br>LLL0 0000 | ATtiny48 : H=PC10~8,L=PC7~5<br>ATtiny88 : H=PC11~8,L=PC7~5 |
| EEPROMバイ書き込み    | 0000 0000              | OOLL LLLL              | ATtiny48/88 : L=EEA5∼0                                     |
| EEPROMページ書き込み   | 0000 0000              | 00LL LL00              | ATtny48/88 : L=EEA5~2                                      |

# 21.4. フラッシュとEEPROM用のプログラミング時間

フラッシュ メモリとEEPROMの待ち時間は表21-9.で一覧にされます。

表21-9. ヒューズ,フラッシュ,EEPROMの次位置書き込み前の待ち時間

| シンホ゛ル      | 最低待機時間 | 備考                    |
|------------|--------|-----------------------|
| two_flash  | 4.5ms  | フラッシュ メモリ(含むヒュース)書き込み |
| twd_eeprom | 3.6ms  | EEPROM書き込み            |
| twd_erase  | 9.0ms  | チップ。消去                |





# 22. 電気的特性

# 22.1. 絶対最大定格 (警告)

### (警告)

絶対最大定格を超える負担はデバイスに定常的な損傷を与えます。 絶対最大定格は負担の定格を示すためだけのもので、この値また は、この仕様書の動作特性で示された値を超える条件で動作する ことを示すものではありません。長時間の最大定格での使用はデバイスの信頼性を損なう場合があります。

# 22.2. DC特性

TA=-40℃~85℃, VCC=1.8V~5.5V (特記事項を除く)

| シンボル     | 項目                                        | 条件                  | 最小                   | 代表 (注1) | 最大                   | 単位   |
|----------|-------------------------------------------|---------------------|----------------------|---------|----------------------|------|
|          | Lowレベル入力電圧                                | VCC=1.8∼2.4V        | -0.5                 |         | 0.2VCC ( <b>注2</b> ) |      |
| $V_{IL}$ | (RESETt°ンを除く)                             | VCC=2.4~5.5V        | -0.5                 |         | 0.3VCC ( <b>注2</b> ) |      |
|          | Lowレヘブル入力電圧(RESET ピン) (注3)                | VCC=1.8∼5.5V        | -0.5                 |         | 0.2VCC ( <b>注2</b> ) |      |
|          | Highレベル入力電圧                               | VCC=1.8∼2.4V        | 0.7VCC ( <b>注4</b> ) |         | VCC+0.5              |      |
| Vih      | (RESETt°ンを除く)                             | VCC=2.4~5.5V        | 0.6VCC ( <b>注4</b> ) |         | VCC+0.5              |      |
|          | Highレヘ・ル入力電圧 (RESETt°ン) (注3)              | VCC=1.8∼5.5V        | 0.9VCC ( <b>注4</b> ) |         | VCC+0.5              |      |
|          | Lレベル出力電圧                                  | IOL=10mA, VCC=5V    |                      |         | 0.7                  |      |
|          |                                           | IOL=5mA, VCC=3V     |                      |         | 0.5                  |      |
|          | RESETピンを除く)                               | IOL=2mA, VCC=1.8V   |                      |         | 0.4                  |      |
|          | 10. 小儿上帝民                                 | IOL=20mA, VCC=5V    |                      |         | 0.7                  |      |
| Vol      | Lレヘブル出力電圧<br>(高吸い込みI/Oピン) ( <b>注5,7</b> ) | IOL=10mA, VCC=3V    |                      |         | 0.5                  | V    |
|          | (同文( · )乙( / ) ( ) ( )                    | IOL=4mA, VCC=1.8V   |                      |         | 0.4                  |      |
|          | Lレベル出力電圧                                  | IOL=2mA, VCC=5V     |                      |         | 0.7                  |      |
|          | (I/O(PC6)としての (注3,5,6)<br>RESETt°ン)       | IOL=1mA, VCC=3V     |                      |         | 0.5                  |      |
|          |                                           | IOL=0.4mA, VCC=1.8V |                      |         | 0.4                  |      |
|          |                                           | IOH=-10mA, VCC=5V   | 4.3                  |         |                      |      |
|          |                                           | IOH=-5mA, VCC=3V    | 2.5                  |         |                      |      |
| Voh      | RESETt°ンを除く)                              | IOH=-2mA, VCC=1.8V  | 1.4                  |         |                      |      |
| VOH      | 111. "礼山五帝厅"                              | IOH=-10mA, VCC=5V   | 4.3                  |         |                      |      |
|          | Hレヘ・ル出力電圧<br>(高吐き出しI/Oピン) ( <b>注7,8</b> ) | IOH=-5mA, VCC=3V    | 2.5                  |         |                      |      |
|          |                                           | IOH=-2mA, VCC=1.8V  | 1.4                  |         |                      |      |
| IIL      | I/OビンLowレベル入力漏れ電流                         | VCC=5.5V            |                      | <0.05   | 1 (注9)               | Λ    |
| IIH      | I/OビンHighレベル入力漏れ電流                        | 確実なH/L範囲            |                      | <0.05   | 1 (注9)               | μA   |
| Rpu      | I/Oピン プルアップ抵抗                             | VCC=5.5V, Low入力     | 20                   |         | 50                   | kΩ   |
| KPU      | RESETピン プルアップ抵抗                           | VCC-5.5V, LOW/\/    | 30                   |         | 60                   | K12  |
|          |                                           | VCC=2V, 1MHz        |                      | 0.2     | 0.4                  |      |
|          | 活動動作消費電流 (注10)                            | VCC=3V, 4MHz        |                      | 1.4     | 2.5                  |      |
|          |                                           | VCC=5V, 8MHz        |                      | 4.5     | 8                    | mA   |
| Icc      |                                           | VCC=2V, 1MHz        |                      | 0.03    | 0.1                  |      |
| 100      | アイドル動作消費電流 (注10)                          | VCC=3V, 4MHz        |                      | 0.25    | 0.6                  |      |
|          |                                           | VCC=5V, 8MHz        |                      | 1       | 2                    |      |
|          | ハプワーダウン動作消費電流 (注11)                       | VCC=3V, WDT有効       |                      | 4       | 10                   | 11 Λ |
|          | ハソーグリン野バF旧貨電流 (注Ⅱ)<br>                    | VCC=3V, WDT禁止       |                      | <0.2    | 2                    | μA   |

(注1)~(注11)は次頁へ

**注1**: 25℃での代表値です。

注2: "最大"はLowレベルの認識が保証される最高電圧を意味します。

注3: これらのパラメータは製造で検査されていません。

注4: "最小"はHighレベルの認識が保証される最低電圧を意味します。

注5: 各I/Oポートが安定状態(非過渡時)下で検査条件(VCC=5Vで10mA,VCC=3Vで5mA,VCC=2Vで2mA)よりも多く吸い込めるとは言え、以下が厳守されなければなりません。

- ・ポートA3.0、B7~0、C7、D7~5に対する全IOLの合計が100mAを超えるべきではありません。
- ・ポートA2,1、C6~0、D4~0に対する全IOLの合計が100mAを超えるべきではありません。

IOLが検査条件を超える場合、VOLは関連する仕様書での値を超えるかもしれません。ピンは記載した検査条件よりも大きな電流を吸い込むことを保証されません。

注6: RESETピンは(高電圧)プログラミング動作に移行して操作する時に高電圧を許容しなければならず、その結果として通常のI/O ピンと比べると弱い駆動能力を持ちます。(155頁から始まる)図23−34.~39.をご覧ください。

注7: 高吐き出しI/OピンはPD0,PD1,PD2,PD3です。

注8: 各I/Oポートが安定状態(非過渡時)下で検査条件(VCC=5Vで10mA,VCC=3Vで5mA,VCC=2Vで2mA)よりも多く吐き出せると は言え、以下が厳守されなければなりません。

- ・ポートA3,2、B7~0、C6、D7~0に対する全IOHの合計が100mAを超えるべきではありません。
- ・ポートA1.0、C7,5~0に対する全IOHの合計が100mAを超えるべきではありません。

IOHが検査条件を超える場合、VOHは関連する仕様書での値を超えるかもしれません。ピンは記載した検査条件よりも大きな電流を吐き出すことを保証されません。

注9: これらは検査環境の漏れ電流に対する評価の検査限界です。実際のデバイスの漏れ電流はより少量です。

**注10**: 22頁の「消費電力の最小化」で記述された方法を用いた外部クロックでの値です。電力削減が許可(PRR=\$FF)され、I/Oの駆動はありません。

注11: 低電圧検出(BOD)禁止での測定です。

## 22.3. 速度

デバイスの最大動作周波数は供給電圧(VCC)に依存します。供給電圧と最大動作周波数の関係は図22-1.で示されるように区分的線形です。最高周波数対VCC曲線は1.8~4.5V間で直線です。





# 22.4. クロック特性

# 22.4.1. 校正付き内蔵発振器精度

工場既定校正よりも高い精度に内蔵発振器を手動校正することが可能です。この発振器周波数が温度と電圧に依存することに注意してください。電圧と温度の特性は162頁の図23-55.と図23-56.と182頁の図23-112.と図23-113.で得られます。

# 表22-1. 校正付き内蔵発振器の校正精度

| 校正種別  | 周波数               | Vcc            | 温度            | 校正精度(注1) |
|-------|-------------------|----------------|---------------|----------|
| 工場校正  | 8.0MHz            | 3V             | 25°C          | ±10%     |
| 使用者校正 | 7.3~8.1MHz内の固定周波数 | 1.8~5.5V内の固定電圧 | -40~85℃内の固定温度 | ±1%      |

注1: 校正点での発振器周波数精度(固定温度と固定電圧)

# 22.4.2. 外部クロック特性



# 表22-2. 外部クロック特性

| シンホ゛ル        | 項目            | VCC=1. | 8 <b>~</b> 5.5∨ | VCC=2. | 7 <b>~</b> 5.5∨ | VCC=4.5∼5.5V |     | 単位  |  |
|--------------|---------------|--------|-----------------|--------|-----------------|--------------|-----|-----|--|
| クンボル         | <b>块</b> 日    | 最小     | 最大              | 最小     | 最大              | 最小           | 最大  | 中位  |  |
| $1/t_{CLCL}$ | クロック周波数       | 0      | 2               | 0      | 6               | 0            | 12  | MHz |  |
| tclcl        | クロック周期        | 500    |                 | 166    |                 | 83           |     |     |  |
| tchcx        | Highレヘル時間     | 240    |                 | 80     |                 | 40           |     | ns  |  |
| tclcx        | Lowレヘール時間     | 240    |                 | 80     |                 | 40           |     |     |  |
| tclch        | 上昇時間          |        | 2.0             |        | 1.6             |              | 0.5 | 110 |  |
| tchcl        | 下降時間          |        | 2.0             |        | 1.6             |              | 0.5 | μs  |  |
| ⊿tclcl       | 隣接クロック周期間の変化率 |        | 2               |        | 2               |              | 2   | %   |  |

注: 詳細については18頁の「外部クロック信号」を参照してください。

# 22.5. システムとリセットの特性

表22-3. リセット、低電圧検出(BOD)、内部基準電圧の特性

| シンホ゛ル             | 項目                  | 条件               | 最小     | 代表  | 最大     | 単位 |
|-------------------|---------------------|------------------|--------|-----|--------|----|
| V <sub>POT</sub>  | 上昇時電源ONリセット閾値電圧     | TA=-40~85°C      |        | 1.5 |        | V  |
| VPOT              | 下降時電源ONリセット閾値電圧(注1) | 1A-40 905 C      |        | 1.2 |        | V  |
| $V_{RST}$         | RESETt°ン閾値電圧        |                  | 0.2VCC |     | 0.9VCC | V  |
|                   |                     | VCC=1.8V         | 2      |     |        |    |
| $t_{RST}$         | RESETピンでの最小パルス幅     | VCC=3V           | 0.7    |     |        | μs |
|                   |                     | VCC=5V           | 0.4    |     |        |    |
| V <sub>HYST</sub> | 低電圧検出(BOD)ヒステリシス電圧  |                  |        | 50  |        | mV |
| $t_{BOD}$         | 最小低電圧検出(BOD)時間      |                  |        | 2   |        | μs |
| $V_{BG}$          | 基準電圧                | Mag FM           | 1.0    | 1.1 | 1.2    | V  |
| ${ m t_{BG}}$     | 起動時間                | VCC=5V<br>TA=25℃ |        | 40  | 70     | μs |
| $I_{\mathrm{BG}}$ | 消費電流                | 171 20 0         |        | 15  |        | μA |

注1: 供給電圧がこの電圧以下にならないと、上昇時の電源ONJセットは動作しません。

注: 値は指針の意味だけで、実際の値はTBDです。

# 表22-4. BODLEVELヒュース (VBOT) 設定 (注1)

| BODLEVEL2~0 | 最小  | 代表    | 最大     | 単位  |  |
|-------------|-----|-------|--------|-----|--|
| 1 1 1       | 低電圧 | E検出(B | OD)リセッ | 卜禁止 |  |
| 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    |     |  |
| 0 x x       |     | (予    | 約)     |     |  |

注1: いくつかのデバイスでVBOTが公称最低動作電圧以下の可能性があります。この状態のデバイスについては、製造検査中、VCC=VBOTに落として検査されます。これはマイクロコントローラの正しい動作がもはや保証されない電圧になる前に、低電圧検出(BOD)リセットが起きることを保証します。

# 22.6. アナログ 比較器特性

表22-5. アナログ比較器特性 (TA=-40°C~85°C)

| シンホ゛ル | 項目            | 条件               | 最小  | 代表  | 最大 | 単位                 |
|-------|---------------|------------------|-----|-----|----|--------------------|
| VAIO  | 入力変位(オフセット)電圧 | VCC=5V,Vin=VCC/2 |     | <10 | 40 | mV                 |
| ILAC  | 入力漏れ電流        | VCC=5V,Vin=VCC/2 | -50 |     | 50 | nA                 |
|       | アナログ伝播遅延      | VCC=2.7V         |     | 750 |    |                    |
| tado  | (飽和から僅かな過駆動へ) | VCC=4.0V         |     | 500 |    |                    |
| tAPD  | アナログ伝播遅延      | VCC=2.7V         |     | 100 |    | ns                 |
|       | (大きな段階変化)     | VCC=4.0V         |     | 75  |    |                    |
| tDPD  | デジタル伝播遅延      | VCC=1.8∼5.5V     | ·   | 1   | 2  | clk <sub>I/O</sub> |

注: 全てのパラメータはシミュレーション結果に基いており、製造に於いて検査されません。





# 22.7. A/D変換器特性

表22-6. A/D変換特性 (TA=-40~85℃)

| シンホ゛ル | 項目                                     |                   | 条件                      | 最小      | 代表   | 最大      | 単位  |
|-------|----------------------------------------|-------------------|-------------------------|---------|------|---------|-----|
|       | 分解能                                    |                   |                         |         |      | 10      | ピット |
|       | 絶対精度                                   |                   | 変換クロック=200kHz           |         | 2    |         |     |
|       |                                        |                   | 変換クロック=1MHz             |         | 3    |         |     |
|       | (積分非直線性誤差、<br>微分非直線性誤差、<br>量子化誤差、利得誤差、 | VCC=4V<br>VREF=4V | 変換クロック=200kHz<br>雑音低減動作 |         | 1.5  |         |     |
|       | オフセット誤差を含む)                            |                   | 変換クロック=1MHz<br>雑音低減動作   |         | 2.5  |         | LSB |
|       | 積分非直線性誤差                               |                   |                         |         | 1    |         |     |
|       | 微分非直線性誤差                               | VCC=4V、VR         | EF=4V                   |         | 0.5  |         |     |
|       | 利得誤差                                   | 変換クロック=20         | 00kHz                   |         | 2.5  |         |     |
|       | オフセット(セ゛ロ)誤差                           |                   |                         |         | 1.5  |         |     |
|       | 変換時間                                   | 連続変換動作            | F                       | 13      |      | 260     | μs  |
|       | 変換クロック周波数                              |                   |                         | 0.05    |      | 1       | MHz |
| AVCC  | アナログ供給電圧                               |                   |                         | VCC-0.3 |      | VCC+0.3 |     |
| VREF  | 基準電圧                                   |                   |                         | Vint    |      | AVCC    | V   |
| VIN   | 入力電圧                                   |                   |                         | GND     |      | Vref    |     |
|       | 入力周波数帯域                                |                   |                         |         | 38.5 |         | kHz |
| VINT  | 内蔵基準電圧                                 |                   |                         | 1.0     | 1.1  | 1.2     | V   |
| RREF  | 基準電圧入力インピーダンス                          |                   |                         |         | 32   |         | kΩ  |
| RAIN  | アナログ入力インピーダンス                          |                   |                         |         | 100  |         | ΜΩ  |

<u>注</u>: 絶対最小/最大AVCCは1.8/5.5Vです。

# 22.8. 2線直列インターフェース特性

以下のデータはシミュレーションと特性付けに基づきます。**表22-7**.で一覧にされたパラメータは製品で検査されません。シンボルは**図22-3**.を参照してください。



| シンボル                | 直列インターフェース必要条件<br>項目 | 条件                                                | 最小      | 最大      | 単位  |
|---------------------|----------------------|---------------------------------------------------|---------|---------|-----|
| VIL                 | Lowレベル入力電圧           | <b>本</b> 日                                        | -0.5    | 0.3VCC  | +12 |
| VIH                 | Highレベル入力電圧          |                                                   | 0.7VCC  | VCC+0.5 | 1   |
|                     | ŭ                    | VCC≧2.7V                                          | 0.05VCC | -       | V   |
| VHYS                | シュミット トリガ 入力ヒステリシス電圧 | VCC<2.7V                                          | 0       | -       | 1   |
| Vol                 | Lowレベル出力電圧           | IOL=3mA                                           | 0       | 0.4     |     |
| tsp                 | 入力パルス最小幅(尖頭消去濾波)     |                                                   | 0       | 50      | ns  |
| $f_{ m SCL}$        | SCLクロック周波数 (注1)      | $f_{\text{CK}}$ >max(16 $f_{\text{SCL}}$ ,250kHz) | 0       | 400     | kHz |
| t <sub>HD:STA</sub> | (再送)開始条件保持時間         |                                                   | 0.6     | -       |     |
| tLOW                | SCLクロックLowレヘブル時間     |                                                   | 1.3     | -       |     |
| tHIGH               | SCLクロックHighレヘブル時間    |                                                   | 0.6     | -       | μs  |
| tsu:sta             | 再送開始条件準備時間           |                                                   | 0.6     | _       |     |
| t <sub>HD:DAT</sub> | データ保持時間              |                                                   | 0       | 0.9     |     |
| tsu:DAT             | データ準備時間              |                                                   | 100     | -       | ns  |
| tsu:sto             | 停止条件準備時間             |                                                   | 0.6     | _       | 110 |
| tBUF                | 停止条件→開始条件間バス開放時間     |                                                   | 1.3     | _       | μs  |

<u>注</u>1: f<sub>CK</sub>はCPU(システム)クロック周波数です。





# 22.9. SPIタイミング特性





# 表22-8. SPI タイミング 特性

| 番号 | 項目                 | 動作種別 | 最小   | 代表                  | 最大  | 単位  |
|----|--------------------|------|------|---------------------|-----|-----|
| 1  | SCK周期              | 主装置  |      | 表14-5.参照            |     |     |
| 2  | SCK High/Low期間     | 主装置  |      | 50%デューティ比           |     |     |
| 3  | SCK上昇/下降時間         | 主装置  |      | 3.6                 |     |     |
| 4  | 入力データ 準備時間         | 主装置  |      | 10                  |     |     |
| 5  | 入力データ 保持時間         | 主装置  |      | 10                  |     |     |
| 6  | 出力からSCK変移時間        | 主装置  |      | 0.5t <sub>SCK</sub> |     | ns  |
| 7  | SCKからの出力遅延時間       | 主装置  |      | 10                  |     |     |
| 8  | SCKからのHigh出力時間     | 主装置  |      | 10                  |     |     |
| 9  | SS↓からの出力遅延時間       | 従装置  |      | 15                  |     |     |
| 10 | SCK周期              | 従装置  | 4tcK |                     |     |     |
| 11 | SCK High/Low期間 (注) | 従装置  | 2tck |                     |     |     |
| 12 | SCK上昇/下降時間         | 従装置  |      |                     | 1.6 | μs  |
| 13 | 入力データ 準備時間         | 従装置  | 10   |                     |     |     |
| 14 | 入力データ 保持時間         | 従装置  | tcĸ  |                     |     |     |
| 15 | SCKからの出力遅延時間       | 従装置  |      | 15                  |     | ns  |
| 16 | SCKからのSS↑遅延時間      | 従装置  | 20   |                     |     | 118 |
| 17 | SS↑からの出力Hi-Z遅延時間   | 従装置  |      | 10                  |     |     |
| 18 | SS↓からのSCK遅延時間      | 従装置  | 20   |                     |     |     |

注: SPIプログラミングでの最小SCK High/Low期間は、2tCLCL(tCK < 12MHz)、3tCLCL(tCK ≥ 12MHz)です。

# 22.10. 並列プログラミング特性





注: 図22-6.で示されるタイミング必要条件(即ち、tDVXH、tXHXL、tXLDX)は設定操作にも適用されます。



注: 図22-6.で示されるタイミング必要条件(即ち、tDVXH、tXHXL、tXLDX)は読み出し操作にも適用されます。



表22-9. 並列プログラミング特性 (TA=25°C, VCC=5V±10%)

| シンホ゛ル             | 項目                           | 最小   | 代表 | 最大   | 単位 |
|-------------------|------------------------------|------|----|------|----|
| Vpp               | プログラミング許可電圧                  | 11.5 |    | 12.5 | V  |
| Ipp               | プログラミング許可電流                  |      |    | 250  | μA |
| $t_{ m DVXH}$     | CLKI↑に対するデータと制御の準備時間         | 67   |    |      |    |
| $t_{XLXH}$        | CLKI↓から次CLKI↑までの待機時間         | 200  |    |      |    |
| txHXL             | CLKI Highパルス幅                | 150  |    |      |    |
| txldx             | CLKIパルス↓後のデータと制御の保持時間        | 67   |    |      |    |
| $t_{XLWL}$        | CLKIパルス↓後のWR↓待機時間            | 0    |    |      |    |
| txlph             | CLKIパルス↓後のPAGELパルス↑待機時間      | 0    |    |      |    |
| t <sub>PLXH</sub> | PAGELパハス↓後のCLKIパルス↑待機時間      | 150  |    |      |    |
| t <sub>BVPH</sub> | PAGELパルス↑に対するBS1準備時間         | 67   |    |      | ns |
| tPHPL             | PAGEL Highパルス幅               | 150  |    |      |    |
| t <sub>PLBX</sub> | PAGELパルス↓後のBS1保持時間           | 67   |    |      |    |
| t <sub>WLBX</sub> | WRパルス↓後のBS1,BS2保持時間          | 67   |    |      |    |
| t <sub>PLWL</sub> | PAGELパルス↓後のWRパルス↓待機時間        | 67   |    |      |    |
| t <sub>BVWL</sub> | WRパルス↓に対するBS1準備時間            | 67   |    |      |    |
| twlwh             | WR Lowパルス幅                   | 150  |    |      |    |
| twlrl             | WRパルス↓後のRDY/BSY↓遅延時間         | 0    |    | 1    | μs |
| twlrh             | 書き込み時間 (WR↓からRDY/BSY↑) (注1)  | 3.7  |    | 4.5  |    |
| twlrh_ce          | チップ消去時間 (WR↓からRDY/BSY↑) (注2) | 7.5  |    | 9    | ms |
| $t_{ m XLCL}$     | CLKIパルス↓後のOE↓待機時間            | 0    |    |      |    |
| tbvdv             | BS1有効からのDATA遅延時間             | 0    |    | 250  |    |
| toldv             | OE ↓後のDATA出力遅延時間             |      |    | 250  | ns |
| toHDZ             | ŌE↑後のDATA Hi−Z遅延時間           |      |    | 250  |    |

注1: フラッシュ メモリ、EEPROM、ヒュース、ビット、施錠ビット書き込み指令に対して有効です。

注2: チップ消去指令に対して有効です。

# **22.11**. 直列プログラミング特性





| 表22-10. 直列プログラミング特性 (別記を除いて、TA=-40℃~85℃, VCC=1.8~5.5V) |                                                   |          |                    |    |    |         |
|--------------------------------------------------------|---------------------------------------------------|----------|--------------------|----|----|---------|
| シンホ゛ル                                                  | 項目                                                |          | 最小                 | 代表 | 最大 | 単位      |
| 1/t <sub>CLCL</sub>                                    | 発振器周波数                                            | 2.7~4.5V | 0                  |    | 6  | MHz     |
| 1/tCLCL                                                | TURAN PUR AND | 4.5~5.5V | 0                  |    | 12 | IVII IZ |
| toror                                                  | <br>  発振器周期                                       | 2.7~4.5V | 166                |    |    |         |
| tclcl                                                  | 光版和內夠                                             | 4.5~5.5V | 83                 |    |    |         |
| tshsl                                                  | SCKパルスHレヘル幅                                       |          | 2tclcl             |    |    | ne      |
| tslsh                                                  | SCKパルスLレヘブル幅                                      |          | 2t <sub>CLCL</sub> |    |    | ns      |
| tovsh                                                  | SCK↑に対するMOSI準備時間                                  |          | tclcl              |    |    |         |
| tshox                                                  | SCK↑に対するMOSI保持時間                                  |          | 2tclcl             |    |    |         |





# 23. 代表特性

本項内に含まれたデータは主に同じ製法と設計法の類似デバイスの特徴付けとシミュレーションに基いています。従って、このデータはデバイスがどう反応するかについての指標として扱われるべきです。

以下の図は代表的な特性を示します。これらの図は製造中に検査されていません。全ての消費電流測定は全I/Oピンを入力として設定した内部プルアップ許可で行われています。電源幅振幅の方形波発振器がクロック源として使われています。

パワーダウン動作での消費電力はクロック選択と無関係です。

消費電流は動作電圧、動作周波数、I/Oピンの負荷、I/Oピンの切り替え速度、命令実行、周囲温度のような様々な要素の関数です。 支配的な要素は動作電圧と動作周波数です。

容量性負荷のピンの引き込み電流は(1つのピンに対して)  $CL(負荷容量) \times VCC(動作電圧) \times fSW(I/Oピンの平均切り替え周波数) として推測できます。$ 

デバイスは検査範囲よりも高い周波数特性を示します。デバイスは注文番号が示す周波数よりも高い周波数での機能特性を保証されません。

ウォッチト、ック、タイマ許可のパワーダウン動作での消費電流とウォッチト、ック、タイマ禁止のパワーダウン動作での消費電流間の違いは、ウォッチト、ック、タイマによって引き込んだ(消費した)差電流を表します。

### 23.1. ATtiny48

# 23.1.1. 活動動作消費電流















#### 23.1.2. アイドル動作消費電流











### 23.1.3. パワーダウン動作消費電流









#### 23.1.4. リセット消費電流





# 23.1.5. 周辺機能部消費電流













# 23.1.6. プルアップ 抵抗

















# 23.1.7. 出力駆動部能力







































### 23.1.8. 入力閾値とヒステリシス

















#### 23.1.9. 低電圧検出器(BOD)、バント、キ・ャップ、リセット



















### 23.1.10. 内部発振器周波数



















### 23.2. ATtiny88

### 23.2.1. 活動動作消費電流











### 23.2.2. アイドル動作消費電流















# 23.2.3. パワーダウン動作消費電流









#### 23.2.4. リセット消費電流





### 23.2.5. 周辺機能部消費電流













#### 23.2.6. プルアップ 抵抗

















#### 23.2.7. 出力駆動部能力





































### 23.2.8. 入力閾値とヒステリシス















#### 23.2.9. 低電圧検出器(BOD)、バント・キ・ャップ、リセット



















# 23.2.10. 内部発振器周波数















# 24. レジスタ要約

| 拡張I/Oレシ          | <b>バスタ領域</b> (1/ | 2)       |        |                 |                                 |                            |       |         |       |            |
|------------------|------------------|----------|--------|-----------------|---------------------------------|----------------------------|-------|---------|-------|------------|
| アト・レス            | レジスタ略称           | ピット7     | ピット6   | ピット5            | ピット4                            | ピット3                       | ピット2  | ピット1    | ビット0  | 頁          |
| (~\$FF)          | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$BF)           | 予約               |          |        |                 |                                 |                            |       |         |       | 101        |
| (\$BE)<br>(\$BD) | TWHSR<br>TWAMR   | TWAM6    | TWAM5  | TWAM4           | TWAM3                           | TWAM2                      | TWAM1 | TWAM0   | TWHS  | 104<br>104 |
| (\$BC)           | TWCR             | TWINT    | TWEA   | TWSTA           | TWSTO                           | TWWC                       | TWEN  | 1 WANIO | TWIE  | 104        |
| (\$BB)           | TWDR             | 1 771171 | IVVL/I | - 1W31/A<br>2線ī | <u>  TVVSTO</u><br>  百列  インターフ: | エーステータレ                    |       |         | I WIL | 103        |
| (\$BA)           | TWAR             | TWA6     | TWA5   | TWA4            | TWA3                            | TWA2                       | TWA1  | TWA0    | TWGCE | 103        |
| (\$B9)           | TWSR             | TWS7     | TWS6   | TWS5            | TWS4                            | TWS3                       | _     | TWPS1   | TWPS0 | 103        |
| (\$B8)           | TWBR             |          |        | 2線直             | 列インターフェー                        | スピット速度                     | レジスタ  |         |       | 102        |
| (\$B7)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$B6)<br>(\$B5) |                  |          |        |                 |                                 |                            |       |         |       |            |
| (\$B4)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$B3)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$B2)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$B1)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$B0)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$AF)<br>(\$AE) | <u>予約</u><br>予約  |          |        |                 |                                 |                            |       |         |       |            |
| (\$AD)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$AC)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$AB)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$AA)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$A9)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$A8)<br>(\$A7) | <u>予約</u><br>予約  |          |        |                 |                                 |                            |       |         |       |            |
| (\$A6)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$A5)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$A4)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$A3)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$A2)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$A1)<br>(\$A0) | <u>予約</u><br>予約  |          |        |                 |                                 |                            |       |         |       |            |
| (\$A0)<br>(\$9F) | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$9E)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$9D)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$9C)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$9B)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$9A)<br>(\$99) | <u>予約</u><br>予約  |          |        |                 |                                 |                            |       |         |       |            |
| (\$98)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$97)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$96)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$95)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$94)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$93)<br>(\$92) | <u>予約</u><br>予約  |          |        |                 |                                 |                            |       |         |       |            |
| (\$92)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$90)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$8F)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$8E)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$8D)           | 予約               |          |        |                 |                                 |                            |       |         |       |            |
| (\$8C)<br>(\$8B) | 予約<br>OCR1BH     |          |        | カイコ             | カウンタ1 トレ 歩                      | <br>Bレジスタ 上作               | さんごろし |         |       |            |
| (\$8A)           | OCRIBH<br>OCRIBL |          | 1      |                 |                                 | Bレジ ヘタ 上1                  |       | -       |       | 74         |
| (\$89)           | OCR1AH           |          |        |                 |                                 | Aレジスタ 上作                   |       |         |       | 7.4        |
| (\$88)           | OCR1AL           |          |        | タイマ/:           | カウンタ1 比較                        | Aレジスタ 下作                   | 立バイト  |         |       | 74         |
| (\$87)           | ICR1H            |          |        | タイマ/            | /カウンタ1 捕獲                       | レジスタ 上位                    | バイト   |         |       | 74         |
| (\$86)           | ICR1L            |          |        | タイマ/            |                                 | レジスタ 下位                    | 7/1/1 |         |       | 1 1        |
| (\$85)           | TCNT1H<br>TCNT1L |          | -      | -               |                                 | 1 上位バ <u>イト</u><br>1 下位バイト | -     | -       |       | 73         |
| (\$84)<br>(\$83) | 予約               |          |        |                 | ブイマ/ カリング                       | 1 1.17/1/1                 |       |         |       |            |
| (\$82)           | TCCR1C           | FOC1A    | FOC1B  | _               | _                               | _                          | _     | _       | -     | 73         |
| (\$81)           | TCCR1B           | ICNC1    | ICES1  | -               | WGM13                           | WGM12                      | CS12  | CS11    | CS10  | 72         |
| (\$80)           | TCCR1A           | COM1A1   | COM1A0 | COM1B1          | COM1B0                          | -                          | -     | WGM11   | WGM10 | 71         |





#### 拡張I/Oレジスタ領域(2/2)

| アト・レス  | レジスタ略称 | ピット7    | ピット6             | ヒット5     | ピット4    | ピット3     | ピット2    | ピット1    | <b>WŁĠMO</b> 0 | 買       |
|--------|--------|---------|------------------|----------|---------|----------|---------|---------|----------------|---------|
| (\$7F) | DIDR1  | -       | -                | -        | _       | -        | -       | AIN1D   | AIN0D          | 106     |
| (\$7E) | DIDR0  | ADC7D   | ADC6D            | ADC5D    | ADC4D   | ADC3D    | ADC2D   | ADC1D   | ADC0D          | 115     |
| (\$7D) | 予約     |         |                  |          |         |          |         |         |                |         |
| (\$7C) | ADMUX  | -       | REFS0            | ADLAR    | -       | MUX3     | MUX2    | MUX1    | MUX0           | 113     |
| (\$7B) | ADCSRB | ı       | ACME             | -        | -       | -        | ADTS2   | ADTS1   | ADTS0          | 105,114 |
| (\$7A) | ADCSRA | ADEN    | ADSC             | ADATE    | ADIF    | ADIE     | ADPS2   | ADPS1   | ADPS0          | 113     |
| (\$79) | ADCH   |         |                  |          | スタ上位バイト |          |         |         |                | 115     |
| (\$78) | ADCL   |         | A/               | Dデータ レシン | なり下位バイト | (ADC7~0ま | たはADC1~ | 0)      |                | 110     |
| (\$77) | 予約     |         |                  |          |         |          |         |         |                |         |
| (\$76) | 予約     |         |                  |          |         |          |         |         |                |         |
| (\$75) | 予約     |         |                  |          |         |          |         |         |                |         |
| (\$74) | 予約     |         |                  |          |         |          |         |         |                |         |
| (\$73) | 予約     |         |                  |          |         |          |         |         |                |         |
| (\$72) | 予約     |         |                  |          |         |          |         |         |                |         |
| (\$71) | 予約     |         |                  |          |         |          |         |         |                |         |
| (\$70) | 予約     |         |                  |          |         |          |         |         |                |         |
| (\$6F) | TIMSK1 | -       | -                | ICIE1    | -       | -        | OCIE1B  | OCIE1A  | TOIE1          | 75      |
| (\$6E) | TIMSK0 | -       | -                | -        | -       | -        | OCIE0B  | OCIE0A  | TOIE0          | 56      |
| (\$6D) | PCMSK2 | PCINT23 | PCINT22          | PCINT21  | PCINT20 | PCINT19  | PCINT18 | PCINT17 | PCINT16        | 36      |
| (\$6C) | PCMSK1 | PCINT15 | PCINT14          | PCINT13  | PCINT12 | PCINT11  | PCINT10 | PCINT9  | PCINT8         | 36      |
| (\$6B) | PCMSK0 | PCINT7  | PCINT6           | PCINT5   | PCINT4  | PCINT3   | PCINT2  | PCINT1  | PCINT0         | 36      |
| (\$6A) | PCMSK3 | -       | -                | -        | -       | PCINT27  | PCINT26 | PCINT25 | PCINT24        | 36      |
| (\$69) | EICRA  | -       | -                | -        | -       | ISC11    | ISC10   | ISC01   | ISC00          | 33      |
| (\$68) | PCICR  | -       | -                | -        | -       | PCIE3    | PCIE2   | PCIE1   | PCIE0          | 35      |
| (\$67) | 予約     |         |                  |          |         |          |         |         |                |         |
| (\$66) | OSCCAL |         | 内蔵RC発振器発振校正値レジスタ |          |         |          |         |         | 20             |         |
| (\$65) | 予約     |         |                  |          |         |          |         |         |                |         |
| (\$64) | PRR    | PRTWI   | -                | PRTIM0   | -       | PRTIM1   | PRSPI   | -       | PRADC          | 24      |
| (\$63) | 予約     |         |                  |          |         |          |         |         |                |         |
| (\$62) | 予約     |         |                  |          |         |          |         |         |                |         |
| (\$61) | CLKPR  | CLKPCE  | -                | -        | -       | CLKPS3   | CLKPS2  | CLKPS1  | CLKPS0         | 20      |
| (\$60) | WDTCSR | WDIF    | WDIE             | WDP3     | WDCE    | WDE      | WDP2    | WDP1    | WDP0           | 30      |

注: 暗背景のレシ、スタとビットは28ピン外囲器で利用できません。

- 注意: ・将来のデバイスとの共通性のため、アクセスされる場合の予約ビットは0を書かれるべきです。予約したI/Oメモリ アドレスは決して書かれるべきではありません。
  - ・アト・レス範囲\$00~\$1F内のI/Oレシ、スタはSBIとCBI命令を使う直接的なビットアクセスが可能です。これらのレシ、スタではSBISとSBIC 命令を使うことによって単一ビット値が検査できます。
  - ・いくつかの状態ビットはそれらへ論理1を書くことによって解除(0)されます。他の多くのAVRの様ではなく、CBIとSBI命令は指定ビットだけを操作し、故にこのような状態フラグを含むレジスタで使えます。CBIとSBI命令は\$00~\$1Fのレジスタだけで動作します
  - ・I/O指定命令INとOUTを使う時はI/Oアドレス\$00~\$3Fが使われなければなりません。LDとST命令を使ってデータ空間として I/Oレジスタをアドレス指定する時はこれらのアドレスに\$20が加算されなければなりません。ATtiny48/88はINとOUT命令で予約した64位置で支援できるよりも多くの周辺部(機能)の複合マイクロ コントローラです。SRAM(データ空間)内の拡張I/O空間はST/STS/STDとLD/LDS/LDD命令だけが使えます。

| マじょっ                   | バスタ領域            | ا ا ا ا      | الاستار     | المراج       | ا ا ا ا ا ا  | ال الله    | الاستام      | ا ا ا ا ا  | ا دا ا    | <b>-</b> |
|------------------------|------------------|--------------|-------------|--------------|--------------|------------|--------------|------------|-----------|----------|
| アトレス                   | レジスタ略称           | <u> ビットフ</u> | <u>ビット6</u> | <u> ビット5</u> | <u>L'y\4</u> | ヒット3       | <u>t*y\2</u> | <u> </u>   | ヒット0      | <u>頁</u> |
| 3F (\$5F)              | SREG             | I            | Т           | Н            | S            | V          | N            | Z          | C         | 10       |
| 3E (\$5E)              | SPH              | - CD=        | - CDo       | - CD-        | - CD.        | - CDo      | - CDo        | (SP9)      | SP8       | 10       |
| 3D (\$5D)              | SPL              | SP7          | SP6         | SP5          | SP4          | SP3        | SP2          | SP1        | SP0       |          |
| 3C (\$5C)              | 予約               |              |             |              |              |            |              |            |           |          |
| 3B (\$5B)              | 予約               |              |             |              |              |            |              |            |           |          |
| 3A (\$5A)              | 予約               |              |             |              |              |            |              |            |           |          |
| 39 (\$59)              | 予約               |              |             |              |              |            |              |            |           |          |
| 38 (\$58)              | 予約               |              |             |              |              |            |              |            |           |          |
| 37 (\$57)              | SPMCSR           | -            | RWWSB       | -            | CTPB         | RFLB       | PGWRT        | PGERS      | SELFPRGEN | 120      |
| 36 (\$56)              | 予約               |              |             |              |              |            |              |            |           |          |
| 35 (\$55)              | MCUCR            | _            | BODS        | BODSE        | PUD          | _          | _            | _          | _         | 23,49    |
| 34 (\$54)              | MCUSR            | _            | _           | -            | _            | WDRF       | BORF         | EXTRF      | PORF      | 29       |
| 33 (\$53)              | SMCR             | -            | -           | -            | -            | -          | SM1          | SM0        | SE        | 23       |
| 32 (\$52)              | 予約               |              |             |              |              |            | 5.111        | 21110      |           |          |
| 31 (\$51)              | DWDR             |              |             | <u> </u>     | デンバック WIRE   | データルジス     | Ż            |            |           | 116      |
| 30 (\$50)              | ACSR             | ACD          | ACBG        | ACO          | ACI          | ACIE       | ACIC         | ACIS1      | ACIS0     | 106      |
| 2F (\$4F)              | 予約               | ACD          | ACDG        | 7100         | 7101         | ACIL       | ACIC         | ACISI      | 710150    | 100      |
| 2F (\$4F)<br>2E (\$4E) |                  |              |             |              | SPI デー       | カ 1 パブ フ カ |              |            |           | 83       |
| 2E (\$4E)<br>2D (\$4D) | SPDR<br>SPSR     | SPIF         | WCOL        |              | SF1 / =      | -          | _            |            | SPI2X     | 82       |
|                        |                  |              |             | DODD         | MSTR         | CDOL       | CDLIA        | CDD1       |           |          |
| 2C (\$4C)              | SPCR             | SPIE         | SPE         | DORD         |              | CPOL       | СРНА         | SPR1       | SPR0      | 82       |
| 2B (\$4B)              | GPIOR2           |              |             |              |              | レシスタ2      |              |            | +         | 16       |
| 2A (\$4A)              | GPIOR1           |              |             |              | 汎用I/C        | リレン スター    |              |            |           | 16       |
| 29 (\$49)              | 予約               |              |             |              |              | II deline  |              |            |           |          |
| 28 (\$48)              | OCR0B            |              |             |              | イマ/カウンタ0     |            |              |            |           | 56       |
| 27 (\$47)              | OCR0A            |              |             |              | イマ/カウンタ0     |            | 9            | <b>.</b>   |           | 55       |
| 26 (\$46)              | TCNT0            |              |             |              | タイマ/フ        |            |              |            |           | 55       |
| 25 (\$45)              | TCCR0A           | 1            | -           | 1            | _            | CTC0       | CS02         | CS01       | CS00      | 55       |
| 24 (\$44)              | 予約               |              |             |              |              |            |              |            |           |          |
| 23 (\$43)              | GTCCR            | TSM          | _           | _            | _            | _          | -            | -          | PSRSYNC   | 77       |
| 22 (\$42)              | 予約               |              |             |              |              |            |              |            |           |          |
| 21 (\$41)              | EEARL            | -            | -           |              | EEPROM       | アドレス レシ スタ | 下位バイト(B      | EEAR5~0)   | 1         | 15       |
| 20 (\$40)              | EEDR             |              |             |              | EEPROM       |            | 1 1 12 11 (2 | 7211110 07 | ·         | 15       |
| 1F (\$3F)              | EECR             | _            | _           | EEPM1        | EEPM0        | EERIE      | EEMPE        | EEPE       | EERE      | 15       |
| 1E (\$3E)              | GPIOR0           |              |             | EDI WII      |              | シンジスタ0     | DEIVII E     | DEI E      | BERE      | 16       |
| ID (\$3D)              | EIMSK            | _            | _           | _            | 7/1/11/      | _          | _            | INT1       | INT0      | 34       |
| IC (\$3C)              | EIFR             | _            | _           | _            | _            | _          | _            | INTF1      | INTF0     | 34       |
|                        |                  |              |             | _            | _            | DCIE       | DCIEO        |            |           |          |
| 1B (\$3B)              | PCIFR            | _            | _           | _            | _            | PCIF3      | PCIF2        | PCIF1      | PCIF0     | 35       |
| IA (\$3A)              | 予約               |              |             |              |              |            |              |            |           |          |
| 19 (\$39)              | 予約               |              |             |              |              |            |              |            |           |          |
| 18 (\$38)              | 予約               |              |             |              |              |            |              |            |           |          |
| 17 (\$37)              | 予約               |              |             |              |              |            |              |            |           |          |
| 16 (\$36)              | TIFR1            | -            | -           | ICF1         | -            | -          | OCF1B        | OCF1A      | TOV1      | 75       |
| 15 (\$35)              | TIFR0            | -            | -           | -            | -            | -          | OCF0B        | OCF0A      | TOV0      | 56       |
| 14 (\$34)              | 予約               |              |             |              |              |            |              |            |           |          |
| 13 (\$33)              | 予約               |              |             |              |              |            |              |            |           |          |
| 12 (\$32)              | PORTCR           | BBMD         | BBMC        | BBMB         | BBMA         | PUDD       | PUDC         | PUDB       | PUDA      | 49       |
| 11 (\$31)              | 予約               |              |             |              |              |            |              |            |           |          |
| 10 (\$30)              | 予約               |              |             |              |              |            |              |            |           |          |
| 0F (\$2F)              | 予約               |              |             |              |              |            |              |            |           |          |
| 0E (\$2E)              | PORTA            | _            | _           | _            | _            | PORTA3     | PORTA2       | PORTA1     | PORTA0    | 49       |
| DD (\$2D)              | DDRA             | _            | _           | _            | _            | DDA3       | DDA2         | DDA1       | DDA0      | 49       |
| OC (\$2C)              | PINA             | _            | _           | _            | _            | PINA3      | PINA2        | PINA1      | PINA0     | 49       |
| OB (\$2B)              | PORTD            | PORTD7       | PORTD6      | PORTD5       | PORTD4       | PORTD3     | PORTD2       | PORTD1     | PORTD0    | 50       |
| )A (\$2A)              |                  |              |             |              |              |            |              |            |           | 50<br>50 |
|                        | DDRD             | DDD7         | DDD6        | DDD5         | DDD4         | DDD3       | DDD2         | DDD1       | DDD0      |          |
| 09 (\$29)              | PIND             | PIND7        | PIND6       | PIND5        | PIND4        | PIND3      | PIND2        | PIND1      | PIND0     | 50       |
| 08 (\$28)              | PORTC            | PORTC7       | PORTC6      | PORTC5       | PORTC4       | PORTC3     | PORTC2       | PORTC1     | PORTC0    | 50       |
| 07 (\$27)              | DDRC             | DDC7         | DDC6        | DDC5         | DDC4         | DDC3       | DDC2         | DDC1       | DDC0      | 50       |
| 06 (\$26)              | PINC             | PINC7        | PINC6       | PINC5        | PINC4        | PINC3      | PINC2        | PINC1      | PINC0     | 50       |
| 05 (\$25)              | PORTB            | PORTB7       | PORTB6      | PORTB5       | PORTB4       | PORTB3     | PORTB2       | PORTB1     | PORTB0    | 49       |
|                        | DDRB             | DDB7         | DDB6        | DDB5         | DDB4         | DDB3       | DDB2         | DDB1       | DDB0      | 50       |
| 04 (\$24)              |                  | DILID -      | DILID -     | DILID -      | DIVID        | DIMIDO     | DINIDO       | DINID 1    | DIMDO     | FO       |
| 04 (\$24)<br>03 (\$23) | PINB             | PINB7        | PINB6       | PINB5        | PINB4        | PINB3      | PINB2        | PINB1      | PINB0     | 50       |
| 03 (\$23)              |                  | PINB7        | PINB6       | PINB5        | PINB4        | PINB3      | PINB2        | PINDI      | PINBU     | - 00     |
|                        | PINB<br>予約<br>予約 | PINB7        | PINB6       | PINB5        | PINB4        | PINB3      | PINB2        | PINBI      | PINBU     | 50       |

注: 暗背景のレシ、スタとヒ、ットは28ピ、ン外囲器で利用できません。()付きビットはATtiny88でのみ利用可能です。

(訳注) 原書本位置の注意は前頁に移動しました。





# 25. 命令要約

| ニーモニック | オペラント゛ | 意味                        | 動作                                              | フラク゛                           | クロック |
|--------|--------|---------------------------|-------------------------------------------------|--------------------------------|------|
|        |        |                           | <b>建</b> 演算命令                                   |                                |      |
| 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,0,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                                  | I,T,H,S,0,N,Z,0                |      |
| NEG    | Rd     | 2の補数                      | Rd ← \$00 - Rd                                  | I,T,H,S,V,N,Z,C                | 1    |
| SBR    | Rd,K   | 汎用レジスタの(複数)ビット設定(1)       | Rd ← Rd OR K                                    | I,T,H,S,0,N,Z,C                | 1    |
| CBR    | Rd,K   | 汎用レシブスタの(複数)ビット解除(0)      | Rd ← Rd AND (\$FF - K)                          | I,T,H, <mark>S,0,N,Z,</mark> C | 1    |
| INC    | Rd     | 汎用レジスタの増加(+1)             | Rd ← Rd + 1                                     | I,T,H,S,V,N,Z,C                | 1    |
| DEC    | Rd     | 汎用レジスタの減少(-1)             | Rd ← Rd − 1                                     | I,T,H,S,V,N,Z,C                | 1    |
| TST    | Rd     | 汎用レシブスタのセブロとマイナス検査        | Rd ← Rd AND Rd                                  | I,T,H, <mark>S,0,N,Z,</mark> C | 1    |
| CLR    | Rd     | 汎用レジスタの全0設定(=\$00)        | Rd ← Rd EOR Rd                                  | $I,T,H,\theta,0,0,1,C$         | 1    |
| SER    | Rd     | 汎用レジスタの全1設定(=\$FF)        | Rd ← \$FF                                       | I,T,H,S,V,N,Z,C                | 1    |
|        |        |                           | 命令                                              |                                |      |
| RJMP   | k      | 相対分岐                      | $PC \leftarrow PC + k + 1$                      | I,T,H,S,V,N,Z,C                | 2    |
| IJMP   |        | Zレシブスタ間接分岐                | PC ← Z                                          | I,T,H,S,V,N,Z,C                | 2    |
| RCALL  | k      | 相対サブルーチン呼び出し              | $STACK \leftarrow PC, PC \leftarrow PC + k + 1$ | I,T,H,S,V,N,Z,C                | 3    |
| ICALL  |        | Zレシブスタ間接サブルーチン呼び出し        | $STACK \leftarrow PC, PC \leftarrow Z$          | I,T,H,S,V,N,Z,C                | 3    |
| RET    |        | サブルーチンからの復帰               | PC ← STACK                                      | I,T,H,S,V,N,Z,C                | 4    |
| RETI   |        | 割り込みからの復帰                 | 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                |      |
| 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                |      |
| 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                |      |
| SBRS   | Rr,b   | 汎用レジスタのビットが設定(1)でスキップ     | Rr(b)=1なら, PC ← PC + 2or3                       | I,T,H,S,V,N,Z,C                |      |
| SBIC   | P,b    | I/Oレシ、スタのヒ、ットが解除(0)でスキップ。 | P(b)=0なら、PC ← PC + 2or3                         | I,T,H,S,V,N,Z,C                |      |
| SBIS   | P,b    | I/Oレシ、スタのヒットが設定(1)でスキップ   | P(b)=1なら, PC ← PC + 2or3                        | I,T,H,S,V,N,Z,C                |      |
| BRBS   | s,k    | ステータス フラグが設定(1)で分岐        | $SREG(s)=1$ \$\partial pC, PC + K + 1           | I,T,H,S,V,N,Z,C                | 1/2  |
| BRBC   | s,k    | ステータス フラグが解除(0)で分岐        | SREG(s)=0なら, PC ← PC + K + 1                    | I,T,H,S,V,N,Z,C                | 1/2  |
| BREQ   | k      | 一致で分岐                     | Z=1/\$6, PC ← PC + K + 1                        | I,T,H,S,V,N,Z,C                |      |
| BRNE   | k      | 不一致で分岐                    | Z=0/\$6, PC ← PC + K + 1                        | I,T,H,S,V,N,Z,C                | 1/2  |
| BRCS   | k      | キャリー フラグが設定(1)で分岐         | C=1なら, PC ← PC + K + 1                          | I,T,H,S,V,N,Z,C                |      |
|        | k      | キャリー フラグが解除(0)で分岐         | C=07\$6, PC ← PC + K + 1                        | I,T,H,S,V,N,Z,C                |      |
| BRSH   | k      | 符号なしの≧で分岐                 | C=0なら, PC ← PC + K + 1                          | I,T,H,S,V,N,Z,C                |      |
| BRLO   | k      | 符号なしのくで分岐                 | C=1なら, PC ← PC + K + 1                          | I,T,H,S,V,N,Z,C                |      |
| BRMI   | k      | -(マイナス)で分岐                | N=1なら, PC ← PC + K + 1                          | I,T,H,S,V,N,Z,C                | -    |
| BRPL   | k      | +(プラス)で分岐                 | N=07\$\$, 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                |      |
| BRHS   | k      | ハーフキャリー フラグが設定(1)で分岐      | H=1なら, PC ← PC + K + 1                          | I,T,H,S,V,N,Z,C                | 1/2  |
| BRHC   | k      | ハーフキャリーフラグが解除(0)で分岐       | 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                |      |
| BRTC   | k      | 一時フラグが解除(0)で分岐            | T=0なら, PC ← PC + K + 1                          | I,T,H,S,V,N,Z,C                | 1/2  |
| BRVS   | k      | 2の補数溢れフラグが設定(1)で分岐        | V=1なら, PC ← PC + K + 1                          | I,T,H,S,V,N,Z,C                | 1/2  |
| BRVC   | k      | 2の補数溢れフラグが解除(0)で分岐        | V=07\$6, PC ← PC + K + 1                        | I,T,H,S,V,N,Z,C                |      |
| BRIE   | k      | 割り込み許可で分岐                 | I=1なら, PC ← PC + K + 1                          | I,T,H,S,V,N,Z,C                | 1/2  |
| BRID   | k      | 割り込み禁止で分岐                 | I=0なら, PC ← PC + K + 1                          | I,T,H,S,V,N,Z,C                | 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)

| ニーモニック       | オペラント゛          |                                                                                                          | 動作                                                                                                                                                 | フラク゛                                                 | クロック     |
|--------------|-----------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|----------|
|              |                 |                                                                                                          | 動命令                                                                                                                                                |                                                      |          |
| MOV<br>MOVW  | Rd,Rr           | 汎用レジスタ間の複写<br>汎用レジスタ対間の複写                                                                                | Rd ← Rr<br>  Rd+1:Rd ← Rr+1:Rr                                                                                                                     | I,T,H,S,V,N,Z,C                                      | 1        |
| LDI          | Rd,Rr<br>Rd,K   | 即値の取得                                                                                                    | Rd ← K                                                                                                                                             | I,T,H,S,V,N,Z,C<br>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                                      | 2        |
| LD           | Rd,-X           | 事前減少付きXレジスタ間接での取得                                                                                        | $X \leftarrow X - 1$ , Rd $\leftarrow$ (X)                                                                                                         | I,T,H,S,V,N,Z,C                                      | 2        |
| LD<br>LD     | Rd,Y<br>Rd,Y+   | Yレジスタ間接での取得<br>事後増加付きYレジスタ間接での取得                                                                         | $Rd \leftarrow (Y)$ $Rd \leftarrow (Y), Y \leftarrow Y + 1$                                                                                        | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C                   | 2 2      |
| LD           | Rd, 1 +         | 事前減少付きYレジスタ間接での取得                                                                                        | $Y \leftarrow Y - 1, Rd \leftarrow (Y)$                                                                                                            | I,T,H,S,V,N,Z,C                                      | 2        |
| LDD          | Rd,Y+q          | 変位付きYレジスタ間接での取得                                                                                          | $Rd \leftarrow (Y + q)$                                                                                                                            | I,T,H,S,V,N,Z,C                                      | 2        |
| LD           | Rd,Z            | Zレジスタ間接での取得                                                                                              | $Rd \leftarrow (Z)$                                                                                                                                | I,T,H,S,V,N,Z,C                                      | 2        |
| LD           | Rd,Z+           | 事後増加付きZレジスタ間接での取得                                                                                        | $Rd \leftarrow (Z), Z \leftarrow Z + 1$                                                                                                            | I,T,H,S,V,N,Z,C                                      | 2        |
| LD<br>LDD    | Rd,-Z           | 事前減少付きZレジスタ間接での取得                                                                                        | $Z \leftarrow Z - 1$ , $Rd \leftarrow (Z)$                                                                                                         | I,T,H,S,V,N,Z,C                                      | 2        |
| LDD          | Rd,Z+q<br>Rd,k  | 変位付きZレジスタ間接での取得<br>データ空間(SRAM)から直接取得                                                                     | $Rd \leftarrow (Z + q)$ $Rd \leftarrow (k)$                                                                                                        | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C                   | 2        |
| ST           | X,Rr            | Xレジスタ間接での設定                                                                                              | $(X) \leftarrow Rr$                                                                                                                                | I,T,H,S,V,N,Z,C                                      | 2        |
| ST           | X+,Rr           | 事後増加付きXレジスタ間接での設定                                                                                        | $(X) \leftarrow Rr, X \leftarrow X + 1$                                                                                                            | I,T,H,S,V,N,Z,C                                      | 2        |
| ST           | -X,Rr           | 事前減少付きXレジスタ間接での設定                                                                                        | $X \leftarrow X - 1$ , $(X) \leftarrow Rr$                                                                                                         | I,T,H,S,V,N,Z,C                                      | 2        |
| ST           | Y,Rr            | Yレジスタ間接での設定                                                                                              | $(Y) \leftarrow Rr$                                                                                                                                | I,T,H,S,V,N,Z,C                                      | 2        |
| ST<br>ST     | Y+,Rr<br>-Y,Rr  | 事後増加付きYレジスタ間接での設定                                                                                        | $(Y) \leftarrow Rr, Y \leftarrow Y + 1$<br>$Y \leftarrow Y - 1, (Y) \leftarrow Rr$                                                                 | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C                   | 2 2      |
| STD          | -Y,Rr<br>Y+q,Rr | 事前減少付きYレジスタ間接での設定<br>変位付きYレジスタ間接での設定                                                                     | $(Y \leftarrow Y - 1, (Y) \leftarrow Rr$<br>$(Y + q) \leftarrow Rr$                                                                                | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C                   | 2        |
| ST           | Z,Rr            | Zレジスタ間接での設定                                                                                              | $(Z) \leftarrow Rr$                                                                                                                                | I,T,H,S,V,N,Z,C                                      | 2        |
| ST           | Z+,Rr           | 事後増加付きZレジスタ間接での設定                                                                                        | $(Z) \leftarrow Rr, Z \leftarrow Z + 1$                                                                                                            | I,T,H,S,V,N,Z,C                                      | 2        |
| ST           | -Z,Rr           | 事前減少付きZレジスタ間接での設定                                                                                        | $Z \leftarrow Z - 1$ , $(Z) \leftarrow Rr$                                                                                                         | I,T,H,S,V,N,Z,C                                      | 2        |
| STD          | Z+q,Rr          | 変位付きZレジスタ間接での設定                                                                                          | $(Z + q) \leftarrow Rr$                                                                                                                            | I,T,H,S,V,N,Z,C                                      | 2        |
| STS          | k,Rr            | データ空間(SRAM)へ直接設定                                                                                         | $(k) \leftarrow Rr$                                                                                                                                | I,T,H,S,V,N,Z,C                                      | 2        |
| LPM<br>LPM   | Rd,Z            | プログラム領域からZレジスタ間接での取得<br>同上(任意のレジスタへ)                                                                     | $ R0 \leftarrow (Z) \\ Rd \leftarrow (Z) $                                                                                                         | I,T,H,S,V,N,Z,C                                      | 3        |
| LPM          | Rd,Z+           | 同上(事後増加付き)                                                                                               | $Rd \leftarrow (Z)$<br>$Z \leftarrow Z + 1$                                                                                                        | I,T,H,S,V,N,Z,C                                      | 3        |
| SPM          |                 | プログラム領域へZレジスタ間接での設定                                                                                      | $(Z) \leftarrow R1:R0$                                                                                                                             | I,T,H,S,V,N,Z,C                                      | _        |
| IN           | Rd,P            | I/Oレジスタからの入力                                                                                             | Rd ← P                                                                                                                                             | I,T,H,S,V,N,Z,C                                      | 1        |
| OUT          | P,Rr            | I/Oレジスタへの出力                                                                                              | P ← Rr                                                                                                                                             | I,T,H,S,V,N,Z,C                                      | 1        |
| PUSH<br>POP  | Rr<br>Rd        | 汎用レジスタをスタックへ保存<br>スタックから汎用レジスタへ復帰                                                                        | STACK ← Rr<br>Rd ← STACK                                                                                                                           | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C                   | 2        |
| гОг          | Nu              |                                                                                                          | IK STACK                                                                                                                                           | 1, 1, 11, 0, V, N, L, C                              | 4        |
| SBI          | P,b             | I/Oレジスタのビット設定(1)                                                                                         | $I/O(P,b) \leftarrow 1$                                                                                                                            | I,T,H,S,V,N,Z,C                                      | 2        |
| CBI          | P,b             | I/Oレジスタのビット解除(0)                                                                                         | $I/O(P,b) \leftarrow 0$                                                                                                                            | I,T,H,S,V,N,Z,C                                      | 2        |
| LSL          | Rd              | 論理的左ビット移動                                                                                                | $Rd(n+1) \leftarrow Rd(n), Rd(0) \leftarrow 0$                                                                                                     | I,T,H,S,V,N,Z,C                                      | 1        |
| LSR<br>ROL   | Rd<br>Rd        | 論理的右ビット移動<br>キャリーを含めた左回転                                                                                 | $\begin{array}{l} Rd(n) \leftarrow Rd(n+1),  Rd(7) \leftarrow 0 \\ Rd(0) \leftarrow C,  Rd(n+1) \leftarrow Rd(n),  C \leftarrow Rd(7) \end{array}$ | I,T,H,S,V,Ø,Z,C<br>I,T,H,S,V,N,Z,C                   | 1        |
| ROR          | Rd              | キャリーを含めた右回転                                                                                              | $Rd(0) \leftarrow C$ , $Rd(1) \leftarrow Rd(1)$ , $C \leftarrow Rd(1)$<br>$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                                      | 1        |
| SWAP         | Rd              | ニブル(4ビット)上位/下位交換                                                                                         | $Rd(7\sim4) \Leftrightarrow Rd(3\sim0)$                                                                                                            | I,T,H,S,V,N,Z,C                                      | 1        |
| BSET         | S               | ステータス レシブスタのビット設定(1)                                                                                     | $SREG(s) \leftarrow 1$                                                                                                                             | 1,T,H,\$,Y,N,X,C                                     |          |
| BCLR         | S               | ステータス レシ・スタのビット解除(0)                                                                                     | $SREG(s) \leftarrow 0$                                                                                                                             | 0,0,0,0,0,0,0,0                                      | 1        |
| BST<br>BLD   | Rr,b<br>Rd,b    | 汎用レジ、スタのビットを一時フラグへ移動<br>  一時フラグを汎用レジ、スタのビットへ移動                                                           | $T \leftarrow Rr(b)$ $Rd(b) \leftarrow T$                                                                                                          | I, <b>T</b> ,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C          | 1        |
| SEC          | ru,D            | キャリー フラグを設定(1)                                                                                           | $C \leftarrow 1$                                                                                                                                   | I,T,H,S,V,N,Z,C                                      |          |
| CLC          |                 | キャリー フラク・を解除( <mark>0</mark> )                                                                           | C ← 0                                                                                                                                              | I,T,H,S,V,N,Z, <b>0</b>                              |          |
| SEN          |                 | 負フラグを設定(1)                                                                                               | N ← 1                                                                                                                                              | I,T,H,S,V,N,Z,C                                      | 1        |
| CLN          |                 | 負フラグを解除(0)                                                                                               | $N \leftarrow 0$                                                                                                                                   | I,T,H,S,V,0,Z,C                                      | 1        |
| SEZ<br>CL 7  |                 | セ <sup>i</sup> ロ フラク <sup>i</sup> を設定( <u>1</u> )<br>  セ <sup>i</sup> ロ フラク <sup>i</sup> を解除( <u>0</u> ) |                                                                                                                                                    | I,T,H,S,V,N, <b>1</b> ,C<br>I,T,H,S,V,N, <b>0</b> ,C | 1        |
| CLZ<br>SEI   |                 | ゼロ / 7/7 を解除(U)   全割り込み許可                                                                                | Z ← 0<br>I ← 1                                                                                                                                     | 1, T, H, S, V, N, Ø, C<br>1, T, H, S, V, N, Z, C     | 1        |
| CLI          |                 | 全割り込み禁止                                                                                                  | I ← 0                                                                                                                                              | 0,T,H,S,V,N,Z,C                                      | 1        |
| SES          |                 | 符号フラグを設定(1)                                                                                              | S ← 1                                                                                                                                              | I,T,H,\$,V,N,Z,C                                     | 1        |
| CLS          |                 | 符号フラグを解除(0)                                                                                              | S ← 0                                                                                                                                              | I,T,H,0,V,N,Z,C                                      | 1        |
| SEV          |                 | 2の補数溢れフラグを設定(1)                                                                                          | $V \leftarrow 1$                                                                                                                                   | I,T,H,S,Y,N,Z,C                                      | 1        |
| CLV<br>SET   |                 | 2の補数溢れフラグを解除( <mark>0</mark> )<br>一時フラグを設定( <u>1</u> )                                                   | V ← 0<br>T ← 1                                                                                                                                     | I,T,H,S, <b>V</b> ,N,Z,C<br>I,T,H,S,V,N,Z,C          | 1        |
| CLT          |                 | 一時フラグを設定(1)<br>一時フラグを解除(0)                                                                               | $T \leftarrow 1$ $T \leftarrow 0$                                                                                                                  | I, <b>1</b> ,n,s,v,N,Z,C                             | 1        |
| SEH          |                 | ハーフキャリー フラグを設定(1)                                                                                        | H ← 1                                                                                                                                              | I,T,H,S,V,N,Z,C                                      | 1        |
| CLH          |                 | ハーフキャリー フラグを解除(0)                                                                                        | H ← 0                                                                                                                                              | I,T, <b>0</b> ,S,V,N,Z,C                             | 1        |
|              |                 |                                                                                                          | 御命令                                                                                                                                                | I m I I o I i i i                                    |          |
| NOP          |                 | 無操作<br>休止形態開始                                                                                            |                                                                                                                                                    | I,T,H,S,V,N,Z,C                                      | 1        |
| SLEEP<br>WDR |                 | 1个上が態開始 <br>  ウォッチト゛ック゛ タイマ リセット                                                                         | か上が態参照<br>  ウォッチト、ッケ、タイマ参照                                                                                                                         | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C                   | 1        |
| BREAK        |                 | 一時停止                                                                                                     | 内蔵デバッグWIRE機能専用                                                                                                                                     | I,T,H,S,V,N,Z,C                                      |          |
|              |                 | ,.=                                                                                                      | , , , , , , , , , , , , , , , , , , ,                                                                                                              | -, -, 1, 2, 0, 7, 1, 1, 2, 0                         | - 1/ 4 1 |





# 26. 注文情報

| <b>デバイ</b> ス | 速度(MHz) | 電源電圧     | 注文コード(注1,2,3) | 外囲器      | 動作範囲           |
|--------------|---------|----------|---------------|----------|----------------|
|              |         |          | ATtiny48-MMU  |          |                |
|              |         |          | ATtiny48-MMUR | 28M1     |                |
|              |         |          | ATtiny48-MMH  | 201/11   |                |
|              |         |          | ATtiny48-MMHR |          |                |
|              |         |          | ATtiny48-PU   | 28P3     |                |
| ATtiny48     | 12      | 1.8~5.5V | ATtiny48-AU   | 32A      |                |
|              |         |          | ATtiny48-AUR  | 32A      |                |
|              |         |          | ATtiny48-CCU  | 32CC1    | 工業用 (−40℃∼85℃) |
|              |         |          | ATtiny48-CCUR | 32001    |                |
|              |         |          | ATtiny48-MU   | 32M1-A   |                |
|              |         |          | ATtiny48-MUR  | JZIVII A |                |
|              |         |          | ATtiny88–MMU  |          |                |
|              |         |          | ATtiny88-MMUR | 28M1     |                |
|              |         |          | ATtiny88-MMH  | 20111    |                |
|              |         |          | ATtiny88-MMHR |          |                |
|              |         |          | ATtiny88–PU   | 28P3     |                |
| ATtiny88     | 12      | 1.8~5.5V | ATtiny88–AU   | 32A      |                |
|              |         |          | ATtiny88–AUR  | 0211     |                |
|              |         |          | ATtiny88-CCU  | 32CC1    |                |
|              |         |          | ATtiny88-CCUR | 52CC1    |                |
|              |         |          | ATtiny88-MU   | 32M1-A   |                |
|              |         |          | ATtiny88-MUR  | JANII A  |                |

注1: 符号識別子は次のとおりです。

・H: ニッケル・パラシ'ウム・金(NiPdAu)仕上げ。

• U: 半光沢錫。

• R: テープ とリール。

注2: 全ての外囲器は鉛フリー、ハロケン化合物フリーで完全に安全で、これらは有害物質使用制限に関する欧州指令(RoHS指令)に 適合します。

注3: このデバイスはウェハー(チップ単体)形状でも供給できます。最低数量と詳細な注文情報については最寄のAtmel営業所へお問い合わせください。

|        | 外囲器形式                                                  |  |  |  |  |  |
|--------|--------------------------------------------------------|--|--|--|--|--|
| 28M1   | 28パッド4×4×1mm 0.45mmピッチ 4方向平板リードなし外囲器 (QFN)             |  |  |  |  |  |
| 28P3   | 28ピン 300mil幅 プラスティック2列直線外囲器 (PDIP)                     |  |  |  |  |  |
| 32A    | 32リード1.0mm厚 プラスティック4方向平板外囲器 (TQFP)                     |  |  |  |  |  |
| 32CC1  | 32球(6×6配列) 4×4×0.6mm 0.50mmピッチ 超薄型密ピッチ球格子配列外囲器 (UFBGA) |  |  |  |  |  |
| 32M1-A | 32パッド5×5×1mm 0.5mmピッチ 4方向平板リードなし外囲器 (QFN)              |  |  |  |  |  |

# 27. 外囲器情報

#### 27.1. 32A



#### 27.2. 28P3



# 27.3. 28M1



# 27.4. 32M1-A







# 27.5. 32CC1



# 28. 障害情報

この章の改訂番号はATtiny48/88デバイスの改訂版を参照してください。

ATtiny48改訂A,B : 試供されていません。 ATtiny48改訂C : 既知の障害はありません。 ATtiny88改訂A : 試供されていません。 ATtiny88改訂B,C : 既知の障害はありません。





# 29. データシート改訂履歴

本項内の頁参照が本資料の現状版を参照していることに注意してください。

### 29.1. 改訂8008A - 2008年6月

1. 初版

# 29.2. 改訂8008B - 2008年6月

- 1. 37頁で「**入出力ポート**」の「**序説**」を更新
- 2. 134頁の「DC特性」を更新
- 3. 144頁に「代表特性」を追加

### 29.3. 改訂8008C - 2009年3月

- 1. 項更新
  - ・1頁の「特徴」
  - ・8頁の「リセットと割り込みの扱い」
  - ・15頁の「EECR EEPROM制御レジスタ」
  - ・84頁の「特徴」
  - 87頁の「ビット速度発生器」
  - 102頁の「TWBR TWI ビット速度レジスタ」
  - ・104頁の「TWHSR TWI 高速レジスタ」
  - 105頁の「アナログ比較器」
  - ・107頁の「概要」
  - ・108頁の「操作」
  - 108頁の「変換の開始」
  - ・130頁の「施錠ビット書き込み」
  - ・134頁の「絶対最大定格」
  - ・134頁の「**DC特性**」
  - ・135頁の「速度」
  - ・183頁の「レジスタ要約」
- 2. 項追加
  - ・17頁の「高速TWIクロック-clkTWIHS」
  - 137頁の「アナログ・比較器特性」
- 3. 17頁の図6-1.を更新
- 4. リート・枠合成に於ける変更を反映するために188頁の注文符号を更新

#### 29.4. 改訂8008D - 2010年3月

- 1. 代表特性図分離、164頁に「23.2. ATtiny88」項を追加
- 2. 更新
  - ・3頁の「1.1. ピン説明」項、ポートD、「吸い込みと吐き出し」と「高い吸い込み」文字補正
  - ・TBD修正のため、18頁の表6-3.を補正(訳注:後に削除)
  - ・TBD修正のため、18頁の「6.2.3. 128kHz内部発振器」項を補正
  - ・27頁の「8.4. ウォッチト゛ック゛タイマ」項を更新
  - ・135頁の「**22.2. DC特性**」項で注5と8のTBDを更新
- 3. 追加
  - ・1頁の「特徴」、2頁の「ピン配置」、188頁の「26. 注文情報」章、189頁の「27. 外囲器情報」でのUFBGA外囲器(32CC1)
  - ・レジスタ要約への相互参照で全てのレジスタ説明表でのアトレス
  - 188頁の「26. 注文情報」章でのテープとリール

#### 29.5. 改訂8008E - 2010年5月

- 1. 183頁の24章「レシ、スタ要約」でアトレス\$3EにSPHを追加
- 2. 正しい外囲器図で189頁の27.1.項「28M1」を更新

# 29.6. 改訂8008F - 2010年6月

- 1. 134頁の「22.2. DC特性」の表で注の1と10を更新
- 2. 190頁の「27.5. 32CC1」で外囲器図を更新
- 3. データシート全体を通してビット表記法を更新、例えばCS02:0からCS0[2:0]へ (訳注:本書では表記法が異なるため無効)

# 29.7. 改訂8008G - 2011年4月

- 1. 更新
  - ・4頁の「構成図」
  - ・11頁の「**メモリ**」
  - 17頁の「クロック体系」
  - ・121頁の「施錠ビット、ヒュース゛ビット、デバイス識票」
  - ・124頁の「**外部プログラミング**」
  - ・135頁の「速度」
  - ・139頁の「**2線直列インターフェース特性**」
- 2. 追加
  - ・5頁の「容量性接触感知」
  - ・10頁の「コア関係レジスタ」
  - ・84頁の「概要」
  - 101頁の「SMBusとの適合性」
- 3. 資料の状況を"暫定"から"最終"に変更

# 29.8. 改訂8008H - 2011年4月

- 1. 更新
  - 188頁の「注文情報」、テープとリールの符号-MMURを追加





# 目次

|     | 特徴・・・・・・・・・・・・・・・・・・・・・・・ 1                                                   |     |               | 概要 ••••••                                                       |              |
|-----|-------------------------------------------------------------------------------|-----|---------------|-----------------------------------------------------------------|--------------|
| 1   | <b>ピン配置 ・・・・・・・・・</b> 2                                                       |     |               | タイマ/カウンタのクロック ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・               |              |
| ٠.  | 1.1. L°ン説明 ······· 3                                                          |     |               | 計数器部 ••••••                                                     |              |
| ^   | 1.1. Cノのルタオ                                                                   |     | 11.5.         | 出力比較部 ************************************                      | •• 52        |
| 2.  | 概要 4                                                                          |     | 11.6.         | 動作種別                                                            | • • 53       |
|     | 2.1. 構成図                                                                      |     |               | タイマ/カウンタのタイミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・              |              |
|     | <b>2.2</b> . ATtiny48とATtiny88間の違い ・・・・・・ 5                                   |     |               | 8ビットタイマ/カウンタ0用レジスタ ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・         |              |
| 3.  | <b>一般情報 · · · · · · · · </b> 5                                                | 10  |               | ト タイマ/カウンタ1 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                |              |
|     | 3.1. 資料                                                                       | 12. |               | d Lade                                                          | • 57         |
|     | <b>3.2.</b> コート 例について ······ 5                                                |     | 12.1.         |                                                                 |              |
|     | 3.3. 容量性接触感知                                                                  |     |               | 概要                                                              |              |
|     | 3.4. データ保持力 · · · · · · · · · · · · · · · · · · ·                             |     | 12.3.         | 16ピットレジスタのアクセス・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・              | • • 59       |
|     | <b>3.5.</b> お断り · · · · · · · · · · · · · · · · · · ·                         |     |               | タイマ/カウンタのクロック ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・               |              |
| 1   | AVR CPU 37 · · · · · 6                                                        |     |               | 計数器部 ••••••                                                     |              |
| 4.  |                                                                               |     | 12.6.         | 捕獲入力部 · · · · · · · · · · · · · · · · · · ·                     | •• 62        |
|     | 4.1. 序説                                                                       |     | 12.7.         | 比較出力部 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                      | •• 63        |
|     | 4.2. 構造概要                                                                     |     | 12.8.         | 比較一致出力部 ••••••                                                  |              |
|     | 4.3. ALU (Arithmetic Logic Unit) · · · · 6                                    |     | 12.9.         |                                                                 |              |
|     | <b>4.4.</b> ステータス レシ スタ · · · · · · · 7                                       |     |               | タイマ/カウンタのタイミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・              |              |
|     | 4.5. 汎用レジスタ ファイル・・・・・・・ 7                                                     |     | 12.11.        | 16ビット タイマ/カウンタ1用レジスタ ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・       | • • 71       |
|     | <b>4.6.</b> スタック ホ°インタ ・・・・・・・・・・ 7                                           | 13  |               | カウンタ0とタイマ/カウンタ1の前置分周器・・                                         |              |
|     | <b>4.7.</b> 命令実行タイミング・・・・・・・8                                                 | 10. | 13.1.         |                                                                 |              |
|     | 4.8. リセットと割り込みの扱い・・・・・・8                                                      |     |               | 前置分周器リセット・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                   | 70           |
|     | 4.9. コア関係レジスタ・・・・・・・・・・・・・・・・・10                                              |     | 13.2.         | 外部クロック元・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                      |              |
| 5   | <b>片り ・・・・・・・・・・・・・・・・・</b> 11                                                |     | 13.3.         |                                                                 |              |
| ٥.  | 5.1. プログラム メモリ ・・・・・・・・・ 11                                                   |     |               | タイマ/カウンタ前置分周器制御用レジスタ・・・・・                                       |              |
|     | 5.2. データ メモリ(SRAM)とレジスタ ファイル ・・・・・・・11                                        | 14. | SPI (I        | 直列周辺インターフェース)・・・・・・・・・                                          | • 78         |
|     | 5.3. $\bar{\tau}$ -9 $\star$ +U(EEPROM) · · · · · · · · · · · · · · · · · · · |     |               | 特徴 •••••                                                        |              |
|     | 5.4. メモリ関係レジスタ・・・・・・・・15                                                      |     |               | 概要 ••••••                                                       |              |
| _   |                                                                               |     | 14.3.         | SSt°ンの機能・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                    |              |
| 6.  | <b>クロック体系</b> 17                                                              |     | 14.4.         |                                                                 |              |
|     | 6.1. クロック副系統 ・・・・・・・・・・17                                                     |     | 14.5.         | SPI用レジスタ ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                   | • 82         |
|     | <b>6.2. クロック元 ・・・・・・・・・・</b> 17                                               | 15  | 2線イ           | ンターフェース(TWI)・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                | <b>8</b> 4   |
|     | 6.3. システム クロック前置分周器 ・・・・・・・・19                                                |     | 15.1.         | at Linux                                                        | 84           |
|     | 6.4. システム クロック出力緩衝部 ・・・・・・・19                                                 |     |               | <u>12 22</u>                                                    |              |
|     | <b>6.5. クロック起動手順 ・・・・・・・・・・・</b> 19                                           |     |               |                                                                 |              |
|     | 6.6. クロック関係レジスタ・・・・・・・・・・20                                                   |     | 15.4.         |                                                                 | 05           |
| 7.  | 電力管理と休止形態・・・・・・・・・ 21                                                         |     |               | 複数主装置バスシステムの調停と同期・・・・・                                          |              |
| •   | 7.1. 休止形態種別                                                                   |     | 15.5.         |                                                                 |              |
|     | 7.2. ソフトウェア低電圧検出器(BOD)禁止・・・・・・・・ 21                                           |     | 15.6.         | TWI部の概要 ····································                    | 01           |
|     | 7.3. 消費電力の最小化 ・・・・・・・・・・・・ 22                                                 |     |               |                                                                 |              |
|     | 7.4. 電力管理用レジスタ・・・・・・・・・・・23                                                   |     | 15.8.         |                                                                 |              |
| 0   | システム制御とリセット・・・・・・・・・・・・25                                                     |     | 15.9.         |                                                                 |              |
| Ö.  | 8.1. AVRのリセット ・・・・・・・・・・25                                                    |     | 15.10.        | SMBusとの適合性 ····································                 | • 101        |
|     | 8.1. AVROJETY                                                                 |     |               | TWI用レジスタ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                    |              |
|     | 8.2. リセット元 · · · · · · · · · · · · · · · · · · ·                              | 16. |               | `比較器 • • • • • • • • • • • • • • • • • • •                      |              |
|     | 8.3. 内部基準電圧                                                                   |     |               | アナログ比較器入力選択・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                 |              |
|     | <b>8.4.</b> ウォッチト ック タイマ · · · · · 27                                         |     | 16.2.         | アナログ比較器用レジスタ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                | • 105        |
|     | 8.5. リセット関係レシ、スタ・・・・・・・・・29                                                   | 17  | A/D刻          | 变换器 ••••••                                                      | 107          |
| 9.  | 割り込み ・・・・・・・・・・ 31                                                            | .,. | 171           | 特徴 ······                                                       | • 107        |
|     | 9.1. 割り込みベクタ ・・・・・・・・・・ 31                                                    |     |               | 概要 ••••••                                                       |              |
|     | <b>9.2</b> . 外部割り込み ······· 32                                                |     |               | 操作 ····································                         |              |
|     | 9.3. 外部割り込み用レジスタ・・・・・・ 33                                                     |     | 17.5.<br>17.4 | 変換の開始・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                       | - 100        |
| 10  | 入出力ポート・・・・・・・・・・・・・・・37                                                       |     | 17.4.<br>17.5 | 前置分周と変換タイミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                | - 100<br>100 |
| 10. | 10.1. 序説                                                                      |     | 17.0.         | 明直分周と変換すミグ<br>チャネル変更と基準電圧選択・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | - 105        |
|     | 10.1. 序説 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                  |     |               | アヤイル 変更 C 基件 電                                                  | • 110        |
|     |                                                                               |     | 17.7.         | 雜音低減機能 · · · · · · · · · · · · · · · · · · ·                    |              |
|     | 10.3. 交換ポート機能 ・・・・・・・・・・・・・・・・・ 41<br>10.4. I/Oポート用レジスタ ・・・・・・・・・・・・・・ 49     |     | 17.8.         | アナログ入力回路 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                   | • 111        |
|     |                                                                               |     | 17.9.         | アナログ雑音低減技術・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                  | • 111        |
| 11. | 8ビット <b>タイマ/カウンタ0 ·····</b> 51                                                |     | 17.10.        | A/D変換の精度定義・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                  | • 112        |
|     | 11.1. 特徴                                                                      |     | 17.11.        | A/D変換の結果・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                    | • 112        |
|     |                                                                               |     |               |                                                                 |              |

|     | 17.12.         | 温度測定 ••••••                                                              | • 112                   |
|-----|----------------|--------------------------------------------------------------------------|-------------------------|
|     |                | A/D変換用レジスタ ····································                          |                         |
| 18. | デバッ            | グWIRE内蔵デバッグ機能 ・・・・・・・・・                                                  | 116                     |
|     | 18.1.          | 特徵                                                                       | <ul> <li>116</li> </ul> |
|     | 18.2.          | 概要                                                                       | • 116                   |
|     | 18.3.          | 物理インターフェース・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                            | • 116                   |
|     | 18.4.          | ソフトウェア中断点・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                            | • 116                   |
|     | 18.5.          | <i>〒゙バッグ</i> WIREの制限・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                 | • 116                   |
|     | 18.6.          | デバッグWIRE用レジスタ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                        |                         |
| 19. | フラッシ           | ュの自己プログラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                          |                         |
|     | 19.1.          | 自己プログラミングでのフラッシュアドレス指定・・・・                                               |                         |
|     | 19.2.          | 自己プログラミング用レジスター・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                      |                         |
| 20. | 施錠b            | ごット、ヒュース゛ヒ゛ット、デバイス識票・・・・・・                                               | 121                     |
|     | 20.1.          | 施錠ビット ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                               | • 121                   |
|     | 20.2.          | ヒュース゛ヒ゛ット・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                             | • 122                   |
|     | 20.3.          | 識票バイト ・・・・・・・・・・・・・・・・・・・・・・・ 校正バイト ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | • 123                   |
|     | 20.4.          | 校正バイト ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                               | • 123                   |
| 21. |                | プログラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                              | 124                     |
|     | 21.1.          | メモリ ハプラメータ ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                          | • 124                   |
|     | 21.2.          | 並列プログラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                             | • 124                   |
|     | 21.3.          | 直列プログラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                             |                         |
|     | 21.4.          | フラッシュとEEPROM用のプログラミング時間・・・・                                              |                         |
| 22. |                | 的特性 • • • • • • • • • • • • • • • • • • •                                | 134                     |
|     | 22.1.          |                                                                          | • 134                   |
|     | 22.2.          | DC特性····································                                 | • 134                   |
|     | 22.3.<br>22.4. | 速度 ····································                                  | 135                     |
|     | 22.4.<br>22.5. | システムとリセットの特性 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                        | • 130<br>• 197          |
|     | 22.5.<br>22.6. | マナログトが発体性・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                            | • 137                   |
|     | 22.7.          | アナログ 比較器特性 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                          | • 138                   |
|     | 22.8.          | 2線直列インターフェース特性・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                       | • 139                   |
|     | 229            | SPI タイミング特性 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                         | <b>1</b> 40             |
|     | 22.10.         | 並列プログラミング特性・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                          | • 141                   |
|     | 22.11.         | 並列プログラミング特性 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                         | • 143                   |
| 23. | 代表             | <b>恃性 • • • • • • • • • • • • • • • • • • •</b>                          | 144                     |
|     | 23.1.          | ATtinv48 · · · · · · · · · · · · · · · · · · ·                           | <ul> <li>144</li> </ul> |
|     | 23.2.          | ATtiny88 · · · · · · · · · · · · · · · · · ·                             | • 164                   |
| 24. | レジスタ           | 要約 • • • • • • • • • • • • • • • • • • •                                 | 183                     |
| 25  | 命令             | ATtiny88 ···································                             | 186                     |
| 26  | 注文             | 李叝                                                                       | 188                     |
| 20. | ᄊᄪ             | 青報 · · · · · · · · · · · · · · · · · · ·                                 | 100                     |
| 21. | アロー            | 价   月 FIX                                                                | 101                     |
| 28. | 障害(            | 再 <b>知</b>                                                               | 191                     |
| 29. | テータ            | ,ト改訂履歴 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                              | • 192                   |





#### 本社

#### Atmel Corporation

2325 Orchard Parkway San Jose, CA 95131 USA

TEL 1(408) 441-0311 FAX 1(408) 487-2600

# 国外営業拠点

#### Atmel Asia Limited

Unit 1-5 & 16, 19/F BEA Tower, Millennium City 5 418 Kwun Tong Road Kwun Tong, Kowloon HONG KONG

TEL (852) 2245-6100 FAX (852) 2722-1369

#### Atmel Munich GmbH

Business Campus
Parking 4
D-85748 Garching b. Munich
GERMANY

TEL (+49) 89-31970-0 FAX (+49) 89-3194621

## Atmel Japan

141-0032 東京都品川区 大崎1-6-4 新大崎勧業ピル 16F アトメル ジャハン株式会社 TEL (+81)(3)-6417-0300 FAX (+81)(3)-6417-0370

# 製品窓口

# ウェブサイト

www.atmel.com

## 文献請求

www.atmel.com/literature

# 技術支援

avr@atmel.com

# 販売窓口

www.atmel.com/contacts

お断り:本資料内の情報はAtmel製品と関連して提供されています。本資料またはAtmel製品の販売と関連して承諾される何れの知的所有権も禁反言あるいはその逆によって明示的または暗示的に承諾されるものではありません。Atmelのウェブサイに位置する販売の条件とAtmelの定義での詳しい説明を除いて、商品性、特定目的に関する適合性、または適法性の暗黙保証に制限せず、Atmelはそれらを含むその製品に関連する暗示的、明示的または法令による如何なる保証も否認し、何ら責任がないと認識します。たとえるtmelがそのような損害賠償の可能性を進言されたとしても、本資料を使用できない、または使用以外で発生する(情報の損失、事業中断、または利益の損失に関する制限なしの損害賠償を含み)直接、間接、必然、偶然、特別、または付随して起こる如何なる損害賠償に対しても決してAtmelに責任がないでしょう。Atmelは本資料の内容の正確さまたは完全性に関して断言または保証を行わず、予告なしでいつでも製品内容と仕様の変更を行う権利を保留します。Atmelはここに含まれた情報を更新することに対してどんな公約も行いません。特に別の方法で提供されなければ、Atmel製品は車載応用に対して適当ではなく、使用されるべきではありません。Atmel製品は延命または生命維持を意図した応用での部品としての使用に対して意図、認定、または保証されません。

© Atmel Corporation 2011. 不許複製 Atmel®、ロゴとそれらの組み合わせ、AVR®とその他はAtmel Corporationの登録商標または商標またはその付属物です。他の用語と製品名は一般的に他の商標です。

#### © HERO 2022.

本データシートはAtmelのATtiny48/88英語版データシート(改訂8008H-04/11)の翻訳日本語版です。日本語では不自然となる重複する 形容表現は省略されている場合があります。日本語では難解となる表現は大幅に意訳されている部分もあります。必要に応じて一部 加筆されています。 頁割の変更により、原本より頁数が少なくなっています。

汎用入出力ポートの出力データレジスタとピン入力は、対応関係からの理解の容易さから出力レジスタと入力レジスタで統一表現されています。一部の用語がより適切と思われる名称に変更されています。必要と思われる部分には()内に英語表記や略称などを残す形で表記しています。

青字の部分はリンクとなっています。一般的に赤字の0,1は論理0,1を表します。その他の赤字は重要な部分を表します。 原書に対して若干構成が異なるため、一部の項番号が異なります。