# 特徴

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

# ■ データ メモリと不揮発性プログラム メモリ

- ・実装自己書き換え(ISP)可能な2Kバイト(1K語)フラッシュメモリ内蔵
  - ・10,000回の書き換え可能
- 実装書き換え可能な128パイのEEPROM
  - ・100,000回の書き換え可能
- 128バイの内蔵SRAM
- ・プログラム用フラッシュ メモリとデータ用EEPROM保護用の設定可能な施錠機能

#### ■ 内蔵周辺機能

- ・分離された前置分周器と比較動作付き1つの8ビットタイマ/カウンタ
- ・分離された前置分周器と比較、捕獲動作付き1つの16ビットタイマ/カウンタ
- 4つのPWM出力
- ・アナログ比較器
- ・設定可能な専用発振器付きウォッチト、ック、タイマ
- ・多用途直列インターフェース(USI)
- 全二重USART

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

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

## ■ I/Oと外囲器

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

## ■ 動作電圧

- 1.8~5.5V (ATtiny2313V)
- 2.7~5.5V (ATtiny2313)

#### ■ 動作速度

- ATtiny2313V:
  - $0\sim4 MHz/1.8\sim5.5 V$
  - 0~10MHz/2.7~5.5V
- ATtiny2313 :
  - $0 \sim 10 MHz/2.7 \sim 5.5 V$
  - $\cdot 0 \sim 20 MHz/4.5 \sim 5.5 V$

#### ■ 代表消費電力

- · 230µA (1MHz,1.8V,活動動作)
- · 20µA (32kHz,1.8V,活動動作)
- ・0.1μA未満 (1.8V,パワータ`ウン動作)





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

ATtiny2313 ATtiny2313V

Rev. 2543M-10/16, 2543MJ3-06/22





# ピン配置



# 概要

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

# 構成図



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





ATtiny2313は2Kハ・ハの実装書き込み可能なフラッシュメモリ、128ハ・ハのEEPROM、128ハ・ハのSRAM、18本の汎用入出力線、32個の汎用作業レジ、スタ、内蔵デ・バック・用の単線インターフェース、比較動作付きの2つの柔軟なタイマ/カウンタ、内部及び外部割り込み、設定変更可能な直列USART、開始条件検出器付き多用途直列インターフェース(USI)、内蔵発振器付きの設定変更可能なウォッチト・ック・タイマ、ソフトウェアで選択できる3つの低消費動作を提供します。アイトル動作はCPUを停止し、一方SRAM、タイマ/カウンタ、割り込み機構に機能の継続を許します。ハ・ワータ・ウン動作は発振器を停止しますがレジ、スタの内容を保護し、以降のハート・ウェアリセットか外部割り込みまで他の全機能を禁止します。スタンハ・イ動作ではクリスタル発振子/セラミック振動子用発振器が動作する一方で、デ・バーイスのその他は休止します。これは低消費電力と非常に速い起動の組み合わせを許します。

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

ATtiny2313 AVRはCコンパイラ、マクロ アセンブラ、デバッカ、シミュレータ、インサーキット エミューレータ、評価キットを含む完全なプログラム及びシステム開発ツールで支援されます。

## ピン概要

VCC

電源ピン。

#### **GND**

接地ピン。

#### **PA2~PA0** (ポートA)

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

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

#### **PB7~PB0**(本°-トB)

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

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

#### **PD6~PD0** (ポートD)

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

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

## RESET

リセット入力。例えクロックが走行していなくても、最小パルス幅はり長いこのピンのLowレヘ・ルはリセットを生成します。最小パルス幅は120頁の表80.で与えられます。より短いパルスはリセットの生成が保証されません。リセット入力はPA2及びdW(デバッグWIRE)との切り替え機能です。

#### XTAL1

発振器反転増幅器への入力と内部クロック操作回路への入力。XTAL1はPA0との切り替え機能です。

# XTAL2

発振器反転増幅器からの出力。XTAL2はPA1との切り替え機能です。

# 一般情報

# 資料

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

# コード例

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

# データ保持力

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





# AVR CPU 17

#### 序説

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

# 構造概要

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

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

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

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

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

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

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

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

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

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

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

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



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

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

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

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

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

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

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

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

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

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

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

#### ■ ビット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**h1** - **Z** : **t**"**D 777** (Zero Flag)

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

#### **■ L** \* **vb O O** : **キャリー フラク** \* (Carry Flag)

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





# 汎用レジスタファイル

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

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

図4.はCPU内の32個の汎用作業レジスタの構造を示します。

レジスタファイルを操作する殆どの命令は全てのレジスタに直接アクセスし、それらの殆どは単一周期命令です。

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

| 図4. AV      | R CPU 汎用レジスタ構り | <b></b> |                       |
|-------------|----------------|---------|-----------------------|
|             | 7 0            | アドレス    |                       |
|             | R0             | \$00    |                       |
|             | R1             | \$01    |                       |
|             | R2             | \$02    |                       |
|             | }              |         |                       |
|             | R13            | \$0D    |                       |
|             | R14            | \$0E    |                       |
| уп 🖽        | R15            | \$0F    |                       |
| 汎用<br>レシブスタ | R16            | \$10    |                       |
| ファイル        | R17            | \$11    |                       |
| , , ,       | }              |         |                       |
|             | R26            | \$1A    | Xレジスター 下位バイト<br>上位バイト |
|             | R27            | \$1B    | 上位バイト                 |
|             | R28            | \$1C    | マレンブファ 下位バイト          |
|             | R29            | \$1D    | 上化ハイト                 |
|             | R30            | \$1E    | フレンブスター 下位バイト         |
|             | R31            | \$1F    | 上位バイト                 |

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

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

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

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

# ■ スタック ポインタ (Stack Pointer) SPL (SP)

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

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

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



# 命令実行タイミング

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

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

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





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

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

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

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

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

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

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

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





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

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

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

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

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

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

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

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

# AVR ATtiny2313のメモリ

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

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

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

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

定数表は全てのプログラム メモリ アドレス空間に配置できます。(LPM命令記述参照)

命令の取得と実行のタイミング図は9頁の「命令実行タイミング」で示されます。

# 図8. プログラム メモリ配置図 プログラム用 フラッシュ メモリ 1K×16 \$03FF

# データ用SRAM メモリ

図9.はATtiny2313のSRAMメモリ構成方法を示します。

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

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

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

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

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

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



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

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

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





# データ用EEPROMメモリ

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

#### **EEPROMアクセス**

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

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

予期せぬEEPROM書き込みを防止するため特別な書き込み手順に従わなければなりません。この詳細についてはEEPROM制御レジスタの説明と13頁の「非分離バー書き込み」と「分離バー書き込み」を参照してください(訳注:本行内容追加)。

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

#### ■ EEPROMアトレス レシ、スタ (EEPROM Address Register) EEAR

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

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

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

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

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

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

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

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

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

#### ■ **EEPROM制御レジスタ** (EEPROM Control Register) **EECR**

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

# 消去

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

## 書き込み

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

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





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

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

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

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

# EEPROMデータ化けの防止

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

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

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

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

# I/O メモリ (レジスタ)

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

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

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

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

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

# 汎用I/Oレジスタ

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

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

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

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

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

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

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





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

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

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



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

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

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

I/Oクロックはタイマ/カウンタやUSARTのようなI/O部の大部分で使われます。I/Oクロックは外部割り込み部でも使われますが、いくつかの外部割り込みは例えI/Oクロックが停止されても検出されることをこのような割り込みに許す非同期論理回路によって検出されることに注意してください。多用途直列(USI)部の開始条件検出はclk<sub>I/O</sub>が停止される時に非同期に実行され、全休止形態でUSI開始条件検出を可能とすることにも注意してください。

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

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

#### クロック元

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

各クロック選択に対する様々な選択は次項で得られます。CPUがハ<sup>o</sup>ワーダウンから起動するとき、選択したクロック元は命令実行開始前に安定な発振器動作を保証する起動時間に使われます。CPUがリセットから始まるとき、これらは通常動作開始前に安定電圧へ達するのを電源に許す付加遅延です。ウォッチトゥグ発振器は、この起動時間の実時間部のタイミングに使われます。各計時終了に使われるウォッチトゥグ(WDT)発振器の各周期数は表3.で示されます。121頁の「代表特性」で示されるようにウォッチトゥグ発振器の周波数は電圧に依存します。

| 表2. クロック種別選択          |           |  |  |  |  |
|-----------------------|-----------|--|--|--|--|
| クロック種別                | CKSEL3~0  |  |  |  |  |
| 外部クリスタル/セラミック発振子      | 1111~1000 |  |  |  |  |
| 128kHz内部(WDT)発振器      | 0110      |  |  |  |  |
| 8MHz校正付き内蔵RC発振器       | 0100      |  |  |  |  |
| 4MHz校正付き内蔵RC発振器       | 0010      |  |  |  |  |
| 外部クロック信号              | 0000      |  |  |  |  |
| (予約)                  | 0xx1      |  |  |  |  |
| 注・1=非プログラム ∩=プログラム v= | ·∩キた/ナ1   |  |  |  |  |

<u>注: 1=非プログラム、0=プログラム、x=0または1</u>

| 表3. WDT発振器の代表的計時終了値、周期数 |       |           |  |  |
|-------------------------|-------|-----------|--|--|
| VCC=3.0V                | 周期数   |           |  |  |
| 4.3ms                   | 4.1ms | 512       |  |  |
| 69ms                    | 65ms  | 8K (8192) |  |  |

## 既定のクロック元

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

# クリスタル用発振器

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

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

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

# 図12. クリスタル発振子接続図



# 表4. クリスタル用発振器動作

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

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

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

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

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

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

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





# 校正付き内蔵RC発振器 (訳注:共通性のため内容を一部追加/修正)

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

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

| CKSEL3~0 | 公称周波数 (MHz) |
|----------|-------------|
| 0 1 0 0  | 8.0 (注1)    |
| 0 0 1 0  | 4.0         |

ウュアが発振校正レジスタ(OSCCAL)に校正値バイトを設定し、これによってRC発振器を自動的に校正します。 3V,25℃でこの校正は公 称周波数±10%以内の周波数を与えます。atmel.com/avrで利用可能な応用記述に記載された実行時校正法の使用で、与えられた どのVCCと温度でも±2%の精度を達成することができます。この発振器がチップ(システム)クロックとして使われるとき、ウォッチト・ッケ発振器は 未だウォッチドッグタイマとリセット付加遅延タイマに使われます。予め設定された校正値のより多くの情報については、107頁の「**校正バイト**」 項をご覧ください。このデバイスはCKDIV8ヒュースがプログラム(0)で出荷されます。

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

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

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

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

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

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

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

■ ビット7 - Res: 予約 (Reserved) (訳注:共通性のため追加)

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

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

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

| ± ^ | # # 00 | <b>2</b> 6 4⊏ BB 6 | 事 2世 樂 | - 445 IIII |
|-----|--------|--------------------|--------|------------|
| ÆX  | 内蔵RC   | 至 振 态 l            | 引冷外    | * 审门  开    |

| OSCCAL値 | 公称周波数に対する割合 |       |  |  |
|---------|-------------|-------|--|--|
| USUCAL恒 | 最小          | 最大    |  |  |
| \$00    | 50 %        | 100 % |  |  |
| \$3F    | 75 %        | 150 % |  |  |
| \$7F    | 100 %       | 200 % |  |  |

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

# 外部クロック信号

ます。

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

| 表9. 外部クロック信号動作 |         |  |  |  |
|----------------|---------|--|--|--|
| CKSEL3~0       | 周波数範囲   |  |  |  |
| 0 0 0 0        | 0∼16MHz |  |  |  |

'0000'にプログラム(設定)されなければなりません。
このクロック元が選択されると、起動時間は**表10**.で示されるようにSUTヒューズによって決定され



| 表10    | 外部カロック   | 信号取制   | 田記動渥   | 延時間選択表 |
|--------|----------|--------|--------|--------|
| 1X IU. | フトロロノロノノ | 16 与敝野 | 川川に当川年 | 些时间选为农 |

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

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

システム クロック前置分周器が安定な動作を保証しながら、内部クロック周波数の実行時変更の実現に使えることに注意してください。詳細については20頁の「システム クロック前置分周器」を参照してください(<mark>訳注</mark>:共通性のため本行追加)。

# 128kHz内部発振器

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

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

表11.128kHz内部発振器用起動遅延時間選択表

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

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





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

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

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

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

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

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

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

# ■ クロック前置分周レシ、スタ (Clock Prescale Register) CLKPR

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

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

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

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

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

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

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

# 電力管理と休止形態

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

3つの休止形態の何れかへ移行するにはMCU制御レジスタ(MCUCR)の休止許可(SE)ビットが論理1を書かれ、SLEEP命令が実行されなければなりません。MCUCRの休止種別選択(SM1,0)ビットはSLEEP命令によって活性(有効)にされる休止形態(アイドル,パワーダウン, スタンハイ)のどれかを選びます。一覧については表13.をご覧ください。MCUが休止形態中に許可した割り込みが起こると、MCUは起動します。その時にMCUは起動時間に加えて4周期停止され、割り込みルーチンを実行し、そしてSLEEP命令の次の命令から実行を再開します。デハイスが休止から起動するとき、レジスタファイルとSRAMの内容は変えられません。休止形態中にリセットが起こると、MCUは起動し、リセット ヘブクから実行します。

16頁の図11.はATtiny2313の各種クロック系統とその配給を示します。この図は適切な休止形態を選択する助けになります。

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

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

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

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

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

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

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

| 表13. 休止形態種別選択  |   |          |  |  |  |  |  |  |  |  |
|----------------|---|----------|--|--|--|--|--|--|--|--|
| SM1 SM0 休止形態種別 |   |          |  |  |  |  |  |  |  |  |
| 0              | 0 | アイドル動作   |  |  |  |  |  |  |  |  |
| 0              | 1 | パプーダウン動作 |  |  |  |  |  |  |  |  |
| 1              | 0 | スタンハーイ動作 |  |  |  |  |  |  |  |  |
| 1              | 1 | パプーダウン動作 |  |  |  |  |  |  |  |  |

注: スタンバイ動作は外部クリスタル発振子また はセラミック振動子での使用に対してだけ 推奨されます。

# アイドル動作

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

ア介・ル動作はMCUにタイマ溢れやUSARTの送信完了などの内部割り込みだけでなく、外部で起動された割り込みからの起動も可能にします。アナログ比較器割り込みからの起動が必要とされないなら、アナログ比較器制御/状態レジ、スタ(ACSR)のアナログ比較器禁止(ACD)ビットを設定(1)することによってアナログ比較器を電源断にできます。これはアイデル動作での消費電力を削減します。

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

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

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

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

## スタンバイ動作

外部クリスタル発振子/セラミック振動子クロック種別が選択され、SM1,0ビットが'10'の時に、SLEEP命令はMCUをスタンバイ動作へ移行させます。この動作は(外部クリスタル用)発振器が走行(動作)を保たれる例外を除いてパワーダウン動作と同じです。デバイスはスタンバイ動作から6クロック周期で起動します。





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

|            | 動作クロック範囲   |              | 発振器動作     |              | 復帰起重              | 加要因(割り込み)     |                   |               |            |
|------------|------------|--------------|-----------|--------------|-------------------|---------------|-------------------|---------------|------------|
| 休止種別       | clk<br>CPU | clk<br>flash | clk<br>10 | 主クロック<br>供給元 | INT0,INT1<br>ピン変化 | USI開始条件<br>検出 | SPM/EEPROM<br>操作可 | ウォッチ<br>ト゛ック゛ | その他<br>I/O |
| アイドル       |            |              | 0         | 0            | 0                 | 0             | 0                 | 0             | 0          |
| パプータ・ウン    |            |              |           |              | 2                 | 0             |                   | 0             |            |
| スタンバイ (注1) |            |              |           | 0            | 2                 | 0             |                   | 0             |            |

注1: クロック元として推奨した外部クリスタル発振子またはセラミック振動子が選択された場合だけです。

② INT0とINT1についてはレヘル割り込みのみです。

# 消費電力の最小化

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

#### アナログ比較器

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

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

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

# 内部基準電圧

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

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

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

#### ポートピン

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

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

#### 内蔵デバッグ機能(dW)(訳注:共通性から追加)

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

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

#### AVRのリセット

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

AVRのI/Oポートはリセット元が有効になると直ちにそれらの初期状態にリセットされます。これはどのクロック元の走行も必要ありません。

全てのリセット元が無効にされてしまった後、遅延計数器(タイマ)が始動され、内部リセットを引き伸ばします。これは通常動作開始前に安定電圧へ達することを電源に許します。遅延タイマの遅延時間はSUTヒューズとCKSELヒューズを通して使用者によって定義されます。この遅延時間についての各種選択は16頁の「クロック元」で示されます。

## リセット元

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

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



# 電源ONリセット

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

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









## 外部リセット

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



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

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

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

BOD回路は電圧が表16.で与えられるtBOD時間より長く起動電圧以下に留まる場合のみ、VCCでの低下を検出します。



|   | 表16. 低電圧検出(BOD)特性 |               |    |    |    |    |  |  |  |  |  |
|---|-------------------|---------------|----|----|----|----|--|--|--|--|--|
|   | シンホ゛ル             | 項目            | 最小 | 代表 | 最大 | 単位 |  |  |  |  |  |
| I | V <sub>HYST</sub> | 低電圧検出ヒステリシス電圧 |    | 50 |    | mV |  |  |  |  |  |
| I | $t_{ m BOD}$      | 最小低電圧検出時間     |    | 2  |    | μs |  |  |  |  |  |

## 表15. BODLEVELヒューズ(VBOT) 設定(注1)

| BODLEVEL2~0    | 最小   | 代表  | 最大 | 単位 |  |  |  |  |  |
|----------------|------|-----|----|----|--|--|--|--|--|
| 111            | 低電圧  | 卜禁止 |    |    |  |  |  |  |  |
| 1 1 0          |      | 1.8 |    |    |  |  |  |  |  |
| 1 0 1          |      | 2.7 |    | V  |  |  |  |  |  |
| 1 0 0          |      | 4.3 |    |    |  |  |  |  |  |
| $000 \sim 011$ | (予約) |     |    |    |  |  |  |  |  |

注1: いくつかのデバイスでVBOTが公称最低動作電圧以下の可能性があります。この状態のデバイスについては製造検査中、VCC=VBOTに落として検査されています。これはマイクロコントローラの正しい動作がもはや保証されない電圧になる前に低電圧検出(BOD)リセットが起きることを保証します。この検査はATtiny2313VについてBODLEVEL=110を、ATtiny 2313についてBODLEVEL=101を使って実行されます。

# ウォッチト゛ック゛ リセット

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



# ■ MCU状態レジスタ (MCU Status Register) MCUSR

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

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

#### ■ ビット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)されると、リセット元はリセット フラグを調べることによって得られます。

# 内部基準電圧

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

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

この基準電圧には使われるべき方法に影響を及ぼすかもしれない起動時間があります。この起動時間は表17.で与えられます。節電のために、この基準電圧は常にONではありません。この基準電圧は次の状態中ONです。

- 1. 低電圧検出リセット許可時 (BODLEVEL2~0ヒュース のプログラム(0)により)
- 2. アナログ 比較器基準電圧接続時 (アナログ 比較器制御/状態レジスタ(ACSR)の基準電圧入力選択(ACBG)=1)

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

#### 表17. 内部基準電圧特性

| シンホ゛ル             | 項目   | 条件                  | 最小  | 代表  | 最大  | 単位 |
|-------------------|------|---------------------|-----|-----|-----|----|
| $V_{BG}$          | 基準電圧 |                     | 1.0 | 1.1 | 1.2 | V  |
| t <sub>BG</sub>   | 起動時間 | VCC=2.7V<br>TA=25°C |     | 40  | 70  | μs |
| $I_{\mathrm{BG}}$ | 消費電流 | 1A-25 C             |     | 15  |     | μA |





# ウォッチト゛ック゛タイマ

ATtiny2313は強化されたウォッチドッグタイマ(WDT)を持ちます。主な機能を次に示します。

- 独立した内蔵発振器からのクロック駆動
- 3つの動作種別
  - 割り込み
  - システム リセット
  - 割り込みとシステム リセット
- •選択可能な16ms~8sの計時完了時間
- 安全動作用のウォッチト、ック、常時ONハート、ウェア ヒュース、

ウォッチドッグタイマ(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
                                                       ;ウォッチドック゛タイマ リセット
                   R16, MCUSR
                                                       ;MCUSR値を取得
            ΤN
            ANDI
                   R16, ~ (1<<WDRF)
                                                       ;WDRF論理0値を取得
                                                       ;ウォッチト、ック、リセットフラク、(WDRF)解除
            OUT
                  MCUSR, R16
                   R16, WDTCSR
                                                       ;現WDTCSR値を取得(他ビット保護用)
            IN
                                                       ;WDCEとWDE論理1値を設定
                   R16, (1<<WDCE) | (1<<WDE)
            ORI
            OUT
                   WDTCSR, R16
                                                       ;WDCEとWDEに論理1書き込み
            LDI
                   R16, (0<<WDE)
                                                       ;WDE論理0値を取得
            OUT
                   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();
```

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

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

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

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

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





## ■ ウォッチドック タイマ制御/状態レシ スタ (Watchdog Timer Control Register) WDTCSR

| ピット         | 7    | 6    | 5    | 4    | 3   | 2    | 1    | 0    |        |
|-------------|------|------|------|------|-----|------|------|------|--------|
| \$21 (\$41) | 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)されなければなりません。然しながら、ウォッチト、ッケ、システムリセット動作種別の安全機能に危険を及ぼすかもしれないため、これは割り込み処理ルーチン自身内で行われるべきではありません。次の計時完了に先立って割り込みが実行されない場合、システムリセットが適用(実行)されます。

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

# ■ ビット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)

注: WDTONヒューズは、0がプログラム、1が非プログラムを意味します。

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

| 表19. ウォッチドッグ前置分周選択    |      |      |      |        |       |      |      |      |      |       |      |   |   |   |   |   |
|-----------------------|------|------|------|--------|-------|------|------|------|------|-------|------|---|---|---|---|---|
| WDP3                  |      | 0 1  |      |        |       |      |      |      |      |       |      |   |   |   |   |   |
| WDP2                  | 0    |      |      | 1      |       |      | 0    |      |      | 1     |      |   |   |   |   |   |
| WDP1                  | (    | )    |      | 1      | (     | )    |      | L    | (    | )     | -    | 1 | ( | ) | ] |   |
| WDP0                  | 0    | 1    | 0    | 1      | 0     | 1    | 0    | 1    | 0    | 1     | 0    | 1 | 0 | 1 | 0 | 1 |
| WDT発振周期数              | 2k   | 4k   | 8k   | 16k    | 32k   | 64k  | 128k | 256k | 512k | 1024k |      |   |   |   |   |   |
| 代表的計時完了<br>周期(VCC=5V) | 16ms | 32ms | 64ms | 0.125s | 0.25s | 0.5s | 1.0s | 2.0s | 4.0s | 8.0s  | (予約) |   |   |   |   |   |

# 割り込み

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

# ATtiny2313の割り込みべかタ

表20. リセットと割り込みのべつタ

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

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

| アト・レス  | ラヘ゛ル   | 命令   |                   | 注釈                 |
|--------|--------|------|-------------------|--------------------|
| \$0000 |        | RJMP | RESET             | ;各種リセット            |
| \$0001 |        | RJMP | EXT_INTO          | ;外部割り込み要求0         |
| \$0002 |        | RJMP | EXT_INT1          | ;外部割り込み要求1         |
| \$0003 |        | RJMP | TIM1_CAPT         | ;タイマ/カウンタ1捕獲発生     |
| \$0004 |        | RJMP | TIM1_COMPA        | ;タイマ/カウンタ1比較A一致    |
| \$0005 |        | RJMP | TIM1_OVF          | ;タイマ/カウンタ1溢れ       |
| \$0006 |        | RJMP | TIMO_OVF          | ;タイマ/カウンタ0溢れ       |
| \$0007 |        | RJMP | USART_RXC         | ;USART 受信完了        |
| \$0008 |        | RJMP | USART_UDRE        | ;USART 送信緩衝部空き     |
| \$0009 |        | RJMP | USART_TX          | ;USART 送信完了        |
| \$000A |        | RJMP | ANA_COMP          | ;アナログ比較器出力遷移       |
| \$000B |        | RJMP | PCINT             | ;ピン変化割り込み要求        |
| \$000C |        | RJMP | TIM1_COMPB        | ;タイマ/カウンタ1 比較B一致   |
| \$000D |        | RJMP | TIMO_COMPA        | ;タイマ/カウンタ0 比較A一致   |
| \$000E |        | RJMP | TIMO_COMPB        | ;タイマ/カウンタ0 比較B一致   |
| \$000F |        | RJMP | USI_STRT          | ;USI 開始条件検出        |
| \$0010 |        | RJMP | USI_OVF           | ;USI 計数器溢れ         |
| \$0011 |        | RJMP | EE_RDY            | ;EEPROM操作可         |
| \$0012 |        | RJMP | WDT_OVF           | ;ウォッチドッグ計時完了       |
| ;      |        |      |                   |                    |
| \$0013 | RESET: | LDI  | R16, LOW (RAMEND) | ;RAM最終アドレス下位を取得    |
| \$0014 |        | OUT  | SPL, R16          | ;スタック ポインタ(下位)を初期化 |
|        |        | }    |                   | ;以下、I/O初期化など       |





# 入出力ポート

# 序説

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



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

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

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

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

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

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



## ピンの設定

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

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

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

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

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

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

# 入出力間の切り替え

耒21 ポート ピンの設定

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)のどちらかを使わなければなりません。

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

| 我Z1. パート こ200設と |        |             |     |         |                               |  |  |  |  |  |
|-----------------|--------|-------------|-----|---------|-------------------------------|--|--|--|--|--|
| DDxn            | PORTxn | PUD (MCUCR) | 入出力 | プルアップ抵抗 | 備考                            |  |  |  |  |  |
| 0               | 0      | X           | 入力  | なし      | 高インピーダンス (Hi-Z)               |  |  |  |  |  |
| 0               | 1      | 0           | 入力  | あり      | Pxnに外部からLowを入力すると吐き出し電流が流れます。 |  |  |  |  |  |
| 0               | 1      | 1           | 入力  | なし      | 高インピーダンス (Hi-Z)               |  |  |  |  |  |

# なし 出力 Low (吸い込み)出力 出力 なし High (吐き出し)出力

## ピン値の読み込み

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

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

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









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

```
アセンブリ言語プログラム例
            LDI
                    R16, (1<<PB7) | (1<<PB6) | (1<<PB1) | (1<<PB0)
                                                                 ;プルアップとHigh値を取得
                    R17, (1<<DDB3) | (1<<DDB2) | (1<<DDB1) | (1<<DDB0)
                                                                 ;出力ビット値を取得
            LDI
                    PORTB, R16
                                                                 ;プルアップとHigh値を設定
            OUT
            OUT
                    DDRB, R17
                                                                 ;入出力方向を設定
            NOP
                                                                 ;同期化遅延対処
                                                                 ;ピン値読み戻し
            IN
                    R16, PINB
C言語プログラム例
unsigned char i;
                                                                 /* */
    PORTB = (1 << 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つの一時レジスタが使われます。

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

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

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

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

#### 未接続ピン (訳注:共通性のため本項追加)

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

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

# 交換ポート機能

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



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

|         | XHEAD CYTHDATIC LINCAVERY |                                                                                                    |  |  |  |  |  |  |
|---------|---------------------------|----------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 表22. 交換 | 機能用交換信号の一般定義              |                                                                                                    |  |  |  |  |  |  |
| 信号略名    | 信号名                       | 意味                                                                                                 |  |  |  |  |  |  |
| 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     | アナログ入出力                   | 交換機能用アナログ入出力です。この信号はピンに直接接続され、双方向使用ができます。                                                          |  |  |  |  |  |  |

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





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

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

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

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

## ポートAの交換機能

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

| 表23. ポートAピンの交換機能 |                                        |  |  |  |  |  |  |  |  |
|------------------|----------------------------------------|--|--|--|--|--|--|--|--|
| ポ−ト ピン           | 交換機能                                   |  |  |  |  |  |  |  |  |
| PA2              | RESET (外部リセット入力)<br>dW (デンブッグWIRE入出力)  |  |  |  |  |  |  |  |  |
| PA1              | XTAL2 (システム クロック用発振増幅器出力)              |  |  |  |  |  |  |  |  |
| PA0              | XTAL1 (システム クロック用発振増幅器入力または外部クロック信号入力) |  |  |  |  |  |  |  |  |

交換ピンの設定は次のとおりです。(訳注:共通性のため本項追加)

#### • RESET - ポートA ビット2 : PA2

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

PA2がリセット ピンとして使われると、PORTA2, DDA2, PINA2は全て0を読みます。

dW: デバッグWIRE双方向通信ピン。デバッグWIREによる内蔵デバッグ時の双方向通信に使います。dWピンとして使われると、このピン は他の機能ピンとして使えません。

#### • XTAL2 - ポートA ビット1 : PA1

XTAL2: チップ(システム) クロック発振器ピン2。 クリスタル用発振器クロック ピンとして使われます。 クロック ピンとして使われると、このピンルはI/Oピンとして使えません。

PA1がクロック ピンとして使われると、PORTA1, DDA1, PINA1は全て0を読みます。

#### • XTAL1 - ポートA ビット0 : PA0

XTAL1: チップ(システム) クロック発振器ピン1。 クリスタル用発振器クロック ピンまたは外部クロック入力ピンとして使われます。これらのピンとして使われると、このピンはI/Oピンとして使えません。

PAOがクロック ピンとして使われると、PORTAO, DDAO, PINAOは全てOを読みます。

## ポートBの交換機能

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

#### 表24 ポートBピンの交換機能

|        | ロビノの文法版化                                                                  |        |                                                      |
|--------|---------------------------------------------------------------------------|--------|------------------------------------------------------|
| ポート ピン | 交換機能                                                                      | ポート ピン | 交換機能                                                 |
| PB7    | USCK (3線動作USIクロック入出力)<br>SCL (2線動作USI(TWI)クロック入出力)<br>PCINT7(ピン変化割り込み7入力) | PB3    | OC1A (タイマ/カウンタ1 比較A一致/PWM出力)<br>PCINT3 (ピン変化割り込み3入力) |
| PB6    | DO (3線動作USIデータ出力)<br>PCINT6 (ピン変化割り込み6入力)                                 | PB2    | OC0A (タイマ/カウンタ0 比較A一致/PWM出力)<br>PCINT2 (ピン変化割り込み2入力) |
| PB5    | DI (3線動作USIデータ入力)<br>SDA (2線動作USI(TWI)データ入出力)<br>PCINT5 (ピン変化割り込み5入力)     | PB1    | AIN1 (アナログ比較器反転入力)<br>PCINT1 (ピン変化割り込み1入力)           |
| PB4    | OC1B (タイマ/カウンタ1 比較B一致/PWM出力)<br>PCINT4 (ピン変化割り込み4入力)                      | PB0    | AIN0 (アナログ比較器非反転入力)<br>PCINT0 (ピン変化割り込み0入力)          |

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

• USCK/SCL/PCINT4 - ホートB ビット7: PB7

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

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

• DO/PCINT6 - ホ°ートB ビット6: PB6

DO: 3線動作USIのデータ出力。

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

• DI/SDA/PCINT5 - ホートB ビット5: PB5

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

SDA: 2線動作USI(TWI)のデータ入出力。

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

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

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

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

• OC1A/PCINT3 - ポートB ビット3 : PB3

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

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

• OC0A/PCINT2 - ポートB ビット2 : PB2

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

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

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

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

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

• AIN0/PCINT0 - ホートB ビット0 : PB0

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

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





表25.と表26.はポートBの交換機能を33頁の図25.で示される交換信号に関連付けます。(訳注:原書無効行削除)

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

| 信号名   | PB7/USCK/SCL/PCINT7  | PB6/DO/PCINT6 | PB5/DI/SDA/PCINT5    | PB4/OC1B/PCINT4 |
|-------|----------------------|---------------|----------------------|-----------------|
| PUOE  | 2線USI                | 0             | 0                    | 0               |
| PUOV  | 0                    | 0             | 0                    | 0               |
| DDOE  | 2線USI                | 0             | 2線USI                | 0               |
| DDOV  | (SCL保持+PORTB7)+DDB7  | 0             | (SDA+PORTB5)•DDB5    | 0               |
| PVOE  | 2線USI·DDB7           | 3線USI         | 2線USI·DDB5           | OC1B許可          |
| PVOV  | 0                    | DO            | 0                    | OC1B            |
| PTOE  | USI許可                | 0             | 0                    | 0               |
| DIEOE | (PCIE•PCINT7)+USISIE | PCIE•PCINT6   | (PCIE•PCINT5)+USISIE | PCIE•PCINT4     |
| DIEOV | 1                    | 1             | 1                    | 1               |
| DI    | USCK/SCL/PCINT7入力    | PCINT6入力      | DI/SDA/PCINT5入力      | PCINT4入力        |
| AIO   | _                    | -             | _                    | -               |

# 表26. ポートB3~0の交換機能用交換信号(訳注:矛盾点を一部修正)

| 信号名   | PB3/OC1A/PCINT3 | PB2/OC0A/PCINT2 | PB1/AIN1/PCINT1     | PB0/AIN0/PCINT0     |
|-------|-----------------|-----------------|---------------------|---------------------|
| PUOE  | 0               | 0               | 0                   | 0                   |
| PUOV  | 0               | 0               | 0                   | 0                   |
| DDOE  | 0               | 0               | 0                   | 0                   |
| DDOV  | 0               | 0               | 0                   | 0                   |
| PVOE  | OC1A許可          | OC0A許可          | 0                   | 0                   |
| PVOV  | OC1A            | OC0A            | 0                   | 0                   |
| PTOE  | 0               | 0               | 0                   | 0                   |
| DIEOE | PCIE•PCINT3     | PCIE•PCINT2     | (PCIE•PCINT1)+AIN1D | (PCIE•PCINT0)+AIN0D |
| DIEOV | 1               | 1               | 1                   | 1                   |
| DI    | PCINT3入力        | PCINT2入力        | PCINT1入力            | RXD/PCINT0入力        |
| AIO   | _               | _               | AIN1入力              | AIN0入力              |

注: AINODとAIN1Dは101頁の「デッタル入力禁止レップスタ - DIDR」で記述されます。

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

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

#### 表27 ポートDピンの交換機能

| ホ°ート ヒ°ン | 交換機能                                                        |
|----------|-------------------------------------------------------------|
| PD6      | ICP (タイマ/カウンタ1 捕獲起動入力)                                      |
| PD5      | OC0B (タイマ/カウンタ0 比較B一致/PWM出力)<br>T1 (タイマ/カウンタ1 外部クロック入力)     |
| PD4      | T0 (タイマ/カウンタ0 外部クロック入力)                                     |
| PD3      | INT1 (外部割り込み1 入力)                                           |
| PD2      | INT0 (外部割り込み0 入力) XCK (USART 外部クロック入出力) CKOUT (システム クロック出力) |
| PD1      | TXD (USART 送信データ出力)                                         |
| PD0      | RXD (USART 受信データ入力)                                         |

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

• ICP - ポートD ビット6 : PD6

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

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

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

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

• T0 - ポートD ビット4 : PD4

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

• INT1 - ホートD ビット3: PD3

INT1:外部割り込み1入力。PD3t°ンはMCUへの外部割り込み元として扱えます。

• INT0/XCK/CKOUT - ホートD ビット2: PD2

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

**XCK**: USARTの外部クロック入出力。ポートD方向レジ、スタ(DDRD)のDDD2は、このクロックが入力(DDD2=0)または出力(DDD2=1)のどちらかを制御します。 XCKピンはUSARTが同期種別で動作する時だけ活動します(有効です)。

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

• TXD - ポ-トD ビット1 : PD1

TXD: 送信データ(USART用データ出力ピン)。USART送信部が許可されると、ピンはDDRDのDDD1値に拘らず出力として設定されます。

• RXD - ポートD ビット0 : PD0

RXD: 受信データ(USART用データ入力ピン)。 USART受信部が許可されると、このピンはDDRDのDDD0の値に拘らず入力として設定されます。 USARTがこのピンを入力に強制するとき、プルアップは未だPORTD0ピットによって制御できます。





表28.と表29.はポートDの交換機能を33頁の図25.で示される交換信号に関連付けます。

# 表28. ポートD6~4の交換機能用交換信号

| 信号名   | PD6/ICP | PD5/OC1B/T1 | PD4/T0 |
|-------|---------|-------------|--------|
| PUOE  | 0       | 0           | 0      |
| PUOV  | 0       | 0           | 0      |
| DDOE  | 0       | 0           | 0      |
| DDOV  | 0       | 0           | 0      |
| PVOE  | 0       | OC0B許可      | 0      |
| PVOV  | 0       | OC0B        | 0      |
| PTOE  | 0       | 0           | 0      |
| DIEOE | ICP許可   | T1許可        | T0許可   |
| DIEOV | 1       | 1           | 1      |
| DI    | ICP入力   | T1入力        | T0入力   |
| AIO   | -       | _           | _      |

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

| 信号名   | PD3/INT1 | PD2/INT0/XCK/CKOUT | PD1/TXD  | PD0/RXD    |
|-------|----------|--------------------|----------|------------|
| PUOE  | 0        | 0                  | TXEN     | RXEN       |
| PUOV  | 0        | 0                  | 0        | PORTD0•PUD |
| DDOE  | 0        | 0                  | TXEN     | RXEN       |
| DDOV  | 0        | 0                  | 1        | 0          |
| PVOE  | 0        | XCK出力許可            | TXEN     | 0          |
| PVOV  | 0        | XCK                | TXD      | 0          |
| PTOE  | -        | 0                  | 0        | 0          |
| DIEOE | INT1許可   | INTO許可·XCK入力設定     | 0        | 0          |
| DIEOV | 1        | 1                  | 0        | 0          |
| DI    | INT1入力   | INT0/XCK入力         | <u> </u> | RXD入力      |
| AIO   | _        | _                  | <u>-</u> | _          |

# I/Oポート用レジスタ

# ■ ポートA出力レジスタ (Port A Data Register) PORTA

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

# ■ ポートA方向レジスタ (Port A Data Direction Register) DDRA

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

# ■ ポートA入力レジスタ (Port A Input Address) PINA

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

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

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

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

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

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

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

# ■ ポートD出力レジスタ (Port D Data Register) PORTD

| ピット         | 7 | 6      | 5      | 4      | 3      | 2      | 1      | 0      |       |
|-------------|---|--------|--------|--------|--------|--------|--------|--------|-------|
| \$12 (\$32) | - | PORTD6 | PORTD5 | PORTD4 | PORTD3 | PORTD2 | PORTD1 | PORTD0 | PORTD |
| Read/Write  | R | R/W    |       |
| 初期値         | 0 | 0      | 0      | 0      | 0      | 0      | 0      | 0      |       |

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

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

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

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





# 外部割り込み

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

INT0とINT1割り込みは上昇端または下降端(含む両端)、またはLowレヘルによって起動できます。これはMCU制御レジスタ(MCUCR)の詳述で示される設定です。INT0またはINT1割り込みがレヘル起動として設定、且つ許可されると、そのピンがLowに保持される限り、割り込みは(継続的に)起動します。INT0またはINT1の上昇端または下降端割り込みの認知は16頁の「クロック系統とその配給」で記述されるI/Oクロックの存在を必要とすることに注意してください。INT0とINT1のLowレヘル割り込みは非同期に検知されます。これはそれらの割り込みがアイトル動作以外の休止形態からもデハイスを起動するのに使えることを意味します。I/Oクロックはアイトル動作を除く全休止形態で停止されます。

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

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

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

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





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

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

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

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

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

|   | 表30. 外部割り込み1(INT1)割り込み条件 |       |                 |  |  |  |
|---|--------------------------|-------|-----------------|--|--|--|
|   | ISC11                    | ISC10 | 割り込み発生条件        |  |  |  |
| I | 0                        | 0     | INT1ピンのLowレベル   |  |  |  |
| I | 0                        | 1     | INT1ピンの論理変化(両端) |  |  |  |
|   | 1                        | 0     | INT1ピンの下降端      |  |  |  |
|   | 1                        | 1     | INT1ピンの上昇端      |  |  |  |

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

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

| Ī | 表31. 外部割り込み0(INTO)割り込み条件 |       |                 |  |  |  |
|---|--------------------------|-------|-----------------|--|--|--|
|   | ISC01                    | ISC00 | 割り込み発生条件        |  |  |  |
|   | 0                        | 0     | INT0ピンがLowレヘブル  |  |  |  |
|   | 0                        | 1     | INT0ピンの論理変化(両端) |  |  |  |
| ı | 1                        | 0     | INT0ピンの下降端      |  |  |  |
|   | 1                        | 1     | INT0ピンの上昇端      |  |  |  |

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

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

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

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

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

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

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

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

#### ■ 外部割り込み要求フラク゛レジスタ (External Interrupt Flag Register) EIFR

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

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

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

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

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

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

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

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

| ピット         | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |       |
|-------------|--------|--------|--------|--------|--------|--------|--------|--------|-------|
| \$20 (\$40) | 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と一般割り込み許可レジスタ (GIMSK)のPCIEが設定(1)なら、対応するI/Oピンのピン変化割り込みが許可されます。PCINT0~7が解除(0)されると、対応するI/Oピンのピン変化割り込みは禁止されます。





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

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

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

### 概要

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



#### 関係レジスタ

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

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

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

#### 定義

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

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

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

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

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

# 計数器部

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



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

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

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





### 比較出力部

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

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

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

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

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



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

### 強制比較出力

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

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

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

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

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

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

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

### 比較一致出力部

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



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

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

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

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

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





### 動作種別

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

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

#### 標準動作

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

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

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

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

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



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

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

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

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

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

### 高速PWM動作

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

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



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

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

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

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

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

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





### 位相基準PWM動作

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

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



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

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

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

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

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

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

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

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

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



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



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



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







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

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

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

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

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

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

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

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

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

| 表33. 非 | 表33. 非PWM動作比較A出力選択 |                       |  |  |  |  |  |
|--------|--------------------|-----------------------|--|--|--|--|--|
| COM0A1 | COM0A0             | 意味                    |  |  |  |  |  |
| 0      | 0                  | 標準ポート動作(OC0A切断)       |  |  |  |  |  |
| 0      | 1                  | 比較一致でOC0Aピン トグル(交互)出力 |  |  |  |  |  |
| 1      | 0                  | 比較一致でOC0Aピン Lowレベル出力  |  |  |  |  |  |

比較一致でOC0At°ン Highレヘブル出力

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

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

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

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

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

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

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

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

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

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

| 表36. 非PWM動作比 | 較B出力選択 |
|--------------|--------|
|--------------|--------|

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

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

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

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

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

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

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

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

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

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

#### 表39. 波形生成種別選択

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

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

### ■ タイマ/カウンタ0制御レシ、スタB (Timer/Counter0 Control Register B) TCCR0B

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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





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

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

#### 表40. タイマ/カウンタ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    | TOピンの上昇端(外部クロック)                  |

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

## ■ タイマ/カウンタ0 (Timer/Counter0) TCNT0

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

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

# ■ タイマ/カウンタ0 比較Aレジスタ (Timer/Counter0 Output Compare A Register) OCR0A

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

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

### ■ タイマ/カウンタ0 比較Bレジスタ (Timer/Counter0 Output Compare B Register) OCR0B

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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





# タイマ/カウンタ0とタイマ/カウンタ1の前置分周器

タイマ/カウンタ0とタイマ/カウンタ1は同じ前置分周器部を共用しますが、タイマ/カウンタは異なる前置分周器設定ができます。以下の記述はタイマ/カウンタ0とタイマ/カウンタ1の両方に適用されます。

### 内部クロック元

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

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

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

プログラム実行にタイマ/カウンタを同期することに対して前置分周器リセットを使うことが可能です。しかし、同じ前置分周器を共用する他のタイマ/カウンタも前置分周を使う場合、注意が必要とされなければなりません。前置分周器リセットはそれが接続される全タイマ/カウンタに関する前置分周器周期に影響を及ぼします。

#### 外部クロック元

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

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



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

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

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

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



★1. 八刀 □ ノ(10/11/07円 朔1□/エック | 快山神|| 上門 | 日間 | は図30. 「小されまり。

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

| ピット         | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |       |
|-------------|---|---|---|---|---|---|---|-------|-------|
| \$23 (\$43) | _ | - | - | - | ı | - | - | PSR10 | GTCCR |
| Read/Write  | R | R | R | R | R | R | R | R/W   |       |
| 初期値         | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0     |       |

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

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

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

このビットが1の時にタイマ/カウンタ0とタイマ/カウンタ1の前置分周器はリセットします。通常、このビットはハードウェアによって直ちに解除(0)されます。タイマ/カウンタ0とタイマ/カウンタ1は同じ前置分周器を共用し、この前置分周器のリセットが両方のタイマ/カウンタに影響を及ぼすことに注意してください。





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

この16ビット タイマ/カウンタ部は正確なプログラム実行タイミング(事象管理)、波形生成、信号タイミング計測を許します。主な特徴は次に示されます。

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

#### 概要

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

この16ビット タイマ/カウンタの簡単化した構成図は**図40**.で示されます。CPUがアクセス可能な(I/OビットとI/Oピンを含む)I/Oレジスタは<mark>赤文字</mark> (<mark>訳注</mark>: 原文太字)で示されます。デバイス仕様のI/Oレジスタとビット位置は70頁の「16ビット タイマ/カウンタ1用レジスタ」で示されます。



### 関係レジスタ

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

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

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

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

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

### 定義

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

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

#### 互換性

この16ビット タイマ/カウンタは旧版の16ビット AVR タイマ/カウンタから改良更新されてしまっています。この16ビット タイマ/カウンタは次の点に関して以前の版と完全な互換性があります。

- ・タイマ/カウンタ割り込み関係レシ、スタを含め、16ビットタイマ/カウンタに関連する全てのI/Oレシ、スタアト・レスの位置。
- ・タイマ/カウンタ割り込み関係レシ、スタを含め、16ビット タイマ/カウンタに関連する全てのI/Oレシ、スタ内のビット位置。
- ・ 割り込みべかり。

次の制御ビットは変更された名前を持ちますが、同じ機能とレジスタ位置を持ちます。

- ・PWM10はWGM10に変更。
- ・PWM11はWGM11に変更。
- ・CTC1はWGM12に変更。

次の制御ビットが16ビット タイマ/カウンタ制御レジスタ内に追加されます。

- FOC1AとFOC1BがTCCR1Aに追加。
- ・WGM13がTCCR1Bに追加。

この16ビットタイマ/カウンタにはいくつかの特別な状況で互換性に影響を及ぼす改良点があります。





### 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)を保存 */
   CLI();
                                                  /* 全割り込み禁止 */
   i = TCNT1;
                                                  /* TCNT1値を取得 */
                                                  /* 全割り込み許可フラグ(I)を復帰 */
   SREG = sreg;
   return i;
                                                  /* TCNT1値で呼び出し元へ復帰 */
```

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

アセンブリ言語コート 例は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)を保存 */
   CLI();
                                                  /* 全割り込み禁止 */
                                                  /* TCNT1値を設定 */
   TCNT1 = i;
                                                  /* 全割り込み許可フラグ(I)を復帰 */
   SREG = sreg;
```

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

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

### 上位バイト一時レジスタの再使用

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



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

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

### 計数器部

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



この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比較出力に生成される方法間の接続に近いものです。進化した計数順序と波形生成についてより多くの詳細に対しては65頁の「動作種別」をご覧ください。

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

### 捕獲入力部

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

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



捕獲起動入力(ICP)ピン若しくは代わりにアナロケ・比較器出力(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ビット レジスタ アクセス法のより多くの情報については58頁の「16ビット レジスタのアクセス」を参照してください。

### 捕獲起動元

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

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

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

## 雑音消去器

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

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





### 捕獲入力の使用

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

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

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

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

### 比較出力部

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

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

図43.は比較出力部の構成図を示します。レシブスタとビット名での小文字の'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)が方に優野であると、一時レジ、スタ内の)上位パイトは(下位パイト書き込みと)同じシステムクロック周期でOCR1x緩衝部またはOCR1xレジ、スタのどちらかに複写されます。

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

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

#### 強制比較出力

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

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

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

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

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

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

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





## 比較一致出力部

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



COM1x1,0ビットのどちらかが設定(1)されると、標準I/Oポート機能は波形生成器からの比較出力(OC1x)によって無効にされます。けれどもOC1xピンの方向(入出力)はポート ピンに対するポート方向レジスタ(DDR)によって未だ制御されます。OC1xピンに対するポート方向レジスタのビット(DDR\_OC1x)はOC1x値がピンで見えるのに先立って出力として設定されなければなりません。このポートの交換機能は一般的に波形生成種別と無関係ですが、いくつかの例外があります。詳細については表42、表43、表44.を参照してください。

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

COM1x1.0ビットは捕獲入力部での何の効果もありません。

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

波形生成器は標準、CTC、PWM動作でCOM1x1,0ビットを違うふうに使います。全動作種別に対してCOM1x1,0= $\frac{00}{00}$ 設定は次の比較一致で実行すべきOC1xレジスタの動きがないことを波形生成器へ告げます。非PWM動作での比較出力動作については70頁の表42.を参照してください。高速PWM動作については70頁の表43.、位相基準PWMと位相/周波数基準PWMについては70頁の表44.を参照してください。

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

## 動作種別

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

タイミング情報の詳細については69頁の「タイマ/カウンタ1のタイミング」を参照してください。

#### 標準動作

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

捕獲入力部は標準動作での使用が容易です。けれども外部の事象間の最大間隔がタイマ/カウンタの分解能(16ビット長)を越えてはならないことに気付いてください。事象間の間隔が長すぎる場合、捕獲部に対して分解能を拡張するために、タイマ/カウンタ溢れ割り込みまたは前置分周器が使われなければなりません。

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

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

比較一致タイマ/カウンタ解除(CTC)動作(WGM13~0=0100または1100)ではOCR1AまたはICR1がカウンタの分解能を操作するのに使われます。CTC動作ではカウンタ(TCNT1)値がOCR1A(WGM13~0=4)またはICR1(WGM13~0=12)のどちらかと一致する時にカウンタが\$0000に解除されます。OCR1AまたはICR1はカウンタに対するTOP値、従って分解能も定義します。この動作種別はより大きい比較一致出力周波数の制御を許します。それは外部の出来事の計数操作も簡単にします。

CTC動作についてのタイミング図は**図45**.で示されます。カウンタ(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)されます。





### 高速PWM動作

高速パルス幅変調(PWM)動作(WGM13~0=0101,0110,0111,1110,1111)は高周波数PWM波形生成選択を提供します。高速PWMはそれが単一傾斜(鋸波)動作であることによって他のPWM動作と異なります。カウンタはBOTTOMからTOPまで計数し、その後BOTTOMから再び始めます。非反転比較出力動作(COM1x1,0=10)での比較出力(OC1x)はTCNT1とOCR1x間の比較一致で解除(0)され、BOTTOMで設定(1)されます。反転出力動作(COM1x1,0=11)の出力は比較一致で設定(1)され、BOTTOMで解除(0)されます。単一傾斜動作のため、高速PWM動作の動作周波数は両傾斜(三角波)動作を使う位相基準や位相/周波数基準PWM動作よりも2倍高くできます。この高い周波数は電力調節、整流、D/A変換に対して高速PWM動作を都合よく適合させます。高い周波数は物理的に小さな外部部品(コイルやコンデンサ)を許し、従ってシステム総費用を削減します。

高速PWMのPWM分解能は8,9,10ビットに固定、若しくはOCR1AかICR1のどちらかによって定義できます。許された最小分解能は2 ビット(OCR1AまたはICR1が\$0003設定)、最大分解能は16ビット(OCR1AまたはICR1がMAX設定)です。ビットでのPWM分解能は次式を使うことによって計算できます。

高速PWM動作でのカウンタはカウンタ値が固定値\$00FF,\$01FF,\$03FF(WGM13~0=0101,0110,0111)、ICR1 値(WGM13~0=1110)またはOCR1A値(WGM13~0=1111)のどれかと一致するまで増加されます。そしてカウンタは(一致の)次のタイマ/カウンタ クロック周期で解除(\$0000)されます。高速PWM動作のタイミング図は図46.

 $R_{\text{FPWM}} = \frac{\log (\text{TOP} + 1)}{\log 2}$ 

で示されます。本図は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動作での比較部はOC1xピンでのPWM波形の生成を許します。COM1x1,0ビットを'10'に設定することは非反転PWM出力を作成し、反転PWM出力はCOM1x1,0を'11'に設定することで生成できます。70頁の表43.をご覧ください。実際のOC1x値はそのポートピンに対するデータ方向が出力(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波形出力を生成する時の特別な場合にあたります。OCR

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

1xがBOTTOM(\$0000)に等しく設定されると、出力はTOP+1 タイマ/カクンタ クロック周期毎の狭いスパイク(パルス)になるでしょう。TOPに等しいOCR1x設定は(COM1x1,0ビットによって設定される出力極性に依存して)定常的なLowまたはHigh出力に終わるでしょう。

高速PWM動作で(デューティ比50%)周波数の波形出力は比較一致毎に論理反転するOC1A設定(COM1A1,0=01)によって達成できます。これはTOP値を定義するのにOCR1Aが使われる(WGM13 $\sim$ 0=1111)の場合にだけ適用されます。生成された波形はOCR1Aが0 (\$0000)に設定される時に $f_{\rm OC1A}=f_{\rm clk\_I/O}/2$ の最大周波数でしょう。この特性は高速PWM動作で比較出力部の2重緩衝機能が許可されることを除いて、CTC動作でのOC1A交互出力(COM1A1,0=01)と同じです。

### 位相基準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動作のタイング図は**図47**.で示されます。本図は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で隠(に置換)されることに注意してください。図47.で示される第3周期が図解するようにタイマ/カウンタが位相基準PWM動作で走行中にTOPを積極的に変更するのは、非対称出力で終わることが有り得ます。これに対する理由はOCR 1xレジスタの更新時に見出せます。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'に設定することで生成できます(70頁の表44.をご覧ください)。実際の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%で交互に変化します。





### 位相/周波数基準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)です(図47.と図48.参照)。

位相/周波数基準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動作のタイミング図は**図48**.で示されます。この図は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間で比較一致は決して起きません。

図48.が示すように、生成された出力は位相基準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'に設定することで生成できます(70頁の表44.をご覧ください)。実際のOC1x値はそのポート ピンに対するデータ方向が出力(DDR\_OC1x=1)として設定される場合にだけ見えるでしょう。PWM波形はカウンタが増加する 時のTCNT1とOCR1x間の比較一致でOC1x(内部)レジスタを設定(1)(または解除(0))と、カウンタが減少する時のTCNT1とOCR1 x間の比較一致で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~0 = 1001)、COM1A1,0=01なら、OC1A出力はデューティ比50%で交互に変化します。

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

このタイマ/カウンタは同期設計で、従ってタイマ/カウンタ クロック(clkT1)が下図のクロック許可信号として示されます。この図は割り込みフラクが設定(1)される時、そしてOCR1xレシ、スタがOCR1x緩衝値で更新される時(2重緩衝部を使う動作種別のみ)の情報を含みます。図49.はOCF1xの設定についてのタイシング図を示します。



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



図51.は各動作種別でのTOP近辺の計数手順を示します。位相/周波数基準PWM動作使用時のOCR1xレジスタはBOTTOMで更新されます。タイミング図は同じになりますが、当然TOPはBOTTOMで、TOP-1はBOTTOM+1でなどのように置き換えられます。BOTTOMでTOV1を設定(1)する動作種別についても、同様な名称変更が適用されます。



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







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

■ タイマ/カウンタ1制御レシ、スタA (Timer/Counter1 Control Register A) TCCR1A

| ピット         | 7      | 6      | 5      | 4      | 3 | 2 | 1     | 0     |        |
|-------------|--------|--------|--------|--------|---|---|-------|-------|--------|
| \$2F (\$4F) | 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ビット設定に依存します。**表42**.はWGM13~0ビットが標準動作またはCTC動作(つまり非PWM)に設定される時のCOM1x1,0ビット機能を示します。

## 表42. 非PWM動作での比較出力選択(注: xはAまたはB)

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

表43.はWGM13~0ビットが高速PWM動作に設定される時のCOM1x1,0ビット機能を示します。

### 表43. 高速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、BOTTOMでHighをOC1xピンへ出力(非反転動作)                                                    |
| 1      | 1      | 比較一致でHigh、BOTTOMでLowをOC1xピンへ出力(反転動作)                                                     |

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

表44.はWGM13~0ビットが位相基準または位相/周波数基準PWM動作に設定される時のCOM1x1,0ビット機能を示します。

### 表44. 位相基準または位相/周波数基準PWM動作での比較出力選択(注: xはAまたはB, Xは0または1)

| COM1x1 | COM1x0 | 意味                                                                                       |
|--------|--------|------------------------------------------------------------------------------------------|
| 0      | 0      | 標準ポート動作(OC1x切断)                                                                          |
| 0      | 1      | WGM13~0=10X1 : 比較一致でOC1Aピン トグル(交互)出力、OC1Bは標準ポート動作(OC1B切断)<br>WGM13~0上記以外:標準ポート動作(OC1x切断) |
| 1      | 0      | 上昇計数時の比較一致でLow、下降計数時の比較一致でHighをOC1xピンへ出力                                                 |
| 1      | 1      | 上昇計数時の比較一致でHigh、下降計数時の比較一致でLowをOC1xピンへ出力                                                 |

注: COM1x1が設定(1)され、OCR1xがTOPと等しい時に特別な状態が起きます。より多くの詳細については67頁の「位相基準PWM動作」をご覧ください。

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

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

表45. 波形生成種別選択

| 番号 | 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          | BOTTOM      |
| 2  | 0     | 0               | 1                | 0                | 9ビット位相基準PWM動作         | \$01FF | TOP          | BOTTOM      |
| 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 | BOTTOM       | TOP         |
| 6  | 0     | 1               | 1                | 0                | 9ビット高速PWM動作           | \$01FF | BOTTOM       | TOP         |
| 7  | 0     | 1               | 1                | 1                | 10ビット高速PWM動作          | \$03FF | BOTTOM       | 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         |
| 15 | 1     | 1               | 1                | 1                | 高速PWM動作               | OCR1A  | BOTTOM       | TOP         |

注: CTC1とPWM11,0ビット定義名は旧名です。WGM12~0定義を使ってください。しかし、これらのビットの機能と位置は旧版のタイマ/カウンタと一致します。

#### ■ タイマ/カウンタ1制御レシ、スタB (Timer/Counter1 Control Register B) TCCR1B

| ピット         | 7     | 6     | 5 | 4     | 3     | 2    | 1    | 0    |        |
|-------------|-------|-------|---|-------|-------|------|------|------|--------|
| \$2E (\$4E) | 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に)設定することが捕獲起動入力雑音消去器を活性(有効)にします。雑音消去器が有効にされると、捕獲起動入力(ICP) ピンからの入力が濾波されます。この濾波機能はそれが出力を更新するのに、連続4回等しく評価されたICPピンの採取を必要とします。雑音消去器が許可されると、捕獲入力はそれによって4発振器(システム クロック)周期遅らされます。

### ■ ビット6 - ICES1: 捕獲起動入力端選択 (Input Capture1 Edge Select)

このビットは出来事での捕獲を起動するのに使われる捕獲起動入力(ICP)ピンのどちらかのエッジを選択します。ICES1ビットが0を書かれると起動動作として下降(負)端が使われ、ICES1ビットが1を書かれると上昇(正)端が捕獲を起動します。

捕獲がICES1設定に従って起動されると、カウンタ値が捕獲レシ、スタ(ICR1)に複写されます。この出来事は捕獲入力割り込み要求フラク (ICF1)も設定(1)し、そしてこれは、この割り込みが許可されていれば捕獲入力割り込みを起こすのに使えます。

ICR1がTOP値として使われると(TCCR1AとTCCR1Bに配置されたWGM13~0ビットの記述をご覧ください)、ICPが切り離され、従って捕獲入力機能は禁止されます。

### ■ ビット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)によって使われるべきクロック元を選択します。図49.と図50.をご覧ください。

### 表46. タイマ/カウンタ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ピンの遷移はカウンタをクロック駆動します。この特性はソフトウェアに計数制御を許します。

## ■ タイマ/カウンタ1制御レジスタC (Timer/Counter1 Control Register C) TCCR1C

| ピット         | 7     | 6     | 5 | 4 | 3 | 2 | 1 | 0 |        |
|-------------|-------|-------|---|---|---|---|---|---|--------|
| \$22 (\$42) | 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として読まれます。

### ■ タイマ/カウンタ1 (Timer/Counter1) TCNT1H,TCNT1L (TCNT1)

| ピット         | 15    | 14  | 13  | 12  | 11  | 10  | 9   | 8     |        |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|--------|
| \$2D (\$4D) | (MSB) |     |     |     |     |     |     |       | 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     |        |
| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |        |
| \$2C (\$4C) |       |     |     |     |     |     |     | (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ビット レシ、スタのアクセス」をご覧ください。

カウンタが走行中にカウンタ(TCNT1)を変更することはOCR1xの1つとTCNT1間の比較一致消失の危険を誘発します。

TCNT1への書き込みは全ての比較部に対して次のタイマ/カウンタ クロックでの比較一致を妨害(除去)します。

# ■ タイマ/カウンタ1 比較Aレジスタ (Timer/Counter1 Output Compare Register A) OCR1AH,OCR1AL (OCR1A)

| 15    | 14                | 13    | 12                                            | 11                                                        | 10                                                                    | 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|-------------------|-------|-----------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (MSB) |                   |       |                                               |                                                           |                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | OCR1AH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |                   |       |                                               |                                                           |                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | (LSB)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | OCR1AL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| R/W   | R/W               | R/W   | R/W                                           | R/W                                                       | R/W                                                                   | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0     | 0                 | 0     | 0                                             | 0                                                         | 0                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       | (MSB) R/W 0 7 R/W | (MSB) | (MSB)  R/W R/W R/W 0 0 0 0 7 6 5  R/W R/W R/W | (MSB)  R/W R/W R/W R/W 0 0 0 0 0 7 6 5 4  R/W R/W R/W R/W | (MSB)  R/W R/W R/W R/W R/W 0 0 0 0 0 0 7 6 5 4 3  R/W R/W R/W R/W R/W | (MSB)         R/W         R/W </td <td>(MSB)         R/W         R/W<!--</td--><td>(MSB)         R/W         R/W<!--</td--></td></td> | (MSB)         R/W         R/W </td <td>(MSB)         R/W         R/W<!--</td--></td> | (MSB)         R/W         R/W </td |

# ■ タイマ/カウンタ1 比較Bレジスタ (Timer/Counter1 Output Compare Register B) OCR1BH,OCR1BL (OCR1B)

|             |       |     |     | -   | -   | ,   |     |       | ,      |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|--------|
| ピット         | 15    | 14  | 13  | 12  | 11  | 10  | 9   | 8     | _      |
| \$29 (\$49) | (MSB) |     |     |     |     |     |     |       | 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     |        |
| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |        |
| \$28 (\$48) |       |     |     |     |     |     |     | (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ビット レジスタによって共用されます。58頁の「16ビット レジスタのアクセス」をご覧ください。

# ■ タイマ/カウンタ1 捕獲レシ スタ (Timer/Counter1 Input Capture Register) ICR1H,ICR1L (ICR1)

| ピット         | 15    | 14  | 13  | 12  | 11  | 10  | 9   | 8     |       |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$25 (\$45) | (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     | _     |
| \$24 (\$44) |       |     |     |     |     |     |     | (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     |       |
|             |       |     |     |     |     |     |     |       |       |

この捕獲レジスタはICPピン(またはタイマ/カウンタ1については任意のアナログ比較器出力)で出来事が起こる毎にカウンタ(TCNT1)値で更新されます。この捕獲レジスタはタイマ/カウンタのTOP値を定義するのに使えます。

この捕獲レジスタは容量が16ビットです。CPUがこれらのレジスタをアクセスする時に上位と下位の両バイが同時に読まれるのを保証するため、このアクセスは8ビット上位バイト一時レジスタ(TEMP)を使って実行されます。この一時レジスタは他の全ての16ビット レジスタによって共用されます。58頁の「16ビット レジスタのアクセス」をご覧ください。





# ■ タイマ/カウンタ割り込み許可レシ、スタ (Timer/Counter Interrupt Mask Register) TIMSK

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

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

このビットが1を書かれて、ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されると、タイマ/カウンタ1溢れ割り込みが許可されます。タイマ/カウンタ割り込み要求フラグレジスタ(TIFR)に配置されたタイマ/カウンタ1溢れ割り込み要求フラグ(TOV1)が設定(1)されると、対応する割り込みベクタ(29頁の「割り込み」参照)が実行されます。

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

このビットが1を書かれて、ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されると、タイマ/カウンタ1比較A一致割り込みが許可されます。タイマ/カウンタ割り込み要求フラグ レジスタ(TIFR)に配置された比較1A割り込み要求フラグ(OCF1A)が設定(1)されると、対応する割り込みベクタ(29頁の「割り込み」参照)が実行されます。

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

このビットが1を書かれて、ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されると、タイマ/カウンタ1比較B一致割り込みが許可されます。タイマ/カウンタ割り込み要求フラグ レジスタ(TIFR)に配置された比較1B割り込み要求フラグ(OCF1B)が設定(1)されると、対応する割り込みベクタ(29頁の「割り込み」参照)が実行されます。

■ ビット3 - ICIE1: タイマ/カウンタ1捕獲割り込み許可 (Timer/Counter1 Input Capture Interrupt Enable)

このビットが1を書かれて、ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されると、タイマ/カウンタ1捕獲割り込みが許可されます。タイマ/カウンタ割り込み要求フラグレジスタ(TIFR)に配置された捕獲割り込み要求フラグ(ICF1)が設定(1)されると、対応する割り込みベクタ(29頁の「割り込み」参照)が実行されます。

■ タイマ/カウンタ割り込み要求フラグレジスタ (Timer/Counter Interrupt Flag Register) TIFR

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

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

このフラグの(1)設定はWGM13~0ビット設定に依存します。標準またはCTC動作でのTOV1フラグはタイマ/カウンタ1溢れ時に設定(1)されます。他のWGM13~0ビット設定を使う時のTOV1フラグ動作については71頁の表45.を参照してください。

タイマ/カウンタ1溢れ割り込みベクタが実行されると、TOV1は自動的に解除(0)されます。代わりにこのビット位置へ論理1を書くことによってもTOV1は解除(0)できます。

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

このフラグはカウンタ(TCNT1)値が比較Aレジスタ(OCR1A)と一致した後(次)のタイマ/カウンタ クロック周期で設定(1)されます。

強制的な比較出力(FOC1A)ストローブがOCF1Aフラグを設定(1)しないことに注意してください。

比較A一致割り込みベクタが実行されると、OCF1Aは自動的に解除(0)されます。代わりにこのビット位置へ論理1を書くことによっても OCF1Aは解除(0)できます。

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

このフラグはカウンタ(TCNT1)値が比較Bレジスタ(OCR1B)と一致した後(次)のタイマ/カウンタ クロック周期で設定(1)されます。

強制的な比較出力(FOC1B)ストローブがOCF1Bフラグを設定(1)しないことに注意してください。

比較B一致割り込み  $^{\prime}$  クタが実行されると、OCF1Bは自動的に解除 (0) されます。代わりにこの  $^{\prime}$  ット位置へ論理1を書くことによってもOCF1Bは解除 (0) できます。

■ ビット3 - ICF1: タイマ/カウンタ1捕獲割り込み要求フラグ(Timer/Conter1, Input Capture Flag)

ICPピンに捕獲の事象が起こると、このフラグが設定(1)されます。捕獲レジスタ(ICR1)がWGM13~0によってTOP値として設定されると、ICF1フラグはカウンタがTOP値に到達する時に設定(1)されます。

捕獲割り込みベクタが実行されると、ICF1は自動的に解除( $\frac{0}$ )されます。代わりにこのビット位置へ論理 $\frac{1}{2}$ を書くことによってもICF1は解除( $\frac{0}$ )できます。

## **USART**

USART(Universal Synchronous and Asynchronous Receiver and Transmitter)は高い柔軟性をもつ直列通信機能です。主な特徴を次に示します。

- 全二重動作(独立した送受信レジスタ)
- 同期または非同期動作
- 同期クロック駆動された主装置/従装置動作
- 高分解能ボーレート発振器
- 5, 6, 7, 8または9ビット データと1または2停止ビットの直列フレームの支援
- ハート・ウェアによって支援された奇数または偶数パリティの生成と検査
- データ オーバーラン検出
- フレーミング異常検出
- 不正開始ビット検出とデジタル低域通過濾波器を含む雑音除去器
- 受信完了、送信完了、送信データレジスタ空きの3つの分離した割り込み
- 複数プロセッサ通信機能
- 倍速非同期通信動作

# 概要

USARTの簡単化した構成図は図53.で示されます。CPUがアクセス可能なレジスタとI/Oピンは赤文字(訳注:原文は太字)で示されます。



注: USARTピン配置については2頁の「ピン配置」、38頁の表29.を参照してください。

構成図内の破線はUSARTの3つの主要部分、(上から)クロック生成部、送信部、受信部を分けます。制御レジスタは全部によって共用されます。クロック生成論理部はボーレート発振器と同期従装置動作によって使われる外部クロック入力に対する同期化論理回路から成ります。転送クロック(XCK)ピンは同期転送動作だけで使われます。送信部は単一書き込み緩衝部(UDR)、直列移動レジスタ、パリティ発生器、異なる直列フレーム形式を扱うための制御論理回路から成ります。書き込み緩衝部はどんなフレーム間の遅れもなくデータの継続転送を許します。受信部はクロックとデータの再生部のため、USART部の最も複雑な部分です。再生部は非同期データ受信で使われます。再生部に加えて、受信部は2重の受信緩衝部(UDR)、移動レジスタ、パリティ検査器、制御論理回路を含みます。受信部は送信部と同じフレーム形式を支援し、フレーミング異常、データ オーバーラン発生、パリティ誤りを検知できます。





## UARTとの互換性

USARTはAVRのUARTと次の項目に関して完全な互換性があります。

- ・全てのUSART側レジスタでのビット位置
- ボーレート生成
- 送信操作
- ・送信緩衝の動作
- 受信操作

けれども受信緩衝動作にはいくつかの特別な場合で互換性に影響を及ぼす2つの改良点があります。

- ・第2受信緩衝部が追加されました。2つの緩衝レジスタは循環型FIFO緩衝部として動作します。従ってUSARTデータレジスタ(UDR)は 到着データ毎に一度だけ読まれなければなりません。より重要なのは異常フラグ(FEとDOR)と第9データ ビット(RXB8)が受信緩衝部内のデータと共に緩衝されることの事実です。従って状態ビットは常にUSARTデータレジスタ(UDR)が読まれる前に読まれなければなりません。さもなければ緩衝部の状態が失われるため、異常情報も失われます。
- ・受信部移動レジスタは第3緩衝段のように動けます。これは緩衝レジスタが一杯の場合、新規開始ビットが検出されるまで直列移動レジスタ(図53.参照)内に留まるのを受信したデータに許すことによって行われます。従ってUSARTはデータオーハーラン(DOR)異常条件により耐えます。

次の制御ビットは名称変更されましたが、機能とレジスタ(ビット)位置は同じです。

- 9ビット選択(CHR9)ビットはデータ長選択ビット2(UCSZ2)へ変更
- ・オーバーラン発生(OR)フラク はオーバーラン発生(DOR)フラク へ変更
- ・パリティ誤り(PE)フラケ゛はパリティ誤り(UPE)フラケ、〜変更(訳注:原書で欠落のため追加)

## クロック生成

クロック生成論理回路は送受信部用基準クロックを生成します。USARTは標準非同期、倍速非同期、同期主装置、同期従装置の4つのクロック動作種別を支援します。USART制御/状態レシ、スタC(UCSRC)のUSART動作種別選択(UMSEL)ビットは同期動作と非同期動作のどちらかを選びます。倍速動作(非同期動作のみ)はUSART制御/状態レシ、スタA(UCSRA)にある倍速許可(U2X)ビットによって制御されます。同期動作(UMSEL=1)を使うとき、XCKピンに対する方向制御ビット(DDR\_XCK)はクロック元が内部(主装置動作)または外部(従装置動作)のどちらかを制御します。このXCKピンは同期動作を使う時だけ活性(有効)です。

図54.はクロック生成論理回路の構成図を示します。



## ボーレート発振器での内部クロック発生

内部クロック生成は非同期と同期主装置動作種別に対して使われます。本項の記述は図54.を参照してください。

USARTボーレート レジスタ(UBRR(UBRRH:UBRRL))と下降計数器は設定変更可能な前置分周器またはボーレート発振器として機能するように接続されます。システム クロック(fosc)で走行する下降計数器は0への下降計数時毎またはUBRRLレジスタが書かれる時にUBRR値で設定されます。1クロック(パルス)はカウンタが0に達する毎に生成されます。このクロックがボーレート発振器出力(=fosc/(UBRR+1))です。送信部は動作種別に依存してボーレート発振器出力を2,8,16分周します。ボーレート発振器出力は受信部クロックとデータ再生部によって直接使われます。しかし、再生部はUSART動作種別選択(UMSEL)、倍速許可(U2X)、DDR\_XCKビットの状態によって設定される動作種別に依存して2,8,16段を使う順次処理回路を使います。

表47.は内部的に生成したクロック元を使う各動作種別に於けるボーレート(bps)とUBRR値の計算式を含みます。

| 表47. ボーレート レジスタ(UBRR)値 | 計算式                                         |                                             |
|------------------------|---------------------------------------------|---------------------------------------------|
| 動作種別                   | ボーレート計算式                                    | UBRR値計算式                                    |
| 標準速非同期動作 (U2X=0)       | $BAUD = \frac{f_{OSC}}{16 \times (UBRR+1)}$ | $UBRR = \frac{f_{OSC}}{16 \times BAUD} - 1$ |
| 倍速非同期動作 (U2X=1)        | $BAUD = \frac{f_{OSC}}{8 \times (UBRR+1)}$  | $UBRR = \frac{f_{OSC}}{8 \times BAUD} - 1$  |
| 同期主装置動作                | $BAUD = \frac{f_{OSC}}{2 \times (UBRR+1)}$  | $UBRR = \frac{fOSC}{2 \times BAUD} - 1$     |

注: ボーレートは転送速度(ビット/1秒)で定義されます。

BAUD : ボーレート (bps)

UBRR: UBRRHとUBRRLレジスタ値(0~4095)

fosc : システム発振器クロック周波数

いくつかのシステム クロック周波数に対するいくつかのUBRR値の例は表55.で得られます(90~91頁参照)。





## 倍速動作(U2X)

転送速度はUSART制御/状態レジスタA(UCSRA)で倍速許可(U2X)ビットを設定(1)することによって倍にできます。このビットの設定は非同期動作に対してだけ有効です。同期動作を使うとき、このビットは0に設定してください。

このビットの設定(1)は事実上、非同期通信に対する転送速度を倍にするボーレート分周器の分周数を16から8に減じます。けれども受信部がデータ採取とクロック再生に対して半分の(16から8に減じた)採取数をこの場合だけ使い、従ってこの動作種別が使われる時はシステム クロックとボーレート設定の精度がより必要とされることに注意してください。送信部についての低下要因はありません。

## 外部クロック

外部クロックは同期従装置動作種別によって使われます。本項の記述での詳細については図54.を参照してください。

XCKピンからの外部クロック入力は不確定レベル状態(メタステーブル)の機会を最少とするために同期化レジスタによって採取されます。同期化レジスタからの出力は送受信部で使い得るのに先立ってエッジ検出器を通過しなければなりません。この処理手順が2CPUクロック周期の遅延を持ち込み、このため最大外部XCKクロック周波数は次式によって制限されます。

$$f_{\text{XCK}} < \frac{f_{\text{OSC}}}{4}$$

foscがシステム クロック元の安定度に依存することに注意してください。従って周波数変動によるデータ消失の可能性を避けるため、いくらかの余裕分を追加することが推奨されます。

## 同期クロック動作

同期動作が使われる(UMSEL=1)とき、XCKピンはクロック入力(従装置)またはクロック出力(主装置)のどちらかとして使われます。データ採取またはデータ変更とクロック端間の依存性は同じです。基本原則はデータ出力(TXD)が変更されるエッシンと反対のXCKクロック端でデータ入力(RXD)が採取されることです。

USART制御/状態レシ、スタC(UCSRC)のXCK極性(UCPO L)ビットはデータ採取とデータ変更に対してどちらのクロック端が使われるかを選びます。図55.で示されるようにUCPOLがのとき、データはXCKの上昇端で変更され、下降端で採取されます。UCPOLが設定(1)の場合、データはXCKの下降端で変更され、上昇端で採取されます。



## フレーム形式

1つの直列フレームは複数のデータ ビットと同期ビット(開始ビット、停止ビット)、任意の異常検査用パリティ ビットで定義されます。USARTは有効なフレーム形式として以下の組み合わせ30種全てを受け入れます。

- 1 開始ビット
- 5, 6, 7, 8, 9 ビット データ
- 奇数または偶数パリティビット、またはなし
- 1または2停止ビット

フレームは最下位データ ビット(LSB)が次に続く開始ビットで始まります。その後に次データ ビットが最後の最上位データ ビット(MSB)まで(最大)合計9ビット続きます。許可したなら、パリティ ビットがデータ ビットの後、停止ビットの前に挿入されます。完全なフレームが送信されると、新規フレームによって直ちに後続されるか、または通信線をアイドル状態(high)に設定できます。図56.は組み合わせ可能なフレーム形式を図解します。[]付きビットは任意選択です。



USARTによって使われるフレーム形式はUSART制御/状態レジスタBとC(UCSRB, UCSRC)でデータ長選択(UCSZ2~0)ビット、パリティ選択(UPM1,0)ビット、停止ビット選択(USBS)ビットによって設定されます。受信部と送信部は同じ設定を使います。これらのどのビットの設定変更も、送受信部両方に対して進行中の通信を不正とすることに注意してください。

データ長選択(UCSZ2~0)ビットはフレーム内のデータ ビット数を選びます。 パリティ選択(UPM1,0)ビットはパリティビットの許可と種別(奇/偶)を設定します。 1または2停止ビットのどちらかの選択は停止ビット選択(USBS)ビットによって行います。 受信部は第2停止ビットを無視します。 従ってフレーシング異常(FE)は最初の停止ビットが0(Low)の場合にだけ検出されます。

## パリティビットの計算

パリティ ビットは全データ ビットの排他的論理和(Ex-OR)を行うことによって計算されます。 奇数パリティが使われる場合は排他的論理和の結果が反転されます。 パリティ ビットとデータ ビットの関係は次のとおりです。

```
偶数パリティ ビット = D0 Ex-OR D1 Ex-OR D2 Ex-OR ~ Ex-OR Dn-1
奇数パリティ ビット = D0 Ex-OR D1 Ex-OR D2 Ex-OR ~ Ex-OR Dn-1 Ex-OR 1 n: データ ビット長
```

使った場合、パリティビットは直列フレームの最後のデータビットと最初の停止ビット間に配置されます。

# USARTの初期化

何れかの通信が行えるのに先立ってUSARTは初期化されなければなりません。標準的な初期化手順は使用方法に依存するボーレート設定、フレーム形式設定、送受信部許可から成ります。割り込み駆動USART操作に関して初期化を行うとき、ステータスレジスタの全割り込み許可(I)ピットは解除(0)される(そして全割り込みが禁止される)べきです。

ボーレートまたはフレーム形式の変更を伴う再初期化を行う前には、レシブスタが変更される期間中に進行中の送信がないことを確実にしてください。USART制御/状態レジスタA(UCSRA)の送信完了(TXC)フラケ は送信部の全転送完了検査に使え、受信完了(RXC)フラケ は受信緩衝部内の未読データ有無検査に使えます。この目的(次送信タイミンケ)にTXCフラケが使われる場合、各々の送信(USARTデータレジスタ (UDR)が書かれる)前にTXCフラケが解除(0)されなければならないことに注意してください。

次の簡単なUSART初期化コート・例が示すアセンフ・リ言語とC言語の関数は機能的に同じです。この例は固定フレーム形式でポーリングを使う(割り込み不許可)非同期動作と仮定します。ボーレート(UBRR)値は関数の引数として与えられます。アセンブリ言語でのボーレート引数はR17:R16レジ、スタに格納されると仮定されます。

```
アセンブリ言語プログラム例
USART_Init: OUT
                   UBRRH, R17
                                                        ;ボーレート設定(上位バイト)
                   UBRRL, R16
                                                        ;ボーレート設定(下位バイト)
            OUT
            LDI
                   R16, (1<<USBS) | (3<<UCSZ0)
                                                        ;フレーム形式値を取得
                   UCSRC, R16
                                                        ;フレーム形式設定(8ビット,2停止ビット)
            OUT
            LDT
                   R16, (1<<RXEN) | (1<<TXEN)
                                                        ;送受信許可値を取得
            OUT
                   UCSRB, R16
                                                        ;送受信許可
                                                        ;呼び出し元へ復帰
            RET
C言語プログラム例
#define FOSC 1843200
                                                        /* MCUクロック周波数 */
#define BAUD 9600
                                                        /* 目的USARTボーレート速度 */
#define MYUBRR FOSC/16/BAUD-1
                                                        /* 目的UBRR值 */
void main(void)
USART_Init(MYUBRR);
                                                        /* USART初期化 */
void USART Init (unsigned int baud)
    UBRRH = (unsigned char) (baud>>8);
                                                        /* ボーレート設定(上位バイト) */
    UBRRL = (unsigned char)baud;
                                                        /* ボーレート設定(下位バイト) */
    UCSRC = (1 << USBS) | (3 << UCSZ0) :
                                                        /* フレーム形式設定(8ビット,2停止ビット) */
    UCSRB = (1 << RXEN) \mid (1 << TXEN);
                                                        /* 送受信許可 */
```

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

割り込みの禁止や引数としてフレーム形式を含めるなどで、より進化した初期化ルーチンが作成できます。けれども多くの応用はボーレートや制御レジスタの固定した設定が使われ、これらの応用形式での初期化コートは主ルーチンに直接置けるか、または他のI/Oの初期化コートと併せられます。



# USARTのデータ送信

USART送信部はUSART制御/状態レジスタB(UCSRB)で送信許可(TXEN)ビットを設定(1)することによって許可されます。送信部が許可されると、TXDピンの標準ピン動作はUSARTによって無視され、送信部の直列出力としての機能を与えられます。何か送信を行う前に一度はボーレート、フレーム形式、動作種別が設定されなければなりません。同期動作が使われる場合、XCKピンの(受信)クロックは無視され、送信クロックとして使われます。

## 5~8ビットデータフレーム送信

データ送信は送信されるべきデータを送信緩衝部に設定することによって開始されます。CPUはUSARTデータレジスタ(UDR)I/O位置へ書くことによって送信緩衝部に設定できます。送信緩衝部内のデータは移動レジスタが新規フレームを送る準備が整った時に移動レジスタへ移されます。移動レジスタはアイデル状態(送信進行中以外)、または直前のフレームの最後の停止ビット送信後、直ちに新規データが設定されます。移動レジスタが新規データを設定されると、ボーレートレジスタ(UBRRH:UBRRL)と倍速許可(U2X)ビット、また動作種別によってはXCKビンによって与えられる速度で1つの完全なフレームを転送します。8ビット未満のフレームを使うとき、UDRに書かれた上位ビットは無視されます。

次のコート・例はUSART制御/状態レシ、スタA(UCSRA)の送信データレシ、スタ空き(UDRE)フラケ、のポーリンケ。を基準とした簡単なUSART送信関数を示します。この関数が使われ得る前にUSARTが初期化されなければなりません。アセンブリ言語での送るべきデータはR16レシ、スタに格納されると仮定されます。

```
アセンブリ言語プログラム例
USART_Tx:
           SBIS
                 UCSRA, UDRE
                                                  ;送信緩衝部空きでスキップ
           RJMP
                 USART_Tx
                                                  ;送信緩衝部空き待機
           OUT
                 UDR, R16
                                                  ;データ送信(送信開始)
           RET
                                                  ;呼び出し元へ復帰
C言語プログラム例
void USART_Transmit(unsigned char data)
           while (!(UCSRA & (1<<UDRE)));
                                                  /* 送信緩衝部空き待機 */
           UDR = data;
                                                  /* データ送信(送信開始) */
```

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

この関数は送信されるべき新規データを設定する前に、UDREの検査によって送信緩衝部が空になるのを単純に待ちます。送信緩衝部空き割り込みが使われる場合、その割り込み処理ルーチンがデータを緩衝部内に書きます。

# 9ビット データ フレーム送信

9ビット データが使われる場合(UCSZ2~0=111)、データの下位バイトがUSARTデータ レジスタ(UDR)に書かれる前に、第9ビットがUSART制御/状態レジスタB(UCSRB)の送信データ ビット8(TXB8)ビットに書かれなければなりません。次のコード例は9ビット データを扱う送信関数を示します。アセンブリ言語での送るべきデータはR17:R16レジスタに格納されると仮定されます。

```
アセンブリ言語プログラム例
                                                      ;送信緩衝部空きでスキップ。
USART_Tx:
            SBIS
                  UCSRA, UDRE
                                                      ;送信緩衝部空き待機
            RJMP
                  USART_Tx
                                                      ;第9ビットを0に仮設定
            CBT
                  UCSRB, TXB8
            SBRC
                   R17, 0
                                                       ;送信すべき第9ビットが<mark>0</mark>でスキップ
            SBI
                   UCSRB, TXB8
                                                       ;第9ビットを1に設定
                                                       ;データ送信(送信開始)
            OUT
                   UDR, R16
                                                       ;呼び出し元へ復帰
C言語プログラム例
void USART_Transmit(unsigned int data)
            while (!(UCSRA & (1<<UDRE)));
                                                      /* 送信緩衝部空き待機 */
            UCSRB &= ^{\sim}(1 << TXB8);
                                                      /* TXB8を0に仮設定 */
            if (data \& 0x0100) UCSRB = (1 << TXB8);
                                                      /* 第9ビットをR17からTXB8へ複写 */
            UDR = data;
                                                      /* データ送信(送信開始) */
```

注: これらの送信関数は一般的な機能で書かれています。UCSRBの内容が静的(換言すると、UCSRBのTXB8ビットが初期化後に使われるだけ)ならば最適化できます。

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

第9ビットは複数プロセッサ通信使用時のアドレス フレーム識別、また例えば同期として扱う他の規約で使うことができます。

## 送信フラグと割り込み

USART送信部には状態を示す2つのフラグ、USARTデータレジスタ空き(UDRE)と送信完了(TXC)があります。両フラグは割り込みを発生するのに使えます。

USARTデータレジスタ空き(UDRE)フラグは送信緩衝部が新規データを受け取る準備ができているかどうかを示します。このビットは送信緩衝部が空の時に設定(1)され、送信緩衝部が移動レジスタに未だ移動されてしまっていない送信されるべきデータを含む時に解除(0)されます。将来のデバイスとの共通性のため、USART制御/状態レジスタA(UCSRA)に書くとき、常にこのビットに0を書いてください。

USART制御/状態レジスタB(UCSRB)でデータレジスタ空き割り込み許可(UDRIE)ビットが1を書かれると、(全割り込みが許可されているならば)UDREフラグが設定(1)されている限り、USARTデータレジスタ空き割り込みが実行されます。UDREはUSARTデータレジスタ(UDR)書き込みによって解除(0)されます。割り込み駆動データ送信が使われるとき、データレジスタ空き割り込みルーチンはUDREを解除(0)するために新規データをUDRに書くか、データレジスタ空き割り込みを禁止するかのどちらかを行わなければならず、さもなければ一旦割り込みルーチンを終了しても新しい割り込みが(継続的に)起こります。

送信完了(TXC)フラグは送信移動レシ、スタ内の完全なフレームが移動出力されてしまい、送信緩衝部に新規データが現在存在しない時に設定(1)されます。TXCフラグは送信完了割り込みが実行されるとき、自動的に解除(0)されるか、またはこのビット位置に1を書くことによっても解除(0)できます。TXCフラグは送信応用プログラムが送信完了後、直ちに通信回線を開放し、受信動作へ移行しなければならない(RS485規格のような)半二重(ハーフデュープレックス)通信インターフェースで有用です。

UCSRBで送信完了割り込み許可(TXCIE)ビットが設定(1)され、(全割り込みが許可されていれば)TXCフラグが設定(1)になる時に USART送信完了割り込みが実行されます。送信完了割り込みが使われるとき、割り込み処理ルーチンはTXCフラグを解除(0)しなくてもよく、これは割り込みが実行されるとき、自動的に行われます。

## パリティ発生器

パリティ発生器は直列フレーム データに対するパリティ ビットを計算します。 パリティ ビットが許可されると(UPM1=1)、送信部制御論理回路は送られているフレームの最終データ ビットと最初の停止ビット間にパリティ ビットを挿入します。

#### 送信の禁止

送信部の禁止(UCSRBのUSART送信許可(TXEN)ビット=0)は進行中と保留中の送信が完了される(換言すると、送信移動レジスタと送信緩衝レジスタが送信されるべきデータを含まない時)まで有効になりません。禁止されると、送信部はもはやTXDピン(の標準ピン機能)を無効にしません。

# USARTのデータ受信

USART受信部はUSART制御/状態レジスタB(UCSRB)で受信許可(RXEN)ビットに1を書くことによって許可されます。受信部が許可されると、RXDピンの標準ピン動作はUSARTによって無視され、受信部の直列入力としての機能を与えられます。何か直列受信が行われ得る前に一度はボーレート、フレーム形式、動作種別が設定されなければなりません。同期動作が使われる場合、XCKピンのクロックは転送クロックとして使われます。

# 5~8ビット データ フレーム受信

受信部は有効な開始ビットを検出する時にデータ受信を開始します。開始ビットに続く各ビットはボーレートまたはXCKクロックで採取され、フレームの最初の停止ピットが受信されるまで受信移動レジスタ内へ移動されます。第2停止ビットは受信部によって無視されます。最初の停止ピットが受信されると(換言すると、受信移動レジスタに完全なフレームが存在すると)、この移動レジスタの内容は受信緩衝部内へ移されます。受信緩衝部はUSARTデータレジスタ(UDR)I/O位置を読むことによって読めます。8ピット未満のフレームを使うとき、UDRから読むデータの上位ビットは0で覆われます。

次のコート・例はUSART制御/状態レシ、スタA(UCSRA)の受信完了(RXC)フラケのポーリンケを基にした簡単なUSART受信関数を示します。 この関数が使われ得る前にUSARTが初期化されなければなりません。

```
アセンブリ言語プログラム例
USART Rx:
           SBIS
                  UCSRA, RXC
                                                    ;受信完了でスキップ
           R TMP
                  USART Rx
                                                    ;受信完了待機
           IN
                  R16, UDR
                                                    ;受信データ取得
           RET
                                                    ;呼び出し元へ復帰
C言語プログラム例
unsigned char USART Receive (void)
   while (!(UCSRA & (1<<RXC)));
                                                    /* 受信完了待機 */
                                                    /* 受信データ取得 */
   return UDR;
```

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

この関数は緩衝部を読んで値を戻す前に、RXCフラグの検査によって受信緩衝部にデータが存在するのを単純に待ちます。





## 9ビット データ フレーム受信

9ビット データが使われる場合(UCSZ2~0=111)、USARTデータ レジスタ(UDR)から下位バイトを読む前に、第9ビットがUSART制御/状態レジスタB(UCSRB)の受信データ ビット8(RXB8)ビットから読まれなければなりません。この規則はフレーミング異常(FE)、オーーバーラン発生(DOR)、パリティ誤り(UPE)状態フラグにも適用します。USART制御/状態レジスタA(UCSRA)から状態情報を読み、その後にUDRからデータを読んでください。UDR I/O位置を読むことが受信FIFO緩衝部の状態を切り替え、その結果、FIFO内に保管されるRXB8,FE,DOR,UPEビット全てが切り替わります。

次のコート'例は9ビット データと状態ビット両方を扱う簡単なUSART受信関数を示します。

```
アセンブリ言語プログラム例
USART_Rx:
                  UCSRA, RXC
                                                        ;受信完了でスキップ
           SBIS
                                                        ;受信完了待機
           R.JMP
                  USART Rx
                  R18, UCSRA
                                                        ;状態フラグ取得
           IN
           IN
                  R17, UCSRB
                                                        ;受信第9ビット取得
                                                        ;受信データ取得
                  R16, UDR
           IN
                  R18, (1<<FE) | (1<<DOR) | (1<<UPE)
           ANDI
                                                        ;受信異常検査
           BREQ
                  USART Rx V
                                                        ;異常なしで分岐
           LDI
                  R17, -1
                                                        ;異常で-1値設定
           LDI
                  R16, -1
USART_Rx_V: LSR
                                                        ;RXB8ビットをビット0位置へ移動
                  R17
                  R17, $01
                                                        ;RXB8ビットのみ有効
           ANDI
           RET
                                                        ;呼び出し元へ復帰
C言語プログラム例
unsigned int USART_Receive(void)
    unsigned char status, resh, resl;
                                                        /*一時変数定義 */
    while (!(UCSRA & (1<<RXC)));
                                                        /* 受信完了待機 */
    status = UCSRA;
                                                        /* 状態フラグ取得 */
    resh = UCSRB;
                                                        /* 受信第9ビット取得 */
                                                        /* 受信データ取得 */
    res1 = UDR;
    if ( status & ((1<<FE) | (1<<DOR) | (1<<UPE)) ) return -1; /* 受信異常で-1値設定/復帰*/
    resh = (resh >> 1) \& 0x01;
                                                        /* RXB8ビットのみ有効最下位へ */
                                                        /* 結果9ビット データ取得/復帰 */
   return ((resh<<8) resl);
```

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

この受信関数例は何か評価を行う前に、全てのI/Oレシ、スタをレシ、スタファイルに読みます。これは読まれた緩衝部位置が可能な限り早く新規データを自由に受け入れできるため、最適な受信緩衝部利用になります。

## 受信完了フラグと割り込み

USART受信部には受信部の状態を示す1つのフラグがあります。

USART受信完了(RXC)フラグは未読データが受信緩衝部に存在するかを示します。このフラグは受信緩衝部に未読データが存在する時に1で、受信緩衝部が空の(換言すると、何も未読データを含まない)時に0です。受信部が禁止される場合(RXEN=0)、受信緩衝部が破棄され、その結果としてRXCフラグは0になります。

USART制御/状態レジスタB(UCSRB)でUSART受信完了割り込み許可(RXCIE)ビットが設定(1)されると、(全割り込みが許可されていれば)RXCフラケが設定(1)されている限り、USART受信完了割り込みが実行されます。割り込み駆動データ受信が使われるとき、受信完了割り込みルーチンはRXCフラケを解除(0)するためにUSARTデータレジスタ(UDR)から受信したデータを読まなければならず、さもなければ一旦割り込みルーチンを終了しても新しい割り込みが(継続的に)起きます。

## 受信異常フラグ

USART受信には3つの異常フラグ、フレーミング異常(FE)、データ オーハーラン発生(DOR)、パリティ誤り(UPE)があります。全てがUSART制御/状態レジ、スタA(UCSRA)を読むことによってアクセスできます。異常フラグに対する共通点は異常状態を示しているフレームと共に受信緩衝部に配置されることです。異常フラグが緩衝されるため、USARTデータレジ、スタ(UDR) I/O位置を読むことが緩衝部読み出し位置を切り替えるので、UCSRAは受信緩衝部(UDR)の前に読まれなければなりません。異常フラグに対するその他の共通点はソフトウェアがこのフラグ位置へ書き込みを行うことによって変更できないことです。しかし、将来のUSART(機能)実装の上位互換性のため、UCSRAが書かれるとき、全てのフラグは0に設定されなければなりません。異常フラグはどれも割り込みを生成できません。

フレーミング、異常(FE)フラグは受信緩衝部に格納された、次に読み込み可能なフレームの第1停止ビットの状態を示します。FEフラグは停止ビットが正しく(Highとして)読まれた時に0で、停止ビットが不正(Low)だった時にFEフラグは1です。このビットは同期外れ状態の検出、中断状態検出、規約での操作に使えます。受信部が最初(第1)以外の全停止ビットを無視するため、FEフラグはUSART制御/状態レジスタC(UCSRC)の停止ビット選択(USBS)ビット設定によって影響を及ぼされません。将来のデバイスとの共通性のため、UCSRAに書くとき、常にこのビットを0に設定してください。

データ オーハーラン発生(DOR)フラグは受信部緩衝部が一杯状態のためのデータ消失を示します。データ オーハーランは受信緩衝部(2フレーム)が一杯で、(次の)新規フレーム データが受信移動レジスタで待っており、(更に次の)新規開始ビットが検出される時に起きます。DORフラグが設定(1)なら、最後にUDRから読んだフレームと次にUDRから読むフレーム間で1つ以上の直列フレームが失われています。将来のデバイスとの共通性のため、UCSRAに書くとき、常にこのビットに0を書いてください。DORフラグは受信されたデータが移動レジスタから受信緩衝部へ正常に移動された時に解除(0)されます。

パリティ誤り(UPE)フラク゛は受信緩衝部内の次フレームで、受信時にパリティ異常があったことを示します。パリティ検査が許可されていない場合、UPEフラク゛は常にOが読めます。将来のテ、ハ´イスとの共通性のため、UCSRAに書くとき、常にこのビットをOに設定してください。より多くの詳細については79頁の「パリティ ビットの計算」と次の「パリティ検査器」をご覧ください。

## パリティ検査器

パリティ検査器はパリティ種別上位ビット(UPM1)が設定(1)されると活性(有効)になります。実行されるべきパリティ検査の形式(偶数または奇数)はUPM0ビットによって選択されます。許可されると、パリティ検査器は到着フレーム内のデータ ビットのパリティを計算し、その結果と(受信)直列フレーム内のパリティ ビットを比較します。検査の結果は受信データ、停止ビットと共に受信緩衝部に格納されます。その後パリティ誤り(UPE)フラグはフレームにパリティ異常があるかを検査するため、ソフトウェアによって読むことができます。

UPEフラグは受信緩衝部から読まれ得る次フレームで受信時にパリティ異常があり、その時点でパリティ検査が許可されていた(UPM1=1)場合に設定(1)されます。このビットはUSARTデータレジスタ(UDR)が読まれるまで有効です。

## 受信の禁止

送信部と対照的に受信部の禁止は即時です。従って受信進行中のデータは失われます。禁止されると(換言すると、USART制御/状態レジスタB(UCSRB)のUSART受信許可(RXEN)ビットが0に設定)、受信部はもはやRXDポート ピンの標準機能を無効にしません。受信FIFO緩衝部は受信部が禁止されると破棄されます。緩衝部内の残データは失われます。

## 受信緩衝部の破棄

受信FIFO緩衝部は受信が禁止されると破棄(換言すると、緩衝部は内容を空に)されます。未読データは失われます。例えば異常状態のため、通常動作中に緩衝部が破棄されなければならない場合、USART制御/状態レジスタA(UCSRA)の受信完了(RXC)フラケが解除(0)されるまでUSARTデータレシ、スタ(UDR) I/O位置を読んでください。次のコート例は受信緩衝部の破棄方法を示します。

```
アセンブリ言語プログラム例
                                                   ;未読データありでスキップ。
USART Flush: SBIS
                  UCSRA, RXC
            RET
                                                   ;未読データなしで復帰
                                                   :データ受信
            IN
                  R16, UDR
                                                   ;未読データなしまで継続
            RJMP
                  USART_Flush
C言語プログラム例
void USART Flush (void)
   unsigned char dummy;
                                                   /* 一時変数定義 */
   while ( UCSRA & (1<<RXC) ) dummy=UDR;
                                                   /* 未読データ読み捨て */
注: このコート 例はデバイス定義ファイルがインクルート されることが前提です。
```





# 非同期受信

USARTは非同期データ受信を扱うためのクロック再生とデータ再生部を含みます。クロック再生論理回路は内部的に生成したボーレートクロックをRXDピンに到着する非同期直列フレームに同期化するのに使われます。データ再生論理回路は到着ビット毎に低域通過の濾波と採取をし、それによって受信部の雑音耐性を改善します。非同期受信動作範囲は内部ボーレートクロック精度、到着フレーム速度、フレーム長のビット数に依存します。

# 非同期クロック再生

クロック再生論理回路は内部クロックを到着直列フレームに同期化します。**図57.**は到着フレームの開始ビット採取手順を図解します。採取速度は標準速動作でボーレートの16倍、倍速動作で8倍です。赤帯(<mark>訳注</mark>:原文は水平矢印)は採取処理のための同期変量を図示します。倍速動作(U2X=1)を使う時の広い変量時間に注意してください。採取番号0はRXD信号がアイドル(換言すると、通信の動きなし)の時に行われる採取です。



クロック再生論理回路がRXD信号線でHigh(アイ・ル)からLow(開始)の遷移を検出すると、開始ビット検出手順が開始されます。図で示されるように採取1は最初のLow採取を意味します。その後にクロック再生回路は有効な開始ビットが受信されるかを決めるために、標準速動作に対して採取8,9,10、倍速動作に対して採取4,5,6(図の赤数字(訳注:原文は箱枠内)で示された採取番号)を使います。これら3回で2回以上の採取が論理Highレベルの場合(多数決)、この開始ビットは尖頭雑音として捨てられ、受信部は次のHighからLowの遷移を探し始めます。けれども有効な開始ビットが検出されると、クロック再生論理回路は同期化され、データ再生が開始されます。この同期化手順は各開始ビット毎に繰り返されます。

## 非同期データ再生

受信部クロックが開始ビットに同期化されるとデータ再生が始められます。データ再生部は標準速動作で16段、倍速動作で8段の順列回路を使います。図58.はデータ ビットとパリティ ビットの採取を示します。各採取は再生部の各段に等しい番号を与えられます。



受信したビットの論理値の決定は受信したビット中央の3採取で論理値の多数決を取ることによって行われます。この中央の3採取は図上の赤文字(訳注:原文は箱枠内)の採取番号によって強調されます。多数決の手順は次のように行われます。2または全3採取がHighレヘルならば受信したビットは論理1が記録されます。2または全3採取がLowレヘルならば受信したビットは論理0が記録されます。この多数決手順はRXDピンの到着信号に対して低域通過濾波器( $p-n^2$ スフィルタ)のように働きます。この再生手順はその後に完全なフレームが受信されるまで繰り返されます。これには最初の(第1)停止ビットを含みます。受信部がフレームの最初の停止ビットだけを使うことに注意してください。

図59.は停止ビットの採取と次フレームの最も早い開始ビット開始の可能性を示します。



フレーム内の他のビットに対して行われるのと同じ多数決が停止ビットにも行われます。停止ビットが論理0値と記録されると、フレーミング異常 (FE)フラグが設定(1)されます。

新規フレームの開始ビットを示すHighからLowへの遷移は多数決に使った最後のビット後に実現できます。標準速動作での最初のLowレヘル採取は図59.のA点で有り得ます。倍速動作での最初のLowレヘルはB点に遅れます。C点は完全な長さの停止ビット(の終点)を示します。この早い開始ビット検出は受信部の動作範囲に影響します。

## 非同期での動作範囲

受信部の動作範囲は受信したビット速度と内部的に生成したボーレート間の不一致に依存します。送信部が速すぎるまたは遅すぎるビット速度でフレームを送出したり、内部的に発生した受信部のボーレートが類似した(表48.参照)基準周波数を持たない場合、受信部は開始ビットでフレームを同期できません。

次式は到着データ速度と内部受信部ボーレート間の比率計算に使えます。

 $R_{\text{slow}} = \frac{(D+1)\times S}{S-1+D\times S+S_F}$   $R_{\text{fast}} = \frac{(D+2)\times S}{(D+1)\times S+S_M}$ 

D: データとパリティのビット数 (5~10)

S: ビットあたりの採取数(標準速=16、倍速=8)

S<sub>F</sub> : 多数決に使う最初の採取番号 (標準速=8、倍速=4) S<sub>M</sub> : 多数決に使う中心の採取番号 (標準速=9、倍速=5)

R<sub>slow</sub>:は受信側ボーレートに対して許容できる最低受信ビット速度の比率です。 R<sub>fast</sub>:は受信側ボーレートに対して許容できる最高受信ビット速度の比率です。

表48.は許容できる最大受信部ボーレート誤差一覧です。標準速動作には、より高いボーレート変動許容力があることに注目してください。

#### 表48. 標準速と倍速での受信部ボーレート推奨最大許容誤差

|    | 100 T TO 100          |          |                                    |           |                       |          |             |           |  |  |
|----|-----------------------|----------|------------------------------------|-----------|-----------------------|----------|-------------|-----------|--|--|
| D  |                       | 標        | <b>準速動作</b> (U2X= <mark>0</mark> ) |           | <b>倍速動作</b> (U2X=1)   |          |             |           |  |  |
|    | R <sub>slow</sub> (%) | Rfast(%) | 総合許容誤差(%)                          | 推奨許容誤差(%) | R <sub>slow</sub> (%) | Rfast(%) | 総合許容誤差(%)   | 推奨許容誤差(%) |  |  |
| 5  | 93.20                 | 106.67   | -6.80~+6.67                        | ±3.0      | 94.12                 | 105.66   | -5.88~+5.66 | ±2.5      |  |  |
| 6  | 94.12                 | 105.79   | -5.88~+5.79                        | ±2.5      | 94.92                 | 104.92   | -5.08~+4.92 | ±2.0      |  |  |
| 7  | 94.81                 | 105.11   | -5.19~+5.11                        | ±2.0      | 95.52                 | 104.35   | -4.48~+4.35 | ±1.5      |  |  |
| 8  | 95.36                 | 104.58   | -4.54~+4.58                        | ±2.0      | 96.00                 | 103.90   | -4.00~+3.90 | ±1.5      |  |  |
| 9  | 95.81                 | 104.14   | -4.19~+4.14                        | ±1.5      | 96.39                 | 103.53   | -3.61~+3.53 | ±1.5      |  |  |
| 10 | 96.17                 | 103.78   | -3.83~+3.78                        | ±1.5      | 96.70                 | 103.23   | -3.30~+3.23 | ±1.0      |  |  |

注: Dはデータ ビット数とパリティ ビットの合計ビット数です。

(訳注)原書は表48.に標準速、表49.に倍速を記載していますが、比較が容易なように表48.として纏めました。

受信部ボーレートの推奨最大許容誤差は最大総合許容誤差を送信部と受信部で等分割するという仮定の元で作られました。

受信部ボーレート誤差に対して2つの起こり得る原因があります。受信部のシステム クロック(XTAL)は供給電圧範囲と温度範囲に関して常に若干の不安定性があります。システム クロックを生成するのにクリスタル発振子を使う時は殆ど問題ありませんが、(セラミック)振動子でのシステム クロックは振動子偏差に依存して2%を越えて異なるかもしれません。2つ目の誤り原因はより制御可能です。ボーレート発振器は欲したボーレートを得るためにシステム周波数の正確な分周を常に行うことはできません。この場合、可能ならば受け入れ可能な低い誤差を与えるUBRR値が使えます。





# 複数プロセッサ通信動作

USART制御/状態レジスタA(UCSRA)での複数プロセッサ通信動作(MPCM)ビットの設定(1)はUSART受信部によって受信された到着フレームの選別機能を許可します。アドレス情報を含まないフレームは無視され、受信緩衝部に格納されません。これは同一直列バス経由で通信する複数MCUのシステムで、CPUによって扱われなければならない到着フレーム数を効果的に減らします。送信部はMPCMビット設定によって影響されませんが、複数プロセッサ通信動作を利用するシステムの一部の時は違うふうに使われなければなりません。

受信部が5~8データ ビットを含むフレームを受信するように設定されるなら、最初の停止ビットはデータまたはアドレス情報を含むフレームかどうかを示します。受信部が9データ ビットのフレームに設定されるなら、USART制御/状態レジスタB(UCSRB)の受信第9(RXB8)ビットがアドレスとデータのフレームを識別するのに使われます。フレーム種別(最初の停止または第9)ビットが1の時にフレームはアドレスを含みます。フレーム種別ビットが0の時にそのフレームはデータフレームです。

複数プロセッサ通信動作は主MCUからのデータを多くの従MCUで受信することを可能にします。これはどのMCUがアトレス指定されるかを検出するため、最初にアトレスフレームを調べることによって行われます。特定の従MCUがアトレス指定されたなら、そのMCUは後続するデータフレームを通常のように受信し、一方その他の従MCUは他のアトレスフレームが受信されるまで受信したフレームを無視します。

# 複数プロセッサ通信の使用法

主MCUとして動作するMCUは9ビット データ フレーム形式(UCSZ=7)を使えます。UCSRBの送信第9(TXB8)ビットはアドレス フレーム時に設定(1)、またはデータ フレーム時に解除(0)されて送信されなければなりません。この場合、従MCUは9ビット データ フレーム形式の使用に設定されなければなりません。

複数プロセッサ通信動作でデータを交換するのに次の手順が使われるべきです。

- 1. 全ての従MCUは複数プロセッサ通信動作です(UCSRAの複数プロセッサ通信動作(MPCM)ビットが設定(1))。
- 2. 主MCUはアドレス フレームを送り、全ての従装置がこのフレームを受信し、これを読みます。従CPUでは通常のようにUCSRAで受信完了(RXC)フラグが設定(1)されます。
- **3.** 各従MCUはUSARTデータレシ、スタ(UDR)を読み、選択されたかを判定します。選択された場合はUCSRAのMPCMビットを解除(0)し、そうでなければ(非選択の場合は)MPCMビット設定を保ち、次のアドレス フレームを待ちます。
- 4. アドレス指定されたMCUは新規アドレス フレームが受信されるまで全データ フレームを受信します。MPCMビットが未だ設定(1)されている他の従CPUはこのデータ フレームを無視します。
- 5. 最後のデータフレームがアドレス指定されたMCUによって受信されると、アドレス指定されたMCUはMPCMビットを設定(1)し、主装置からの新規アドレスフレームを待ちます。以降、手順は2.からを繰り返します。

5~8ビット データ フレーム形式のどの使用も可能ですが、受信側が使うnとn+1ビット データ フレーム形式間を切り替えなければならないため 非実用的です。これは送信部と受信部が同じデータ ビット長設定を使うため、全二重(フルデュープレックス)動作を困難にします。5~8ビット データ フレームが使われる場合、最初の停止ビットがフレーム種別を示すのに使われるので、送信部は2停止ビット使用(USBS=1)に設定されなければなりません。

MPCMビットを設定(1)または解除(0)するのに読み-修正-書き(リード モデファイ ライト)命令(SBIとCBI)を使ってはいけません。MPCMビットは送信完了(TXC)フラグと同じI/O位置を共用しており、SBIまたはCBI命令を使うと偶然に解除(0)されるかもしれません。

# USART用レジスタ

## ■ USARTデータレジスタ (USART I/O Data Register) UDR

| ピット         | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |     |
|-------------|--------|--------|--------|--------|--------|--------|--------|--------|-----|
| \$0C (\$2C) | R/TXB7 | R/TXB6 | R/TXB5 | R/TXB4 | R/TXB3 | R/TXB2 | R/TXB1 | R/TXB0 | UDR |
| Read/Write  | R/W    |     |
| 初期値         | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |     |

同じI/Oアトンスを共用するUSART受信データ緩衝レシ、スタとUSART送信データ緩衝レシ、スタはUSARTデータレジ、スタまたはUDRとして引用しました。送信データ緩衝レシ、スタ(TXB)はUDRレシ、スタ位置に書かれるデータの転送先です。UDRレシ、スタ位置読み込みは受信データ緩衝レシ、スタ(RXB)の内容を返します。

5~7ビット データでの上位未使用ビットは送信部によって無視され、受信部によって0に設定されます。

送信緩衝部はUCSRAで送信データレジ、スタ空き(UDRE)フラグが設定(1)される時にだけ書けます。UDREフラグが設定(1)されない時にUDRへ書かれたデータはUSART送信部によって無視されます。送信部が許可されて送信緩衝部にデータが書かれると、送信部は送信移動レジ、スタが空きの時にそのデータを送信移動レジ、スタへ設定(移動)します。その後にデータはTXDピンで直列送信されます。

受信緩衝部は2段のFIFOから成ります。このFIFOは受信緩衝部がアクセスされる毎にその状態を切り替えます。この受信緩衝部の動きのため、この位置に読み-修正-書き(リート・モテ・ファイライト)命令(SBIとCBI)を使えません。ビット検査(SBICとSBIS)命令もFIFOの状態を換えるので、これらの命令を使う時は注意してください。

## ■ USART制御/状態レジスタA (USART Control and Status Register A) UCSRA

| ピット         | 7   | 6   | 5    | 4  | 3   | 2  | 1   | 0    |       |
|-------------|-----|-----|------|----|-----|----|-----|------|-------|
| \$0B (\$2B) | RXC | TXC | UDRE | FE | DOR | PE | U2X | MPCM | UCSRA |
| Read/Write  | R   | R/W | R    | R  | R   | R  | R/W | R/W  |       |
| 初期値         | 0   | 0   | 1    | 0  | 0   | 0  | 0   | 0    |       |

# ■ ビット7 - RXC: USART受信完了フラグ(USART Receive Complete)

このフラグは受信緩衝部に未読データがある時に設定(1)され、受信緩衝部が空の(換言すると、どんな未読データも含まない)時に解除 (0)されます。受信部が禁止されると、受信緩衝部が破棄され、その結果RXCフラグは0になります。RXCフラグは受信完了割り込みを発生するのに使えます(USART制御/状態レジスタB(UCSRB)の受信完了割り込み許可(RXCIE)ビットをご覧ください)。

## ■ ビット6 - TXC: USART送信完了フラク (USART Transmit Complete)

このフラグは送信移動レジスタ内の完全なフレームが移動出力されてしまい、送信緩衝部(UDR)に新規データが現状存在しない時に設定 (1)されます。TXCフラグは送信完了割り込みが実行されるとき、自動的に解除(0)されるか、またはこのビット位置に1を書くことによって解除(0)できます。TXCフラグは送信完了割り込みを発生できます(UCSRBの送信完了割り込み許可(TXCIE)ビットをご覧ください)。

## ■ ビット5 - UDRE: USART送信データ レジスタ空きフラグ (USART Data Register Empty)

UDREフラグは送信緩衝部(UDR)が新規データを受け取る準備ができているかどうかを示します。UDREが1ならば緩衝部は空で、従って書かれる準備ができています。UDREフラグは送信緩衝部空き割り込みを発生できます(UCSRBの送信データレジスタ空き割り込み許可(UDRIE)とずりをご覧ください)。送信部が準備できているのを示すため、リセット後のUDREは設定(1)です。

#### ■ ビット4 - FE: フレーミング異常フラグ (Framing Error)

受信緩衝部の次データが受信した時にフレーミング異常(換言すると、受信緩衝部で次データの最初の(第1)停止ビットがLow)だった場合、このビットが設定(1)されます。このフラグは受信緩衝部(UDR)が読まれるまで有効です。受信したデータの停止ビットがHighの時にFEフラグは0です。UCSRAに書くとき、常にこのビットを0に設定してください。

# ■ ビット3 - DOR: データ オーバーラン発生フラグ(Data OverRun)

このビットはオーハーラン状態が検出されると設定(1)されます。受信緩衝部(2フレーム分)が一杯で、新規フレームが受信移動レジスタ内で待機中に新規開始ビットが検出されるとデータオーハーランが起こります。UCSRAに書くとき、常にこのビットを0に設定してください。

# ■ Ľット2 – UPE: パリティ誤りフラク゛(USART Parity Error)

受信緩衝部の次データが受信した時にパリティ異常があり、その時点でパリティ検査が許可されていれば(UPM1=1)、このビットが設定(1)されます。このフラグは受信緩衝部(UDR)が読まれるまで有効です。UCSRAに書くとき、常にこのビットを0に設定してください。

#### ■ ビット1 - U2X: 倍速許可 (Double the USART Transmission Speed)

このビットは非同期動作でだけ有効です。同期動作を使うとき、このビットに0を書いてください。

このビットに1を書くことはボーレート分周器の分周値を16から8に減らして事実上、非同期通信の転送速度を倍にします。

# ■ ビット0 - MPCM: 複数プロセッサ通信動作 (Multi-Processor Communication Mode)

このビットは複数プロセッサ通信動作を許可します。MPCMビットが1を書かれると、USART受信部で受信したアドレス情報を含まない全到着フレームは無視されます。送信部はMPCM設定に影響されません。より多くの詳細情報については86頁の「複数プロセッサ通信動作」をご覧ください。





## ■ USART制御/状態レジスタB (USART Control and Status Register B) UCSRB

| ピット         | 7     | 6     | 5     | 4    | 3    | 2     | 1    | 0    |       |
|-------------|-------|-------|-------|------|------|-------|------|------|-------|
| \$0A (\$2A) | RXCIE | TXCIE | UDRIE | RXEN | TXEN | UCSZ2 | RXB8 | TXB8 | UCSRB |
| Read/Write  | R/W   | R/W   | R/W   | R/W  | R/W  | R/W   | R    | R/W  |       |
| 初期値         | 0     | 0     | 0     | 0    | 0    | 0     | 0    | 0    |       |

#### ■ ビット7 - RXCIE: 受信完了割り込み許可 (Receive Complete Interrupt Enable)

このビットに1を書くことはUSART制御/状態レジスタA(UCSRA)の受信完了(RXC)フラグでの割り込みを許可します。USART受信完了割り込みはRXCIEビットが1を書かれ、ステータス レジスタ(SREG)で全割り込み許可(I)ビットが1を書かれ、UCSRAでRXCフラグが設定(1)される場合にだけ生成されます。

## ■ ビット6 - TXCIE: 送信完了割り込み許可 (Transmit Complete Interrupt Enable)

このビットに1を書くことはUSART制御/状態レジスタA(UCSRA)の送信完了(TXC)フラグでの割り込みを許可します。USART送信完了割り込みはTXCIEビットが1を書かれ、SREGで全割り込み許可(I)ビットが1を書かれ、UCSRAでTXCフラグが設定(1)される場合にだけ生成されます。

## ■ ビット5 - UDRIE: 送信データ レジスタ空き割り込み許可 (Transmit Data Register Empty Interrupt Enable)

このビットに1を書くことはUSART制御/状態レジスタA(UCSRA)の送信データ レジスタ空き(UDRE)フラグでの割り込みを許可します。USART 送信データ レジスタ空き割り込みはUDRIEビットが1を書かれ、SREGで全割り込み許可(I)ビットが1を書かれ、UCSRAでUDREフラグが設定(1)される場合にだけ生成されます。

## ■ ビット4 - RXEN: 受信許可 (Receiver Enable)

このビットに1を書くことはUSART受信(部)を許可します。受信部は許可されるとRXDピンの標準ポート動作を無効にします。受信(部)を禁止することは受信緩衝部を破棄し、フレーミング異常(FE)、オーバーラン(DOR)、パリティ誤り(UPE)のフラグを無効にします。

## ■ ビット3 - TXEN: 送信許可 (Transmitter Enable)

このビットに1を書くことはUSART送信(部)を許可します。送信部は許可されるとTXDピンの標準ポート動作を無効にします。送信(部)の禁止(TXEN=0書き込み)は進行中と保留中の送信が完了される(換言すると、送信移動レジスタと送信緩衝レジスタが送信されるべきデータを含まない)まで有効になりません。禁止したとき、送信部はもはやTXDポート(の標準I/O機能)を無効にしません。

## ■ ビット2 - UCSZ2: データ ビット長選択2 (Character Size)

USART制御/状態レジスタC(UCSRC)のUCSZ1,0ビットと組み合わせたUCSZ2ビットは送受信部で使うフレームのデータ ビット数(Character size)を設定します。

# ■ ビット1 - RXB8 : 受信データ ビット8 (Receive Data Bit 8)

RXB8は9ビット データでの直列フレーム操作時に受信したフレームの第9データ ビット(ビット8)です。UDRから下位ビットを読む前に読んでください。

#### ■ ビット0 - TXB8 : 送信データ ビット8 (Transmit Data Bit 8)

TXB8は9ビット データでの直列フレーム操作時に送信されるべきデータの第9データ ビット(ピット8)です。UDRへ下位ビットを書く前に書いてください。

#### ■ USART制御/状態レジスタC (USART Control and Status Register C) UCSRC

| ピット         | 7 | 6     | 5    | 4    | 3    | 2     | 1     | 0     | _     |
|-------------|---|-------|------|------|------|-------|-------|-------|-------|
| \$03 (\$23) | - | UMSEL | UPM1 | UPM0 | USBS | UCSZ1 | UCSZ0 | UCPOL | UCSRC |
| Read/Write  | R | R/W   | R/W  | R/W  | R/W  | R/W   | R/W   | R/W   |       |
| 初期値         | 0 | 0     | 0    | 0    | 0    | 1     | 1     | 0     |       |

#### ■ ビット7 - Res: 予約 (Reserved) (訳注:共通性のため本項追加)

このビットは将来使用するために予約されています。将来のデバイスとの共通性を保つため、UCSRCが書かれるとき、このビットは<mark>0</mark>が書かれなければなりません。

#### ■ ビット6 - UMSEL: USART動作選択 (USART Mode Select)

このビットは非同期と同期の動作種別のどちらかを選びます。

| 表50. USART動 | 作選択   |
|-------------|-------|
| UMSEL       | 動作種別  |
| 0           | 非同期動作 |
| 1           | 同期動作  |

## ■ ビット5,4 - UPM1,0: パリティ選択 (Parity Mode)

これらのビットはパリティの発生と検査の許可と種別を設定します。許可した場合、送信部は各フレーム内での送信したデータ ビットのパリティを自動的に生成して送出します。受信部は到着データからパリティ値を生成し、UPM0設定と比較します。不一致が検出されると、USART制御/状態レジスタA(UCSRA)でパリティ誤り(UPE)フラグが設定(1)されます。

| ā | 表51. パリティ選択 |      |          |  |  |  |  |  |  |  |  |
|---|-------------|------|----------|--|--|--|--|--|--|--|--|
|   | UPM1        | UPM0 | パリティ動作   |  |  |  |  |  |  |  |  |
| I | 0           | 0    | 禁止       |  |  |  |  |  |  |  |  |
|   | 0           | 1    | (予約)     |  |  |  |  |  |  |  |  |
|   | 1           | 0    | 偶数パリティ許可 |  |  |  |  |  |  |  |  |
|   | 1           | 1    | 奇数パリティ許可 |  |  |  |  |  |  |  |  |

## ■ ビット3 - USBS: 停止ビット選択 (Stop Bit Select)

このビットは送信部によって挿入される停止ビット数を選びます。受信部はこの設定を無視します(**訳補**:常に第1停止ビットだけが有効)。

| 表52. 停止ビット選択 | 5      |
|--------------|--------|
| USBS         | 停止ビット数 |
| 0            | 1ピット   |
| 1            | 2t*y}  |

## ■ ビット2,1 - UCSZ1,0: データ ビット長選択 (Character Size)

USART制御/状態レジスタB(UCSRB)のUCSZ2ビットと組み合わせたUCSZ1,0ビットは送受信部で使うフレームのデータ ビット数(Character size)を設定します。

| 表53. | データピ | ット長選択 |
|------|------|-------|
|------|------|-------|

| UCSZ2~0 | 0 0 0 | 0 0 1 | 0 1 0 | 0 1 1 | 100  | 101  | 1 1 0 | 111  |
|---------|-------|-------|-------|-------|------|------|-------|------|
| データビット数 | 5ピット  | 6Ľ'yF | 7ピット  | 8ť'yh | (予約) | (予約) | (予約)  | 9ピット |

#### ■ ビット0 - UCPOL: クロック極性選択 (Clock Polarity)

このビットは同期動作に対してだけ使われます。非同期動作が使われるとき、このビットに0を書いてください。 UCPOLビットは同期クロック(XCK)、データ出力変更、データ 入力採取間の関係を設定します。

| 表54. XCKクロック極性選択 |                  |                  |  |  |  |  |  |  |  |
|------------------|------------------|------------------|--|--|--|--|--|--|--|
| UCPOL            | 送信データ変更(TXDピン出力) | 受信データ採取(RXDピン入力) |  |  |  |  |  |  |  |
| 0                | XCKの上昇端          | XCKの下降端          |  |  |  |  |  |  |  |
| 1                | XCKの下降端          | XCKの上昇端          |  |  |  |  |  |  |  |

## ■ USARTホーレートレジスタ (USART Baud Rate Register) UBRRH, UBRRL (UBRR)

| ピット         | 15    | 14    | 13    | 12    | 11     | 10     | 9     | 8     |       |
|-------------|-------|-------|-------|-------|--------|--------|-------|-------|-------|
| \$02 (\$22) | _     | _     | -     | -     | UBRR11 | UBRR10 | UBRR9 | UBRR8 | UBRRH |
| Read/Write  | R     | R     | R     | R     | R/W    | R/W    | R/W   | R/W   |       |
| 初期値         | 0     | 0     | 0     | 0     | 0      | 0      | 0     | 0     |       |
| ピット         | 7     | 6     | 5     | 4     | 3      | 2      | 1     | 0     | _     |
| \$09 (\$29) | UBRR7 | UBRR6 | UBRR5 | UBRR4 | UBRR3  | UBRR2  | UBRR1 | UBRR0 | UBRRL |
| 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     |       |

## ■ ビット15~12 - Res: 予約 (Reserved Bits)

これらのビットは将来使用するために予約されています。将来のデバイスとの共通性のため、UBRRHが書かれるとき、これらのビットはのが書かれなければなりません。

#### ■ ビット11~0 - UBRR11~0: ボーレート分周値 (USART Baud Rate Register)

これはUSARTのボーレートを含む12ビット レジスタです。UBRRHがUSARTボーレートの上位4ビットを含み、UBRRLが下位8ビットを含みます。ボーレートが変更されると、送受信部で進行中の転送は不正にされます。UBRRL書き込みはボーレート前置分周器の更新を直ちに始めます。





# ボーレート設定例

標準的なクリスタル発振子やセラミック振動子の周波数に対して最も一般的に使われる非同期動作のボーレートは**表55**.のUBRR設定を使うことによって生成できます。目的のボーレートに対して設定誤差1.5%(標準速:U2X=0)、1.0%(倍速:U2X=1)以上を赤字で示します(<mark>訳注</mark>:原書の本文は0.5%未満を太字)。より高い誤差率でも受け入れ可能ですが、特に長い直列フレーム(85頁の「非同期での動作範囲」参照)で誤差率が高いと、受信部は雑音耐性が低下します。誤差率は次式を使って計算されます。

誤差率(%) = ( UBRR設定ボーレート(最近似値) - 1 ) ×100(%)

表55. Xtal、ボーレート対UBRRH.UBRRL設定(UBRR=UBRRH:UBRRL)

| 2,00. At | <u> </u> |       | Hz   |       | X.C. (© |                   | 2MHz | 3 DICCE)  |      | 2M                 | lHz  |       |      | 2 457             | 6MHz |       |
|----------|----------|-------|------|-------|---------|-------------------|------|-----------|------|--------------------|------|-------|------|-------------------|------|-------|
| ホーレート    | U2       | X=0   |      | !X=1  | U2      | X= <mark>0</mark> |      | 2X=1      | U2   | 2X= <mark>0</mark> |      | 2X=1  | U2   | X= <mark>0</mark> |      | !X=1  |
| (bps)    | UBRR     | 誤差(%) | UBRR | 誤差(%) | UBRR    | 誤差(%)             | UBRR | 誤差(%)     | UBRR | 誤差(%)              | UBRR | 誤差(%) | UBRR | 誤差(%)             | UBRR | 誤差(%) |
| 1200     | 51       | 0.2   | 103  | 0.2   | 95      | 0.0               | 191  | 0.0       | 103  | 0.2                | 207  | 0.2   | 127  | 0.0               | 255  | 0.0   |
| 2400     | 25       | 0.2   | 51   | 0.2   | 47      | 0.0               | 95   | 0.0       | 51   | 0.2                | 103  | 0.2   | 63   | 0.0               | 127  | 0.0   |
| 4800     | 12       | 0.2   | 25   | 0.2   | 23      | 0.0               | 47   | 0.0       | 25   | 0.2                | 51   | 0.2   | 31   | 0.0               | 63   | 0.0   |
| 9600     | 6        | -7.0  | 12   | 0.2   | 11      | 0.0               | 23   | 0.0       | 12   | 0.2                | 25   | 0.2   | 15   | 0.0               | 31   | 0.0   |
| 14400    | 3        | 8.5   | 8    | -3.5  | 7       | 0.0               | 15   | 0.0       | 8    | -3.5               | 16   | 2.1   | 10   | -3.0              | 20   | 1.6   |
| 19200    | 2        | 8.5   | 6    | -7.0  | 5       | 0.0               | 11   | 0.0       | 6    | -7.0               | 12   | 0.2   | 7    | 0.0               | 15   | 0.0   |
| 28800    | 1        | 8.5   | 3    | 8.5   | 3       | 0.0               | 7    | 0.0       | 3    | 8.5                | 8    | -3.5  | 4    | 6.7               | 10   | -3.0  |
| 38400    | 1        | -18.6 | 2    | 8.5   | 2       | 0.0               | 5    | 0.0       | 2    | 8.5                | 6    | -7.0  | 3    | 0.0               | 7    | 0.0   |
| 57600    | 0        | 8.5   | 1    | 8.5   | 1       | 0.0               | 3    | 0.0       | 1    | 8.5                | 3    | 8.5   | 2    | -11.1             | 4    | 6.7   |
| 76800    | 0        | -18.6 | 1    | -18.6 | 1       | -25.0             | 2    | 0.0       | 1    | -18.6              | 2    | 8.5   | 1    | 0.0               | 3    | 0.0   |
| 115.2k   | _        | _     | 0    | 8.5   | 0       | 0.0               | 1    | 0.0       | 0    | 8.5                | 1    | 8.5   | 0    | 33.3              | 2    | -11.1 |
| 230.4k   | _        | _     | 0    | -45.7 | 0       | -50.0             | 0    | 0.0       | 0    | -45.7              | 0    | 8.5   | 0    | -33.3             | 0    | 33.3  |
| 250k     | _        | _     |      | _     | _       | _                 | 0    | -7.8      | _    | _                  | 0    | 0.0   | -    | _                 | 0    | 22.9  |
| 最高速      | 62500    |       | 12   | 125k  |         | 115.2k 230.4k     |      | 125k 250k |      |                    | 50k  | 15    | 3.6k | 307.2k            |      |       |

| ホーレート  |      | 3.276             | 8MHz |       |      | 3.686             | 4MHz |       |      | 4M                 | Hz    |       |                     | 4.608 | BMHz  |       |
|--------|------|-------------------|------|-------|------|-------------------|------|-------|------|--------------------|-------|-------|---------------------|-------|-------|-------|
|        | U2   | X= <mark>0</mark> | U2   | !X=1  | U2   | X= <mark>0</mark> | U2   | X=1   | U2   | 2X= <mark>0</mark> | U2X=1 |       | U2X= <mark>0</mark> |       | U2X=1 |       |
| (bps)  | UBRR | 誤差(%)             | UBRR | 誤差(%) | UBRR | 誤差(%)             | UBRR | 誤差(%) | UBRR | 誤差(%)              | UBRR  | 誤差(%) | UBRR                | 誤差(%) | UBRR  | 誤差(%) |
| 1200   | 170  | -0.2              | 340  | 0.1   | 191  | 0.0               | 384  | 0.0   | 207  | 0.2                | 416   | -0.1  | 239                 | 0.0   | 479   | 0.0   |
| 2400   | 84   | 0.4               | 170  | -0.2  | 95   | 0.0               | 191  | 0.0   | 103  | 0.2                | 207   | 0.2   | 119                 | 0.0   | 239   | 0.0   |
| 4800   | 42   | -0.8              | 84   | 0.4   | 47   | 0.0               | 95   | 0.0   | 51   | 0.2                | 103   | 0.2   | 59                  | 0.0   | 119   | 0.0   |
| 9600   | 20   | 1.6               | 42   | -0.8  | 23   | 0.0               | 47   | 0.0   | 25   | 0.2                | 51    | 0.2   | 29                  | 0.0   | 59    | 0.0   |
| 14400  | 13   | 1.6               | 27   | 1.6   | 15   | 0.0               | 31   | 0.0   | 16   | 2.1                | 34    | -0.8  | 19                  | 0.0   | 39    | 0.0   |
| 19200  | 10   | -3.0              | 20   | 1.6   | 11   | 0.0               | 23   | 0.0   | 12   | 0.2                | 25    | 0.2   | 14                  | 0.0   | 29    | 0.0   |
| 28800  | 6    | 1.6               | 13   | 1.6   | 7    | 0.0               | 15   | 0.0   | 8    | -3.5               | 16    | 2.1   | 9                   | 0.0   | 19    | 0.0   |
| 38400  | 4    | 6.7               | 10   | -3.0  | 5    | 0.0               | 11   | 0.0   | 6    | -7.0               | 12    | 0.2   | 7                   | -6.3  | 14    | 0.0   |
| 57600  | 3    | -11.1             | 6    | 1.6   | 3    | 0.0               | 7    | 0.0   | 3    | 8.5                | 8     | -3.5  | 4                   | 0.0   | 9     | 0.0   |
| 76800  | 2    | -11.1             | 4    | 6.7   | 2    | 0.0               | 5    | 0.0   | 2    | 8.5                | 6     | -7.0  | 3                   | -6.3  | 7     | -6.3  |
| 115.2k | 1    | -11.1             | 3    | -11.1 | 1    | 0.0               | 3    | 0.0   | 1    | 8.5                | 3     | 8.5   | 2                   | -16.7 | 4     | 0.0   |
| 230.4k | 0    | -11.1             | 1    | -11.1 | 0    | 0.0               | 1    | 0.0   | 0    | 8.5                | 1     | 8.5   | 0                   | 25.0  | 2     | -16.7 |
| 250k   | -    | _                 | 1    | -18.1 | 0    | -7.8              | 1    | -7.8  | 0    | 0.0                | 1     | 0.0   | 0                   | 15.2  | 1     | 15.2  |
| 500k   | _    | 1                 | 0    | -18.1 | -    | _                 | 0    | -7.8  | _    | _                  | 0     | 0.0   | 0                   | -42.4 | 0     | 15.2  |
| 1M     | _    | -                 | 1    | _     | -    | _                 | -    | _     | -    | _                  | -     | _     | -                   | _     | 0     | -42.4 |
| 最高速    | 20   | 4.8k              | 40   | 9.6k  | 23   | 0.4k              | 46   | 0.8k  | 2    | 50k                | 50    | 00k   | 2                   | 88k   | 5′    | 76k   |

注: 最高速はUBRR=0、誤差=0.0%です。 以降の周波数は次頁へ続く。

(<mark>訳注</mark>) 原書では頁割された表毎に表番号55.~58.となっていますが、共通性から纏めて表55.としました。 原書に対して数種の発振周波数を追加しました。

| 表55 (続 | 表55 (続き). Xtal、ボーレート対UBRRH,UBRRL設定 (UBRR=UBRRH:UBRRL) |                   |      |       |      |                    |      |       |        |                    |        |       |      |                    |      |       |
|--------|-------------------------------------------------------|-------------------|------|-------|------|--------------------|------|-------|--------|--------------------|--------|-------|------|--------------------|------|-------|
| ボーレート  |                                                       | 4.915             | 2MHz |       |      | 6.144              | IMHz |       |        | 7.372              | 8MHz   |       |      | 8M                 | lHz  |       |
|        | U2                                                    | X= <mark>0</mark> | U2   | !X=1  | U2   | !X= <mark>0</mark> | U2   | X=1   |        | !X= <mark>0</mark> | U2     | !X=1  | U2   | 2X= <mark>0</mark> | U2   | 2X=1  |
| (bps)  | UBRR                                                  | 誤差(%)             | UBRR | 誤差(%) | UBRR | 誤差(%)              | UBRR | 誤差(%) | UBRR   | 誤差(%)              | UBRR   | 誤差(%) | UBRR | 誤差(%)              | UBRR | 誤差(%) |
| 1200   | 255                                                   | 0.0               | 511  | 0.0   | 319  | 0.0                | 639  | 0.0   | 383    | 0.0                | 767    | 0.0   | 416  | -0.1               | 832  | 0.0   |
| 2400   | 127                                                   | 0.0               | 255  | 0.0   | 159  | 0.0                | 319  | 0.0   | 191    | 0.0                | 383    | 0.0   | 207  | 0.2                | 416  | -0.1  |
| 4800   | 63                                                    | 0.0               | 127  | 0.0   | 79   | 0.0                | 159  | 0.0   | 95     | 0.0                | 191    | 0.0   | 103  | 0.2                | 207  | 0.2   |
| 9600   | 31                                                    | 0.0               | 63   | 0.0   | 39   | 0.0                | 79   | 0.0   | 47     | 0.0                | 95     | 0.0   | 51   | 0.2                | 103  | 0.2   |
| 14400  | 20                                                    | 1.6               | 42   | -0.8  | 26   | -1.2               | 52   | 0.6   | 31     | 0.0                | 63     | 0.0   | 34   | -0.8               | 68   | 0.6   |
| 19200  | 15                                                    | 0.0               | 31   | 0.0   | 19   | 0.0                | 39   | 0.0   | 23     | 0.0                | 47     | 0.0   | 25   | 0.2                | 51   | 0.2   |
| 28800  | 10                                                    | -3.0              | 20   | 1.6   | 12   | 2.6                | 26   | -1.2  | 15     | 0.0                | 31     | 0.0   | 16   | 2.1                | 34   | -0.8  |
| 38400  | 7                                                     | 0.0               | 15   | 0.0   | 9    | 0.0                | 19   | 0.0   | 11     | 0.0                | 23     | 0.0   | 12   | 0.2                | 25   | 0.2   |
| 57600  | 4                                                     | 6.7               | 10   | -3.0  | 6    | -4.8               | 12   | 2.6   | 7      | 0.0                | 15     | 0.0   | 8    | -3.5               | 16   | 2.1   |
| 76800  | 3                                                     | 0.0               | 7    | 0.0   | 4    | 0.0                | 9    | 0.0   | 5      | 0.0                | 11     | 0.0   | 6    | -7.0               | 12   | 0.2   |
| 115.2k | 2                                                     | -11.1             | 4    | 6.7   | 2    | 11.1               | 6    | -4.8  | 3      | 0.0                | 7      | 0.0   | 3    | 8.5                | 8    | -3.5  |
| 230.4k | 1                                                     | 33.3              | 2    | -11.1 | 1    | -16.7              | 2    | 11.1  | 1      | 0.0                | 3      | 0.0   | 1    | 8.5                | 3    | 8.5   |
| 250k   | 1                                                     | 22.9              | 2    | -18.1 | 1    | -23.2              | 2    | 2.4   | 1      | -7.8               | 3      | 0.0   | 1    | 0.0                | 3    | 0.0   |
| 500k   | 0                                                     | -38.6             | 0    | 22.9  | 0    | -23.2              | 1    | -23.2 | 0      | -7.8               | 1      | -7.8  | 0    | 0.0                | 1    | 0.0   |
| 1M     | -                                                     | 1                 | 0    | -38.6 | _    | _                  | 0    | -23.2 | -      | _                  | 0      | -7.8  | 1    | _                  | 0    | 0.0   |
| 最高速    | 最高速 307.2k                                            |                   | 61   | 4.4k  | 38   | 84k                | 70   | 58k   | 460.8k |                    | 921.6k |       | 500k |                    | 1M   |       |

| ボーレート          |      | 9.216              | 6MHz |       |      | 9.830              | 4MHz |       |      | 101                | ИHz  |       |      | 11.059            | 92MHz |       |
|----------------|------|--------------------|------|-------|------|--------------------|------|-------|------|--------------------|------|-------|------|-------------------|-------|-------|
| 小ーレート<br>(bps) | U2   | 2X= <mark>0</mark> | U2   | !X=1  | U2   | !X= <mark>0</mark> | U2   | 2X=1  | U2   | 2X= <mark>0</mark> | U2   | 2X=1  | U2   | X= <mark>0</mark> | U2    | !X=1  |
| (bps)          | UBRR | 誤差(%)              | UBRR | 誤差(%) | UBRR | 誤差(%)              | UBRR | 誤差(%) | UBRR | 誤差(%)              | UBRR | 誤差(%) | UBRR | 誤差(%)             | UBRR  | 誤差(%) |
| 1200           | 479  | 0.0                | 959  | 0.0   | 511  | 0.0                | 1023 | 0.0   | 520  | -0.0               | 1041 | -0.0  | 575  | 0.0               | 1151  | 0.0   |
| 2400           | 239  | 0.0                | 479  | 0.0   | 255  | 0.0                | 511  | 0.0   | 259  | 0.2                | 520  | -0.0  | 287  | 0.0               | 575   | 0.0   |
| 4800           | 119  | 0.0                | 239  | 0.0   | 127  | 0.0                | 255  | 0.0   | 129  | 0.2                | 259  | 0.2   | 143  | 0.0               | 287   | 0.0   |
| 9600           | 59   | 0.0                | 119  | 0.0   | 63   | 0.0                | 127  | 0.0   | 64   | 0.2                | 129  | 0.2   | 71   | 0.0               | 143   | 0.0   |
| 14400          | 39   | 0.0                | 79   | 0.0   | 42   | -0.8               | 84   | 0.4   | 42   | 0.9                | 86   | -0.2  | 47   | 0.0               | 95    | 0.0   |
| 19200          | 29   | 0.0                | 59   | 0.0   | 31   | 0.0                | 63   | 0.0   | 32   | -1.4               | 64   | 0.2   | 35   | 0.0               | 71    | 0.0   |
| 28800          | 19   | 0.0                | 39   | 0.0   | 20   | 1.6                | 42   | -0.8  | 21   | -1.4               | 42   | 0.9   | 23   | 0.0               | 47    | 0.0   |
| 38400          | 14   | 0.0                | 29   | 0.0   | 15   | 0.0                | 31   | 0.0   | 15   | 1.8                | 32   | -1.4  | 17   | 0.0               | 35    | 0.0   |
| 57600          | 9    | 0.0                | 19   | 0.0   | 10   | -3.0               | 20   | 1.6   | 10   | -1.4               | 21   | -1.4  | 11   | 0.0               | 23    | 0.0   |
| 76800          | 7    | 6.7                | 14   | 0.0   | 7    | 0.0                | 15   | 0.0   | 7    | 1.8                | 15   | 1.8   | 8    | 0.0               | 17    | 0.0   |
| 115.2k         | 4    | 0.0                | 9    | 0.0   | 4    | 6.7                | 10   | -3.0  | 4    | 8.5                | 10   | -1.4  | 5    | 0.0               | 11    | 0.0   |
| 230.4k         | 2    | -16.7              | 4    | 0.0   | 2    | -11.1              | 4    | 6.7   | 2    | -9.6               | 4    | 8.5   | 2    | 0.0               | 5     | 0.0   |
| 250k           | 1    | 15.2               | 4    | -7.8  | 1    | -23.2              | 4    | -1.7  | 2    | -16.7              | 4    | 0.0   | 2    | -7.8              | 5     | -7.8  |
| 500k           | 0    | 15.2               | 1    | 15.2  | 0    | 22.9               | 1    | 22.9  | 0    | 25.0               | 2    | -16.7 | 0    | 38.2              | 2     | -7.8  |
| 1M             | 0    | -42.4              | 0    | 15.2  | 0    | -38.6              | 0    | 22.9  | 0    | -37.5              | 0    | 25.0  | 0    | -30.9             | 0     | 38.2  |
| 最高速            | 5    | 76k                | 1.1  | 52M   | 61   | 4.4k               | 1.2  | 288M  | 62   | 25k                | 1.   | 25M   | 69   | 1.2k              | 1.3   | 824M  |

| ボーレート  |           | 14.745             | 6MHz |            |      | 161                | ИHz  |       |        | 18.432             | 20MHz  |       |       | 201                | ИHz  |       |
|--------|-----------|--------------------|------|------------|------|--------------------|------|-------|--------|--------------------|--------|-------|-------|--------------------|------|-------|
| / \    | U2        | 2X= <mark>0</mark> | U2   | 2X=1       | U2   | !X= <mark>0</mark> | U2   | X=1   | U2     | 2X= <mark>0</mark> | U2     | !X=1  | U2    | !X= <mark>0</mark> | U2   | !X=1  |
| (bps)  | UBRR      | 誤差(%)              | UBRR | 誤差(%)      | UBRR | 誤差(%)              | UBRR | 誤差(%) | UBRR   | 誤差(%)              | UBRR   | 誤差(%) | UBRR  | 誤差(%)              | UBRR | 誤差(%) |
| 1200   | 767       | 0.0                | 1533 | 0.0        | 832  | 0.0                | 1666 | 0.0   | 959    | 0.0                | 1919   | 0.0   | 1041  | 0.0                | 2082 | 0.0   |
| 2400   | 383       | 0.0                | 767  | 0.0        | 416  | -0.1               | 832  | 0.0   | 479    | 0.0                | 959    | 0.0   | 520   | 0.0                | 1041 | 0.0   |
| 4800   | 191       | 0.0                | 383  | 0.0        | 207  | 0.2                | 416  | -0.1  | 239    | 0.0                | 479    | 0.0   | 259   | 0.2                | 520  | 0.0   |
| 9600   | 95        | 0.0                | 191  | 0.0        | 103  | 0.2                | 207  | 0.2   | 119    | 0.0                | 239    | 0.0   | 129   | 0.2                | 259  | 0.2   |
| 14400  | 63        | 0.0                | 127  | 0.0        | 68   | 0.6                | 138  | -0.1  | 79     | 0.0                | 159    | 0.0   | 86    | -0.2               | 173  | -0.2  |
| 19200  | 47        | 0.0                | 95   | 0.0        | 51   | 0.2                | 103  | 0.2   | 59     | 0.0                | 119    | 0.0   | 64    | 0.2                | 129  | 0.2   |
| 28800  | 31        | 0.0                | 63   | 0.0        | 34   | -0.8               | 68   | 0.6   | 39     | 0.0                | 79     | 0.0   | 42    | 0.9                | 86   | -0.2  |
| 38400  | 23        | 0.0                | 47   | 0.0        | 25   | 0.2                | 51   | 0.2   | 29     | 0.0                | 59     | 0.0   | 32    | -1.4               | 64   | 0.2   |
| 57600  | 15        | 0.0                | 31   | 0.0        | 16   | 2.1                | 34   | -0.8  | 19     | 0.0                | 39     | 0.0   | 21    | -1.4               | 42   | 0.9   |
| 76800  | 11        | 0.0                | 23   | 0.0        | 12   | 0.2                | 25   | 0.2   | 14     | 0.0                | 29     | 0.0   | 15    | 1.7                | 32   | -1.4  |
| 115.2k | 7         | 0.0                | 15   | 0.0        | 8    | -3.5               | 16   | 2.1   | 9      | 0.0                | 19     | 0.0   | 10    | -1.4               | 21   | -1.4  |
| 230.4k | 3         | 0.0                | 7    | 0.0        | 3    | 8.5                | 8    | -3.5  | 4      | 0.0                | 9      | 0.0   | 4     | 8.5                | 10   | -1.4  |
| 250k   | 3         | -7.8               | 6    | 5.3        | 3    | 0.0                | 7    | 0.0   | 4      | -7.8               | 8      | 2.4   | 4     | 0.0                | 9    | 0.0   |
| 500k   | 1         | -7.8               | 3    | -7.8       | 1    | 0.0                | 3    | 0.0   | 1      | 15.2               | 4      | -7.8  | 1     | 25.0               | 4    | 0.0   |
| 1M     | 0         | -7.8               | 1    | -7.8       | 0    | 0.0                | 1    | 0.0   | 0      | 15.2               | 1      | 15.2  | 0     | 25.0               | 1    | 25.0  |
| 最高速    | 高速 921.6k |                    | 1.8  | 1.8432M 1M |      | M                  | 2M   |       | 1.152M |                    | 2.304M |       | 1.25M |                    | 2.5M |       |

<u>注</u>: 最高速はUBRR=0、誤差=0.0%です。





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

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

- **2線同期データ転送** (主装置または従装置: f<sub>SCLmax</sub>=f<sub>CK</sub>/16)
- 3線同期データ転送 (主装置:  $f_{SCKmax} = f_{CK}/2$ 、従装置:  $f_{SCKmax} = f_{CK}/4$ )
- データ受信割り込み
- アイドル動作からの起動復帰
- 2線動作でのパワーダウン動作を含む全休止形態からの起動復帰
- 割り込み能力を持つ2線動作開始条件検出器

## 概要

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



8ビットの移動レジスタ(USIDR)はデータ バス経由で直接的にアクセス可能で、入って来るデータと出て行くデータを含みます。このレジスタは緩衝部を持たないので、データが失われないことを保証するためにデータは可能な限り早く読まなければなりません。最上位ビットは動作種別設定に依存して2つの出力ピンの1つに接続されます。トランスペアレント(透過型)ラッチは直列(移動)レジスタ出力と出力ピン間に挿入され、データの変更をデータ入力採取と逆のクロック端に遅らせます。直列入力は(種別)設定に拘らず、常にデータ入力(DI)ピンから採取されます。

4ビット計数器はデータ バス経由で読み書き両方ができ、溢れ割り込みを生成できます。この計数器と直列(移動)レジスタは同じクロック元によって同時にクロック駆動されます。これは受信または送信したビット数を数え、転送完了時に割り込みの生成を計数器に許します。外部クロック元が選択されると、この計数器が両クロック端で計数することに注意してください。この場合、計数器はビット数ではなく、エッジ数を数えます。クロックは3つの異なるクロック元(USCKピン、タイマ/カウンタ0溢れ、ソフトウェア)から選択できます。

2線クロック制御部(回路)は2線バスで<mark>開始条件</mark>が検出される時に割り込みを発生できます。<mark>開始条件</mark>検出後、または計数器溢れ後、ク ロック ピンをLow</mark>に保持することによって待ち状態を生成することもできます。

## 機能説明

## 3線動作

USIの3線動作は直列周辺インターフェース(SPI)の動作種別0と1に準拠していますが、従装置選択(SS)ピン機能を持ちません。けれども、この特性(機能)は必要ならばソフトウェアで実現できます。この動作で使われるピン名はDI,DO,USCKです。



図61.は3線動作での2つのUSI部(一方は主装置、他方は従装置)動作を示します。このような方法で連結された2つの移動レジスタは8 USCKクロック後、各々のレジスタのデータが交換されます。この同じクロック(USCK)がUSIの4ビット計数器も増加(+1)します。従って計数器溢れ割り込み要求フラグ(USIOIF)は転送が完了される時を決めるのに使えます。このクロックはPORTレジスタ経由USCKピン1/0交互切り替え、またはUSICRのUSITCビットへの1書き込みによる主装置装置ソフトウェアによって生成されます。



3線動作タイミングは図62.で示されます。図の最上部はUSCK周期参照基準です。これらの各周期に対して1ビットがUSI移動レシ、スタ (USIDR)に移動されます。USCKタイミングは両方の外部クロック動作について示されます。外部クロック動作0(USICS0=0)でのDIは上昇端で採取され、DOは下降端で変更(USIDRが1つ移動)されます。外部クロック動作1(USICS0=1)は外部クロック動作0に対して逆端を使い、換言すると下降端でデータを採取、上昇端で出力を変更します。USIクロック動作種別はSPIデータ動作種別0と1に対応します。このタイミング図(図62.)を参照すると、バス転送は次の手順を含みます。

- 1. 主装置と従装置はデータ出力を設定し、使用規約に依存して出力駆動部を許可します(AとB)。この出力は直列データレジスタへの送信されるべきデータ書き込みによって設定します。出力の許可はポート方向レジスタの対応するビット設定によって行います。A点とB点はどんな特別な順番もありませんが、両方共にデータが採取されるC点よりも最低1/2USCK周期前でなければならないことに注意してください。これはデータ設定の必要条件を満足させるのを保証するために行わなければなりません。4ビット計数器は0にリセットします。
- 2. 主装置はUSCK線をソフトウェアで2度切り替えることによってクロック パルスを生成します(CとD)。主装置と従装置のデータ入力(DI)ピンの ビット値は最初のエッシ(C)でUSIによって採取され、データ出力は逆端(D)で変更されます。4ビット計数器は両端で計数します。
- 3. レジスタ(バイト)転送完了のために手順2.が8回繰り返されます。
- 4.8クロック パルス(換言すると16クロック端)後、計数器が溢れて転送完了を示します。転送したバイト データは新規転送が開始され得るのに先立って直ぐに処置されなければなりません。溢れ割り込みはプロセッサがアイドル動作に設定されているなら、プロセッサを起動復帰します。使用規約によって、従装置は直ぐに出力をHi-Z設定にできます。





# SPI主装置操作例

次のコードはSPI主装置としてのUSI使用法を実際に示します。

| アセンブリ言語  | アプログラムイ                  | ·<br>例                                                                                                                                                                                                                              |                                                                    |
|----------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
| SPIM:    | OUT<br>LDI<br>OUT<br>LDI | USIDR, R16<br>R16, (1< <usioif)<br>USISR, R16<br/>R16, (1&lt;<usiwmo) (1<<usiclk)="" (1<<usics1)="" (1<<usitc)<="" td=""  =""><td>;送信データを設定<br/>;USIOIFビットのみ1値を取得<br/>;フラグ解除/計数器初期化<br/>;3線動作クロック生成値を取得</td></usiwmo)></usioif)<br> | ;送信データを設定<br>;USIOIFビットのみ1値を取得<br>;フラグ解除/計数器初期化<br>;3線動作クロック生成値を取得 |
| ;        |                          |                                                                                                                                                                                                                                     |                                                                    |
| SPIM_LP: | OUT                      | USICR, R16                                                                                                                                                                                                                          | ;SCKクロック端発生                                                        |
|          | SBIS                     | USISR, USIOIF                                                                                                                                                                                                                       | ;計数器溢れでスキップ                                                        |
|          | RJMP                     | SPIM_LP                                                                                                                                                                                                                             | ;計数器溢れまで継続                                                         |
| ;        |                          |                                                                                                                                                                                                                                     |                                                                    |
|          | IN<br>RET                | R16, USIDR                                                                                                                                                                                                                          | ;受信データを取得<br>;呼び出し元へ復帰                                             |

このコート、は8命令(+RET)のみ使用の容量最適化です。このコート、例はDOとUSCKビンがDDRBで出力として許可される仮定です。この 関数が呼び出される前にR16レシ、スタへ格納した値は従装置に転送され、転送が完了された時に従装置から受信したデータがR16レシスタに格納されて戻ります。

2行目と3行目の命令は計数器溢れ割り込み要求フラグ(USIOIF)を解除(0)し、USI 4ビット計数器値を解除(=0)します。4行目と6行目の命令は3線動作、上昇端クロック、USITCストロープ計数、SCK出力交互切り替え(PORTB7)を設定します。この繰り返しは16回繰り返されます。

次のコートは最高速( $f_{SCK}=f_{CK}/2$ )でのSPI主装置としてのUSI使用法を実際に示します。

| アセンブリ言語 | 吾フ <sup>°</sup> ロク゛ラム・ | 例                                                                                                            |                        |
|---------|------------------------|--------------------------------------------------------------------------------------------------------------|------------------------|
| SPIM_F: | OUT                    | USIDR, R16                                                                                                   | ;送信データを設定              |
|         | LDI                    | R16, (1< <usiwmo) (0<<usicso)="" (1<<usitc)<="" td=""  =""><td>;3線動作初期値を取得</td></usiwmo)>                    | ;3線動作初期値を取得            |
|         | LDI                    | R17, (1< <usiwmo) (0<<usicso)="" (1<<usiclk)<="" (1<<usitc)="" td=""  =""><td>;3線動作クロック生成値を取得</td></usiwmo)> | ;3線動作クロック生成値を取得        |
| ;       |                        |                                                                                                              |                        |
|         | OUT                    | USICR, R16                                                                                                   | ;MSB転送                 |
|         | OUT                    | USICR, R17                                                                                                   | ;                      |
|         | OUT                    | USICR, R16                                                                                                   | ;ビット6転送                |
|         | OUT                    | USICR, R17                                                                                                   | ;                      |
|         | OUT                    | USICR, R16                                                                                                   | ;ビット5転送                |
|         | OUT                    | USICR, R17                                                                                                   | ;                      |
|         | OUT                    | USICR, R16                                                                                                   | ;ビット4転送                |
|         | OUT                    | USICR, R17                                                                                                   | ;                      |
|         | OUT                    | USICR, R16                                                                                                   | ;ビット3転送                |
|         | OUT                    | USICR, R17                                                                                                   | ,                      |
|         | OUT                    | USICR, R16                                                                                                   | ; ビット2転送               |
|         | OUT                    | USICR, R17                                                                                                   | ,<br>・レペ。 l 1 まつと      |
|         | OUT                    | USICR, R16                                                                                                   | ;t゙ット1転送               |
|         | OUT                    | USICR, R17                                                                                                   | ,<br>;LSB転送            |
|         | OUT                    | USICR, R16                                                                                                   | ,LODEA区                |
|         | OUT                    | USICR, R17                                                                                                   | ,                      |
| ,       | IN                     | R16, USIDR                                                                                                   | ;受信データを取得              |
|         | RET                    | KIO, USIDK                                                                                                   | ,又信/一/を取得<br>;呼び出し元へ復帰 |
|         | KEI                    |                                                                                                              | ,吁い山し儿、海畑              |

## SPI従装置操作例

次のコートはSPI従装置としてのUSI使用法を実際に示します。

| アセンブリ言語  | ラプログラム(   | 列                                                                                |                        |
|----------|-----------|----------------------------------------------------------------------------------|------------------------|
| init:    | LDI       | R16, (1< <usiwmo) (1<<usics1)<="" th=""  =""><th>;3線動作,外部クロック値を取得</th></usiwmo)> | ;3線動作,外部クロック値を取得       |
|          | OUT       | USICR, R16                                                                       | ;3線動作,外部クロック設定         |
| SPIS:    | OUT       | USIDR, R16                                                                       | ;送信データを設定              |
|          | LDI       | R16, (1< <usioif)< td=""><td>;USIOIFビットのみ1値を取得</td></usioif)<>                   | ;USIOIFビットのみ1値を取得      |
|          | OUT       | USISR, R16                                                                       | ;フラグ解除/計数器初期化          |
| SPIS_LP: | SBIS      | USISR, USIOIF                                                                    | ;計数器溢れでスキップ            |
|          | RJMP      | SPIS_LP                                                                          | ;計数器溢れまで継続             |
| ,        | IN<br>RET | R16, USIDR                                                                       | ;受信データを取得<br>;呼び出し元へ復帰 |

このコートは8命令(+RET)のみ使用の容量最適化です。このコート例はDDRBレジスタでDOピンが出力、USCKピンが入力として設定されると仮定します。この関数が呼び出される前にR16レジスタへ格納した値は主装置に転送され、転送が完了された時に主装置から受信したデータがR16レジスタに格納されて戻ります。

最初の2命令は初期化用だけで、一度だけ実行されるのを必要とすることに注意してください。これらの命令は3線動作と上昇端クロックを設定します。この繰り返しはUSI計数器溢れフラグが設定(1)されるまで繰り返されます。

#### 2線動作

USIの2線動作はI<sup>2</sup>C(TWI)バス規約に準拠していますが、出力のスリューレート制限と入力雑音濾波器がありません。この動作で使われるピン名はSCLとSDAです。



図63.は2線動作での2つのUSI部(一方は主装置、他方は従装置)動作を示します。システム動作が使用通信構造に大きく依存するために示されるのは物理層のみです。この段階での主装置動作と従装置動作間の主な違いは常に主装置によって行われる直列クロック生成と、従装置だけがクロック制御部(回路)を使用することです。クロック生成はソフトウェアで実行されなければなりませんが、移動動作は両装置で自動的に行われます。データの移動に関してこの動作種別で下降端でのクロックだけを実際に使うことに注意してください。従装置はSCLクロックをLowに強制することにより、転送の開始と終了で待ち状態(ウェイトステート)を挿入できます。これは(主装置が)上昇端を生成してしまった後に主装置はSCL線が実際に開放されたかを常に検査しなければならないことを意味します。

このクロックが(4ピット)計数器も増加(+1)するため、計数器溢れ(USIOIF)は転送が完了されたことを示すのに使えます。このクロックは主装置によるPORTBレジスタ経由のSCLピン交互切り替えによって生成されます。

データ方向は物理層によって与えられません。データの流れを制御するためにTWIバスで使ったような或る種の規約が実装されなければなりません。





このタイミング 図(図64.)を参照すると、ハ、ス転送は次の手順を含みます。

# 図64. 代表的な2線動作タイミング



- 1. 開始条件は主装置によるSCL線High中のSDA線Low強制によって生成されます(A)。SDAは移動レジスタのビット7への0書き込みか、またはPORTレジスタで対応ビットを0に設定のどちらかによって強制実行できます。出力が許可されるにはデータ方向(DDR)レジスタのビットが1に設定されなければならないことに注意してください。従装置の開始条件検出器論理回路(図65.参照)が開始条件を検出してUSISIFフラグを設定(1)します。このフラグは必要ならば割り込みを発生できます。
- 2. 加えて開始条件検出器は主装置がSCL線で上昇端を強制してしまった後にSCL線をLowに保持します(B)。これはアドレスを受信するために移動レジスタを設定する前に休止形態から起動復帰または他の処理を完了することを従装置に許します。これ(保持解除)は(4ビット)計数器をリセット(=0)して開始条件検出フラグ(USISIF)を解除(0)することによって行われます。
- 3. 主装置は転送されるべき最初のビットを設定してSCL線を開放します(C)。従装置はSCLクロックの上昇端でデータを採取して移動レジスタへ移動します。
- 4. 従装置アドレスとデータ方向(R/W)を含む8ビットが転送された後、従装置の(4ビット)計数器が溢れてSCL線がLowを強制されます(D)。 従装置は主装置の1つがアドレス指定してしまわない場合、SCL線を開放して新規開始条件を待ちます。
- 5. 従装置がアトンス指定されると、再びSCL線をLowに保持する前の応答(ACK)周期の間中、SDA線をLowに保持します(換言すると D点でSCLを開放する前に(4ビット)計数器レジスタは14に設定されなければなりません)。R/Wビットに依存して主装置か従装置は出力を許可します。このビットが設定(1)の場合、主装置読み込み動作が進行中です(換言すると従装置がSDA線を駆動します)。従装置は応答後(E)にSCL線をLowに保持することができます。
- 6. 主装置によって<mark>停止条件(F)</mark>か新規開始条件(<mark>再送開始条件</mark>)が与えられるまで全て同方向で複数バイが直ぐに転送できます。 従装置はより多くのデータを受信できない場合、最後に受信したバイトデータに応答しません。主装置が読み込み動作を行うとき、最後のバイルが転送された後の応答ビットをLowに強制することよってこの動作を終了しなければなりません。

## 開始条件検出器

開始条件検出器は**図65**.で示されます。SDA線はSCL線の有効な採取を保証するために(50~300nsの範囲で)遅延されます。開始条件検出器は2線動作でだけ許可されます。

開始条件検出器は非同期に動作し、従ってパワーダウン休止動作からプロセッサを起動できます。けれども使う規約がSCL保持時間で制限を持つかもしれません。従ってこの場合にこの特徴(機能)を使う時にCKSELヒューズで設定する発振器起動時間(16頁の「クロック系統とその配給」参照)も考慮内に取り入れられなければなりません。より多くの詳細については97頁のUSISIFフラグ記述を参照してください。



## USIでの代替使用

USI部を直列通信に使わないなら、柔軟な設計のため、代替処理を行うように設定できます。

半二重非同期データ転送

3線動作で移動レジスタを使うことによってソフトウェアだけよりも簡潔で高性能のUART実装が可能です。

4ビット計数器

4ビット計数器は溢れ割り込みとの自立型計数器として使えます。この計数器が外部的にクロック 駆動される場合、両クロック端が増加(+1)を発生することに注意してください。

12ビット計数器

USIの4ビット計数器とタイマ/カウンタ0の組み合わせは12ビット計数器としての使用を許します。

エッジ起動外部割り込み

4ビット計数器を最大値(\$F)に設定することによって追加外部割り込みとして機能できます。溢れフラグと割り込み許可ビットはこの外部割り込みに対して使われます。この特徴(機能)はUSICS1 ビットによって選択(=1)されます。

ソフトウェア割り込み

4ビット計数器の溢れ割り込みはクロック ストローブによって起動するソフトウェア割り込みとして使えます。

# USI用 レジスタ

## ■ USI データレシ スタ (USI Data Register) USIDR

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

USIは直列(移動)レジスタの緩衝を使いません、換言するとデータレジスタ(USIDR)をアクセスする時に直列レジスタは直接的にアクセスされます。レジスタが書かれるのと同じ周期で直列クロックが起こると、レジスタは書いた値を含み、移動は実行されません。(左)移動動作はUSIC S1,0ビット設定に従って実行されます。この移動動作は外部クロック端、タイマ/カウンタ0溢れにより、またはUSICLKストローフ、ビットを使うソフトウェアによって直接的に制御できます。2または3線動作種別が選択されない(USIWM1,0=00)時でも、外部データ入力(DI/SDA)と外部クロック入力(USCK/SCL)の両方が未だ移動レジスタによって使われ得ることに注意してください。

動作種別に従って使う出力ピン(DOまたはSDA)は出力ラッチを経由してデータレン、スタの最上位ピット(ビット7)に接続されます。この出力ラッチは外部クロック元が選択される(USICS1=1)時に直列クロック周期の前半中が透過(トランスペプレント)で、内部クロック元が使われる(USICS1=0)時に定常的な透過です。ラッチが透過である限り、新規MSBが書かれると、出力は直ちに変更されます。このラッチは違う(逆の)クロック端でデータ入力が採取され、データ出力が変更されるのを保証します。

移動レジスタからの出力データを許可するために、ピンに対応するデータ方向レジスタ(DDxn)が1に設定されなければならないことに注意してください。

# ■ USI状態レジスタ (USI Status Register) USISR

| ピット         | 7      | 6      | 5     | 4     | 3       | 2       | 1       | 0       |       |
|-------------|--------|--------|-------|-------|---------|---------|---------|---------|-------|
| \$0E (\$2E) | USISIF | USIOIF | USIPF | USIDC | USICNT3 | USICNT2 | USICNT1 | USICNT0 | USISR |
| Read/Write  | R/W    | R/W    | R/W   | R     | R/W     | R/W     | R/W     | R/W     |       |
| 初期値         | 0      | 0      | 0     | 0     | 0       | 0       | 0       | 0       |       |

この状態レジスタは割り込み要求フラグ、状態フラグ、計数器値を含みます。

## ■ ビット7 - USISIF: 開始条件検出割り込み要求フラク (Start Condition Interrupt Flag)

2線動作が選択されるとき、開始条件が検出されると、USISIF7ラケが設定(1)されます。出力禁止動作または3線動作が選択され、(USICS1,0=11且つUSICLK=0)または(USICS1,0=10且つUSICLK=0)の時にUSCKピンのどのエッシ、もがこのフラケを設定(1)します。

ステータスレジスタ(SREG)の全割り込み許可(I)ビットとUSI制御レジスタ(USICR)で開始条件検出許可(USISIE)ビットが設定(1)されている間中にこのフラグが設定(1)されると、割り込みが生成されます。このフラグはUSISIFビットへの論理1書き込みによってのみ解除(0)されます。このビットの解除(0)は2線動作でのSCLの開始条件保持を解除(開放)します。

開始条件検出割り込みは全ての休止形態からプロセッサを起動します。

## ■ ビット6 - USIOIF: 計数器溢れ割り込み要求フラグ (Counter Overflow Interrupt Flag)

このフラグは4ビット計数器が溢れると(換言すると15から0への遷移で)設定(1)されます。SREGの全割り込み許可(I)ビットとUSICRで計数器溢れ割り込み許可(USIOIE)ビットが設定(1)されている間にこのフラグが設定(1)されると、割り込みが生成されます。本フラグはUSIOIF ビットへの論理1書き込みによってのみ解除(0)されます。本ビットの解除(0)は2線動作でのSCLの計数器溢れ保持を解除(開放)します。計数器溢れ割り込みはアイデル休止動作からプロセッサを起動します。

# ■ ビット5 - USIPF: 停止条件検出フラグ(Stop Condition Flag)

2線動作が選択された時に<mark>停止条件</mark>が検出されると、USIPFフラケが設定(1)されます。このフラケはこのビットへの1書き込みによって解除(0)されます。これが割り込み要求フラケでないことに注意してください。この合図は2線バス主装置調停の実装時に有用です。

## ■ ビット4 - USIDC: 出力データ衝突フラグ(Data Output Collision Flag)

移動レジスタのビット7(MSB)が物理ピン値と異なる時にこのビットは論理1です。このフラグは2線動作が使われる時にだけ有効です。この合図は2線バス主装置調停の実装時に有用です。

## ■ ビット3~0 - USICNT3~0: 計数器値 (Counter Value)

これらのビットは現在の4ビット計数器値を反映します。この4ビット計数器値はCPUによって直接的に読み書きできます。

この4ビット計数器は外部クロック端検出器、タイマ/カウンク0溢れ、USICLKまたはUSITCストローブビットを使うソフトウェアのどれかによって生成した各クロックに対して1つ増加します。このクロック元はUSICS1,0ビット設定に依存します。外部クロック動作に対してUSITCストローブビットへの書き込みによって生成されることをクロックに許す、特別な特徴が付加されます。この特徴は外部クロック元(USICS1=1)設定中のUSICLKへの1書き込みによって許可されます。

出力禁止動作(USIWM1,0=00)が選択されている時でも、外部クロック入力(USCK/SCL)が未だ計数器によって使われることに注意してください。





# ■ USI 制御レジスタ (USI Control Register) USICR

| ピット         | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0     | _     |
|-------------|--------|--------|--------|--------|--------|--------|--------|-------|-------|
| \$0D (\$2D) | USISIE | USIOIE | USIWM1 | USIWM0 | USICS1 | USICS0 | USICLK | USITC | USICR |
| Read/Write  | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | W      | W     |       |
| 初期値         | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0     |       |

この制御レジスタは割り込み許可制御、動作種別設定、クロック選択設定、クロック ストローブを含みます。

## ■ ビット7 - USISIE: 開始条件検出割り込み許可 (Start Condition Interrupt Enable)

このビットを1に設定することが開始条件検出割り込みを許可します。ステータス レジスタ(SREG)の全割り込み許可(I)ビットとUSISIEビットが設定(1)される時に保留割り込みなら、これは直ちに実行されます。より多くの詳細については97頁の開始条件検出割り込み要求フラグ(USISIF)記述を参照してください。

#### ■ ビット6 - USIOIE: 計数器溢れ割り込み許可 (Counter Overflow Interrupt Enable)

このビットを1に設定することが計数器溢れ割り込みを許可します。ステータスレジ、スタ(SREG)の全割り込み許可(I)ビットとUSIOIEビットが設定(1)される時に保留割り込みなら、これは直ちに実行されます。より多くの詳細については97頁の計数器溢れ割り込み要求フラケー(USIOIF)記述を参照してください。

## ■ ビット5,4 - USIWM1,0:動作種別選択 (Wire Mode)

これらのビットは使われるべき動作種別(2または3線動作)を設定します。基本的に出力の機能だけがこれらのビットによって影響を及ぼされます。データとクロック入力は選択した動作種別によって影響を及ぼされず、常に同じ機能を持ちます。従って出力が禁止される時でも移動レジスタと計数器は外部的にクロック駆動でき、入力データが採取されます。USI操作とUSIWM1,0間の関連は表59.で要約されます。

# 表59. USI操作とUSIWM1,0の関係

| USIWM1 | USIWM0 | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | 0      | 出力、クロック保持、開始条件検出器は禁止。ポート ピンは標準として動作。                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0      | 1      | 3線動作。DO,DI,USCKピンを使用。 データ出力(DO)ピンはこの動作でPORTレジスタの対応ビットを無視します。けれども対応するDDRビットは未だデータ方向を制御します。ポート ピンが入力として設定(DDxn=0)されると、そのピンのプルアップはPORTビットによって制御されます。 データ入力(DI)と直列クロック(USCK)ピンは標準ポート操作に影響を及ぼしません。主装置として動作する時のクロック パルスはデータ方向が出力に設定されている(DDxn=1)間のPORTレジスタの交互切り替えによってソフトウェアで生成されます。USICRのUSITCビットがこの目的に使えます。                                                                                                                                                                                                           |
| 1      | 0      | 2線動作。SDA(DI)とSCL(USCK)ピンを使用。(注1)<br>直列データ(SDA)と直列クロック(SCL)ピンは双方向でオープントレイン出力駆動を使います。この出力駆動部は<br>DDRレジスタでSDAとSCLに対応するビットの設定(=1)によって許可されます。<br>SDAピンに対して出力駆動部が許可されると、出力駆動部は移動レジスタの出力またはPORTレジスタの対応<br>ピットが0ならばSDA線をLowに強制します。さもなければ、SDA線は駆動されません(換言すると開放されま<br>す)。SCLピン出力駆動部が許可されると、SCL線はPORTレジスタの対応ビットが0なら、または開始条件検出<br>器によってLowを強制されます。さもなければSCL線は駆動されません。<br>SCL線は出力が許可され、開始条件検出器が開始条件を検出すると、Lowに保持されます。開始条件検<br>出フラグ(USISIF)の解除(0)がその線を開放します。SDAとSCLピン入力はこの動作の許可によって影響を及<br>ぼされません。SDAとSCLピンのプルアップは2線動作で禁止されます。 |
| 1      | 1      | 2線動作。SDAとSCLピンを使用。<br>SCL線は計数器溢れが起こる時にもLow〜保持され、計数器溢れフラグ(USIOIF)が解除(0)されるまでLow<br>に保持されることを除いて、上で記述される2線動作と同じ動作です。                                                                                                                                                                                                                                                                                                                                                                                               |

注1: DIとUSCKピンは動作種別間での混乱を避けるため、各々直列データ(SDA)と直列クロック(SCL)に改称されます。

## ■ ビット3.2 - USICS1.0: クロック選択 (Clock Source Select)

これらのビットは移動レジスタと計数器に対するクロック元を設定します。外部クロック元(USCK/SCL)を使う時にデータ出力ラッチはデータ入力 (DI/SDA)の採取の逆端で出力が変更されるのを保証します。タイマ/カウンタ0溢れまたはソフトウェア ストローブが選択されると、出力ラッチは透過で、従って出力は直ちに変更されます。USICS1,0ビットの解除(=00)がソフトウェア ストローブ選択を許可します。この選択を使う時の USICLKビットへの1書き込みは移動レジスタと計数器の両方をクロック駆動します。外部クロック元(USICS1=1)に対してUSICLKビットはもはや ストローブとして使われませんが、外部クロックとUSITCストロープビットによるソフトウェア クロック間を選択します。

表60.は移動レジスタと4ビット計数器に対して使われるクロック元とUSICS1,0、USICLK設定間の関連を示します。

| 表60    | LISTOS1 | <b>OFFICION</b> | K設定との             | り関係    |
|--------|---------|-----------------|-------------------|--------|
| イソ ひひ. | USIUST  | .บะ บอเบเ       | - 17 44 4 14 6 17 | ノルモルポー |

| USICS1 | USICS0 | USICLK | 移動レジスタ クロック元               | 4ビット計数器クロック元                 |
|--------|--------|--------|----------------------------|------------------------------|
|        | 0      | 0      | クロックなし                     | クロックなし                       |
| 0      | U      | 1      | ソフトウェア クロック ストローフ゛(USICLK) | ソフトウェア クロック ストローフ゛(USICLK)   |
|        | 1      | X      | タイマ/カウンタ0溢れ                | タイマ/カウンタ0溢れ                  |
|        | 0      | 0      | 外部クロック上昇端                  | 外部クロック両端                     |
| 1      | 1      | 0      | 外部クロック下降端                  | クト音Dクロツク 町 4幅<br>            |
| 1      | 0      | 1      | 外部クロック上昇端                  | ソフトウェア クロック ストローフ゛(USITC)    |
|        | 1      | 1      | 外部クロック下降端                  | // //±// // // // // (USIIC) |

## **■ ビット1 - USICLK**: クロック ストローフ (Clock Strobe)

ソフトウェア ストローフ、選択が選ばれるように行うことによってUSICS1,0ビットがゼロ(=00)に設定されるなら、このビット位置への1書き込みは移動レジスタを1段移動して計数器を1つ増加します。このクロック ストローブが実行される時、直ちに、換言すると同じ命令周期内で出力が替わります。移動レジスタ内に移動した値は直前の命令周期で採取されます。このビットは0として読まれます。

外部クロック元が選択される(USICS1=1)と、USICLK機能はクロックストローブからクロック選択レシ、スタに変更されます。この場合のUSICLKビットの設定(=1)は4ビット計数器に対するクロック元としてのUSITCストローブを選びます(表60.参照)。

## ■ ビット0 - USITC: クロック値切り替え (Toggle Clock Port Pin)

このビット位置に1を書くことはUSCK/SCL値を0から1、または1から0のどちらかへ切り替えます。この切り替えはデータ方向レジスタでの設定と無関係ですが、PORT値がピンで見られるべきなら、DDB7が出力として設定(=1)されなければなりません。この特徴は主装置を実現する時の容易なクロック生成を許します。このビットは0として読まれます。

外部クロック元が選択され(USICS1=1)、USICLKビットが1に設定されると、USITCストローブビットへの書き込みは直接的に4ビット計数器をク ロック駆動します。これは主装置として動作する時に転送が行われる時の早い検出を許します。





# アナログ比較器

アナログ比較器は非反転入力AINOピンと反転入力AIN1ピンの入力値を比較します。非反転AIN0ピンの電圧が反転AIN1ピンの電圧よりも高い時にACSRのアナログ比較器出力(ACO) ピットが設定(1)されます。この比較器出力はタイマ/カウンタ1の捕獲機能を起動するように設定できます。加えて、この比較器はアナログ比較器専用の、独立した割り込みを起動できます。使用者は比較器出力の上昇端、下降端、またはその両方での割り込み起動を選べます。この比較器とその周辺論理回路の構成図は図66.で示されます。

#### 図66. アナログ比較器部構成図 内部 VCC 基準電圧 **ACIE** Q **ACBG ←** ACD アナログ AIN0 比較器 割り込み 割り込み 選択 AIN: ► ACI ACIS1 ACIS0 ACIC → タイマ/カウンタ1 捕獲起動 ACO 選択へ

注: アナログ 比較器のピン配置については2頁の「ピン配置」と36頁の表 26.を参照してください。

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

| ピット         | 7   | 6    | 5   | 4   | 3    | 2    | 1     | 0     |      |
|-------------|-----|------|-----|-----|------|------|-------|-------|------|
| \$08 (\$28) | 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)されると、AIN0がアナログ比較器の非反転入力に印加されます。内部基準電圧がアナログ比較器入力として使われる時に電圧の安定に一定時間を必要とします。安定(待機を)しない場合、最初は不正値を与えるかもしれません。25頁の「内部基準電圧」をご覧ください。

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

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

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

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

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

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

# ■ ビット2 - ACIC: アナログ比較器捕獲起動許可 (Analog Comparator Input Capture Enable)

論理1を書かれると、このビットはアナログ比較器によって起動されるタイマ/カウンタ1の捕獲機能を許可します。この場合、比較器出力は比較器にタイマ/カウンタ1捕獲割り込みの雑音消去機能とエッジ選択機能を利用させる捕獲入力前置論理回路へ直接的に接続されます。 論理0を書かれると、アナログ比較器と捕獲機能間の接続は存在しません。比較器がタイマ/カウンタ1捕獲割り込みを起動するには、タイマ/カウンタ割り込み許可レジスタ(TIMSK)の捕獲割り込み許可(ICIE1)ビットが設定(1)されなければなりません。

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

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

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

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

# ■ デッタル入力禁止レシ、スタ (Digital Input Disable Register) **DIDR**

| ピット         | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0     |      |
|-------------|---|---|---|---|---|---|-------|-------|------|
| \$01 (\$21) | - | - | - | - | - | - | AIN1D | AIN0D | DIDR |
| Read/Write  | R | R | R | R | R | R | R/W   | R/W   |      |
| 初期値         | 0 | 0 | 0 | 0 | 0 | 0 | 0     | 0     |      |

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

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





# テブバック WIRE 内蔵デブック システム

# 特徴

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

## 概要

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

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

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

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

デバッグWIREが使われるシステムの設計時、正しい動作のために次の注意点が厳守されなければなりません。



- ・dW/(RESET)線のプルアップ抵抗は $10k\Omega$ よりも大きくなければなりません。とは言え、プルアップ抵抗は任意選択です。
- ・RESETピンのVCCへの直接的な接続では動作しません。
- ・RESETピンに挿入したコンデンサはデバッグWIRE使用時、切断されなければなりません。
- ・全ての外部リセット元は切断されなければなりません。

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

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

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

## デバッグWIREの制限

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

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

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

## デバッグWIREに関連するI/Oメモリ内のレジスタ

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

## ■ デバック WIRE データレシ スタ (debugWIRE Data Register) DWDR



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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

へージ書き込みを行うにはZポインタにアトレスを設定してSPMCSRに'00000101'を書き、SPMCSR書き込み後4クロック周期内にSPM命令を実行してください。R1とR0のデータは無視されます。ヘージ アトレスは(Zポインタの)PCPAGEに書かれなければなりません。この操作の間中、Zポインタの他のビットは0を書かれなければなりません。

・ページ書き込み中、CPUは停止されます。

## 自己プログラミング中のフラッシュメモリのアドレス指定

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 |

フラッシュ メモリがペーシ で構成されるため(107頁の表68.参照)、プログラム カウンタ(アト・レス ポインタ)は2つの違う領域を持つように取り扱われます。1つの領域は下位側ビットから成り、ペーシ・内の語(ワート・)をアト・レス指定し、一方上位側ビットはそのペーシ・をアト・レス指定します。これは次頁の図68.で示されます。ペーシ・消去とペーシ・書き込み操作が個別にアト・レス指定されることに注意してください。従ってソフトウェアがペーシ・消去とペーシ・書き込み操作の両方で同じペーシ・をアト・レス指定することが最も重要です。

LPM命令はアドレスを格納するのにZポインタを使います。この命令はフラッシュメモリのバイト単位をアドレス指定するので、Zポインタの最下位ビット(Z0)も使われます。







# ■ SPM命令制御/状態レジスタ (Store Program Memory Control and Status Register) SPMCSR

このレシ、スタはプログラムメモリ操作を制御するために必要とする制御ビットを含みます。

| \$37 (\$57)    |      |      |       |       |           |        |
|----------------|------|------|-------|-------|-----------|--------|
| 231 (251)      | CTPB | RFLB | PGWRT | PGERS | SELFPRGEN | SPMCSR |
| Read/Write R R | R/W  | R/W  | R/W   | R/W   | R/W       |        |
| 初期値 0 0 0      | 0    | 0    | 0     | 0     | 0         |        |

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

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

■ ビット4 - CTPB: ペ-ジ一時緩衝部消去 (Clear Temporary Page Buffer)

へージー時緩衝部を満たしている間にCTPBビットが1を書かれると、ヘージー時緩衝部は消去され、データが失われます。

## ■ ビット3 - RFLB: ヒューズ/施錠ビット読み込み (Read Fuse and Lock Bits)

SPMCSRでRFLBとSELFPRGENが設定(1)された後の3クロック周期内のLPM命令は(ZポインタのZ0によって)ヒュース、ビットまたは施錠ビットのどちらかを転送先レジスタに読みます。詳細については105頁の「ソフトウェアからのヒュース、ビットと施錠ビットの読み出し」をご覧ください。

# ■ ビット2 - PGWRT : ページ書き込み (Page Write)

このビットがSELFPRGENと同時に1を書かれると、次の4クロック周期内のSPM命令は一時緩衝部に格納したデータでページ書き込みを実行します。ページアドレスはZポインタの上位部から取得されます。R1とR0のデータは無視されます。PGWRTビットはページ書き込みの完了で、または4クロック周期内にSPM命令が実行されない場合、自動的に解除(0)されます。ペーシ´全体の書き込み動作中、CPUは停止されます。

#### ■ ビット1 - PGERS: ページ消去 (Page Erase)

このビットがSELFPRGENと同時に1を書かれると、次の4クロック周期内のSPM命令はページ消去を実行します。ページアドレスはZポインタの上位部から取得されます。R1とR0のデータは無視されます。PGERSビットはページ消去の完了で、または4クロック周期内にSPM命令が実行されない場合、自動的に解除(0)されます。ページ全体の消去中、CPUは停止されます。

# ■ ビット0 - SELFPRGEN: 自己プログラミング許可 (Self Programming Enable)

このビットは次の4クロック周期間SPM命令を許可します。このビットがCTPB,RFLB,PGWRT,PGERSのどれかと共に1を書かれると、続くSPM命令は特別な意味を持ちます(上の記述をご覧ください)。SELFPRGENだけが書かれると、続くSPM命令はZポインタでアドレス指定したページ一時緩衝部へR1:R0の値を格納します。Zレジスタの最下位ビットは無視されます。SELFPRGENビットはSPM命令の完了で、または4クロック周期内にSPM命令が実行されないと自動的に解除(0)されます。ページ消去とページ書き込み中、SELFPRGENピットはその動作が完了されるまで1に留まります。

下位5ビットに10001,01001,00101,00011,00001以外のどんな組み合わせを書いても無効です。

(<mark>訳注</mark>) ビット0の名称SELFPRGENはヒューズ ビットに同一名が存在します。状況によっては不都合かもしれません。従ってソフトウェアに於ける本ビットの参照は、他の多くのAVRと同様にSPMENの使用が推奨されます。AVR Studioでのデバイス定義インクルード ファイルでは既に本ビットに対してシンボルSPMENが定義されており、SELFPRGENはヒューズ ビット定義になっています。

## SPM命令での書き込み時のEEPROM書き込みによる妨害

EEPROM書き込み動作がフラッシュ メモリへの全ソフトウェア プログラミングを妨げることに注意してください。ソフトウェアからのヒューズと施錠ビット読み出しもEEPROM書き込み動作中、妨げられます。使用者はEEPROM制御レジスタ(EECR)のEEPROMプログラム許可(EEPE)ビットを検査し、SPM命令制御/状態レジスタ(SPMCSR)へ書く前に、このビットが解除(0)されているのを確認することが推奨されます。

#### ソフトウェアからのヒュース゛ビットと施錠ビットの読み出し

ソフトウェアからヒューズと施錠ビットの両方を読むことが可能です。施錠ビットを読むにはZポインタに \$0001を設定し、SPMCSRのSELFPRGEN とフラッシュ/施錠ビット読み込み(RFLB)ビットを設定(1)してください。SELFPRGENとRFLBビットがSPMCSRに設定された後3 CPU周期内にLPM命令が実行されると、施錠ビットの値が転送先レジスタに格納されます。SELFPRGENとRFLBビットは施錠ビット読み出しの完了で、または3 CPU周期内にLPM命令が実行されないか、または4 CPU周期内にSPM命令が実行されない場合、自動的に解除(0)されます。SELFPRGENとRFLBビットが解除(0)されると、LPMは命令一式手引書で記述されるように動作します。

| ピット | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0   |
|-----|---|---|---|---|---|---|-----|-----|
| Rd  | - | - | - | - | _ | _ | LB2 | LB1 |

ヒュース、下位ビットを読む手順は上記の施錠ビット読み出しと同様です。ヒュース、下位ビットを読み出すにはZポーインタに \$0000を設定して SPMCSRのSELFPRGENとRFLBビットを設定(1)してください。SELFPRGENとRFLBビットがSPMCSRに設定された後3 CPU周期内にLP M命令が実行されると、以下で示されるようにヒュース、下位ビット(FLB)の値が転送先レジスタに格納されます。ヒュース、下位ビットの配置と詳細な記述については107頁の表67.を参照してください。

| ピット | 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)の値が転送先レジスタに格納されます。 ヒュース、上位ビットの配置と詳細な記述については106頁の表66.を参照してください。

| ピット | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|------|------|------|------|------|------|------|------|
| Rd  | FHB7 | FHB6 | FHB5 | FHB4 | FHB3 | FHB2 | FHB1 | FHB0 |

プログラム(0)されたヒュース、と施錠ビットは0として読めます。非プログラム(1)にされたヒュース、と施錠ビットは1として読めます。

## フラッシュ メモリ データ化けの防止

低VCCの期間中、CPUとフラッシュメモリの正しい動作に対して供給電圧が低すぎるためにフラッシュメモリのプログラムが不正にされ得ます。 これらの問題はフラッシュメモリを使う基板段階の装置と同じで、同じ設計上の解決策が適用されるべきです。

フラッシュ メモリのプログラム化けは電圧が低すぎる時の2つの状態によって起こされます。1つ目としてフラッシュ メモリへの通常の書き込み手順は正しく動作するための最低電圧が必要です。2つ目として供給電圧が低すぎると、CPU自身が命令を間違って実行し得ます。フラッシュ メモリ化けは次の推奨設計によって容易に避けられます(1つは必須)。

- / クツシュ クモリイヒリィは外の推奨設計にようて谷勿に延りりイレまタ(1゚フ/は必須)。
- ・不十分な供給電源電圧の期間中、AVR RESETを活性(Low)に保ってください。これは動作電圧が検出電圧と一致するなら、内部 低電圧検出器(BOD)を許可することによって行えます。そうでなければ外部低VCCリセット保護回路が使えます。書き込み操作進 行中にリセットが起こると、その書き込み動作は供給電源電圧が充分であれば完了されます。
- ・低VCCの期間中、AVRコアをパワーダウン休止動作に保ってください。これはCPUが命令の復号と実行を試みることを防ぎ、SPMCSR 従ってフラッシュ メモリを予期せぬ書き込みから効果的に保護します。

# SPM命令使用時のフラッシュ メモリ用プログラミング(書き込み)時間

校正された内蔵RC発振器がフラッシュメモリアクセス時間に使われます。表62.はCPUからのフラッシュメモリアクセスに対する代表的なプログラミング時間を示します。

| 表62    | SPM命令によるフラッシュ     | メモリのプログラミング時間         |
|--------|-------------------|-----------------------|
| 1X UZ. | 3F M m コ にあるノ バノエ | プレフリンプ ロフ フミンフ 11寸1日1 |

| <b>K02. Of Mith [1] Cの の / / / / エア に / 00 / ドリ 川</b> |       |       |  |  |  |  |
|-------------------------------------------------------|-------|-------|--|--|--|--|
| 項目                                                    | 最小    | 最大    |  |  |  |  |
| SPM命令によるフラッシュ書き込み(ヘーシ'消去、ヘーシ'書き込み)                    | 3.7ms | 4.5ms |  |  |  |  |





# メモリ プロク゛ラミンク゛

本章はATtiny2313のメモリプログラミングについての各種方法を記述します。

# プログラム メモリとデータ メモリ用施錠ビット

ATtiny2313は非プログラム(1)のままか、表64.で一覧される付加機能を得るためにプログラム(0)できる2つの施錠ビットを提供します。この施錠ビットはチップ消去指令でのみ1に消去できます。

SELFPRGENヒュースがプログラム(0)されると、SPM命令はフラッシュ メモリ全体に対して許可され、さもなくば禁止されます(訳注:追加)。

## 表63. 施錠ビット バイの内容

| 名称  | ピット番号        | 意味                                             | 既定值 ( <mark>注</mark> ) |
|-----|--------------|------------------------------------------------|------------------------|
| _   | 7 <b>~</b> 2 |                                                | 1 (非プログラム)             |
| LB2 | 1            | フラッシュとEEPROMメモリに対する一般保護用施錠ビット                  | 1 (非プログラム)             |
| LB1 | 0            | フラッシュ CEEPROMP モゾ(これ) 9 (3) 一 放 休 護 用 旭 爽 に ッド | 1 (非プログラム)             |

注: 0はプログラム、1は非プログラムを意味します。

## 表64. 施錠ビットの保護種別

|               | メモリ施錠ビット 保護種別 |     |                                                                                      |
|---------------|---------------|-----|--------------------------------------------------------------------------------------|
| LB 種別 LB2 LB1 |               | LB1 | 直列、並列、またはデバッグWIRE経由プログラミングに対する保護                                                     |
| 1             | 1             | 1   | メモリ施錠機能は機能しません。                                                                      |
| 2             | 1             |     | フラッシュ、EEPROMの更なるプログラミング(書き込み)が禁止されます。 ヒュース゛ビットが固定されます。 ( <mark>注1</mark> )           |
| 3             | 0             |     | フラッシュ、EEPROMの更なるプログラミング(書き込み)と照合(読み出し)が禁止されます。ヒュース<br>ヒットが固定されます。( <mark>注1</mark> ) |

注: 0はプログラム、1は非プログラムを意味します。

注1: 施錠ビットを書く前にヒューズビットを書いてください。 デバッグWIREは全面的に禁止されます。

# ヒュース゛ヒ゛ット

ATtiny2313には3つのヒュース、ハ・イトがあります。**表65**.~**67**.は全てのヒュース、の概略機能とヒュース、ハ・イト内でどのように配置されるかを示します。ヒュース、はプログラムされると、論理0として読まれることに注意してください。

## 表65. 拡張ヒュース・バイト一覧

| 名称        | ピット          | 意味             | 既定値                     |
|-----------|--------------|----------------|-------------------------|
| _         | 7 <b>~</b> 1 |                | 1 (非プログラム)              |
| SELFPRGEN | 0            | 自己プログラミング機能許可。 | 1 (非プログラム) 自己プログラミング不許可 |

注1: SPM命令を許可します。103頁の「フラッシュ メモリの自己プログラミング」をご覧ください。

# 表66. ヒュース・上位バイー覧

| 名称                  | ピット | 意味                             | 既定値                      |
|---------------------|-----|--------------------------------|--------------------------|
| DWEN ( <b>注3</b> )  | 7   | デバッグWIRE機能許可。                  | 1 (非プログラム) テブバックWIRE不許可  |
| EESAVE              | 6   | チップ消去からEEPROM内容を保護。            | 1 (非プログラム) EEPROMは未保護    |
| SPIEN (注1)          | 5   | 直列プログラミング許可。                   | 0 (プログラム) 直列プログラミング許可    |
| WDTON ( <b>注2</b> ) | 4   | ウォッチドッグタイマ常時有効。                | 1 (非プログラム) WDTはWDTCSRで許可 |
| BODLEVEL2           | 3   |                                | 1 (非プログラム)               |
| BODLEVEL1           | 2   | 低電圧検出(BOD)リセットの制御と検出電圧選択。 (注4) | 1 (非プログラム)               |
| BODLEVEL0           | 1   |                                | 1 (非プログラム)               |
| RSTDISBL (注5)       | 0   | PA2がI/OピンかまたはRESETピンかを選択します。   | 1 (非プログラム) PA2はRESETtプン  |

注1: SPIENヒュース は直列プログラミングでアクセスできません。

注2: 詳細については28頁の「ウォッチト、ック、タイマ制御/状態レジスタ - WDTCSR」をご覧ください。

注3: 施錠ビットの設定に拘らず、DWENヒューズがプログラム(0)された製品の出荷は決してありません。プログラム(0)されたDWENヒューズは全休止形態でクロック系の一部を許可します。これは消費電力の増加になってしまいます。

注4: BODLEVELヒューズの符号化については24頁の表15.をご覧ください。

注5: RSTDISBLヒューズの記述については34頁の「ポートAの交換機能」をご覧ください。

| + ^ - | 1 *-  | T /                       | . * / | 臣 一 |
|-------|-------|---------------------------|-------|-----|
| 表6/.  | ヒュース゛ | $\Gamma 1 \overline{U} I$ | ۱۱ ۱  | 一員  |

| 名称     | ピット | 意味                    | 既定值                                                |
|--------|-----|-----------------------|----------------------------------------------------|
| CKDIV8 | 7   | システム クロック 8分周選択。      | 0 (プログラム) 8分周                                      |
| CKOUT  | 6   | システム クロック出力許可。        | 1 (非プログラム) 不許可                                     |
| SUT1   | 5   | 起動時間選択。 (注1)          | 1 (非プログラム)                                         |
| SUT0   | 4   | 性期時间进入。               | <mark>0</mark> (プ <sup>°</sup> ログ <sup>*</sup> ラム) |
| CKSEL3 | 3   |                       | <mark>0</mark> (プ <sup>°</sup> ログ <sup>*</sup> ラム) |
| CKSEL2 | 2   | <br>  クロック種別選択。       | 1 (非プログラム)                                         |
| CKSEL1 | 1   | プロツング里が以送が、<br>  (注2) | <mark>0</mark> (プ <sup>°</sup> ロク <sup>*</sup> ラム) |
| CKSEL0 | 0   |                       | <mark>0</mark> (プ <sup>°</sup> ロク <sup>*</sup> ラム) |

注1: SUT1,0の既定値は既定クロック元に対して最大起動時間になります。詳細については18頁の表7.をご覧ください。

注2: 既定のCKSEL3~0設定は8MHz校正付き内蔵RC発振器になります。詳細については18頁の表6.をご覧ください。

ヒュース、ヒ、ットの状態はチップ。消去によって影響されません。施錠ビット1(LB1)がプログラム(0)されると、ヒュース、ヒ、ットが固定されることに注意してください。施錠ビ、ットをプログラム(0)する前にヒュース、ビットをプログラミング(書き込み)してください。

# ヒュース゛のラッチ

ヒュース<sup>\*</sup>値はデバイスがプログラミング動作へ移行する時にラッチされ、ヒュース<sup>\*</sup>値の変更はデバイスがプログラミング動作を去るまで無効です。これは一旦プログラム(0)されると直ぐに効果があるEESAVEヒュース<sup>\*</sup>には適用されません。ヒュース<sup>\*</sup>は通常動作での電源投入でもラッチされます。

## 識票バイ

全てのAtmelマイクロコントローラはデバイスを識別する3バイトの識票符号を持ちます。この符号は直列と並列の両プログラミング動作で、またデバイスが施錠されていても読めます。この3バイトは分離された空間に存在します。ATtiny2313の識票バイトを右に示します。

① \$000: \$1E 製造業者Atmelを示します。

② \$001:\$91 フラッシュ メモリ容量2Kバイトを示します。

③ \$002: \$0A ②値\$91と合せ、ATtiny2313を示します。

## 校正バイ

ATtiny2313の識票領域は内蔵RC発振器用に1バイトの校正データを持ちます。このバイトはアドレス\$0000の上位バイトに存在します。校正付き内蔵RC発振器の正しい周波数を保証するため、リセット中にこのバイトが18頁の「発振校正レジスタ - OSCCAL」へ自動的に書かれ(設定され)ます。

# ページ容量

# 表68. フラッシュ メモリのヘ°ージ数とヘ°ージの語数全容量ヘ°ーン。容量PCWORDヘ°ーン。数PCPAGEPCMSB1Kワート (2Kハベト)16ワート PC3~064PC9~49

| 表69. EEPROMメモリのページ数とページの語数 |       |        |      |        |        |
|----------------------------|-------|--------|------|--------|--------|
| 全容量                        | ページ容量 | PCWORD | ページ数 | PCPAGE | EEAMSB |
| 128バイト                     | 4バイト  | EEA1,0 | 32   | EEA6~2 | 6      |





# 並列プログラミング

この項はATtiny2313のプログラム用フラッシュメモリ、データ用EEPROM、メモリの施錠ビット、ヒュース・ビットの並列プログラミングと照合の方法を記述します。特記事項を除いて、ハプルス幅は最低250nsと仮定されます。

## 信号名

本項でATtiny2313のいくつかのピンは並列プログラミング中の機能を表す信号名で参照されます。図69.と表70.をご覧ください。後続の表で記載されないピンはピン名によって参照されます。

XA0とXA1ピンはXTAL1ピンが正パルスを与えられる時に実行される動作を決めます。このビット符号化は表72.で示されます。

WRまたはOEパルス送出時、設定された指令が実行される動作を決めます。各種指令は表73.で示されます。



#### 表70. 信号名とピン名の関係

| 信号名           | ピン名   | 入出力 | 機能                                                |
|---------------|-------|-----|---------------------------------------------------|
| RDY/BSY       | PD1   | 出力  | 0(Low): 多忙(プログラミング中) 1(High): 準備可(指令受付可)          |
| ŌĒ            | PD2   | 入力  | 出力許可(負論理)                                         |
| WR            | PD3   | 入力  | 書き込みパルス(負論理)                                      |
| PAGEL/BS1 (注) | PD4   | 入力  | ページー時緩衝部に設定 / 上位/下位バイ選択1 (0:下位, 1:上位) (一般用)       |
| XA0           | PD5   | 入力  | XTAL動作ビット0                                        |
| XA1/BS2(注)    | PD6   | 入力  | XTAL動作ビット1 / 上位/下位バイト選択2 (0:下位, 1:上位) (ヒューズ ビット用) |
| DATA          | PB7∼0 | 入出力 | 双方向データ バス (OE=Low時出力)                             |

注: このピンは2つの異なる制御信号に対して使われます。以降の記述で、通常1つの信号(名)だけが参照されます。例えば、「BS1に正パルスを与える」は「PAGEL/BS1に正パルスを与える」と同等です。

## 表71. プログラミング動作移行用のピン値

| ピン名       | シンホ゛ル          | 値 |
|-----------|----------------|---|
| XA1/BS2   | Prog_enable[3] | 0 |
| XA0       | Prog_enable[2] | 0 |
| PAGEL/BS1 | Prog_enable[1] | 0 |
| WR        | Prog_enable[0] | 0 |

#### 表72. XA0とXA1の符号化(機能)

| XA1 | XA0 | XTAL1パルス時の動作                        |
|-----|-----|-------------------------------------|
| 0   | 0   | フラッシュまたはEEPROMのアトレス取得(上位/下位はBS1で指定) |
| 0   | 1   | データ取得 (フラッシュ時の上位/下位はBS1で指定)         |
| 1   | 0   | 指令取得                                |
| 1   | 1   | アイドル(動作なし)                          |

注: XA1=1,XA0=1は非動作(アイ・ル)です。XTAL1がパルス駆動されない限り、指令、アトレス、データのレジスタは無変化に留まります。従ってBS2がXA1と多重されても、以降で記述されるようなBS2使用は問題ありません。BS2はヒュース・読み出し(OE=Low)の時だけ利用(1)され、(このとき)XTAL1はパルス駆動されません。

## 表73. 指令バイのビット符号化

| 指令バイト            | 指令の機能             |
|------------------|-------------------|
| \$80 (1000 0000) | チップ消去             |
| \$40 (0100 0000) | ヒューズビット書き込み       |
| \$20 (0010 0000) | 施錠ビット書き込み         |
| \$10 (0001 0000) | フラッシュ メモリ書き込み     |
| \$11 (0001 0001) | EEPROM書き込み        |
| \$08 (0000 1000) | 識票バイト、校正バイト読み出し   |
| \$04 (0000 0100) | ヒューズビット、施錠ビット読み出し |
| \$02 (0000 0010) | フラッシュ メモリ読み出し     |
| \$03 (0000 0011) | EEPROM読み出し        |

(訳注) 原書本位置の表74.は共通性のため「直列プログラミング」項へ移動しました。

### 並列プログラミング手順

### 並列プログラミング動作への移行

次に示す方法がデバイスを(高電圧)並列プログラミング動作にします。

- ① VCCを0V、RESETt°ンを0V、108頁の表71.で一覧されるProg\_enablet°ンを全てLow(0)に設定します。
- ② VCCとGND間に4.5~5.5Vを印加します。
- ③ 20µs以内にVCCが最低1.8Vに達することを保証してください。
- **4** 20~60µs待ち、RESETに11.5~12.5Vを印加します。
- ⑤ Prog\_enable識別がラッチされてしまうのを確実にするため、高電圧が印加されてしまった後、最低10μs、Prog\_enable ピンを無変化に 保ちます。
- ⑥ 如何なる並列プログラミング指令を与えるのにも先立って少なくとも300µs間待ちます。
- ⑦ デバイスの電源を落とすか、RESETピンを0Vに持ってくることによってプログラミング動作を抜けます。

VCCの上昇時間が上で示した必要条件を完全に満たせない場合、次の代替手順が使えます。

- ① VCCを0V、RESETt°ンを0V、108頁の表71.で一覧されるProg\_enablet°ンを全てLow(0)に設定します。
- ② VCCとGND間に4.5~5.5Vを印加します。
- ③ VCCを監視し、0.9~1.1Vに達したら直ぐ、REESTに11.5~12.5Vを印加します。
- ④ Prog\_enable識別がラッチされてしまうのを確実にするため、高電圧が印加されてしまった後、最低10μs、Prog\_enable ピンを無変化に保ちます。
- ⑤ 如何なる並列プログラミング指令を与えるのにも先立ってVCCが実際に4.5~5.5Vに達するまで待ちます。
- ⑥ デバイスの電源を落とすか、RESETピンを0Vに持ってくることによってプログラミング動作を抜けます。

#### 効率的なプログラミングへの考慮

設定した指令とアドレスはプログラミング中、維持されます。効率的なプログラミングを行うために次を考慮すべきです。

- ・複数のメモリ領域を読み書きする時に指令設定は一度だけ必要です。
- ・チップ消去後のフラッシュ メモリと(EESAVEヒューズがプログラム(0)されている場合を除き)EEPROM全体の内容は\$FFなので、値が\$FFの データ書き込みを飛ばします。
- ・アトンス上位バイトはフラッシュ メモリで新規256語(ワード)枠、EEPROMで新規256バイト枠の読み書き前に一度だけ必要です。この考慮は識票バイト読み出しにも適用されます。

#### チップ消去

チップ消去はフラッシュ メモリ、EEPROM(<mark>注1</mark>)、施錠ビットを消去します。施錠ビットはプログラム メモリが完全に消去されてしまうまでリセット(消去)されません。ヒューズ ビットは変更されません。チップ消去はフラッシュ メモリやEEPROMが再書き込みされる前に実行されなければなりません。

注1: EESAVEヒューズがプログラム(0)されていると、EEPROMはチップ消去中、保護されます。

「チップ消去」指令設定

- ① XA1をHigh(1)、XA0をLow(0)に設定します。これは指令設定を許可します。
- ② BS1をLow(0)に設定します。
- ③ DATAを\$80(1000 0000)に設定します。これはチップ消去指令です。
- ④ XTAL1に正パルスを与えます。これはチップ消去指令を設定します。
- ⑤ WRに負パルスを与えます。これはチップ消去を開始します。RDY/BSYがLow(0)になります。
- ⑥ 次の指令を設定する前にRDY/BSYがHigh(1)になるまで待ちます。





### フラッシュ メモリ書き込み (図71.タイミングを参照)

フラッシュ メモリはヘーシ で構成されます(107頁の表68.参照)。フラッシュ メモリを書く時にプログラム データはヘージ 緩衝部にラッチされます。これは同時に書かれることをプログラム データの1ヘージ に許します。 次の手順は完全なフラッシュ メモリの書き込み方法を記述します。

#### A. 「フラッシュ メモリ書き込み | 指令設定

- ① XA1をHigh(1)、XA0をLow(0)に設定します。これは指令設定を許可します。
- **②** BS1をLow(0)に設定します。
- ③ DATAを\$10(0001 0000)に設定します。これはフラッシュ メモリ書き込み指令です。
- ④ XTAL1に正パルスを与えます。これはフラッシュ メモリ書き込み指令を設定します。

#### B. アドレス下位バイト設定

- ① XA1をLow(0)、XA0をLow(0)に設定します。これはアドレス設定を許可します。
- ② BS1をLow(0)に設定します。これは下位アドレス(バイト)を選択します。
- ③ DATAにアドレス下位バイ(\$00~\$FF)を設定します。
- ④ XTAL1に正パルスを与えます。これはアドレス下位バイを設定します。

#### C. データ下位バイト設定

- ① XA1をLow(0)、XA0をHigh(1)に設定します。これはデータ設定を許可します。
- ② DATAにデータ下位ハイト(\$00~\$FF)を設定します。
- ③ XTAL1に正パルスを与えます。これはデータ下位バイトを設定します。

#### D. データ上位バイト設定

- ① BS1をHigh(1)に設定します。これは上位バイを選択します。
- ② XA1をLow(0)、XA0をHigh(1)に設定します。これはデータ設定を許可します。
- ③ DATAにデータ上位ハイト(\$00~\$FF)を設定します。
- ④ XTAL1に正パルスを与えます。これはデータ上位バイを設定します。

#### E. 緩衝部全体が満たされるか、または(必要な)全てのデータが緩衝部内に設定されるまで、B~Dを繰り返し

アト・レス内の下位ビットがページ内の語(ワード)位置を指示する一方、上位ビットがフラッシュ メモリ内のページをアドレス指定します。これは**図70**. で図示されます。 ページ内の語アドレスに8ビット未満が必要とされる場合(ページ容量<256)、アドレス下位バイトの最上位(側)ビットがページ書き込み実行時のページ アドレスに使われることに注意してください。

### F. アドレス上位バイト設定

- ① XA1をLow(0)、XA0をLow(0)に設定します。これはアドレス設定を許可します。
- ② BS1をHigh(1)に設定します。これは上位アドレス(バイト)を選択します。
- ③ DATAにアドレス上位ハイト(\$00~\$03)を設定します。
- ④ XTAL1に正パルスを与えます。これはアドレス上位バイを設定します。

### G. ページ 書き込み

- ① BS1をLow(0)に設定します。
- ② WRに負パルスを与えます。これはデータのページ全体の書き込みを開始します。RDY/BSYがLow(0)になります。
- ③ RDY/BSYがHigh(1)になるまで待ちます。
- H. フラッシュ メモリ全部が書かれるか、または(必要な)全データが書かれてしまうまで、B~Gを繰り返し

### I. ページ書き込み終了

- ① XA1をHigh(1)、XA0をLow(0)に設定します。これは指令設定を許可します。
- ② DATAを\$00(0000 0000)にします。これは無操作指令です。
- ③ XTAL1に正パパスを与えます。これは無操作指令を設定し、内部書き込み信号がリセットされます。





### EEPROM書き込み

EEPROMはヘーンで構成されます(107頁の表69.参照)。EEPROMを書く時にデータはヘーン、緩衝部にラッチされます。これは同時に書かれることをデータの1ヘーンに許します。EEPROMデータメモリの書き込み方法は次のとおりです。(指令、アトレス、データ設定の詳細については110頁の「フラッシュメモリの書き込み」を参照。図72.タイミング参照。)

- 1. EEPROM書き込み指令\$11(0001 0001)を設定します。(「フラッシュ メモリ書き込み」のAを参照)
- 2. アドレス下位ハイト(\$00~\$7F)を設定します。(「フラッシュ メモリ書き込み」のBを参照)
- 3. データ バイト(\$00~\$FF)を設定します。(「フラッシュ メモリ書き込み」のCを参照)
- J. 緩衝部全体が満たされるまで2~3を繰り返します。
- K. EEPROMページ書き込み
  - ① BS1をLow(0)に設定します。
  - ② WRに負^パスを与えます。これはEEPROMへージ書き込みを開始します。RDY/BSYがLow(0)になります。
  - ③ 次のページを書く前に、RDY/BSYがHigh(1)になるまで待ちます。







### フラッシュ メモリ読み出し

フラッシュ メモリの読み出し方法は次のとおりです。(指令とアドレス設定の詳細については110頁の「**フラッシュ メモリの書き込み**」を参照)

- 1. フラッシュ メモリ読み出し指令\$02(0000 0010)を設定します。(「フラッシュ メモリ書き込み」のAを参照)
- 2. アドレス上位 バイト(\$00~\$03)を設定します。(「フラッシュ メモリ書き込み」のFを参照)
- 3. アト・レス下位ハーイト(\$00~\$FF)を設定します。(「フラッシュ メモリ書き込み」のBを参照)
- 4. BS1をLow(0)、OEをLow(0)に設定します。フラッシュ メモリ語(ワート)の下位バイが直ぐにDATAで読めます。
- 5. BS1をHigh(1)に設定します。フラッシュ メモリ語(ワート)の上位バイトが直ぐにDATAで読めます。
- 6. OEをHigh(1)に設定します。DATAはHi-Zになります。

### EEPROM読み出し

データ用EEPROMの読み出し方法は次のとおりです。(指令とアドレス設定の詳細については110頁の「フラッシュメモリの書き込み」を参照)

- 1. EEPROM読み出し指令\$03(0000 0011)を設定します。(「フラッシュ メモリ書き込み」のAを参照)
- 2. アドレス下位バイト(\$00~\$7F)を設定します。(「**フラッシュ メモリ書き込み**」のBを参照)
- 3. BS1をLow(0)、OEをLow(0)に設定します。EEPROMのバイトデータが直ぐにDATAで読めます。
- 4. OEをHigh(1)に設定します。DATAはHi-Zになります。

### **ヒューズビット書き込み**(訳注:原書での拡張/上位/下位ヒューズ項を1つに纏めました。)

各ヒューズバイトの書き込み方法は次のとおりです。(指令とデータ設定の詳細については110頁の「**フラッシュ メモリの書き込み**」を参照)

- 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. ヒューズ n 小 対応BS1,BS2設定

ヒューズ n 小 BS1 BS2

拡張 ハ Low(0) High(1)

上位 ハ 什 High(1) Low(0)

下位 ハ 化 Low(0) Low(0)



#### 施錠ビット書き込み

施錠ビットの書き込み方法は次のとおりです。(指令とデータ設定の詳細については110頁の「フラッシュ メモリの書き込み」を参照)

- 1. 施錠ビット書き込み指令\$20(0010 0000)を設定します。(「フラッシュ メモリの書き込み」のAを参照)
- 2. データ下位ハイト(としてデータ)を設定します。0=プログラム,1=無変化です。LB保護種別3が設定(LB1とLB2がプログラム(0))されると、どの外部的なプログラミング動作種別によっても施錠ビットはプログラミングできません。(「フラッシュ メモリの書き込み」のCを参照)
- 3. WRに負パルスを与え、RDY/BSYがHighになるまで待ちます。

施錠ビットはチップ消去の実行によってのみ解除(1)できます。

### ヒューズビットと施錠ビットの読み出し

ヒュース、ビットと施錠ビットの読み出し方法は次のとおりです。(指令設定の詳細については110頁の「フラッシュ メモリの書き込み」を参照)

- 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になります。



### 識票バイ読み出し

識票バイトの読み出し方法は次のとおりです。(指令とアドレス設定の詳細については110頁の「**フラッシュ メモリの書き込み**」を参照)

- 1. 識票バイト読み出し指令\$08(0000 1000)を設定します。(「フラッシュ メモリの書き込み」のAを参照)
- 2. アトレス下位バイト(\$00~\$02)を設定します。(「フラッシュ メモリの書き込み」のBを参照)
- 3. BS1をLow(0)、OEをLow(0)に設定します。選択した識票バイが直ぐにDATAで読めます。
- 4. OEをHigh(1)に設定します。DATAはHi-Zになります。

### 校正バイ読み出し

校正バイの読み出し方法は次のとおりです。(指令とアドレス設定の詳細については110頁の「フラッシュ メモリの書き込み」を参照)

- 1. 校正バイト読み出し指令\$08(0000 1000)を設定します。(「フラッシュ メモリの書き込み」のAを参照)
- 2. アドレス下位バイトに(\$00~\$01)を設定します。(「フラッシュ メモリの書き込み」のBを参照)
- 3. BS1をHigh(1)、OEをLow(0)に設定します。校正バイが直ぐにDATAで読めます。
- 4. OEをHigh(1)に設定します。DATAはHi-Zになります。





### 並列プログラミング特性





注: 図75.で示されるタイミング必要条件(即ち、tDVXH、tXHXL、tXLDX)は設定操作にも適用されます。

### 図77. 並列プログラミング タイミング (同一ページ 読み出しでの必要条件)



注: 図75.で示されるタイミング必要条件(即ち、tDVXH、tXHXL、tXLDX)は読み出し操作にも適用されます。

#### 表75. 並列プログラミング特性 (VCC=5V±10%)

| シンホ゛ル             | 項目                          | 最小   | 代表 | 最大   | 単位  |
|-------------------|-----------------------------|------|----|------|-----|
| Vpp               | プログラミング許可電圧                 | 11.5 |    | 12.5 | V   |
| Ipp               | プログラミング許可電流                 |      |    | 250  | μA  |
| t <sub>DVXH</sub> | XTAL1↑に対するデータと制御の準備時間       | 67   |    |      |     |
| t <sub>XLXH</sub> | XTAL1↓から次XTAL1↑までの待機時間      | 200  |    |      |     |
| t <sub>XHXL</sub> | XTAL1 Highパルス幅              | 150  |    |      |     |
| txLDX             | XTAL1パルス↓後のデータと制御の保持時間      | 67   |    |      | n a |
| $t_{ m XLWL}$     | XTAL1パルス↓後のWR↓待機時間          | 0    |    |      | ns  |
| t <sub>WLBX</sub> | WRパハス↓後のBS1,BS2保持時間         | 67   |    |      |     |
| $t_{ m BVWL}$     | WRパハス↓に対するBS1準備時間           | 67   |    |      |     |
| twLwH             | WR Lowハ゜ルス幅                 | 150  |    |      |     |
| twlrl             | WRパルス ↓後のRDY/BSY ↓遅延時間      | 0    |    | 1    | μs  |
| twlrh             | 書き込み時間 (WR↓からRDY/BSY↑) (注1) | 3.7  |    | 4.5  | m a |
| twlrh_ce          | チップ消去時間(WR↓からRDY/BSY↑) (注2) | 7.5  |    | 9    | ms  |
| t <sub>XLCL</sub> | XTAL1パルス↓後のŌE↓待機時間          | 0    |    |      |     |
| t <sub>BVDV</sub> | BS1有効からのDATA遅延時間            | 0    |    | 250  | na  |
| toldv             | OE ↓後のDATA出力遅延時間            |      |    | 250  | ns  |
| tohdz             | ŌE↑後のDATA Hi-Z遅延時間          |      |    | 250  |     |

注1: フラッシュ メモリ、EEPROM、ヒュース、ビット、施錠ビット書き込み指令に対して有効です。

注2: チップ消去指令に対して有効です。

### 直列プログラミング

フラッシュ メモリとEEPROMの両方はRESETがGNDに引かれている間に直列SPIハ、スを使ってプログラミングできます。この直列インターフェースはSCK入力、MOSI入力、MISO出力から成ります。RESETがLowに設定された後、書き込み/消去操作が実行され得るのに先立ってプログラミング許可命令が初めに実行されることを必要とします。注意、表74.でSPIプログラミング用のピン配置が一覧されます。全てのデバイスが内部SPIインターフェースに対する専用SPIピンを使うとは限りません。

### 直列プログラミング用ピン配置

| 表7/    | 古列プ⊓ノ | ブラミング   | 用ピン配置      |  |
|--------|-------|---------|------------|--|
| AV 14. |       | 1 12 17 | HI /111.11 |  |

| 信号名  | ピン名 | 入出力 | 機能      |
|------|-----|-----|---------|
| MOSI | PB5 | 入力  | 直列データ入力 |
| MISO | PB6 | 出力  | 直列データ出力 |
| SCK  | PB7 | 入力  | 直列クロック  |

EEPROMをプログラミングする時に自動消去周期が自動書き込み動作内に組み入れられ(直列プログラミングのみ)、チップ消去命令を初めに実行する必要がありません。チップ消去操作はプログラム(フラッシュメモリ)とEEPROM両方の全てのメモリ位置の内容を\$FFにします。

CKSELヒュース'による有効なクロックが与えられなければなりません。直列クロック (SCK)入力のLowとHighの区間の最小値は次のように定義されます。

図78. 直列プログラミング構成図

(GND) PA2/RESET VCC

PA0/XTAL1 PB7 SCK PB6 MISO MOSI

注1: デバイスが内蔵発振器で動作する場合、XTAL1 ピンにクロック元を接続する必要はありません。

 $f_{\mathrm{CK}} < 12 \mathrm{MHz}$ : Low区間>2CPUクロック周期  $f_{\mathrm{CK}} \le 12 \mathrm{MHz}$ : High区間>2CPUクロック周期  $f_{\mathrm{CK}} \ge 12 \mathrm{MHz}$ : High区間>3CPUクロック周期  $f_{\mathrm{CK}} \ge 12 \mathrm{MHz}$ : High区間>3CPUクロック周期

### 直列プログラミング手順

ATtiny2313に直列データを書く時にデータはSCKの上昇端で行われ、ATtiny2313から読む時にデータはSCKの下降端で行われます。タイシングの詳細については図79.,図80.と表78.をご覧ください。

直列プログラミング動作でのATtinv2313のプログラミングと照合は次の手順が推奨されます(4小小命令形式は表77.を参照)。

1. 電源投入手順:

RESETとSCKがLow(0)に設定されている間にVCCとGND間へ電源を印加します。いくつかのシステムで電源投入中、SCKがLowに保持されるのを書き込み器が保証できません。この場合、SCKがLow(0)に設定されてしまった後、RESETは最低2CPUクロック周期幅の正パルスを与えられなければなりません。

- 2. 最低20ms待ち、MOSIピンにプログラミング許可命令を送ることによって直列プログラミングを許可してください。
- 3. 通信が同期を外していると、直列プログラミング命令は動作しません。同期していると、プログラミング許可命令の第3バイ送出時に第2 バイト(\$53)が戻ります。この戻りが正しいかどうかによらず、命令の4バイト全てが送信されなければなりません。\$53が戻らない場合、RESETに正パルスを与え、新規プログラミング許可命令を行ってください。
- 4. フラッシュ メモリは1ペーシ 単位で書かれます。ページ 容量は107頁の表68.で得られます。このメモリペーシ はページ 設定命令と共にアドレスの下位4+1ビットとデータを供給することによって1パイトづつ設定されます。ページ が正しく設定されるのを保証するため、与えられたアドレスにデータ上位パイトが適用される前にデータ下位パイトが設定されなければなりません。プログラム メモリのページ はアドレスの上位6ビットを含むページ 書き込み命令の設定によって(フラッシュ メモリに)格納されます。ポーリング(BSY/RDY)が使われない場合、使用者は次のページを行う前に最低twp FLASH(表76.参照)待たなければなりません。
  - 注: 何れの(フラッシュ、EEPROM、施錠ビット、ヒューズ)書き込み操作が完了される前にポーリング(読み)以外の命令が加えられると、不正な書き込みに終わるかもしれません(訳注:共通性のため原書の該当行に代わり本行追加)。
- 5. EEPROMはペーシー単位かハート単位のどちらかでプログラミングできます。

**バイト単位**: EEPROMは適切なEEPROM書き込み命令と共にアドレスとデータを供給することによって1バイト単位で書かれます。EEP ROMのメモリ位置は新規データが書かれるのに先立って始めで自動的に消去されます。ポーリング(BSY/RDY)が使われない場合、次のバイトを行う前に最低twp\_EEPROM(表76.参照)待たなければなりません。

**ページ単位**: EEPROMの1ページはEEPROMぺージ設定命令と共にアドレスの下位2ビットとデータを供給することによって1バイトづつ設定されます。EEPROMぺージはアドレスの上位5ビットを含むEEPROMぺージ書き込み命令によって(EEPROMに)格納されます。EEPROMぺージアクセス使用時、EEPROMぺージ設定命令で設定したバイト位置だけが変更されます。残りの位置は無変化で留まります。ポ゚ーリング(BSY/RDY)が使われない場合、次のページを行う前に最低twp\_eeprom(表76.参照)待たなければなりません。チップ消去されたデバイスでの\$FFデータは書かれる必要がありません。

- 6. どのメモリ位置も選択したアドレスの内容を直列出力MISOに読み戻す読み出し命令を使うことによって照合できます。
- 7. プログラミング作業終了時、RESETは通常動作を開始するため、High(1)に設定できます。
- 8. 電源OFF手順(必要とされるならば)
  - ・RESETをHigh(1)に設定します。
  - VCC電源をOFFにします。





表76. ヒューズ, フラッシュ, EEPROM次位置書き込み前の待機時間

| 20101 02 111,77 | 及76. CE 77,7777年 CE 100000000000000000000000000000000000 |               |  |  |  |  |  |  |
|-----------------|----------------------------------------------------------|---------------|--|--|--|--|--|--|
| シンホ゛ル           | 最低待機時間                                                   | 備考            |  |  |  |  |  |  |
| two_fuse        | 4.5ms                                                    | ヒュース゛書き込み     |  |  |  |  |  |  |
| two_flash       | 4.5ms                                                    | フラッシュ メモリ書き込み |  |  |  |  |  |  |
| twd_eeprom      | 4.0ms                                                    | EEPROM書き込み    |  |  |  |  |  |  |
| two_erase       | 9.0ms                                                    | チップ消去         |  |  |  |  |  |  |



表77 直列プログラシッグ命令一士

| 命令            |           | 命令        | 形式        |           | 動作                                |             |  |
|---------------|-----------|-----------|-----------|-----------|-----------------------------------|-------------|--|
| 中中            | 第1バイト     | 第2小小      | 第3小小      | 第4小小      | 判TF                               |             |  |
| プログラミング許可     | 1010 1100 | 0101 0011 | XXXX XXXX | XXXX XXXX | RESET=Low後のプログラミングを許可します。         |             |  |
| チップ消去         | 1010 1100 | 100x xxxx | XXXX XXXX | XXXX XXXX | フラッシュ メモリ,EEPROM,施銀               | 定ビットを消去します。 |  |
| フラッシュメモリ読み出し  | 0010 P000 | 0000 00HH | LLLL LLLL | RRRR RRRR | アドレス <mark>H:L</mark> のP(H/L)バイトを | 読み出します。     |  |
| フラッシュページ設定    | 0100 P000 | 000x xxxx | xxxx LLLL | WWWW WWWW | 緩衝部アドレスLのP(H/L)バ                  | 仆に書き込みます。   |  |
| フラッシュページ書き込み  | 0100 1100 | 0000 00HH | LLLL xxxx | XXXX XXXX | アドレスH:Lのページに書き込                   | みます。        |  |
| EEPROM読み出し    | 1010 0000 | 000x xxxx | xLLL LLLL | RRRR RRRR | アドレスLのバイトを読み出しる                   | ます。         |  |
| EEPROMバイト書き込み | 1100 0000 | 000x xxxx | xLLL LLLL | wwww wwww | アドレス <mark>L</mark> のバイトに書き込みます。  |             |  |
| EEPROMへ゜ージ設定  | 1100 0001 | 0000 0000 | 0000 00LL | WWWW WWWW | 緩衝部アドレスLのバイトに書き込みます。              |             |  |
| EEPROMページ書き込み | 1100 0010 | 00xx xxxx | xLLL LL00 | XXXX XXXX | アドレス <mark>L</mark> のページに書き込みます。  |             |  |
| 施錠ビット読み出し     | 0101 1000 | 0000 0000 | XXXX XXXX | xxxx xxRR |                                   | を読み出します。    |  |
| 施錠ビット書き込み     | 1010 1100 | 111x xxxx | xxxx xxxx | 1111 11WW | (106頁の表63.参照)                     | に書き込みます。    |  |
| ヒューズ下位読み出し    | 0101 0000 | 0000 0000 | XXXX XXXX |           | ヒュース・下位ビット                        | を読み出します。    |  |
| ヒューズ下位書き込み    | 1010 1100 | 1010 0000 | XXXX XXXX | wwww wwww | (107頁の <b>表67</b> .参照)            | に書き込みます。    |  |
| ヒューズ上位読み出し    | 0101 1000 | 0000 1000 | XXXX XXXX |           | ヒュース・上位ビット                        | を読み出します。    |  |
| ヒューズ上位書き込み    | 1010 1100 | 1010 1000 | XXXX XXXX | WWOW WWWW | (106頁の <b>表66</b> .参照)            | に書き込みます。    |  |
| 拡張ヒューズ読み出し    | 0101 0000 | 0000 1000 | XXXX XXXX |           | 拡張ヒューズビット                         | を読み出します。    |  |
| 拡張ヒューズ書き込み    | 1010 1100 | 1010 0100 | XXXX XXXX | xxxx xxxW | (106頁の表65.参照)                     | に書き込みます。    |  |
| 識票バ小読み出し      | 0011 0000 | 000x xxxx | xxxx xxLL | RRRR RRRR | アドレスLの識票バイトを読み出します。               |             |  |
| 校正バ小読み出し      | 0011 1000 | 000x xxxx | 0000 000L | RRRR RRRR | アドレスLの校正バイトを読み                    | 出します。       |  |
| 多忙/準備可検査      | 1111 0000 | 0000 0000 | xxxx xxxx | xxxx xxxR | R=1で多忙、他の操作前に                     | .0まで待機します。  |  |

### 直列プログラミング特性



表78. 直列プログラミング特性 (特記条件を除いて、TA=-40℃~85℃, VCC=2.7~5.5V)

| シンホ゛ル             | 項目                 | 項目       |        |  | 最大  | 単位      |
|-------------------|--------------------|----------|--------|--|-----|---------|
| 1/tclcl           | 発振器周波数             | 2.7~5.5V | 0      |  | 10  | MHz     |
| 1/tCLCL           | 光弧矿冲仪效             | 4.5~5.5V | 0      |  | 20  | IVII IZ |
| toror             | 発振器周期              | 2.7~5.5V | 100    |  |     |         |
| tclcl             | 光派奋户别              | 4.5~5.5V | 50     |  |     | ns      |
| tsHSL             | SCKパルスHレヘブル幅       | (注1)     | 2tclcl |  |     |         |
| tslsh             | SCKパルスLレヘブル幅       | (注1)     | 2tclcl |  |     | ns      |
| tovsh             | SCK↑に対するMOSI準備時間   |          | tclcl  |  |     |         |
| t <sub>SHOX</sub> | SCK↑に対するMOSI保持時間   |          | 2tclcl |  |     |         |
| tsliv             | SCK↓に対するMISO出力遅延時間 |          |        |  | 100 |         |

注1:  $f_{CK} < 12MHz$ 時2 $t_{CLCL}$ 、 $f_{CK} \ge 12MHz$ 時3 $t_{CLCL}$ 。





### 電気的特性

### 絶対最大定格 (警告)

### (警告)

絶対最大定格を超える負担はデバイスに定常的な損傷を与えます。 絶対最大定格は負担の定格を示すためだけのもので、この値また は、この仕様書の動作特性で示された値を超える条件で動作する ことを示すものではありません。長時間の最大定格での使用はデバイスの信頼性を損なう場合があります。

### DC特性

TA=-40℃~85℃, VCC=1.8V~5.5V (特記事項を除く)

| シンホ゛ル                         | 項目                           |             | 条件                   | 最小                   | 代表 (注1) | 最大                   | 単位   |
|-------------------------------|------------------------------|-------------|----------------------|----------------------|---------|----------------------|------|
| VIL                           | Lowレベル入力電圧                   |             | VCC=1.8∼2.4V         | -0.5                 |         | 0.2VCC ( <b>注2</b> ) |      |
| VIL                           | (XTAL1,RESETを除く)             | 1           | VCC=2.4~5.5V         | -0.5                 |         | 0.3VCC ( <b>注2</b> ) |      |
| V <sub>IL1</sub>              | Lowレベル入力電圧 (X                | ΓAL1)       | VCC=1.8∼5.5V         | -0.5                 |         | 0.1VCC ( <b>注2</b> ) |      |
| V <sub>I</sub> L <sub>2</sub> | Lowレベル入力電圧 (RI               | ESET)       | VCC=1.8∼5.5V         | -0.5                 |         | 0.2VCC ( <b>注2</b> ) |      |
| VIL3                          | Lowレベル入力電圧                   |             | VCC=1.8∼2.4V         | -0.5                 |         | 0.2VCC ( <b>注2</b> ) |      |
| VIL3                          | (I/OとしてのRESET)               |             | VCC=2.4~5.5V         | -0.5                 |         | 0.3VCC ( <b>注2</b> ) |      |
| Vih                           | Highレベル入力電圧                  |             | VCC=1.8∼2.4V         | 0.7VCC ( <b>注3</b> ) |         | VCC+0.5              |      |
| VIH                           | (XTAL1,RESETを除く)             | )           | VCC=2.4~5.5V         | 0.6VCC ( <b>注3</b> ) |         | VCC+0.5              |      |
| V <sub>IH1</sub>              | Highレベル入力電圧(X                | TAI 1)      | VCC=1.8∼2.4V         | 0.8VCC ( <b>注3</b> ) |         | VCC+0.5              |      |
| VIHI                          | Filgnivベル人刀电圧(A              | IALI)       | VCC=2.4~5.5V         | 0.7VCC ( <b>注3</b> ) |         | VCC+0.5              | V    |
| VIH2                          | Highレヘブル入力電圧 (R              | ESET)       | VCC=1.8∼5.5V         | 0.9VCC ( <b>注3</b> ) |         | VCC+0.5              |      |
| V <sub>IH3</sub>              | Highレベル入力電圧                  |             | VCC=1.8∼2.4V         | 0.7VCC ( <b>注3</b> ) |         | VCC+0.5              |      |
| VIH3                          | (I/OとしてのRESET)               |             | VCC=2.4~5.5V         | 0.6VCC ( <b>注3</b> ) |         | VCC+0.5              |      |
| Vor                           |                              | 1/0としての     |                      |                      |         | 0.7                  |      |
| Vol                           | Lレベル出力電圧( <mark>注4</mark> )  | RESET以外     | IOL=10mA, VCC=3V     |                      |         | 0.5                  |      |
| VOL3                          |                              | RESET=I/O   | TBD                  |                      |         | TBD                  |      |
| Voh                           |                              | I/Oとしての     | IOH=-20mA, VCC=5V    | 4.2                  |         |                      |      |
| VOH                           | Hレヘブル出力電圧( <mark>注5</mark> ) | RESET以外     | IOH=-10mA, VCC=3V    | 2.5                  |         |                      |      |
| Voh3                          |                              | RESET=I/O   | TBD                  | TBD                  |         |                      |      |
| IIL                           | I/OビンLowレベル入力派               | 晶れ電流 しゅうしゅう | VCC=5.5V             |                      |         | 1                    | ., Λ |
| IIH                           | I/OビンHighレベル入力ネ              | <b>漏れ電流</b> | 確実なH/L範囲             |                      |         | 1                    | μA   |
| RRST                          | RESETピン プルアップ抵抗              | 亢           |                      | 30                   |         | 60                   | 1-0  |
| Rpu                           | I/Oピン プルアップ抵抗                |             |                      | 20                   |         | 50                   | kΩ   |
|                               |                              |             | VCC=2V, 1MHz         |                      |         | 0.35                 |      |
|                               | 活動動作消費電流                     |             | VCC=3V, 4MHz         |                      |         | 2                    |      |
|                               |                              |             | VCC=5V, 8MHz         |                      |         | 6                    | m Λ  |
| ICC                           |                              |             | VCC=2V, 1MHz         |                      | 0.08    | 0.2                  | mA   |
| ICC                           | アイル動作消費電流                    |             | VCC=3V, 4MHz         |                      | 0.41    | 1                    |      |
|                               |                              |             | VCC=5V, 8MHz         |                      | 1.6     | 3                    |      |
|                               | パローがかる動作消費電                  |             | VCC=3V, WDT有効        |                      | <3      | 6                    | 11 Λ |
|                               | パターダウン動作消費電流                 |             | VCC=3V, WDT禁止        |                      | <0.5    | 2                    | μA   |
| VACIO                         | アナログ比較器入力オフセ                 | ツト電圧        | VCC=5V, Vin=VCC/2    |                      | <10     | 40                   | mV   |
| IACLK                         | アナログ比較器入力漏れ                  | 電流          | $\sqrt{\frac{1}{2}}$ | -50                  |         | 50                   | nA   |
| tages                         | 74ヵがい 砂 児 仁 採 、 屋 273        | - 中間        | VCC=2.7V             |                      | 750     |                      |      |
| LACPD                         | アナログ比較器伝播遅延                  | Ŀ14.Ⅲ       | VCC=5.0V             |                      | 500     |                      | ns   |

(注1)~(注5)は次頁へ

注1: 25℃での代表値です。

注2: Lowレベルの認識が保証される最高電圧です。

注3: Highレヘブルの認識が保証される最低電圧です。

注4: 各I/Oポートは安定状態(非過渡時)に於いて検査条件(VCC=5Vで10mA、VCC=3Vで5mA)よりも多くの吸い込み電流を流すことができますが、次の条件を厳守してください。

1. 全ポートのIOLの合計が60mAを超えるべきではありません。

IOLが検査条件を超える場合、VOLも仕様書での値を超えます。表の検査条件よりも大きな吸い込み電流を流すことは保証されません。

注5: 各I/Oポートは安定状態(非過渡時)に於いて検査条件(VCC=5Vで10mA、VCC=3Vで5mA)よりも多くの吐き出し電流を流すことができますが、次の条件を厳守してください。

1. 全ポートのIOHの合計が60mAを超えるべきではありません。

IOHが検査条件を超える場合、VOHも仕様書での値を超えます。表の検査条件よりも大きな吐き出し電流を流すことは保証されません。

### 外部クロック特性



### 表79. 外部クロック特性

| シンホール               | 項目                                    | VCC=1. | 8 <b>∼</b> 5.5V | VCC=2.7∼5.5V |     | VCC=4.5∼5.5V |     | 単位  |  |
|---------------------|---------------------------------------|--------|-----------------|--------------|-----|--------------|-----|-----|--|
| シンボ ル               | · · · · · · · · · · · · · · · · · · · | 最小     | 最大              | 最小           | 最大  | 最小           | 最大  | 中位  |  |
| 1/t <sub>CLCL</sub> | クロック周波数                               | 0      | 4               | 0            | 10  | 0            | 20  | MHz |  |
| tclcl               | クロック周期                                | 250    |                 | 100          |     | 50           |     |     |  |
| tchcx               | Highレヘル時間                             | 100    |                 | 40           |     | 20           |     | ns  |  |
| tclcx               | Lowレヘル時間                              | 100    |                 | 40           |     | 20           |     |     |  |
| tclch               | 上昇時間                                  |        | 2.0             |              | 1.6 |              | 0.5 |     |  |
| tchcl               | 下降時間                                  |        | 2.0             |              | 1.6 |              | 0.5 | μs  |  |
| ⊿tclcl              | 隣接クロック周期間の変化率                         |        | 2               |              | 2   |              | 2   | %   |  |

### 最高速と動作電圧

最高周波数は動作電圧に依存します。図82.と図83.で示されるように最高周波数対動作電圧曲線は1.8~2.7Vと2.7~4.5V間で直線です。









### システムとリセットの特性

表80. リセット、低電圧検出(BOD)、内部基準電圧の特性

| シンホ゛ル              | 項目                 | 条件                  | 最小     | 代表  | 最大     | 単位   |
|--------------------|--------------------|---------------------|--------|-----|--------|------|
| V <sub>POT</sub>   | 上昇時電源ONリセット閾値電圧    | TA=-40~85°C         | 0.7    | 1.0 | 1.4    | V    |
| VPOT               | 下降時電源ONリセット閾値電圧(注) | 1A-40 905 C         | 0.05   | 0.9 | 1.3    | V    |
| V <sub>PONSR</sub> | 電源ON電圧傾斜率          |                     | 0.01   |     | 4.5    | V/ms |
| V <sub>RST</sub>   | RESETt°ン閾値電圧       |                     | 0.2VCC |     | 0.9VCC | V    |
| t <sub>RST</sub>   | リセット ハ゜ルス幅         |                     | 2.5    |     |        | μs   |
| V <sub>HYST</sub>  | 低電圧検出ヒステリシス電圧      |                     |        | 50  |        | mV   |
| $t_{ m BOD}$       | 最小低電圧検出時間          |                     |        | 2   |        | μs   |
| $V_{BG}$           | 基準電圧               | VICC 0 7VI          | 1.0    | 1.1 | 1.2    | V    |
| t <sub>BG</sub>    | 起動時間               | VCC=2.7V<br>TA=25°C |        | 40  | 70     | μs   |
| $I_{\mathrm{BG}}$  | 消費電流               | 1A-20 C             |        | 10  |        | μA   |

注:供給電圧がこの電圧以下にならないと、上昇時の電源ONJセットは動作しません。

### 代表特性

以下の図は代表的な特性を示します。これらの図は製造中に検査されていません。全ての消費電流測定は全I/Oピンを入力として設定した内部プルアップ許可で行われています。電源幅振幅の方形波発振器がクロック源として使われています。

パワーダウン動作での消費電力はクロック選択と無関係です。

消費電流は動作電圧、動作周波数、I/Oピンの負荷、I/Oピンの切り替え速度、命令実行、周囲温度のような様々な要素の関数です。 支配的な要素は動作電圧と動作周波数です。

容量性負荷のピンの引き込み電流は(1つのピンに対して) CL(負荷容量)×VCC(動作電圧)×f(I/Ot゚ンの平均切り替え周波数) として推測できます。

デバイスは検査範囲よりも高い周波数特性を示します。デバイスは注文番号が示す周波数よりも高い周波数での機能特性を保証されません。

ウォッチドック タイマ許可のパワーダウン動作での消費電流とウォッチドック タイマ禁止のパワーダウン動作での消費電流間の違いは、ウォッチドッグ タイマによって引き込んだ(消費した)差電流を表します。

### 活動動作消費電流



















### アイドル動作消費電流























### パワーダウン動作消費電流





### スタンバイ動作消費電流



### ピン プルアップ











### ピン駆動能力































# ピン 閾値とヒステリシス





















### 低電圧検出器(BOD)閾値とアナログ比較器オフセット













### 内部発振器周波数





















### 周辺機能部消費電流











### リセット消費電流とリセットパルス幅







# レジスタ要約

| アト・レス                      | レジスタ略称            | ピット7          | じット6          | ヒット5          | ピット4                         | じット3                                      | ヒ゛ット2          | ピット1           | ピット0           | 頁        |
|----------------------------|-------------------|---------------|---------------|---------------|------------------------------|-------------------------------------------|----------------|----------------|----------------|----------|
| \$3F (\$5F)                | SREG              | I             | T             | Н             | S                            | V                                         | N              | Z              | C              | 7        |
| \$3E (\$5E)                | 予約                |               |               |               |                              |                                           |                |                |                |          |
| \$3D (\$5D)                | SPL               | SP7           | SP6           | SP5           | SP4                          | SP3                                       | SP2            | SP1            | SP0            | 8        |
| \$3C (\$5C)                | OCR0B             | INITE1        | INITO         |               | タイマ/カウンタ0                    | 比較Bレンス                                    | ý<br>          | 1              |                | 52       |
| \$3B (\$5B)                | GIMSK<br>EIFR     | INT1<br>INTF1 | INT0<br>INTF0 | PCIE<br>PCIF  | _                            | _                                         | _              | _              | _              | 41<br>41 |
| \$3A (\$5A)<br>\$39 (\$59) | TIMSK             | TOIE1         | OCIE1A        | OCIE1B        | _                            | ICIE1                                     | OCIE0B         | TOIE0          | OCIE0A         | 74,53    |
| \$39 (\$59)                | TIFR              | TOV1          | OCF1A         | OCF1B         | _                            | ICIE1                                     | OCF0B          | TOV0           | OCF0A          | 74,53    |
| \$37 (\$57)                | SPMCSR            | -             | -             | -             | СТРВ                         | RFLB                                      | PGWRT          | PGERS          | SELFPRGEN      | 104      |
| \$36 (\$56)                | OCR0A             |               |               |               | タイマ/カウンタ0                    |                                           | A LOWKI        | TOLKS          | SELIT KOLK     | 52       |
| \$35 (\$55)                | MCUCR             | PUD           | SM1           | SE            | SM0                          | ISC11                                     | ISC10          | ISC01          | ISC00          | 34,21,40 |
| \$34 (\$54)                | MCUSR             | -             | -             | -             | -                            | WDRF                                      | BORF           | EXTRF          | PORF           | 25       |
| \$33 (\$53)                | TCCR0B            | FOC0A         | FOC0B         | -             | _                            | WGM02                                     | CS02           | CS01           | CS00           | 51       |
| \$32 (\$52)                | TCNT0             |               | ,             |               |                              | カウンタ0                                     |                |                |                | 52       |
| \$31 (\$51)                | OSCCAL            | -             |               |               |                              | 辰器 発振校                                    | 正値レジスタ         |                |                | 18       |
| \$30 (\$50)                | TCCR0A            | COM0A1        | COM0A0        | COM0B1        | COM0B0                       | -                                         | -              | WGM01          | WGM00          | 50       |
| \$2F (\$4F)                | TCCR1A            | COM1A1        | COM1A0        | COM1B1        | COM1B0                       | -                                         | -              | WGM11          | WGM10          | 70       |
| \$2E (\$4E)                | TCCR1B            | ICNC1         | ICES1         | -             | WGM13                        | WGM12                                     | CS12           | CS11           | CS10           | 71       |
| \$2D (\$4D)                | TCNT1H            |               | -             |               | タイマ/カウンタ                     | 1 上位バイ                                    | -              | -              | -              | 72       |
| \$2C (\$4C)                | TCNT1L            |               |               | h/-/          |                              | 1 下位バイト                                   | <b>生パ</b> ガ    | 1              |                | 72       |
| \$2B (\$4B)                | OCR1AH            |               | -             | クイマ/          | カウンタ1 比較<br>カウンタ1 比較         | Aレン 人グ上位                                  | リハイト カップト      | -              | -              | 73<br>73 |
| \$2A (\$4A)<br>\$29 (\$49) | OCR1AL<br>OCR1BH  |               |               |               | カリンタ1 比較<br>カウンタ1 比較         |                                           |                | 1              | 1              | 73       |
| \$29 (\$49)                | OCRIBH<br>OCRIBL  |               | +             |               | <u> カウンク1 比較</u><br>カウンタ1 比較 |                                           |                | +              | +              | 73       |
| \$27 (\$47)                | 予約                |               |               | 714/          | ハフマフエ レ山野                    | (DV \ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ | (217) T        |                |                | 10       |
| \$26 (\$46)                | CLKPR             | CLKPCE        | _             | _             | _                            | CLKPS3                                    | CLKPS2         | CLKPS1         | CLKPS0         | 20       |
| \$25 (\$45)                | ICR1H             | CERTOE        |               | タイマ           | /カウンタ1 捕獲                    |                                           |                | CERTOI         | CLINIO         | 73       |
| \$24 (\$44)                | ICR1L             |               | 1             |               | /カウンタ1 捕獲                    |                                           |                |                | 1              | 73       |
| \$23 (\$43)                | GTCCR             | -             | -             | - 1           | -                            | -                                         | <u> </u>       | -              | PSR10          | 55       |
| \$22 (\$42)                | TCCR1C            | FOC1A         | FOC1B         | -             | -                            | _                                         | -              | -              | _              | 72       |
| \$21 (\$41)                | WDTCSR            | WDIF          | WDIE          | WDP3          | WDCE                         | WDE                                       | WDP2           | WDP1           | WDP0           | 28       |
| \$20 (\$40)                | PCMSK             | PCINT7        | PCINT6        | PCINT5        | PCINT4                       | PCINT3                                    | PCINT2         | PCINT1         | PCINT0         | 41       |
| \$1F (\$3F)                | 予約                |               |               |               |                              |                                           |                |                |                |          |
| \$1E (\$3E)                | EEAR              | 1             |               | <b>.</b>      |                              | トレス レシ スタ                                 | (EEAR6~0)      | 1              | +              | 12       |
| \$1D (\$3D)                | EEDR              |               |               | DDD (         |                              | ータ レシブスタ                                  |                |                | PPPP           | 12       |
| \$1C (\$3C)                | EECR              | _             | _             | EEPM1         | EEPM0                        | EERIE                                     | EEMPE          | EEPE           | EERE           | 12       |
| \$1B (\$3B)<br>\$1A (\$3A) | PORTA<br>DDRA     | -             | _             | _             | _                            | _                                         | PORTA2<br>DDA2 | PORTA1<br>DDA1 | PORTA0<br>DDA0 | 39<br>39 |
| \$1A (\$3A)<br>\$19 (\$39) | PINA              |               | _             | _             | _                            |                                           | PINA2          | PINA1          | PINA0          | 39       |
| \$18 (\$38)                | PORTB             | PORTB7        | PORTB6        | PORTB5        | PORTB4                       | PORTB3                                    | PORTB2         | PORTB1         | PORTB0         | 39       |
| \$17 (\$37)                | DDRB              | DDB7          | DDB6          | DDB5          | DDB4                         | DDB3                                      | DDB2           | DDB1           | DDB0           | 39       |
| \$16 (\$36)                | PINB              | PINB7         | PINB6         | PINB5         | PINB4                        | PINB3                                     | PINB2          | PINB1          | PINB0          | 39       |
| \$15 (\$35)                | GPIOR2            |               |               |               |                              | シレシブスタ2                                   |                |                |                | 15       |
| \$14 (\$34)                | GPIOR1            |               |               |               | 汎用I/C                        |                                           |                |                |                | 15       |
| \$13 (\$33)                | GPIOR0            |               |               |               | 汎用I/C                        | )レシ`スタ0                                   |                |                |                | 15       |
| \$12 (\$32)                | PORTD             | -             | PORTD6        | PORTD5        | PORTD4                       | PORTD3                                    | PORTD2         | PORTD1         | PORTD0         | 39       |
| \$11 (\$31)                | DDRD              | -             | DDD6          | DDD5          | DDD4                         | DDD3                                      | DDD2           | DDD1           | DDD0           | 39       |
| \$10 (\$30)                | PIND              | _             | PIND6         | PIND5         | PIND4                        | PIND3                                     | PIND2          | PIND1          | PIND0          | 39       |
| \$0F (\$2F)                | USIDR             |               |               |               |                              | タレジスタ                                     | 1,101,01       | 110101         | 110101         | 97       |
| \$0E (\$2E)                | USISR             | USISIF        | USIOIF        | USIPF         | USIDC                        | USICNT3                                   | USICNT2        | USICNT1        | USICNT0        | 97       |
| \$0D (\$2D)                | USICR             | USISIE        | USIOIE        | USIWM1        | USIWM0                       | USICS1                                    | USICS0         | USICLK         | USITC          | 98       |
| \$0C (\$2C)                | UDR               | DVC           | TVC           | LIDDE         |                              | ータ レシ スタ                                  | LIDE           | Hov            | MDCM           | 87       |
| \$0B (\$2B)                | UCSRA             | RXC           | TXC<br>TXCIE  | UDRE<br>UDRIE | FE<br>RXEN                   | DOR                                       | UPE<br>UCS79   | U2X<br>DVDo    | MPCM           | 87       |
| \$0A (\$2A)<br>\$09 (\$29) | UCSRB<br>UBRRL    | RXCIE         | TACIE         |               | ボーレート レシ                     | TXEN                                      | UCSZ2          | RXB8           | TXB8           | 88<br>89 |
| \$09 (\$29)                | ACSR              | ACD           | ACBG          | ACO           | ACI                          | ACIE                                      | ACIC           | ACIS1          | ACIS0          | 100      |
| \$07 (\$27)                | 予約                | ACD           | NODG          | ACO           | TICI                         | ACIE                                      | ACIC           | 710131         | ACISO          | 100      |
| \$06 (\$26)                | 予約                |               |               |               |                              |                                           |                |                |                |          |
| \$05 (\$25)                | 予約                |               |               |               |                              |                                           |                |                |                |          |
| \$04 (\$24)                | 予約                |               |               |               |                              |                                           |                |                |                |          |
| \$03 (\$23)                | UCSRC             | _             | UMSEL         | UPM1          | UPM0                         | USBS                                      | UCSZ1          | UCSZ0          | UCPOL          | 88       |
| \$02 (\$22)                | UBRRH             | -             | _             | -             | -                            |                                           | ボーレートレジ        |                |                | 89       |
| \$01 (\$21)                | DIDR              | =             | -             | =             | -                            | -                                         | -              | AIN1D          | AIN0D          | 101      |
| \$00 (\$20)                | 予約                |               |               |               |                              |                                           |                |                |                |          |
|                            | <b>ゝニ゛゛ノっしの #</b> | >= 1.1        | » »           | > ( D A . )   | 0ナ. 士ノ いも、                   |                                           |                |                |                |          |

- 注:・将来のデバイスとの共通性のため、予約ビットへ書く場合は0を書くべきです。予約I/Oメモリ アドレスは決して書かれるべきではありません。
  - ・アトンス範囲\$00~\$1FのI/OレジスタはCBIとSBI命令の使用で直接アクセス可能です。これらのレジスタの単一ビットはCBISとSBIS命令の使用によって検査できます。
  - ・いくつかの状態ビットはそれらへ論理1を書くことによって解除(0)されます。他の多くのAVRと異なり、CBIとSBI命令は指定ビットだけ操作し、従ってこのような状態フラグを含むレジスタで使えることに注意してください。CBIとSBI命令は\$00~\$1Fのレジスタだけで動作します。





## 命令要約

| ニーモニック | オペラント゛ | 意味                                  | 動作                                                                     | フラク゛                           | クロック              |
|--------|--------|-------------------------------------|------------------------------------------------------------------------|--------------------------------|-------------------|
|        |        | 算術、論理                               |                                                                        |                                |                   |
| ADD    | Rd,Rr  | 汎用レジスタ間の加算                          | $Rd \leftarrow 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 \leftarrow Rd - Rr$                                                | I,T,H,S,V,N,Z,C                | 1                 |
| SUBI   | Rd,K   | 汎用レジスタから即値の減算                       | $Rd \leftarrow 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 \leftarrow 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, <mark>S,0,N,Z,</mark> C | 1                 |
| COM    | Rd     | 1の補数(論理反転)                          | Rd ← \$FF - Rd                                                         | $I,T,H,S,0,N,Z,\mathbb{C}$     | 1                 |
| NEG    | Rd     | 2の補数                                | Rd ← \$00 - Rd                                                         | I,T,H,S,V,N,Z,C                | 1                 |
| SBR    | Rd,K   | 汎用レジスタの(複数)ビット設定(1)                 | Rd ← Rd OR K                                                           | I,T,H,S,0,N,Z,C                | 1                 |
| CBR    | Rd,K   | 汎用レジスタの(複数)ビット解除( <mark>0</mark> )  | $Rd \leftarrow Rd \ AND \ (\$FF - K)$                                  | I,T,H,S,0,N,Z,C                | 1                 |
| INC    | Rd     | 汎用レシブスタの増加(+1)                      | Rd ← Rd + 1                                                            | I,T,H,S,V,N,Z,C                | 1                 |
| DEC    | Rd     | 汎用レシブスタの減少(-1)                      | Rd ← Rd − 1                                                            | I,T,H,S,V,N,Z,C                | 1                 |
| TST    | Rd     | 汎用レシ、スタのセ・ロとマイナス検査                  | Rd ← Rd AND Rd                                                         | I,T,H,S,0,N,Z,C                | 1                 |
| CLR    | Rd     | 汎用レシ、スタの全 <mark>0</mark> 設定(=\$00)  | Rd ← Rd EOR Rd                                                         | $I,T,H,\theta,0,0,1,C$         | 1                 |
| SER    | Rd     | 汎用レシ、スタの全1設定(=\$FF)                 | Rd ← \$FF                                                              | I,T,H,S,V,N,Z,C                | 1                 |
|        | •      |                                     | 命令                                                                     |                                |                   |
| 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                | 1/2,3             |
| CP     | Rd,Rr  | 汎用レジスタ間の比較                          | Rd - Rr                                                                | I,T,H,S,V,N,Z,C                | 1                 |
| CPC    | Rd,Rr  | キャリーを含めた汎用レジスタ間の比較                  | Rd - Rr - C                                                            | I,T,H,S,V,N,Z,C                | 1                 |
| CPI    | Rd,K   | 汎用レジスタと即値の比較                        | Rd - K                                                                 | I,T,H,S,V,N,Z,C                | 1                 |
| SBRC   | Rr,b   | 汎用レジスタのビットが解除(0)でスキップ               | Rr(b)=0なら, PC ← PC + 2or3                                              | I,T,H,S,V,N,Z,C                | 1/2,3             |
| SBRS   | Rr,b   | 汎用レシ、スタのビットが設定(1)でスキップ。             | Rr(b)=1なら, PC ← PC + 2or3                                              | I,T,H,S,V,N,Z,C                | 1/2,3             |
| SBIC   | P,b    | I/Oレシ、スタのヒットが解除(0)でスキップ             | P(b)=07\$6, PC ← PC + 2or3                                             | I,T,H,S,V,N,Z,C                | 1/2,3             |
| SBIS   | P,b    | I/Oレシブスタのビットが設定(1)でスキップ             | P(b)=1なら, PC ← PC + 2or3                                               | I,T,H,S,V,N,Z,C                | 1/2,3             |
| BRBS   | s,k    | ステータス フラグが設定(1)で分岐                  | SREG(s)=1なら, PC ← PC + K + 1                                           | I.T.H.S.V.N.Z.C                | 1/2               |
| BRBC   | s,k    | ステータス フラグが解除(0)で分岐                  | SREG(s)=0なら, PC ← PC + K + 1                                           | I.T.H.S.V.N.Z.C                | 1/2               |
| BREQ   | k      | 一致で分岐                               | Z=1なら, PC ← PC + K + 1                                                 | I,T,H,S,V,N,Z,C                | $\frac{1/2}{1/2}$ |
| BRNE   | k      | 不一致で分岐                              | Z=0なら, PC ← PC + K + 1                                                 | I,T,H,S,V,N,Z,C                | $\frac{1/2}{1/2}$ |
| BRCS   | k      | キャリー フラグが設定(1)で分岐                   | C=1なら, PC ← PC + K + 1                                                 | I,T,H,S,V,N,Z,C                | $\frac{1/2}{1/2}$ |
| BRCC   | k      | キャリーフラグが解除(0)で分岐                    | $C=0$ 766, $PC \leftarrow PC + K + 1$                                  | I,T,H,S,V,N,Z,C                |                   |
| BRSH   | k      | 符号なしの≧で分岐                           | $C=0$ 766, $PC \leftarrow 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                | $\frac{1/2}{1/2}$ |
| BRMI   | k      | -(マイナス)で分岐                          | N=1なら, PC ← PC + K + 1                                                 | I,T,H,S,V,N,Z,C                | $\frac{1/2}{1/2}$ |
| BRPL   | k      | +(プラス)で分岐                           | N=0766, PC ← PC + K + 1                                                | I,T,H,S,V,N,Z,C                |                   |
| BRGE   | k      | 符号付きの≧で分岐                           | (N EOR V)=0なら, PC ← PC + K + 1                                         | I,T,H,S,V,N,Z,C                | $\frac{1/2}{1/2}$ |
| BRLT   | k      | 符号付きのくで分岐                           | $(N EOR V)=1$ \$\frac{1}{2}\$\frac{1}{2}\$, $PC \leftarrow PC + K + 1$ | I,T,H,S,V,N,Z,C                | $\frac{1/2}{1/2}$ |
| BRHS   | k      | ハーフキャリー フラグが設定(1)で分岐                | H=1なら, PC ← PC + K + 1                                                 | I,T,H,S,V,N,Z,C                | $\frac{1/2}{1/2}$ |
| BRHC   | k      | ハーフキャリー フラグが解除(0)で分岐                | H=0なら, PC ← PC + K + 1                                                 | I,T,H,S,V,N,Z,C                | $\frac{1/2}{1/2}$ |
| BRTS   | k      | 一時フラグが設定(1)で分岐                      | T=1なら, PC ← PC + K + 1                                                 | I,T,H,S,V,N,Z,C                | $\frac{1/2}{1/2}$ |
| BRTC   | k      | 一時フラグが解除(0)で分岐                      | T=07\$6, PC ← PC + K + 1                                               | I,T,H,S,V,N,Z,C                | $\frac{1/2}{1/2}$ |
| BRVS   | k      | 1977 が解除(0)で分岐   2の補数溢れフラグが設定(1)で分岐 | V=1なら, PC ← PC + K + 1                                                 | 1 1 1 1 1 1 1                  | $\frac{1/2}{1/2}$ |
| BRVC   | k      |                                     | V=07\$6, PC ← PC + K + 1                                               | I,T,H,S,V,N,Z,C                | $\frac{1/2}{1/2}$ |
| BRIE   |        | 2の補数溢れフラグが解除(0)で分岐                  |                                                                        | I,T,H,S,V,N,Z,C                |                   |
| BRID   | k      | 割り込み許可で分岐   割り込み禁止で分岐               | I=1/\$6, PC ← PC + K + 1                                               | I,T,H,S,V,N,Z,C                | -                 |
| DKID   | 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          | Rd,Rr          | 汎用レジスタ間の複写                                                                                  | Rd ← Rr                                                                                                | I,T,H,S,V,N,Z,C                                                                                                 | 1       |
| MOVW         | Rd,Rr          | 汎用レジスタ対間の複写                                                                                 | Rd+1:Rd ← Rr+1:Rr<br>Rd ← K                                                                            | I,T,H,S,V,N,Z,C                                                                                                 | 1       |
| LDI<br>LD    | Rd,K<br>Rd,X   | 即値の取得<br>Xレジスタ間接での取得                                                                        | $Rd \leftarrow K$<br>$Rd \leftarrow (X)$                                                               | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C                                                                              | 2       |
| LD           | Rd,X+          | 事後増加付きXレジスタ間接での取得                                                                           | $Rd \leftarrow (X)$<br>$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           | Rd,Y           | Yレジスタ間接での取得                                                                                 | $Rd \leftarrow (Y)$                                                                                    | I,T,H,S,V,N,Z,C                                                                                                 | 2       |
| LD<br>LD     | Rd,Y+<br>Rd,-Y | 事後増加付きYレジスタ間接での取得<br>事前減少付きYレジスタ間接での取得                                                      | $Rd \leftarrow (Y), Y \leftarrow Y + 1$ $Y \leftarrow Y - 1, Rd \leftarrow (Y)$                        | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C                                                                              | 2 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           | Rd,-Z          | 事前減少付きZレジスタ間接での取得                                                                           | $Z \leftarrow Z - 1$ , Rd $\leftarrow$ (Z)                                                             | I,T,H,S,V,N,Z,C                                                                                                 | 2       |
| LDD<br>LDS   | 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 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レジスタ間接での設定<br>事前減少付き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       |
| STD          | Y+q,Rr         | 変位付きYレジスタ間接での設定                                                                             | $(Y + q) \leftarrow Rr$                                                                                | 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 $ $ (k) \leftarrow Rr $                                                        | I,T,H,S,V,N,Z,C                                                                                                 | 2       |
| STS<br>LPM   | k,Rr           | データ空間(SRAM)へ直接設定<br>プログラム領域からZレジスタ間接での取得                                                    | $(K) \leftarrow K\Gamma$<br>$R0 \leftarrow (Z)$                                                        | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C                                                                              | 2 3     |
| LPM          | Rd,Z           | 同上(任意のレジスタへ)                                                                                | $Rd \leftarrow (Z)$                                                                                    | I,T,H,S,V,N,Z,C                                                                                                 | 3       |
| LPM          | Rd,Z+          | 同上 (事後増加付き)                                                                                 | $Rd \leftarrow (Z), Z \leftarrow Z + 1$                                                                | I,T,H,S,V,N,Z,C                                                                                                 | 3       |
| SPM          |                | プログラム領域へZレジスタ間接での設定                                                                         | (Z) ← 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<br>PUSH  | P,Rr<br>Rr     | I/Oレジスタへの出力<br>汎用レジスタをスタックへ保存                                                               | P ← Rr<br>STACK ← Rr                                                                                   | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C                                                                              | 1 2     |
| POP          | Rd             | スタックから汎用レジスタ〜復帰                                                                             | Rd ← STACK                                                                                             | I,T,H,S,V,N,Z,C                                                                                                 | 2       |
|              |                | ·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>·<br>· | 係命令                                                                                                    |                                                                                                                 |         |
| 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)<br>論理的左ビット移動                                                              | $I/O(P,b) \leftarrow 0$                                                                                | I,T,H,S,V,N,Z,C                                                                                                 | 2       |
| LSL<br>LSR   | Rd<br>Rd       | 論理的右ビット移動                                                                                   | $Rd(n+1) \leftarrow Rd(n), Rd(0) \leftarrow 0$<br>$Rd(n) \leftarrow Rd(n+1), Rd(7) \leftarrow 0$       | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,Ø,Z,C                                                                              | 1       |
| ROL          | Rd             | キャリーを含めた左回転                                                                                 | $Rd(n) \leftarrow Rd(n+1)$ , $Rd(n) \leftarrow C$<br>$Rd(n+1) \leftarrow Rd(n)$ , $C \leftarrow Rd(7)$ | I,T,H,S,V,N,Z,C                                                                                                 | 1       |
| ROR          | Rd             | キャリーを含めた右回転                                                                                 | $Rd(7) \leftarrow C, Rd(n) \leftarrow Rd(n+1), C \leftarrow Rd(0)$                                     | I,T,H,S,V,N,Z,C                                                                                                 |         |
| 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<br>BCLR | S<br>S         | ステータス レジスタのビット設定(1)<br>ステータス レジスタのビット解除(0)                                                  | $SREG(s) \leftarrow 1$ $SREG(s) \leftarrow 0$                                                          | $1,T,H,\$,\Upsilon,\Lambda,\mathfrak{I},\mathfrak{T}$ $0,0,H,\theta,0,\mathfrak{O},\mathfrak{O},\mathfrak{O},0$ | 1       |
| BST          | Rr,b           | 汎用レジスタのビットを一時フラグへ移動                                                                         | $T \leftarrow Rr(b)$                                                                                   | I,T,H,S,V,N,Z,C                                                                                                 | 1       |
| BLD          | Rd,b           | 一時フラグを汎用レジスタのビットへ移動                                                                         | $Rd(b) \leftarrow T$                                                                                   | I,T,H,S,V,N,Z,C                                                                                                 | 1       |
| SEC          |                | キャリー フラグを設定(1)                                                                              | C ← 1                                                                                                  | I,T,H,S,V,N,Z,C                                                                                                 | 1       |
| CLC          |                | キャリー フラグを解除(0)                                                                              | $C \leftarrow 0$                                                                                       | I,T,H,S,V,N,Z,0                                                                                                 | 1       |
| SEN<br>CLN   |                | 負フラグを設定(1)<br>負フラグを解除(0)                                                                    | $ \begin{array}{l} N \leftarrow 1 \\ N \leftarrow 0 \end{array} $                                      | I,T,H,S,V, <b>1</b> ,Z,C<br>I,T,H,S,V, <b>0</b> ,Z,C                                                            | 1       |
| SEZ          |                | (頁/// を呼哧(U)<br>でロフラグを設定(1)                                                                 | $Z \leftarrow 1$                                                                                       | I,T,H,S,V,N,Z,C                                                                                                 | 1       |
| CLZ          |                | セ゛ロ フラク゛を解除(0)                                                                              | $Z \leftarrow 0$                                                                                       | I,T,H,S,V,N,Ø,C                                                                                                 | 1       |
| SEI          |                | 全割り込み許可                                                                                     | I ← 1                                                                                                  | 1,T,H,S,V,N,Z,C                                                                                                 | 1       |
| CLI          |                | 全割り込み禁止                                                                                     | $I \leftarrow 0$                                                                                       | <b>0</b> ,T,H,S,V,N,Z,C                                                                                         | 1       |
| SES<br>CLS   |                | 符号フラグを設定(1)<br>符号フラグを解除(0)                                                                  | $ \begin{array}{c} S \leftarrow 1 \\ S \leftarrow 0 \end{array} $                                      | I,T,H,\$,V,N,Z,C<br>I,T,H, <b>0</b> ,V,N,Z,C                                                                    | 1       |
| SEV          |                | 行 5 / 7 / を 呼 (M)   2 の 補 数 溢 れ フラケ を 設 定 (1)                                               | V ← 1                                                                                                  | I,T,H,S,Y,N,Z,C                                                                                                 | 1       |
| CLV          |                | 2の補数溢れフラグを解除(0)                                                                             | V ← 0                                                                                                  | I,T,H,S, <b>0</b> ,N,Z,C                                                                                        | 1       |
| SET          |                | 一時フラグを設定(1)                                                                                 | T ← 1                                                                                                  | I,T,H,S,V,N,Z,C                                                                                                 | 1       |
| CLT          |                | 一時フラグを解除(0)                                                                                 | $T \leftarrow 0$                                                                                       | I, <b>0</b> ,H,S,V,N,Z,C                                                                                        | 1       |
| SEH<br>CLH   |                | ハーフキャリー フラグを設定(1)<br>ハーフキャリー フラグを解除(0)                                                      | $\begin{array}{c} H \leftarrow 1 \\ H \leftarrow 0 \end{array}$                                        | I,T,ℍ,S,V,N,Z,C<br>I,T, <b>ω</b> ,S,V,N,Z,C                                                                     | 1       |
| CLH          |                |                                                                                             | <u>  H ← 0                                 </u>                                                        | 1, 1, M,S, V,N,Z,C                                                                                              | 1       |
| NOP          |                | 無操作                                                                                         | 1 hels with [1]                                                                                        | I,T,H,S,V,N,Z,C                                                                                                 | 1       |
| SLEEP        |                | 休止形態開始                                                                                      | 休止形態参照                                                                                                 | I,T,H,S,V,N,Z,C                                                                                                 | 1       |
|              |                | ウェニエビニが カノコ IIカニl                                                                           | ウォッチドッグタイマ参照                                                                                           | I,T,H,S,V,N,Z,C                                                                                                 | 1       |
| WDR<br>BREAK |                | ウォッチドッグ タイマ リセット<br>  一時停止                                                                  | 内蔵デバッグWIRE機能専用                                                                                         | I, T, H, S, V, N, Z, C                                                                                          | N/A     |





### 注文情報

| 速度(MHz)          | 電源電圧     | 注文コート (注2,4)      | 外囲器  | 動作範囲              |
|------------------|----------|-------------------|------|-------------------|
| 10 (注3)          | 1.8∼5.5V | ATtiny2313V-10PU  | 20P3 | 工業用<br>(-40℃~85℃) |
|                  |          | ATtiny2313V-10SU  | 20S  |                   |
|                  |          | ATtiny2313V-10SUR |      |                   |
|                  |          | ATtiny2313V-10MU  | 20M1 |                   |
|                  |          | ATtiny2313V-10MUR |      |                   |
| 20 ( <b>注3</b> ) | 2.7~5.5V | ATtiny2313-20PU   | 20P3 |                   |
|                  |          | ATtiny2313-20SU   | 20S  |                   |
|                  |          | ATtiny2313-20SUR  |      |                   |
|                  |          | ATtiny2313-20MU   | 20M1 |                   |
|                  |          | ATtiny2313-20MUR  |      |                   |

注: このデバイスはウェハー(チップ<sup>°</sup>単体)形状でも供給できます。最低数量と詳細な注文情報については最寄のAtmel営業所へお問い合わせください。

注2: 有害物質使用制限に関する欧州指令(RoHS指令)適合の鉛フリー製品。またハロゲン化合物フリーで完全に安全です。

注3: 速度と電源電圧の関係については119頁の図82.と図83.をご覧ください。

注4: 符号は以下を示します。

U:半光沢錫R:テープとリール

|      | 外囲器形式                                                 |
|------|-------------------------------------------------------|
| 20P3 | 20ピン 300mil幅 プラスティック2列直線外囲器 (PDIP)                    |
| 20S  | 20リート、300mil幅 プラスティック小外形外囲器 (SOIC)                    |
| 20M1 | 20パッド4×4×0.8mm 0.5mmピッチ 4方向平板リードなし/小リード枠外囲器 (QFN/MLF) |

### 外囲器情報









### データシート改訂履歴

本章内の参照頁番号は本文書が参照されることに注意してください。本章内の改訂番号は資料の改訂番号を参照してください。

### 改訂2543A - 2003年9月

1. 初版

### 改訂2543B - 2003年9月

- 1. 1頁の「特徴」でUARTをUSARTに修正、動作速度と消費電力を更新
- 2. 2頁の「ピン配置」を更新
- 3. 119頁の表79.と120頁の表80.を更新
- 4. 115頁の「**直列プログラミング手順**」で項目5.を更新
- 5. 118頁の「電気的特性」を更新
- 6. 119頁の図82.を更新、図83.を追加
- 7. 141頁の「レシ、スタ要約」でSFIORをGTCCRに変更
- 8. 144頁の「注文情報」を更新
- 9. 148頁の「障害情報」に新規障害を追加

### 改訂2543C - 2003年12月

1. 18頁の「校正付き内蔵RC発振器」を更新

### 改訂2543D - 2004年3月

- 1. 16頁の表2.を更新
- 2. 26頁からの「ウォッチト、ック、タイマ」を置換
- 3. 119頁に「最高速と動作電圧」を追加
- 4. 115頁の「**直列プログラミング手順**」を更新
- 5. 138頁の暫定図136.でmAをμAに変更
- 6. 144頁の「注文情報」を更新(MLF外囲器選択を削除)
- 7. 145頁の「**外囲器情報**」で「20P3」を更新
- 8. Cコート 例を更新
- 9. 自己プログラミング許可のSPMENをSELFPRGENに改名

### 改訂2543E - 2004年4月

- 1. 最大動作速度を変更
  - ・12MHzを10MHzへ
- ・24MHzを20MHzへ
- 2. 2頁の「t°ン配置」で図を更新
- 3. 144頁の「注文情報」を更新
- 4. 119頁に「最高速と動作電圧」を更新
- 5. 121頁からの「代表特性」を更新

### 改訂2543F - 2004年8月

- 1. 1頁の「特徴」を更新
- **2**. 35頁の「ポートBの交換機能」を更新
- 3. 106頁の「校正バイ」を更新
- 4. 107頁の表68.と表69.を「ページ容量」節内へ移動
- 5. 109頁の「**並列プログラミング動作への移行**」を更新
- 6. 115頁の「**直列プログラミング手順**」を更新
- 7. 116頁の表77.を更新
- 8. 118頁の「DC特性」を更新
- 9. 121頁からの「代表特性」を更新
- 10. PCINT15をPCINT7、EEMWEをEEMPE、EEWEをEEPEへ変更

### 改訂2543G - 2004年10月

- 1. 1頁の「特徴」を更新
- **2**. 2頁の「**ピン配置**」を更新
- 3. 144頁の「注文情報」を更新

- 4. 145頁の「外囲器情報」を更新
- 5. 148頁の「障害情報」を更新

### 改訂2543H - 2005年2月

- 1. 18頁の表6.、107頁の表67.、119頁の表79.、120頁の表80.を更新
- **2**. 16頁の「**既定のクロック元**」でCKSEL既定値を8MHzに変更
- 3. 144頁の「注文情報」を更新
- 4. 119頁の「プログラミング動作への移行」、110頁の「フラッシュ メモリ書き込み」、111頁の「EEPROM書き込み」を更新
- 5. MLF外囲器を"4方向平板リートなし/小リート"枠外囲器(QFN/MLF)"に更新

### 改訂2543I - 2006年4月

- 1. 誤植修正
- 2. 2頁の「ピン配置」を更新
- 3. 5頁に「資料」を追加
- 4. 16頁の「既定のクロック元」を更新
- 5. 19頁の「128kHz内部発振器」を更新
- 6. 21頁の「電力管理と休止形態」を更新
- 7. 16頁の表3.、21頁の表13.、22頁の表14.、28頁の表18.、40頁の表30.、117頁の表78.を更新
- 8. 40頁の「外部割り込み」を更新
- 9. 41頁の「ビット7~0 PCINT7~0: ピン変化割り込み7~0許可」を更新
- 10. 100頁の「ビット6 ACBG: 内部基準電圧選択」を更新
- 11. 106頁の「校正バ仆」を更新
- 12. 118頁の「DC特性」を更新
- 13. 141頁のレジスタ要約」を更新
- 14. 144頁の「注文情報」を更新
- 15. OCnA, OCnB, OC1xの存在を各々OCFnA, OCFnB, OCF1xへ変更

### 改訂2543J - 2009年11月

- 1. 雛形更新
- 2. デバイス状況を"新規設計に推奨されません"に変更
- 3. 8頁の「スタック ポインタ」を更新
- 4. 21頁の「表13. 休止形態種別選択」を更新
- 5. 107頁の「校正バイト」を(1バイトの校正データに)更新

### 改訂2543K - 2010年3月

1. 148頁の「障害情報」に改訂Cデバイスの"既知の障害はありません"を追加

### 改訂2543L - 2010年8月

- 1. 表紙から"新規設計に推奨されません"の文章を削除
- 2. 144頁の「注文情報」にテープとリール品の番号を追加
- 3. データシート改訂履歴で文献番号不一致を修正

#### 改訂2543M - 2016年10月

- 1. 表紙からデバイス状況の"暫定"を削除
- 2. 5頁に「データ保持力」を追加
- 3. 18頁の表7.と19頁の表11.を更新
- 4. 23頁の図14.を更新(訳注:実際には無変化)
- 5. リセット特性表を23頁の「リセット元」項から「電気的特性」章で117頁の新「システムとリセットの特性」項へ移動して更新
- **6**. 28頁の「ウォッチト`ック゛タイマ制御/状態レジ、スタ WDTCSR」表題を更新
- 7. 107頁の表67.を更新
- 8. 113頁の「識票バ小読み出し」を更新
- 9. 115頁の図78.を更新
- 10. 136頁の図128.を更新
- 11. 裏表紙を更新





障害情報 この章の改訂番号はATtiny2313デバイスの改訂版を参照してください。

改訂A

改訂A版は試供されていません。

改訂B ・単独消去操作後の不正値読み込み

> ・並列プログラミングが動作しない ・ウォッチト、ック、タイマ割り込みが禁止

В В

・1.9V未満でのEEPROM書き込み不可

改訂C 既知の障害はありません。

### 1. 単独消去操作後の不正値読み込み(B)

2.7V以下の電圧印加に於いて、消去操作のみで消去されたEEPROM位置はプログラム(\$00)として読むかも しれません。

В

В

#### 対策/対処

単独消去後にEEPROM位置を読む必要がある場合、その位置を消去するために値として\$FFの非分離書 き込みを使ってください。どんな場合も単独書き込み操作は予定どおりに使えます。 従って消去された位置 がプログラミング以前に読まれない限り、特別な考慮の必要はありません。

#### 2. 並列プログラミングが動作しない(B)

並列プログラムは正常に機能しません。この理由は次の動作種別の1つが選択された場合にデバイスの再プロ グラミングが不可能になるからです。

- 実装書き込み(直列プログラミング)禁止(SPIEN=非プログラム(1))
- ・リセット禁止 (RSTDISBL=プログラム(0))

### 対策/対処

直列プログラミングは正しく動きます。上の2つの動作種別を避ける事により、デバイスは直列で再プログラミングで きます。

### 3. ウォッチト、ッグ タイマ割り込みが禁止(B)

ウォッチト、ック、タイマ割り込み要求フラク、(WDIF)が次の計時完了発生に先立って解除(O)されなければウォッチト、ック、 が禁止され、割り込み要求フラグは自動的に解除(0)されます。これは割り込みのみの動作種別にだけ当ては まります。ウォッチドッグ計時完了に続く割り込みでウォッチドッグがデバイス リセットに設定されれば、デバイスは正しく 動作します。

### 対策/対処

次のウォッチドッグ計時完了が起こる前に、先行する計時完了発生での処理が常に充分な時間であることに注 意してください。これは充分に長い計時完了周期を選択することによって行われます。

#### 4. 1.9V未満でのEEPROM書き込み不可(B)

1.9V未満のVCCでのEEPROM書き込みは失敗するかもしれません。

#### 対策/対処

VCCが1.9V未満の時はEEPROMを書かないでください。

# 目次

| 特徴 ・・・・・・・ 1                                      | タイマ/カウンタの          |
|---------------------------------------------------|--------------------|
| ピン配置 ······ 2                                     | 8ビット <b>タイマ</b> /フ |
| 概要                                                | タイマ/カウンタ0とタイ       |
| 構成図 ・・・・・・・・・・・・・・・・・・・・・・・3                      | 16ビット タイマ/カウン      |
| t <sup>2</sup> ン説明 ······ 4                       | 概要・・・・・            |
|                                                   | 16ビットレジス           |
| 一般情報 5                                            | タイマ/カウンタの          |
| 資料 ······ 5                                       | 計数器部・              |
| コート 例 ・・・・・・・・・・・・・・・・・ 5                         | 捕獲入力部              |
| データ保持力 ・・・・・・・・・・・・・・・・・・・ 5                      | 比較出力部              |
| AVR CPU 17 · · · · · 6                            | 比較一致出              |
| 序説6                                               | 動作種別 •             |
| <b>構造概要 · · · · · · · · · · · · · · · · · · ·</b> | タイマ/カウンタの          |
| ALU (Arithmetic Logic Unit) ••••• 6               | 16ビット タイマ          |
| ステータス レジスタ・・・・・・・・・・・・・・・・ 7                      | USART · · · · · ·  |
| 汎用レジスタファイル・・・・・・・・・8                              | 概要 ••••            |
| スタック ホペインタ ・・・・・・・・・・・・・・・・・・ 8                   | クロック生成・            |
| 命令実行タイミング・・・・・・・・・・・・・・・・・9                       | フレーム形式・            |
| リセットと割り込みの扱い・・・・・・・・・・・・9                         | USARTの初            |
| AVR ATtiny2313のメモリ ・・・・・・・・11                     | USARTのデ            |
| 実装書き換え可能なプログラム用フラッシュ メモリ ・・・ 11                   | USARTのデ            |
| データ用SRAMメモリ ・・・・・・・・・・・・・・・11                     | 非同期受信              |
| <b>データ用EEPROMメモリ・・・・・・・・・・・・・・・</b> 12            | 複数プロセッサ            |
| I/Oメモリ (レジスタ) ・・・・・・・・・・・15                       | USART用い            |
| システム クロックとクロック選択 ・・・・・・・・・ 16                     | ホーレート設定            |
| クロック系統とその配給 ・・・・・・・・・ 16                          | 多用途直列インタ           |
| <b>クロック元 ・・・・・・・・・・・・・・・</b> 16                   | タルが直が177           |
| 既定のクロック元 ・・・・・・・・・・・・ 16                          | 機能説明・              |
| クリスタル用発振器 ・・・・・・・・・・・・・・・・・ 17                    | 版形説明<br>USIでの代替    |
| 校正付き内蔵RC発振器 ・・・・・・・・・ 18                          | USI用レジスタ           |
| 外部クロック信号 ・・・・・・・・・・・・ 19                          |                    |
| 1 <b>28kHz内部発振器 ······</b> 19                     | アナログ比較器・・          |
| システム クロック前置分周器 ・・・・・・・・・・・・ 20                    | テ゛ハ゛ック゛WIRE内i      |
| 電力管理と休止形態 ・・・・・・・・・・ 21                           | 特徴・・・・             |
| <b>アイドル動作 ・・・・・・・・・・・・・・・</b> 21                  | 概要 ••••            |
| <b>パワーダウン動作 ・・・・・・・・・・・・・</b> 21                  | 物理インターフ            |
| <b>スタンバイ動作 ・・・・・・・・・・・・・・・</b> 22                 | ソフトウェア中圏           |
| 消費電力の最小化 ・・・・・・・・・・・ 22                           | テ゛ハ゛ック゛WIRE        |
| システム制御とリセット ・・・・・・・・・・・ 23                        | デバックWIRE           |
| <b>内部基準電圧 ・・・・・・・・・・・</b> 25                      | フラッシュの自己プロ         |
| <u> </u>                                          | 自己プログラ             |
| 割り込み ・・・・・・ 29                                    | メモリ フ゜ロク゛ラミンク゛     |
| ATtiny2313の割り込みベクタ ・・・・・・ 29                      | プログラム メモリ          |
| 入出力ポート ····· 30                                   | ヒュース゛ヒ゛ット          |
| 序説30                                              | 識票バイト ・            |
| 標準デジタル入出力としてのポート・・・・・・・・・・30                      | 校正バイト              |
| 交換ポート機能 ・・・・・・・・・・・・・・・・・・・・33                    | ページ容量・             |
| 1/0ポート用レジスタ ・・・・・・・・・・・・39                        | 並列プログラミ            |
| 外部割り込み ············ 40                            | 並列プログラミ            |
| ピン変化割り込みタイミング・・・・・・・・・・ 40                        | 直列プログラ             |
|                                                   | 電気的特性 • • •        |
| 8ビット タイマ/カウンタ0 (PWM) ・・・・・・・・・ 42                 | 絶対最大定              |
| 概要                                                | DC特性···            |
| タイマ/カウンタのクロック ・・・・・・・・・・・・・・・・・・43                | 外部クロック特            |
| 計数器部 •••••••••••••••••••43                        | 最高速と動              |
| 比較出力部 •••••••••••• 44                             | システムとリセッ           |
| 比較一致出力部 · · · · · · · · · · · · · · · · 45        | 代表特性 •••••         |
| <b>動作種別 ······</b> 46                             |                    |

| 8ビット タイマ/カウンタ0用レジスタ ・・・・・・・・・                                                                                                                                 | ••• 50                                                                            |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
| タイマ/カウンタ0とタイマ/カウンタ1の前置分周器                                                                                                                                     |                                                                                   |
|                                                                                                                                                               |                                                                                   |
| 16ビット タイマ/カウンタ1 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                          | ••• 56                                                                            |
| 似安<br>16ビット レジスタのアクセス ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                    |                                                                                   |
| 10L γr νγ λγογγγελ · · · · · · · · · · · · · · · · · · ·                                                                                                      | 60                                                                                |
| タイマ/カウンタのクロック・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                              | 60                                                                                |
| 可数命可                                                                                                                                                          | C1                                                                                |
| 比較出力部 ······                                                                                                                                                  | 63                                                                                |
| 比較一致出力部 ·············                                                                                                                                         | 64                                                                                |
|                                                                                                                                                               | 65                                                                                |
| 動作種別 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                                     | 60                                                                                |
| 34 マ/カウンタのタイミング<br>16ビット タイマ/カウンタ1 用レジスタ ・・・・・・・・・・                                                                                                           | 70                                                                                |
| 10C 3F 34 4/ 11/73 1 Hr 2 X3                                                                                                                                  | 70                                                                                |
| USART                                                                                                                                                         | •• 75                                                                             |
| 概要 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                                       | ••• 75                                                                            |
| クロック生成・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                                    | • • • 77                                                                          |
| フレーム形式・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                                    | ••• 78                                                                            |
| USARTの初期化 · · · · · · · · · · · · · · · · · · ·                                                                                                               | ••• 79                                                                            |
| USARTのデータ送信・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                               | ••• 80                                                                            |
| USARTのデータ受信・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                               | ••• 81                                                                            |
| 非同期受信 ••••••                                                                                                                                                  | ••• 84                                                                            |
| 複数プロセッサ通信動作・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                               | ••• 86                                                                            |
| USART用レジスタ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                                | • • • 87                                                                          |
| * * - レート設定例 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                             | ••• 90                                                                            |
| 多用途直列インターフェース (USI) ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                      | •• 92                                                                             |
| 概要                                                                                                                                                            | ••• 92                                                                            |
| 機能説明 ••••••                                                                                                                                                   | ••• 93                                                                            |
| USIでの代替使用 ·······                                                                                                                                             | ••• 96                                                                            |
| USI用レジスタ ·······                                                                                                                                              |                                                                                   |
| アナログ比較器・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                                   |                                                                                   |
| デバッグWIRE内蔵デバッグ機能 ・・・・・・・・・                                                                                                                                    | <b>•</b> 102                                                                      |
| 特徴 ····································                                                                                                                       | •• 102                                                                            |
| Low                                                                                                                                                           | 100                                                                               |
| 概要 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                                       | •• 102                                                                            |
| 概要・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                                        | · 102 · 102                                                                       |
| 物理インターフェース ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                               | · · 102                                                                           |
| 物理インターフェース ・・・・・・・・・ソフトウェア中断点 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                            | <ul><li>102</li><li>102</li><li>102</li></ul>                                     |
| 物理インターフェース ・・・・・・・・・ソフトウェア中断点 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                            | <ul><li>102</li><li>102</li><li>102</li></ul>                                     |
| 物理インターフェース・・・・・・・・ソフトウェア中断点・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                               | <ul><li>102</li><li>102</li><li>102</li><li>102</li></ul>                         |
| 物理インターフェース・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                                 | <ul><li>102</li><li>102</li><li>102</li><li>102</li><li>103</li></ul>             |
| 物理インターフェース ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                               | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li></ul>             |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 デバック・WIREの制限 デバック・WIRE関連のI/Oメモリ内レシ・スタ・・・・ フラッシュの自己プログ・ラミング・・・・・ 自己プログ・ラミング・でのフラッシュアト・レス指定・メモリフプログ・ラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |
| 物理インターフェース ソフトウェア中断点 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                     | <ul><li>102</li><li>102</li><li>102</li><li>103</li><li>103</li><li>106</li></ul> |





| 沽動動作消費電流 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・           |      |
|---------------------------------------------------------|------|
| アイドル動作消費電流 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・         | 123  |
| パワーダウン動作消費電流 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・       | 126  |
| スタンバイ動作消費電流・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・         | 126  |
| ヒップルアップ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・               | 127  |
| ピン駆動能力・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・              |      |
| ピン 閾値とヒステリシス・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・         |      |
| 低電圧検出器(BOD)閾値と                                          |      |
| 低電圧検出器(BOD)閾値と<br>アナログ・比較器オフセット                         | 135  |
| 内部発振器周波数 ••••••                                         | 136  |
| 周辺機能部消費電流 ••••••                                        |      |
| リセット消費電流とリセット パルス幅 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ |      |
| レジスタ要約・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・              | 141  |
| <b>レノ ヘン女 小」・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・</b>    |      |
| 命令要約 ••••••                                             | 142  |
| 注文情報 ************************************               | 144  |
| 外囲器情報 · · · · · · · · · · · · · · · · · · ·             | 145  |
|                                                         |      |
| データシート改訂履歴 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・         | 146  |
| 陪宇桂起                                                    | 1/10 |













Atmel Corporation 1600 Technology Drive, San Jose, CA 95110 USA TEL:(+1)(408) 441-0311 FAX: (+1)(408) 436-4200 www.atmel.com

© 2016 Atmel Corporation. / 改訂:Atmel-2543M-ATtiny2313\_Datasheet\_Complete-10/2016

Atmel®、Atmelロでとそれらの組み合わせ、Enabling Unlimited Possilities®、AVR®とその他は米国及び他の国に於けるAtmel Corporationの登録商 標または商標です。他の用語と製品名は一般的に他の商標です。

お断り: 本資料内の情報はAtmel製品と関連して提供されています。本資料またはAtmel製品の販売と関連して承諾される何れの知的所有権も禁 反言あるいはその逆によって明示的または暗示的に承諾されるものではありません。Atmelのウェブサ仆に位置する販売の条件とAtmelの定義での 詳しい説明を除いて、商品性、特定目的に関する適合性、または適法性の暗黙保証に制限せず、Atmelはそれらを含むその製品に関連する暗示 的、明示的または法令による如何なる保証も否認し、何ら責任がないと認識します。たとえAtmelがそのような損害賠償の可能性を進言されたとし ても、本資料を使用できない、または使用以外で発生する(情報の損失、事業中断、または利益と損失に関する制限なしの損害賠償を含み)直 接、間接、必然、偶然、特別、または付随して起こる如何なる損害賠償に対しても決してAtmelに責任がないでしょう。Atmelは本資料の内容の正 確さまたは完全性に関して断言または保証を行わず、予告なしでいつでも製品内容と仕様の変更を行う権利を保留します。Atmelはここに含まれた 情報を更新することに対してどんな公約も行いません。特に別の方法で提供されなければ、Atmel製品は車載応用に対して適当ではなく、使用さ れるべきではありません。Atmel製品は延命または生命維持を意図した応用での部品としての使用に対して意図、認定、または保証されません。

安全重視、軍用、車載応用のお断り: Atmel製品はAtmelが提供する特別に書かれた承諾を除き、そのような製品の機能不全が著しく人に危害を 加えたり死に至らしめることがかなり予期されるどんな応用("安全重視応用")に対しても設計されず、またそれらとの接続にも使用されません。安全 重視応用は限定なしで、生命維持装置とシステム、核施設と武器システムの操作用の装置やシステムを含みます。Atmelによって軍用等級として特に明確 に示される以外、Atmel製品は軍用や航空宇宙の応用や環境のために設計も意図もされていません。Atmelによって車載等級として特に明確に示 される以外、Atmel製品は車載応用での使用のために設計も意図もされていません。

#### © HERO 2022.

本データシートはAtmelのATtiny2313英語版データシート(改訂2543M-10/2016)の翻訳日本語版です。日本語では不自然となる重複する形容表現は省 略されている場合があります。日本語では難解となる表現は大幅に意訳されている部分もあります。必要に応じて一部加筆されています。頁割の変 更により、原本より頁数が少なくなっています。

汎用入出力ポートの出力データレジ、スタとピン入力は、対応関係からの理解の容易さから出力レジ、スタと入力レジ、スタで統一表現されています。一部の用 語がより適切と思われる名称に変更されています。必要と思われる部分には()内に英語表記や略称などを残す形で表記しています。

青字の部分はリンクとなっています。一般的に赤字の0.1は論理0.1を表します。その他の赤字は重要な部分を表します。