# 特徴

- 高性能、低消費AVR® 8ビット マイクロ コントローラ
- 進化したRISC構造
  - ・強力な123命令(多くは1周期実行)
  - ・32個の1バイト長汎用レジスタ
  - ・完全なスタティック動作
- データ メモリと不揮発性プログラム メモリ
  - ・実装書き換え可能な4Kバイト(2K語)フラッシュ メモリ内蔵
  - 64バイトのEEPROM
  - 256バイの内蔵SRAM
  - ・書き換え回数: 10,000/フラッシュ, 100,000/EEPROM
  - ・ データ保持力: 20年/85℃, 100年/25℃
  - ・ソフトウェア保護用の設定可能な施錠機能

#### ■ 内蔵周辺機能

- 容量性接触感知(8チャネル)に対するQTouch®ライブラリ支援
- ・各々2つのPWM出力付き、2つの8ビット タイマ/カウンタ
- ・設定可能な内蔵発振器付きウォッチドッグタイマ
- ・アナログ比較器
- ・10ビット A/D変換器
  - ・ 4つのシングル エント チャネル
- ・多用途直列インターフェース(USI)
- 昇圧変換器

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

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

# ■ I/Oと外囲器

- ・20リート、SOIC、20ハット、QFN/MLFが利用可能
- ・16ビットの設定変更可能なI/O

#### ■ 動作電圧

- 0.7~1.8V(内蔵昇圧変換器経由)
- · 1.8~5.5V (昇圧変換器迂回)

# ■ 動作速度

- 内蔵昇圧変換器使用
  - 0∼4MHz
- 外部電源
  - $\cdot 0 \sim 4 \text{MHz} / 1.8 \sim 5.5 \text{V}$
  - $0 \sim 8 \text{MHz} / 2.7 \sim 5.5 \text{V}$

### ■ 低消費電力

- ・活動動作 (1MHz,昇圧変換器なし):
  - 400µA (3V)
- ・パワーダウン動作(昇圧変換器なし):
  - 150 nA (3V)





8ビット **AV** 『マイクロ コントローラ 実装書き換え可能な 4 K バイト フラッシュ メモリ、 昇圧変換器内蔵

ATtiny43U

Rev. 8048C-02/12, 8048CJ3-04/22





# 1. ピン配置



# 1.1. ピン概要

### 1.1.1. VCC

電源ピン。

# 1.1.2. GND

接地ピン。

#### 1.1.3. PA7~PA0 (ホートA)

ポートAは(ビット単位で選択される)内蔵プルアップ抵抗付きの8ビット双方向入出力ポートです。RESET能力を持つPA7を除いて、ポートA出力緩衝部は共に高い吐き出し/吸い込み能力の対称駆動特性です。PA7ピンをRESETの代わりにI/Oピンとして使うには、RSTDISBL ヒューズをプログラム(0)にしてください。入力のとき、プルアップ抵抗が有効の場合、外部的にLowへ引き込まれたポートAピンには吐き出し電流が流れます。リセット条件が有効になると、クロックが走行していなくても、ポートAピンはHi-Zにされます。

ポートAには45頁の「ホートAの交換機能」で示されるA/D変換器とアナログ比較器用のアナログ入力、ピン変化割り込みとしての交換機能があります。

# 1.1.4. RESET

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

#### 1.1.5. PB3~PB0 (本°-トB)

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

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

### 1.1.6. LSW

昇圧変換器外部インダクタ接続。昇圧変換器が恒久的に禁止される時はGNDに接続してください。

### 1.1.7. VBAT

電池供給電圧。昇圧変換器が恒久的に禁止される時はGNDに接続してください。

# 2. 概要

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







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

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

ATtiny43Uの特殊機能は外部の低い電圧から3Vの供給電圧を提供する組み込み昇圧変換器です。

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

# 3. 一般情報

# 3.1. 資料

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

# 3.2. コート 例

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

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

### 3.3. 容量性接触感知

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

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

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

# 3.4. データ保持力

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

# 4. AVR CPU コア

#### 4.1. 序説

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

# 4.2.構造概要

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

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

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

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

プログラムの流れは条件/無条件分岐や呼び出し命令によって提供され、全アトレス空間を直接アトレス指定できます。 殆どのAVR命令は16ビット語(ワード)形式ですが、32ビット命令もあります。

図4-1. AVR構造構成図 8-bit Data Bus プログラム 状態/制御 割り込み部 カウンタ SPI部 プログラム用  $32 \times 8$ ウォッチトック フラッシュ メモリ 汎用レジスタ 接 タイマ 命令レジスタ アナログ ALU 比較器 バドレス指 直 接 命令復号器 ◆ 周辺機能部 1 データ用 **SRAM** → 周辺機能部 2 シアド 制御信号線 **EEPROM** え 指定 汎用入出力部 **→** 周辺機能部 n

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

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

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

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

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

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





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

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

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

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

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

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

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

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

#### ■ ビット6 - T: ビット変数 (Bit Copy Storage)

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

#### 

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

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

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

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

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

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

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

#### **■ L**'y**\1** - **Z** : **t**'**D 750**' (Zero Flag)

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

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

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

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

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

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

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

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

| <b>図4-2</b> . <i>F</i> | AVR CPU 汎用レジスタ | 構成凶      |                      |
|------------------------|----------------|----------|----------------------|
|                        | 7              | )_ アト・レス |                      |
|                        | R0             | \$00     |                      |
|                        | R1             | \$01     |                      |
|                        | R2             | \$02     |                      |
|                        | >              |          |                      |
|                        | R13            | \$0D     |                      |
|                        | R14            | \$0E     |                      |
| >H H                   | R15            | \$0F     |                      |
| 汎用<br>レシブスタ<br>ファイル    | R16            | \$10     |                      |
|                        | R17            | \$11     |                      |
| × ) (/·                | ₹              |          |                      |
|                        | R26            | \$1A     | Xレジスタ 下位バイト<br>上位バイト |
|                        | R27            | \$1B     | 上位が小                 |
|                        | R28            | \$1C     | Yレジスター 下位バイト         |
|                        | R29            | \$1D     | 上ルハル                 |
|                        | R30            | \$1E     | Zレジスター 下位バイト         |
|                        | R31            | \$1F     | 上位バイ                 |

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

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

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

| ジスタ構 | 成図                 |                                            |                                                                                |                                                                                                                                                                                                                          |
|------|--------------------|--------------------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | XH (上位)            |                                            | XL (下位)                                                                        | 0                                                                                                                                                                                                                        |
| 7    | R27 (\$1B)         | 0 7                                        | R26 (\$1A)                                                                     | 0                                                                                                                                                                                                                        |
| 15   | YH (上位)            |                                            | YL (下位)                                                                        | 0                                                                                                                                                                                                                        |
| 7    | R29 (\$1D)         | 0 7                                        | R28 (\$1C)                                                                     | 0                                                                                                                                                                                                                        |
| 15   | ZH (上位)            |                                            | ZL (下位)                                                                        | 0                                                                                                                                                                                                                        |
| 7    | R31 (\$1F)         | 0 7                                        | R30 (\$1E)                                                                     | 0                                                                                                                                                                                                                        |
|      | 15<br>7<br>15<br>7 | 7 R27 (\$1B)<br>15 YH (上位)<br>7 R29 (\$1D) | 15 XH (上位)<br>7 R27 (\$1B) 0 7<br>15 YH (上位)<br>7 R29 (\$1D) 0 7<br>15 ZH (上位) | 15       XH (上位)       XL (下位)         7       R27 (\$1B)       0 7       R26 (\$1A)         15       YH (上位)       YL (下位)         7       R29 (\$1D)       0 7       R28 (\$1C)         15       ZH (上位)       ZL (下位) |

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

スタックは主に一時データ、局所変数、割り込みとサブルーチン呼び出し後の戻りアドレスの保存に使われます。スタック ポインタ レジ スタはサブルーチンや割り込みのスタックが置かれるデータSRAMのスタック領域に於いて、常にこのスタックの先頭(<mark>訳注</mark>:次に使われるべき位置)を指し示します。

データSRAM内のスタック空間はサブルーチン呼び出しの実行や割り込みの許可の何れにも先立ってプログラムによって定義されなければなりません。スタック ポインタはSRAMの先頭以上に設定されなければなりません(10頁の図5-2.をご覧ください)。初期スタック ポインタ値は内部SRAMの最終アドレスと等価です。

スタックが高位メモリから低位メモリへ伸長するように実行されることに注意してください。これはスタックPUSH命令がスタック ポインタを減らすことを意味します。表4-1.をご覧ください。

| 表4-1.   | スタック | ポ <sup>°</sup> イ | ンタ命令      |
|---------|------|------------------|-----------|
| 1X T I. | ハナノノ | ጥገ               | 7 7 HJ 13 |

| 衣4-1. 人グツグ 小 イノブ叩 ヤ |            |                                           |
|---------------------|------------|-------------------------------------------|
| 命令                  | スタック ホ゜インタ | 内容                                        |
| PUSH                | -1         | データがスタック上に押し込まれます。                        |
| (CALL,ICALL,)RCALL  | -2         | サブルーチン呼び出しまたは割り込みでの戻りアドレスがスタック上に押し込まれます。  |
| POP                 | +1         | データがスタックから引き出されます。                        |
| RET,RETI            | +2         | サブルーチンまたは割り込みからの復帰での戻りアドレスがスタックから引き出されます。 |

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





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

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

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

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

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

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





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

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

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

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

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

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

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

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

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

```
アセンブリ言語プログラム例
                                                    ;ステータスレジスタを保存
           IN
                  R16, SREG
           CLI
                                                    ;EEPROM書き込み手順中割り込み禁止
                  EECR, EEMPE
                                                    ;EEPROM主書き込み許可
           SBI
                  EECR, EEPE
                                                    ;EEPROM書き込み開始
           SBT
           OUT
                  SREG, R16
                                                    ;ステータスレジスタを復帰
C言語プログラム例
                                                   /* ステータス レシ スタ保存変数定義 */
           char cSREG;
           cSREG = SREG;
                                                    /* ステータス レシ スタを保存 */
           _CLI() ;
                                                   /* EEPROM書き込み手順中割り込み禁止 */
           EECR \mid = (1 << EEMPE);
                                                   /* EEPROM主書き込み許可 */
                                                   /* EEPROM書き込み開始 */
           EECR = (1 < EEPE);
           SREG = cSREG:
                                                   /* ステータス レシ スタを復帰 */
注: 4頁の「コート・例」をご覧ください。
```

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

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

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

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

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

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

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





# 5. メモリ

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

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

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

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

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



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

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

下位データ メモリ位置はレシ、スタ ファイル、I/Oメモリ、データ用内蔵SRAMを次のように充てます。

- ・先頭の32位置はレジスタファイルに充てます。
- 次の64位置は標準I/Oメモリに充てます。
- ・最後の256位置はデータ用内蔵SRAMに充てます。

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

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

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

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

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

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

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

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

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



# 5.3. データ用EEPROMメモリ

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

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

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

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

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

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

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

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

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

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

### 5.3.4. 消去

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

# 5.3.5. 書き込み

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

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





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

```
アセンブリ言語プログラム例
EEPROM_WR:
                                                     ;EEPROMプログラミング完了ならばスキップ
           SBIC
                  EECR, EEPE
           RJMP
                  EEPROM WR
                                                     ;以前のEEPROMプログラミング完了まで待機
                  R18, (0<<EEPM1) | (0<<EEPM0)
           LDI
                                                     ;プログラミング種別値取得(本例は非分離)
                                                     ;対応プログラミング種別設定
           OUT
                  EECR, R18
           OUT
                  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 = (1 \le EEPE);
}
```

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

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

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

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

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

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

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

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

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

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

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

全ての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命令は指定ビットだけを操作し、従って状態フラグのようなものを含むレジスタに使えることに留意してください。CBIとSBI命令は(I/Oアドレス)\$00~\$1Fのレジスタでのみ動作します。
I/Oと周辺制御レジスタは以降の項で説明されます。

# 5.4.1. 汎用I/Oレジスタ

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

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

# 5.5.1. **EEPROM7**トレス レシ、スタ (EEPROM Address Register) **EEAR**

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

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

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

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

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

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

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

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

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

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

|              |     |       | 1     | ა     | 2     | 1    | 0    |      |
|--------------|-----|-------|-------|-------|-------|------|------|------|
| \$1C (\$3C)  |     | EEPM1 | EEPM0 | EERIE | EEMPE | EEPE | EERE | EECR |
| Read/Write F | R R | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  |      |
| 初期値 (        | 0   | 不定    | 不定    | 0     | 0     | 不定   | 0    |      |

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

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

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

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





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

EEPROMプログラミング種別ビット設定はEEPROMプログラミング許可(EEPE)書き込み時にどのプログラミング動作が起動されるかを定義しま

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

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

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

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

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

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

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

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

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

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

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

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

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

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

| 1 (1)                          |     |       | _      |
|--------------------------------|-----|-------|--------|
| \$14 (\$34) (MSB)              |     | (LSB) | GPIOR1 |
| Read/Write R/W R/W R/W R/W R/W | R/W | R/W   |        |
| 初期値 0 0 0 0 0 0                | 0   | 0     |        |

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

| Read/Write R/W R/W R/W R/W R/W R/W R/W | ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0   | _      |
|----------------------------------------|-------------|-------|-----|-----|-----|-----|-----|-----|-----|--------|
|                                        | \$13 (\$33) | (MSB) |     |     |     |     |     |     |     | GPIOR0 |
| 初期値 0 0 0 0 0 0 0 0                    |             | R/W   | R/W | R/W | R/W | R/W | R/W | R/W | R/W |        |
| 1/3/3/1E                               | 初期値         | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0   |        |

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

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

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



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

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

#### 6.1.2. I/O クロック - clki/O

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

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

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

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

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

#### 6.2. クロック元

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

| 表6-1. クロック種別選択   |                |  |  |  |  |  |  |
|------------------|----------------|--|--|--|--|--|--|
| クロック種別           | CKSEL3~0       |  |  |  |  |  |  |
| 128kHz内部(WDT)発振器 | 0011           |  |  |  |  |  |  |
| 8MHz校正付き内蔵RC発振器  | 0010           |  |  |  |  |  |  |
| 外部クロック信号         | 0000           |  |  |  |  |  |  |
| (予約)             | 0001,0100~1111 |  |  |  |  |  |  |
| → 1 -112°        | クチナット・1        |  |  |  |  |  |  |

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

# 6.2.1. 外部クロック信号

外部クロック元からデバイスを駆動するには、CLKIが**図6-2**.で示されるように駆動されるべきです。外部クロックでデバイスを動かすにはCKSELヒューズが'0000'にプログラム(設定)されなければなりません(表6-2.をご覧ください)。 **ま6-2 外部クロック信号動作** 

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

表6-2. 外部クロック信号動作

 CKSEL3~0
 周波数範囲

 0 0 0 0
 0~8MHz







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

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

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

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

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

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

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

| X : X II C I I I | W. (0) DU MA HA 2011 |
|------------------|----------------------|
| CKSEL3~0         | 公称周波数 (MHz)          |
| 0 0 1 0          | 8.0 (注1)             |
| `                |                      |

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

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

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

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

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

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

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

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

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

# 6.2.3. 128kHz内部発振器

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

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

表6-6. 128kHz内部発振器動作

| CKSEL3~0 | 公称周波数  |
|----------|--------|
| 0 0 1 1  | 128kHz |

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

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

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

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

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

#### 6.2.5. クロック起動手順

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

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

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

ドッグ発振器の周波数は図21-48.と図21-49.で示されるように、電圧と温度に依存します。

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

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

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

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

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

# 6.3.1. 切り替え時間

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

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

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

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

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





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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

# 7.1. 休止形態種別

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

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

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

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

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

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

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

# 7.1.1. アイドル動作

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

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

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

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

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

# 7.1.3. パワーダウン動作

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





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

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

BODが禁止された時の休止形態からの起動時間はリセットからの起動時間と同じになります。これはMCUが命令コードの実行を継続する前にBODが正しく動作するのを保証するためです。

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

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

# 7.3. 電力削減レジスタ

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

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

# 7.4. 消費電力の最小化

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

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

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

# 7.4.2. アナログ比較器

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

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

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

### 7.4.4. 内部基準電圧

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

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

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

# 7.4.6. ホート ピン

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

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





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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

| ピット         | 7    | 6    | 5    | 4 | 3      | 2      | 1     | 0     | _   |
|-------------|------|------|------|---|--------|--------|-------|-------|-----|
| \$00 (\$20) | PRE2 | PRE1 | PRE0 | - | PRTIM1 | PRTIM0 | PRUSI | PRADC | PRR |
| 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~5 - PRE2~0:調和読み込み許可 (Prepared Read Enable)

これらのビットは調和読み込み操作に用いられます。27頁の「昇圧変換器のソフトウェア制御」と31頁の「A/D変換制御/状態レジスタB(AD CSRB)」項をご覧ください。

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

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

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

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

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

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

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

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

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

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

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

# 8. 電源と内蔵昇圧変換器

マイクロ コントローラを正しく動かすために必要とする代表的な供給電圧を2または3つの電池セルよりも少ない電池パックによって提供することはできません。これは大きさ、費用、設計の複雑さの増加を強制します。ATtiny32Uの統合された昇圧変換器はデバイスの最低供給電圧と、標準マンガン、アルカリ、リチウム、ニッカド(NiCd)、ニッケル水素(NiMH)単セルの代表的な出力電圧間の溝を橋渡しします。昇圧変換器は1Vよりもっと下の供給電圧の供給元からの給電をデバイスに許します。

昇圧変換器の使用を図解する構成図が下の図8-1.で示されます。



### 8.1. 概要

昇圧変換器はDC電圧をより高いレベルに変換する装置です。ATtiny43Uの統合された昇圧変換器は、より低い電圧の外部供給元から生成した固定の供給電圧を持つマイクロコントローラ(とその周辺機能部)を提供します。

ATtiny43Uの昇圧変換器は外部のインダクタ、ダイオード、(雑音)迂回コンデンサを使うスイッチング型昇圧変換器です。この昇圧変換器は自己完結、完全独立で、MCUからのどんな制御も必要としません。変換器はVBATピンに充分な電圧があれば直ぐ、自動的に始めます。電気的特性については105頁の表20-7.をご覧ください。

32頁の「システム制御とリセット」で記述されるように、マイクロコントローラは昇圧変換器で調整した電圧が電源ONまたは(許可ならば)低電圧検出(Brown-out)のリセットレベル以上に上昇すると直ぐに開始します。MCUがリセットから開放されて動き始めた後、応用ソフトウェアは電池電圧を測定して動作継続に充分な電圧かを判定することができます。

昇圧変換器は外部インダクタのエネルギー充填とエネルギー引き出しを継続的に切り替えます。充電段階中、インダクタを通る電流は変換器の入力電圧によって決められる速度で徐々に上がります。放電段階中、インダクタに充填されたエネルギーが負荷へ放たれ、インダクタの電流は入出力電圧間の差によって決められる速度で徐々に下がります。

昇圧変換器は動作のためにいくつかの外部部品が必要です。部品配置については図8-2.をご覧ください。回路はVIN節点とLSWピン間のインダクタとLSWピンとVCC間のショットキーダイオードの挿入によって完成されます。加えて、入力コンデンサと、VCCからGNDへの外部(雑音)迂回コンデンサが代表的に必要とされます。より多くの詳細については29頁の「特性」をご覧ください。



昇圧変換器が接続されなければ、マイクロ コントローラは外部供給元から直接給電することができ、そして102頁の「**電気的特性**」で定義された標準供給電圧制限に従わなければなりません。

統合された昇圧変換器を使う時に、低電圧検出(BOD)回路を最低BODレベル(1.8V)でだけ使うことが推奨されます。これは通常の動作中にマイクロコントローラの供給電圧が最低BODレベルへ落ち得るからです。33頁の「低電圧(Brown-out)検出」をご覧ください。





# 8.2. 動作の状態

昇圧変換器は停止、開始、活動の3つの主な動作状態を持ちます。動作は停止動作状態から始まり、入力電圧(VBAT)が安定な動作に充分な高さの時に開始動作状態へ移転されます。変換器が出力電圧(VCC)の持続可能なレベルへの引き上げを上手く管理した時に、制御は動作の主形態である活動動作状態へ移転されます。

動作の形態は右の図8-3.で図解されます。



#### 8.2.1. 停止状態

昇圧変換器は入力電圧(VBAT)が動作停止電圧(VSTOP、104頁の表20-7.をご覧ください)以下の時に停止状態(動作形態については図8-3.をご覧ください)へ移行します。また、昇圧変換器はファームウェアによってそのように命令された時にも停止状態へ移行します。この動作形態では昇圧変換器が活動せず、電流消費は最小に減らされます。これは電池の放電を防ぐためと電池の損傷を避けるためです。

この状態での変換器出力の電圧(VCC)は無効です。変換器は入力ピンの電圧(VBAT)を監視し、それが開始電圧(VSTART、105頁の表20-7.をご覧ください)以上に上昇するのを待ちます。この入力で充分な電圧がある時に変換器は停止状態を抜け出して開始状態へ移行します。

### 8.2.2. 開始状態

変換器は入力電圧(VBAT)が開始電圧(VSTART、105頁の表20-7.をご覧ください)以上になると直ぐに停止状態から開始状態(図8-3. をご覧ください)へ切り換わります。また、昇圧変換器は出力電圧がVBOOST以下に落ちる時にも活動状態から開始状態に切り換わります。

この動作形態での昇圧変換器は50%デューティサイクルでの切り替えによってVBOOSTに達するまでVCC電圧を持ち上げます。

この段階中、全ての負荷は切断されるべきです。昇圧変換器は短い瞬間の間、開始状態に留まるように設計されていますが、それは(VCC)線上のマイクロ コントローラを引き上げることだけに最適化されています。VCCピンに接続された追加の負荷がある場合、昇圧変換器は活動状態へ移行するのに必要なVCC電圧に達しないかもしれません。

# 8.2.3. 活動状態

変換器は入力と出力の両電圧が充分高い時に活動動作状態(図8-3.をご覧ください)へ移行します。これはVBATがVSTART以上で 且つVCCがVBOOST以上であることを意味します。入力電圧がVSTOP以下に落ちる、または出力電圧がVBOOST以下に落ちると、変 換器は活動状態を抜け出します。また、ファームウェアは活動状態を抜け出して停止状態へ移行することを変換器に強制することができ ます。

この動作の形態では、エネルギーの充電と放電の段階間のデューティサイクルを継続的に調整することにより、昇圧変換器は105頁の表20-7.で与えられる制限内でVCCを維持します。デューティサイクルは主に入力電圧(VBAT)、負荷電流(ILOAD)と温度によって影響を及ぼされます。

既定によって昇圧変換器は調整活動動作で動作しますが、「出力電圧 対 負荷電流」で説明されるように、負荷電流が充分低い時に低電流活動動作へ移行します。低電流活動動作では出力電圧の安定度を犠牲にして電流消費が最小化にされます。

#### 8.2.4. 例

図8-4.は昇圧変換器の動作状態と入出力電圧を図解します。入力電圧(VBAT)がVSTART(105頁の「**昇圧変換器特性**」をご覧くださ い)以上に上昇する時に変換器が開始状態へ移行し、出力電圧(VCC)は上昇を始めます。VBOOST(点)の出力電圧で変換器は開始 状態を抜け出して活動状態へ移行します。出力電圧が電源ON閾値(VPOT、104頁の「システムとリセットの特性」をご覧ください)を越える と、マイクロコントローラがリセットから開放されます。



入力電圧(VBAT)がVSTOP以下に下がると、変換器は停止状態へ移行し、出力電圧(VCC)が下がり始めます。変換器出力電圧、換 言すると、マイクロコントローラの供給電圧がVPOT以下に下がると、MCUはリセットになります。

図8-5.は昇圧変換器出力が負荷電流でどう変化するかを図解します。変換器出力電圧が電源ON閾値以上へ上昇する時に、マイクロ コントローラはON状態にされ、消費電流は変換器に対して調整活動動作に留まるための充分高いレヘルに上昇します。



圧)は数秒として測定されます。

消費電流がIMS(図8-5.をご覧ください)以下になる時に変換器は調整活動状態から低電流活動状態になります。この後、出力コンデン サの放電時間の長さ、換言すると変換器が切り換えをしない時の間、負荷電流は更に減らされます。同様に、充電時間、換言すると 変換器が切り替える時間はより短くなります。低電流活動状態では上昇/切り替えの傾斜の最後の部分だけが変更されます。

充電時間はデバイスを最大デューティサイクル動作形態(26頁の「最大デューティサイクル」をご覧ください)に強制することによって最小にするこ とができます。

負荷電流がIMS以上に増加すると、変換器は調整活動状態に戻ります。





# 8.3. 出力電圧 対 負荷電流

昇圧変換器の出力電圧は負荷の量とデューティサイクル制御方法に依存します。

活動状態での昇圧変換器は調整動作(活動)状態と低電流動作(活動)状態と呼ばれる2つの副動作状態の1つです。調整動作では安定な出力電圧に重きを置き、一方低電流動作では消費電流の最小化に重きを置きます。変換器はいつも最初に調整動作活動状態へ入り、必要な時に低電流動作へ自動的に切り換わりますが、変換器が常に調整動作活動状態に留まるように応用を設計することが可能です。

昇圧変換器はデューティサイクルが最小に達し、且つ出力電圧が最大に達する時に調整動作活動状態から低電流動作活動状態になります。この時点で変換器は切り換えを停止し、出力電圧は下降を始めます。変換器は出力電圧が低電流動作に対して定義された下限へ下降した時に、再び切り換えを開始します。負荷電流がかなり(充分に)増した場合、変換器は低電流動作活動状態から調整動作活動状態へ戻ります。106頁の図20-4.をご覧ください。

出力電圧がVBOOST以下に落ちた場合に昇圧変換器は開始状態へ戻り、入力電圧がVSTOP以下に落ちた場合、またはファームウェアによってそのように命令された時に停止状態から更に開始します。

#### 8.3.1. 調整動作活動状態

これは活動状態に於ける既定動作方法です。変換器は負荷電流が充分高い場合、この動作に留まります。次の「**低電流動作活動状態**」をご覧ください。

この動作状態では出力電圧が定常的に調整されます。これは 低振幅脈流を持つ安定な出力電圧を意味します。図8-6.と105 頁の表20-7.をご覧ください。

ファームウェアはこの動作を抜け出して停止状態へ移行することを変換器に命令することができます。次頁の「**昇圧変換器のソフトウェア制御**」をご覧ください。



# 8.3.2. 低電流動作活動状態

出力電圧がその最大に達し、且つデューティサイクルが最小の時に昇圧変換器は調整動作活動状態から低電流動作活動状態へ移行します。実際の問題として、これは負荷電流が閾値以下に落ちたことを意味します。閾値は入力電圧と温度で変化しますが、代表的な構図が106頁の図20-4.で示されます。

図20-4.からは低入力電圧(代表的にVBATが1.0V以下)と高負荷電流(代表的にILOADが0.6mA以上)で昇圧変換器が決して低電流動作へ入らないことを見ることができます。最大デューティサイクル動作を使って、図20-4.で示されるそれらよりも低い入力電圧で低電流動作へ移行することを昇圧変換器に強制することができます。次の「最大デューティサイクル」をご覧ください。

低電流動作では昇圧変換器が切り替えを停止して消費電流を最小に減らし、一方で未だ活動状態に留まります。活動する外部負荷がなければ、マイクロコントローラがパプーダウン動作(19頁の「休止形態種別」をご覧ください)になる時に昇圧変換器は自動的に低電流動作へ移行します。

この動作状態では変換器が周期的にデューティサイクル下限に達します。これが起きた時に変換器は切り替えを停止し、出力電圧が落ち始めます。出力電圧が低電流動作活動状態の下限へ下がった時に変換器は再び切り替えを開始します。これは図8-5.で図解されるように周期的な形式に帰着します。

(過負荷または回路短絡のために)出力電圧(VCC)がVBOOST以下に落ちると、変換器は開始状態へ戻ります。加えて、ファームウェアはこの状態を抜け出して停止状態へ移行することを変換器に命令できます。次頁の「**昇圧変換器のソフトウェア制御**」をご覧ください。

# 8.3.3. 最大デューティ サイクル

既定により、昇圧変換器は切り替え波形のデューティサイクルを制御することによってVCCを限度内に保ちます。低電流動作移行時にデューティサイクル調整を迂回してデューティサイクルをその最大に固定することが可能で、最大限度までの素早い上昇とその後に低下を始めるVCC電圧に帰着します。右の図8-7.をご覧ください。

デューティサイクル制御のON/OFF切り替え法の指示について は次頁の「**昇圧変換器のソフトウェア制御**」をご覧ください。

最大デューティサイクル動作の使用は低負荷電流でだけ推奨されます。



# 8.4. 過負荷での動き

出力は負荷電流(ILOAD)が105頁の表20-7.で与えられる最大を越える時の過負荷を考慮されます。過負荷状態の間、昇圧変換器は最大デューティサイクルで動作し、もはやVCCを調整することができません。過負荷条件が優性なら、負荷電流増加のために出力電圧が落ちるでしょう。VCCが最小レヘル以下に落ちた場合、変換器が開始状態に切り換わります。

開始状態では変換器が低い負荷電流能力しか持たず、そしてそれは全ての過負荷電流がインダウタとダイオートを経由して殆ど電池から直接引き出されることを意味します。インダウタの抵抗は代表的に非常に低く、電力供給源が一定に留まるなら、過負荷中の出力電圧は電池電圧(VBAT)-使うダイオートの順方向降下電圧(VF)で安定するでしょう。

# 8.5. 昇圧変換器のソフトウェア制御

昇圧変換器はマイクロコントローラによる相互の影響を全く必要としない独立したハードウェア単位部で、とは言えいくつかの機能はファームウェアによって制御することができます。ファームウェアによって制御できる機能が以下の項で記述されます。

# 8.5.1. 昇圧変換器停止

デバイスのファームウェアは求めに応じて昇圧変換器を停止することができます。停止信号を発行すると、昇圧変換器は24頁の図8-3.で図解されるように活動状態を抜け出して停止状態へ移行します。この手続きは基板上のA/D変換器を使って真の電池電圧を読み、選んだ電池の化学的特性に対して電圧が充分かを評価し、そしてそれによる昇圧変換器の制御をデバイスに許します。

昇圧変換器の停止はデバイスリセット処理部へ自動的に要求を送ります。この信号は結局デバイスをリセットに設定しますが、出力電圧 (VCC)が電池電圧の概ね2倍の水準に落ちた後のみです。これは非常に低い電池電圧に対し、供給電圧が最小動作レベル以下に落ちる前にデバイスリセットが保証され得ないことを意味します。デバイス動作限界に違反しないことを保証するため、従ってそれは許可された低電圧検出器(BOD)を持つことが強く推奨されます。

昇圧変換器が停止された後であるけれどもデバイスがリセットされる前、例えば電池充電器が接続される場合に、電池電圧は上昇を開始するかもしれません。この場合、変換器はリセットに対する保留中の要求を解除する、電池電圧がVSTARTを超えた後で自動的に開始します。従って、ファームウェアは昇圧変換器停止がデバイスリセットを導かない状況を作成しなければなりません。この目的に対して、ファームウェアは「A/D変換制御/状態レジスタB(ADCSRB)」の昇圧変換器状態(BS)ビットの監視を選ぶかもしれません。

昇圧変換器を停止するには次の手順に従ってください。

- 1. 電力削減レジスタ(PRR)に110x xxxxを書いてください(22頁をご覧ください)。
- 2. 上からの3クロック周期内にPRRへ10xx xxxxを書いてください。
- 3. 最初の手順から4クロック周期内にPRRへ01xx xxxxを書いてください。

# 8.5.2. 最大デューティサイクル動作形態への切り替え

デューティサイクル制御が禁止されると、昇圧変換器の出力は可能な限り速く上昇し、変換器に対する最小切り替え時間と最大アイドル時間に帰着します。

最大デューティサイクル(FDC)動作をONにするには次の手順に従ってください。

- 1. 電力削減レシブスタ(PRR)に110x xxxxを書いてください(22頁をご覧ください)。
- 2. 上からの3クロック周期内にPRRへ10xx xxxxを書いてください。
- 3. 最初の手順から4クロック周期内にPRRへ111x xxxxを書いてください。

# 8.5.3. 標準(可変デューティ サイクル)動作形態への切り替え

昇圧変換器をデューティサイクル制御に戻すには次の手順に従ってください。

1. 電力削減レジスタ(PRR)に111x xxxxを書いてください(22頁をご覧ください)。

#### 8.6. 部品選択

部品の配置と番号については図8-8.を参照してください。







# 8.6.1. インダウタ

低いインダウタンスはインダウタの瞬間最大電流を増やし、妨害雑音をもっと生じ、変換器の全体効率を低くします。高すぎるインクタンス値は変換器を不安定動作に強制します。この昇圧変換器は或る大きさのインダウタンス(L)に最適化されており、他のインダウタンス値が使われた場合、確実な動作をしないかもしれません。29頁の「表8-1. 昇圧変換器部品値」をご覧ください。

インダクタは次の入力電流を許容できなければなりません。

$$I_{IN} = \frac{VCC \times ILOAD}{VBAT \times \eta}$$

ここでのηは与えられた電圧と負荷電流に於ける変換器の効率です。110頁の「**図21-1. 昇圧変換器(負荷と線の調整)VCC 対 負荷電流とVBAT電圧**」をご覧ください。

インダウタは短い瞬間最大電流も許容できなければなりません。安定状態に於いて、換言すると、一定の負荷電流が導かれた後で変換器が安定にされたとき、瞬間最大電流は次のように計算されます。

$$I_{PEAK} = \frac{VBAT \times TS \times D}{L}$$

ここでのDは昇圧変換器のデューティサイクル、TSは切り替え周期です。制限については105頁の「**昇圧変換器特性**」をご覧ください。安定状態デューティサイクルは次のように計算されます。

$$D = \left(\frac{VCC}{VBAT} - \frac{1}{2}\right) \times \sqrt{ILOAD}$$

昇圧変換器の全体効率はインダクタの直列抵抗とコア損失によって影響を及ぼされます。

#### 8.6.2. ダイオート

可能な限り低い順方向電圧(VF)と逆方向漏れ電流(IR)のショットキーダイオートの使用が推奨されます。これはILOADが最大でVBATが最小の時に変換器の効率が主にダイオートの順方向電圧に依存するためです。逆方向漏れ電流が特に低電流動作活動状態で容易に有力な要素になることに注意すべきです。参照については105頁の表20-7.内の低電流動作中の変換器消費電流をご覧ください。ダイオートはインダクタと同じ大きさの瞬間最大電流に従わなければなりません。「インダクタ」をご覧ください。

逆方向漏れ電流が高い温度依存変数であることに注意すべきです。

### 8.6.3. 入力コンデンサ

電圧供給元が理想的でないのと、配線が0でない抵抗分を持つため、電圧要求元とインダクタ(L1)間で電圧低下が起きます。この電圧低下は応用特有で、電圧供給元の品質、インダクタ電流、配線の太さと長さに依存します。コンデンサ(C1)は高い瞬間最大電流中にエネルギーをインダクタへ供給することによって電圧低下を妨げます。

応用の最低VBATと最高負荷電流でインダクタの最高瞬間電流に至ります。入力コンデンサは入力電圧を安定にし、全ての負荷電流での安定な動作を保証します。コンデンサの容量は負荷電流が低く留まる場合、または低い内部抵抗を持つ電圧供給源が利用可能な場合に減らすことができます。また、良好な低域通過濾波器の設計(次の「RC濾波器」項をご覧ください)がコンデンサの容量必要条件を低減します。

# 8.6.4. RC瀘波器

2つ目の入力コンデンサ(C2)と直列入力抵抗器(R1)は任意選択ですが推奨されます。これらは共に低域通過濾波器(LPF:Low Pass Filter)を形成し、その目的はVBATピンでの脈流電圧を低減することです。濾波器の遮断周波数は次のように計算することができます。

$$f_{LPF} = \frac{1}{2 \times \pi \times R1 \times C2}$$

部品値は応用指定で供給電圧の安定性に依存します。LPFはVBATピンの脈流電圧を低減し、A/D変換測定の安定化を助けます。 高すぎる抵抗値が開始状態失敗を引き起こすかもしれません。推奨部品と制限については「表8-1. 昇圧変換器部品値」をご覧ください。

コンテンサ(C2)はデバイスの近くに配置されるべきです。

# 8.6.5. 出力コンデンサ

出力コンデンサ(C3)はエネルギーがインダウタへ転送される時に出力電圧の安定を保つために必要とされます。高容量と低い等価直列抵抗 (ESR)を持つコンデンサの使用が推奨されます。大きな容量は出力での脈流電圧の低減を助け、低ESRは脈流電圧を低減してコンデンサの温度を制限内に保つのを助けます。

与えられた安定状態負荷に於ける推奨コンデンサ容量は次のように計算されます。

$$C_{OUT} = \frac{ILOAD \times TS \times D}{VPP}$$

ここでのTSは昇圧変換器の切り替え周期、VPPは許された脈流電圧で、Dは前頁の「インダウタ」で示されるように計算されるデューティサイクルです。

推奨ESRは次のように計算されます。

$$ESR \le \frac{VPP}{IPEAK}$$

2つ目の出力コンデンサ(C4)が推奨され、デバイスの近くに配置されるべきです。

#### 8.6.6. 要約

下表は代表的な応用に対する推奨部品値を要約します。

| 部品 | 推奨値                                                            | 最小 ( <mark>注2</mark> ) | 最大 ( <mark>注2</mark> ) |
|----|----------------------------------------------------------------|------------------------|------------------------|
| C1 | С=4.7µF                                                        | 1μF                    |                        |
| C2 | C=0.1µF ( <mark>注</mark> 1)                                    |                        | 1μF                    |
| C3 | C=22μF, ESR<0.1Ω                                               | 10μF                   |                        |
| C4 | C=0.1µF                                                        |                        |                        |
| D1 | IR=10μA/25°C, VF=0.35V/0.5A                                    |                        |                        |
| L1 | L=15 $\mu$ H $\pm$ 20%, IMAX>500mA, IRMS>250mA, R<0.5 $\Omega$ | 10μΗ                   | 15μΗ                   |
| R1 | R=680Ω ( <b>注1</b> )                                           |                        | 22kΩ ( <b>注3</b> )     |

注1: これらの値でLPFは昇圧変換器の切り替え周波数で32dBの減衰を提供し、一方で約±200mVの脈流電圧を許します。

注2: 応用指定限度はより厳しいかもしれません。

注3: 1kΩ値以上でVSTARTレヘールは増します。また、A/D変換器のVBATチャネルでの分圧抵抗値も影響を及ぼされます。

# 8.7. 特性

昇圧変換器の電気的特性は105頁の表20-7.で与えられます。代表特性は110頁の「昇圧変換器」項下で得られます。

# 8.8. 潜在的な制限

デバイスが昇圧変換器経由で給電される時にいくつかの使用制限が適用されるかもしれません。例えば、デバイスの最高許容動作周波数は供給電圧に依存し(103頁の「速度」をご覧ください)、昇圧変換器出力電圧は105頁の表20-7.で与えられる限度内で変化します。これは昇圧変換器が供給電圧が周期的に低下する低電流動作活動状態になるのを許す設計の場合、最大許容動作周波数に影響を及ぼすことを意味します。

負荷電流が充分高くに留まる場合、昇圧変換器は決して低電流動作活動状態へ移行せず、供給電圧はデバイスをより高い周波数で動かすのに充分な高さに留まります。昇圧変換器状態(BS)ビットは昇圧変換器が低電流動作かを判定するのに使うことができます(31頁の「A/D変換制御/状態レジスタB(ADCSRB)」をご覧ください)。

デバイス全体が昇圧変換器から給電されるため、出力変動は全ての周辺機能に現れます。これは例えば、入出力ピンのHighレベルが供給電圧と共に変動するかもしれないことを意味します。

### 8.9. 昇圧変換器の迂回

デバイスが外部供給元から直接給電できるように、昇圧変換器を迂回して禁止することが可能です。昇圧変換器を停止状態に強制するにはVBATピンをGNDに接続し、VCCピン直接でデバイスに供給元を提供してください。昇圧変換器を恒久的に禁止するにはVBATとLSWのピンをGNDに接続し、VCCピン直接でデバイスに供給元を提供してください。





# 8.10. ファームウェア例

昇圧変換器は正しい動作のためにファームウェアの相互作用が必要ない独立したハート・ウェア単位部です。それにもかかわらず、電池電圧を周期的に調査するようないくつかの関すがファームウェアによって実行されることが推奨されます。これは代表的な応用が示される図8-9.の構成図で説明されます。



例プログラムの枠組みは以下で示されます。このプログラムは1.8VのBODLEVELを信頼します(104頁の**表20-5**.をご覧ください)。

| とこ覧くたさい。   |                                  |                                                            |                                               |
|------------|----------------------------------|------------------------------------------------------------|-----------------------------------------------|
|            | .inclu                           | de "tn43Udef.inc"                                          |                                               |
|            | RJMP                             | RESET                                                      | ;リセット処理部                                      |
|            | .org                             | 0x0080                                                     |                                               |
| RESET:     | LDI<br>LDI<br>OUT<br>OUT<br>RJMP | R16, 0x5F<br>R17, 0x01<br>SPL, R16<br>SPH, R17<br>ADC_VBAT | ;スタック ポインタ設定                                  |
| ADC_VBAT:  | LDI<br>OUT                       | R16, 0b01000110<br>ADMUX, R16                              | ;内部1.1V基準電圧とVBAT                              |
|            | LDI<br>OUT                       | R16, 0b10000011<br>ADCSRA, R16                             | ;ADC許可、8前置分周(1MHz)                            |
| ADC_start: | LDI<br>LDI                       | R20, 0x00<br>R21, 0x00                                     | ;累積器(R21:R20)解除                               |
|            | RCALL<br>ADD<br>ADC              | Make_conversion<br>R20, R18<br>R21, R19                    | ;第1回A/D変換                                     |
|            | RCALL<br>ADD<br>ADC              | Make_conversion<br>R20, R18<br>R21, R19                    | ;第2回A/D変換                                     |
|            | RCALL<br>ADD<br>ADC              | Make_conversion<br>R20, R18<br>R21, R19                    | ;第3回A/D変換                                     |
|            | RCALL<br>ADD<br>ADC              | Make_conversion<br>R20, R18<br>R21, R19                    | ;第4回A/D変換                                     |
|            | LSR<br>ROR<br>LSR<br>ROR         | R21<br>R20<br>R21<br>R20                                   | ;累積結果を1/4                                     |
|            | LSR<br>ROR<br>LSR                | R21<br>R20<br>R21                                          | ;下位2ビット切捨て(=8ビットの結果)                          |
|            | ROR<br>CPI<br>BRLO<br>RJMP       | R20<br>R20, 0x68<br>Stop_boost<br>ADC_start                | ;R20に8ビットでの結果を得る。<br>;VBAT<約0.9Vなら、<br>;昇圧停止へ |

Make conversion: ADCSRA, ADSC SBI Wait\_conversion\_ready: SBIC ADCSRA, ADSC **RJMP** Wait\_conversion\_ready IN R18, ADCL IN R19, ADCH **RET** ;全出力禁止 Stop\_boost: LDI R16, 0x00 DDRA, R16 OUT OUT DDRB, R16 LDI R16, 0b01000000 ;内部1.1V基準電圧とADC0 OUT ADMUX, R16 ;ADC禁止、8前置分周(1MHz) LDI R16, 0b00000011 OUT ADCSRA, R16 R16, 0b11000000 LDI PRR, R16 OUT LDI R16, 0b10000000 OUT PRR, R16 LDI R16, 0b01000000 OUT PRR, R16 Read\_Boost\_Status R.JMP Read\_Boost\_Status: ;昇圧変換器状態ビット ポーリング SBIS ADCSRB, 7 ;昇圧再開なら、 ;MCUコアのPORまたはBODのリセットに先立って R TMP Read\_Boost\_Status **RJMP** ;リセットへ飛ぶ Reset

# 8.11. 昇圧変換器関係レジスタ

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

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

# ■ ビット7 - BS: 昇圧変換器状態 (Boost Status)

BSフラグは昇圧変換器の沈黙区間を識別するのに使うことができます。このフラグが1の時は昇圧変換器が活動で切り替え、換言すると、調整動作活動状態、または低電流動作活動状態の切り替え区間のどちらかです。このフラグが0の時は昇圧変換器が非切り替え、換言すると、停止状態または低電流動作活動状態の非切り替え区間のどちらかです。

また、BSフラグは以下のようにして、デューティサイクル制御器の状態を返すように設定することもできます。

- 1. 電力削減レシブスタ(PRR)に11xx xxxxを書いてください。
- 2. 上からの3周期区間内にPRRへ10xx xxxxを書いてください。
- 3. (単一周期のNOPを実行して)待ってください。
- 4. 最初の書き込みから5周期区間内にBSフラグを読んでください。

この時のBSフラグがOなら、変換器は標準デューティサイクル制御状態での動作です。このフラグが1の場合、変換器は最大デューティサイクル動作で動いています。





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

# 9.1. AVRのリセット

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



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

#### 9.2. リセット元

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

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

#### 9.2.1. 電源ONリセット

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

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

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





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

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



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

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

BODが許可され、VCCが起動電圧以下に下降するVCCが起動電圧以下に下降するVCCが起動電圧以上に上昇するVCCが起動電圧以上に上昇するVCCが起動され)遅延タイマは遅延時間(VCC)を始動します。



BOD回路は電圧が104頁の表20-4.で与えられるtBOD時間より長く起動電圧以下に留まる場合のみ、VCCでの低下を検出します。 統合された昇圧変換器を使う時は最低BODレヘル(1.8V)だけを使うことが推奨されます。23頁の「電源と内蔵昇圧変換器」をご覧ください。

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

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







# 9.3. 内部基準電圧

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

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

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

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

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

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

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

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

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



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

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

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

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

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

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

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

# 9.4.1.2. 安全レベル2

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

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

#### 9.4.2. コート 例

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

```
アセンブリ言語プログラム例
WDT OFF:
                                                        ;ウォッチト、ック、タイマ リセット
            WDR
                   R16, (0<<WDRF)
                                                        ;WDRF=0値を取得
            LDI
            OUT
                   MCUSR, R16
                                                        ;MCUSRのWDRFを解除(0)
            IN
                   R16, WDTCSR
                                                        ;現WDTCSR値を取得
            ORI
                   R16, (1<<WDCE) | (1<<WDE)
                                                        ;WDCEとWDE論理1値を設定
                   WDTCSR, R16
                                                        ;WDCEとWDEに論理1書き込み
            OUT
                   R16, (0<<WDE)
                                                        ;WDE論理0値を取得
            LDI
            OUT
                   WDTCSR, R16
                                                        ;ウォッチトッグ禁止
                                                        ;呼び出し元へ復帰
            RET
C言語プログラム例
void WDT_off(void)
                                                       /* ウォッチト・ック・タイマ リセット */
     _WDR();
    MCUSR = 0x00;
                                                       /* MCUSRのWDRFを解除(0)*/
    WDTCSR \mid = (1 << WDCE) \mid (1 << WDE);
                                                       /* WDCEとWDEに論理1書き込み */
    WDTCSR = 0x00;
                                                       /* ウォッチト・ック 禁止 */
}
注: 4頁の「コート「例」をご覧ください。
```

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

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

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

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

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

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

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

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

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

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

■ Ľット1 – EXTRF:外部リセット フラク (External Reset Flag)

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

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

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

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





# 9.5.2. ウォッチト・ック タイマ制御/状態レシ、スタ (Watchdog Timer Control and Status 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)されると、ウォッチドッグ割り込みが許可されます。この動作ではウォッチドッグタイマで計時完了が起きる場合、リセットに代わって対応する割り込みが実行されます。

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

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

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

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

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

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

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

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

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

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

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

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

| 表9-3. ウォッチドッグ前置分周器選択   |       |      |             |              |       |      |      |         |      |       |                  |   |   |   |   |   |  |
|------------------------|-------|------|-------------|--------------|-------|------|------|---------|------|-------|------------------|---|---|---|---|---|--|
| WDP3                   | 0     |      |             |              |       |      |      |         | 1    |       |                  |   |   |   |   |   |  |
| WDP2                   | 0     |      |             |              | 1     |      |      |         | 0    |       |                  |   | 1 |   |   |   |  |
| WDP1                   | (     | 0    |             | 1            |       | 0    |      | 1       |      | 0     |                  | 1 |   | 0 |   | 1 |  |
| WDP0                   | 0     | 1    | 0           | 1            | 0     | 1    | 0    | 1       | 0    | 1     | 0                | 1 | 0 | 1 | 0 | 1 |  |
| WDT発振周期数               | 2k    | 4k   | 8k          | 16k          | 32k   | 64k  | 128k | 256k    | 512k | 1024k | (予約)( <b>注</b> ) |   |   |   |   |   |  |
| 代表的計時完了<br>周期 (VCC=5V) | 16ms  | 32ms | 64ms        | 0.125s       | 0.25s | 0.5s | 1.0s | 2.0s    | 4.0s | 8.0s  |                  |   |   |   |   |   |  |
| 注・選択したから 1             | 1010= | 港の右  | <b>为</b> 型生 | <b>か1つ</b> : | が届わ   | カナナ  | (記注  | · 开:泽/i | 生からる | 大注:迫† | нп)              |   |   |   |   |   |  |

# 10. 割り込み

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

## 10.1. ATtiny43Uの割り込みべか

ATtiny43Uの割り込みへうタは下の表10-1.で記述されます。

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

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

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

| アト・レス  | ラヘ゛ル   | 命令   |                    | 注釈               |
|--------|--------|------|--------------------|------------------|
| \$0000 |        | RJMP | RESET              | ;各種リセット          |
| \$0001 |        | RJMP | INTO               | ;外部割り込み要求0       |
| \$0002 |        | RJMP | PCINTO             | ;ピン変化0群割り込み要求    |
| \$0003 |        | RJMP | PCINT1             | ;ピン変化1群割り込み要求    |
| \$0004 |        | RJMP | WDT                | ;ウォッチドッグ計時完了     |
| \$0005 |        | RJMP | TIMER1_COMPA       | ;タイマ/カウンタ1比較A一致  |
| \$0006 |        | RJMP | TIMER1_COMPB       | ;タイマ/カウンタ1比較B一致  |
| \$0007 |        | RJMP | TIMER1_OVF         | ;タイマ/カウンタ1溢れ     |
| \$0008 |        | RJMP | TIMERO_COMPA       | ;タイマ/カウンタ0比較A一致  |
| \$0009 |        | RJMP | TIMERO_COMPB       | ;タイマ/カウンタ0比較B一致  |
| \$000A |        | RJMP | TIMERO_OVF         | ;タイマ/カウンタ0溢れ     |
| \$000B |        | RJMP | ANA_COMP           | ;アナログ比較器出力遷移     |
| \$000C |        | RJMP | ADC                | ;A/D変換完了         |
| \$000D |        | RJMP | EE_RDY             | ;EEPROM操作可       |
| \$000E |        | RJMP | USI_START          | ;USI 開始条件検出      |
| \$000F |        | RJMP | USI_OVF            | ;USI 計数器溢れ       |
| ;      |        |      |                    |                  |
| \$0010 | RESET: | LDI  | R16, HIGH (RAMEND) | ;RAM最終アドレス上位を取得  |
| \$0011 |        | OUT  | SPH, R16           | ;スタック ポインタ上位を初期化 |
| \$0012 |        | LDI  | R16, LOW (RAMEND)  | ;RAM最終アドレス下位を取得  |
| \$0013 |        | OUT  | SPL, R16           | ;スタック ポインタ下位を初期化 |
|        |        | }    |                    | ;以下、I/O初期化など     |





## 10.2. 外部割り込み

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

- ・PCI1tプン変化割り込みは許可したPCINT8~15tプンの何れかが切り替わると起動します。
- ・PCIOtシ変化割り込みは許可したPCINTO~7tシの何れかが切り替わると起動します。

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

INT0割り込みは上昇端または下降端(含む両端)またはLowレヘルによって起動できます。これはMCU制御レジスタ(MCUCR)で記述されるように構成設定されます。INT0割り込みがレヘル起動として設定、且つ許可されると、そのピンがLowに保持される限り、割り込みは(継続的に)起動します。INT0のLowレヘルとエッジの割り込みは非同期に検知されます。これはそれらの割り込みがアイル動作以外の休止形態からもデバイスを起動するのに使えることを意味します。I/Oクロックはアイル動作を除く全休止形態で停止されます。

レヘール起動割り込みがパワーゲウン動作からの起動に使われる場合、この必要としたレヘールはレヘール割り込みを起動する完全な起動復帰のため、MCUに対して充分長く保持されなければならないことに注意してください。

このレヘ・ルが起動時間の最後に先立って消滅すると、MCUは今までどおり起動しますが、割り込みが生成されません。起動時間は15頁の「システム クロックとクロック選択」で示されるようにSUTヒュース、とCKSELヒュース、で定義されます。

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

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

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





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

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

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

| \$35 (\$55) BODS PUD SE SM1 SM0 BODSE ISC01 | ISC00 | MCUCR |
|---------------------------------------------|-------|-------|
| Read/Write R/W R/W R/W R/W R/W R/W          | R/W   |       |
| 初期値 0 0 0 0 0 0                             | 0     |       |

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

外部割り込み0はステータスレジスタ(SREG)の全割り込み許可(I)ビットと一般割り込み許可レジスタ(GIMSK)の外部割り込み0許可(INTO)ビットが設定(1)される場合のINT 0外部ピッレによって活性(有効)にされます。割り込みを活性にする外部INTOピックエッジとレヘルは表10-2.で定義されます。

INT0ピンのエッジは非同期に記録されます。104頁の表20-6.で与えられるパルス幅よりも広いINT0のパルスが割り込みを生成します。より短いパルスは割り込み発生が保証されません。

Lowレベル割り込みが選択される場合、そのLowレベルは割り込みを生成するために現在実行している命令の完了まで保たれなければなりません。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

PCINT8~15 $t^\circ$ ンの何れかの論理変化が割り込み要求を起動すると、PCIF1が設定(1)になります。ステータスレジスタ(SREG)の全割り込み許可(I) $t^\circ$ ットと一般割り込み許可レジスタ(GIMSK)の $t^\circ$ ン変化1群割り込み許可(PCIE1) $t^\circ$ ットが設定(1)なら、MCUは対応する割り込み  $\wedge^\circ$ クタへ飛びます。このフラグは割り込みルーチンが実行されると解除(0)されます。代わりにこのフラグは論理1を書くことによっても解除(0) できます。

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

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



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

| ピット         | 7       | 6       | 5       | 4       | 3       | 2       | 1      | 0      |        |
|-------------|---------|---------|---------|---------|---------|---------|--------|--------|--------|
| \$20 (\$40) | PCINT15 | PCINT14 | PCINT13 | PCINT12 | PCINT11 | PCINT10 | PCINT9 | PCINT8 | PCMSK1 |
| Read/Write  | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W    | R/W    |        |
| 初期値         | 0       | 0       | 0       | 0       | 0       | 0       | 0      | 0      |        |

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

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

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

| ピット         | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |        |
|-------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| \$12 (\$32) | PCINT7 | PCINT6 | PCINT5 | PCINT4 | PCINT3 | PCINT2 | PCINT1 | PCINT0 | PCMSK0 |
| 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) νッ スタのPCIE0が設定(1)なら、対応するI/Oピンのピン変化割り込みが許可されます。PCINT0~7が解除(0)されると、対応するI/Oピンのピン変化割り込みは禁止されます。

## 11. 入出力ポート

## 11.1. 序説

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



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

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

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

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

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

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





### 11.2.1. ピンの設定

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

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

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

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

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

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

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

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

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

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

| 表11-1. ポート ピンの設定 | 表11-1 | 」、ポ−ト | ピンの設定 |
|------------------|-------|-------|-------|
|------------------|-------|-------|-------|

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

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

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

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

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





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

```
アセンブリ言語プログラム例
            LDI
                   R16, (1<<PA4) | (1<<PA1) | (1<<PA0)
                                                                 ;プルアップとHigh値を取得
                   R17, (1<<DDA3) | (1<<DDA2) | (1<<DDA1) | (1<<DDA0) ;出力ビット値を取得
            LDI
                   PORTA, R16
                                                                 ;プルアップとHigh値を設定
            OUT
            OUT
                   DDRA, R17
                                                                 ;入出力方向を設定
            NOP
                                                                 ;同期化遅延対処
                                                                 ;ピン値読み戻し
            IN
                   R16, PINA
C言語プログラム例
unsigned char i;
                                                                /* */
    PORTA = (1 << PA4) | (1 << PA1) | (1 << PA0);
                                                                /* プルアップとHigh値を設定 */
    DDRA = (1 << DDA3) | (1 << DDA2) | (1 << DDA1) | (1 << DDA0);
                                                                /* 入出力方向を設定 */
                                                                /* 同期化遅延対処 */
    __no_opration();
                                                                /* ピン値読み戻し*/
    i = PINA;
                                                                /* */
```

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

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

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

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

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

### 11.2.6. 未接続ピン

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

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





## 11.3. 交換ポート機能

多くのポート ピンには標準デジタル入出力に加え交換機能があります。下の図11-5.で単純化された図11-2.でのポート ピン制御信号が交換機能によってどう重複し得るかが示されます。



この重複信号は全てのポート ピンに存在する訳ではありませんが、この図はAVR マイクロ コントローラ系統の全ポート ピンに適用できる一般的な記述として取り扱います。

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

表11-2. 交換機能用交換信号の一般定義

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

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

### 11.3.1. ポートAの交換機能

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

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

| ポ <sup>°</sup> ート<br>ピ <sup>°</sup> ン | 交換機能                                                         | ポート<br>ピン | 交換機能                                        |
|---------------------------------------|--------------------------------------------------------------|-----------|---------------------------------------------|
| PA7                                   | RESET (外部リセット入力)<br>dW (デバッケWIRE入出力)<br>PCINT7 (ピン変化割り込み7入力) | PA3       | ADC3 (A/D変換チャネル3入力)<br>PCINT3 (ピン変化割り込み3入力) |
| PA6                                   | CLKI (外部クロック信号入力)<br>PCINT6 (ピン変化割り込み6入力)                    | PA2       | ADC2 (A/D変換チャネル2入力<br>PCINT2 (ピン変化割り込み2入力)  |
| PA5                                   | AIN1 (アナログ比較器反転入力)<br>PCINT5 (ピン変化割り込み5入力)                   | PA1       | ADC1 (A/D変換チャネル1入力<br>PCINT1 (ピン変化割り込み1入力)  |
| PA4                                   | AINO (アナログ比較器非反転入力)<br>PCINT4 (ピン変化割り込み4入力)                  | PA0       | ADC0 (A/D変換チャネル0入力<br>PCINT0 (ピン変化割り込み0入力)  |

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

• RESET/dW/PCINT7 - π°-トΑ Ľット7 : PA7

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

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

 $PCINT7: t^2$ ン変化割り込み元7入力。 $PA7t^2$ ンは $t^2$ ン変化0群割り込みに対する外部割り込み元として扱えます。

• CLKI/PCINT6 - π°-トA L\*y\6 : PA6

CLKI:外部クロック元からのクロック信号入力。クロック ピンとして使用時、このピンは入出力として使えません。

PCINT6: ピン変化割り込み元6入力。PA6ピンはピン変化0群割り込みに対する外部割り込み元として扱えます。

• AIN1/PCINT5 - ホ°ートA ビット5 : PA5

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

 $PCINT5: t^2$ ン変化割9込み元5入力。 $PA5t^2$ ンは $t^2$ ン変化0群割9込みに対する外部割9込み元として扱えます。

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

PCINT4: ピン変化割り込み元4入力。PA4ピンはピン変化0群割り込みに対する外部割り込み元として扱えます。

• ADC3/PCINT3 - π°-トA L"ット3 : PA3

ADC3: A/D変換器チャネル3入力。

 $PCINT3: t^2$ ン変化割り込み元3入力。 $PA3t^2$ ンは $t^2$ ン変化0群割り込みに対する外部割り込み元として扱えます。

ADC2: A/D変換器チャネル2入力。

PCINT2: ピン変化割り込み元2入力。PA2ピンはピン変化0群割り込みに対する外部割り込み元として扱えます。

• ADC1/PCINT1 - π°-トA L "ット1 : PA1

ADC1: A/D変換器チャネル1入力。

PCINT1: ピン変化割り込み元1入力。PA1ピンはピン変化0群割り込みに対する外部割り込み元として扱えます。

• ADC0/PCINT0 - ホートA ビット0: PA0

ADC0: A/D変換器チャネル0入力。

PCINTO: ピン変化割り込み元0入力。PAOピンはピン変化0群割り込みに対する外部割り込み元として扱えます。





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

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

| 信号名   | PA7/RESET/dW/PCINT7              | PA6/CLKI//PCINT6                                                              | PA5/AIN1/PCINT5        | PA4/AIN0/PCINT4        |
|-------|----------------------------------|-------------------------------------------------------------------------------|------------------------|------------------------|
| PUOE  | RSTDISBL+dW許可                    | 外部クロック                                                                        | 0                      | 0                      |
| PUOV  | 1                                | 0                                                                             | 0                      | 0                      |
| DDOE  | RSTDISBL+dW許可                    | 外部クロック                                                                        | 0                      | 0                      |
| DDOV  | dW許可·dW送信                        | 0                                                                             | 0                      | 0                      |
| PVOE  | RSTDISBL+dW許可                    | 外部クロック                                                                        | 0                      | 0                      |
| PVOV  | 0                                | 0                                                                             | 0                      | 0                      |
| PTOE  | 0                                | 0                                                                             | 0                      | 0                      |
| DIEOE | (PCIE0•PCINT7)<br>+RSTDISBL+dW許可 | (PCIEO・PCINT6)<br>+外部クロック                                                     | (PCIE0 • PCINT5)+AIN1D | (PCIE0 • PCINT4)+AIN0D |
| DIEOV | (PCIE0·PCINT7·<br>RSTDISBL)+dW許可 | (PCIEO・PCINT <u>6・外部クロック)</u><br>+(外部クロック・ハ <sup>°</sup> ワータ <sup>°</sup> ウン) | PCIE0 • PCINT5         | PCIE0 • PCINT4         |
| DI    | dW/PCINT7入力                      | CLKI/PCINT6入力                                                                 | PCINT5入力               | PCINT4入力               |
| AIO   | -                                | -                                                                             | アナログ比較器反転入力            | アナログ比較器非反転入力           |

- 注: ・RSTDISBLはRSTDISBLヒューズがプログラム(0)時に1です。
  - ・dW(デバッグWIRE)はDWENヒュースがプログラム(0)で、且つ施錠ビットが非プログラム(1)の時に許可されます。
  - ・外部クロックはシステムクロックとして外部クロック信号の選択時です。
  - ・内部クロックはシステムクロックとして内部のRC発振器選択時です。

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

| 信号名   | PA3/ADC3/PCINT3        | PA2/ADC2/PCINT2        | PA1/ADC1/PCINT1        | PA0/ADC0/PCINT0        |
|-------|------------------------|------------------------|------------------------|------------------------|
| PUOE  | 0                      | 0                      | 0                      | RESET • REFS0          |
| PUOV  | 0                      | 0                      | 0                      | 0                      |
| DDOE  | 0                      | 0                      | 0                      | RESET • REFS0          |
| DDOV  | 0                      | 0                      | 0                      | 0                      |
| PVOE  | 0                      | 0                      | 0                      | RESET • REFS0          |
| PVOV  | 0                      | 0                      | 0                      | 0                      |
| PTOE  | 0                      | 0                      | 0                      | 0                      |
| DIEOE | (PCIE0 • PCINT3)+ADC3D | (PCIE0 • PCINT2)+ADC2D | (PCIE0 • PCINT1)+ADC1D | (PCIE0 • PCINT0)+ADC0D |
| DIEOV | PCIE0 • PCINT3         | PCIE0 • PCINT2         | PCIE0 • PCINT1         | PCIE0 • PCINT0         |
| DI    | PCINT3入力               | PCINT2入力               | PCINT1入力               | PCINT0入力               |
| AIO   | ADC3入力                 | ADC2入力                 | ADC1入力                 | ADC0入力                 |

(訳注) 原書の表11-4.と表11-5.は表11-4.として、表11-6.と表11-7.は表10-5.として纏めました。

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

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

## 表11-8. ポートBピンの交換機能

| ホ <sup>°</sup> ート<br>ヒ <sup>°</sup> ン | 交換機能                                                                                             | ポート<br>ピン | 交換機能                                                                    |
|---------------------------------------|--------------------------------------------------------------------------------------------------|-----------|-------------------------------------------------------------------------|
| PB7                                   | INTO (外部割り込み0入力)<br>PCINT15 (ピン変化割り込み15入力)                                                       | PB3       | T1 (タイマ/カウンタ1 外部クロック入力)<br>CLKO (システム クロック出力)<br>PCINT11 (ピン変化割り込み11入力) |
| PB6                                   | USCK (3線動作USI/pロック入出力)<br>SCL (2線動作USI(TWI)クロック入出力)<br>PCINT14 (ピン変化割り込み14入力)                    | PB2       | OC0B (タイマ/カウンタ0比較B一致)<br>PCINT10 (ピン変化割り込み10入力)                         |
| PB5                                   | OC1B (タイマ/カウンタ1比較B一致)<br>DO (3線動作USIデータ出力)<br>PCINT13 (ピン変化割り込み13入力)                             | PB1       | OC0A (タイマ/カウンタ0比較A一致)<br>PCINT9 (ピン変化割り込み9入力)                           |
| PB4                                   | OC1A (タイマ/カウンタ1比較A一致)<br>DI (3線動作USIデータ入力)<br>SDA (2線動作USI(TWI)データ入出力)<br>PCINT12 (ピン変化割り込み12入力) | PB0       | T0 (タイマ/カウンタ0 外部クロック入力)<br>PCINT8 (ピン変化割り込み8入力)                         |

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

• INT0/PCINT15 - ポートB ビット7 : PB7

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

PCINT15: ピン変化割り込み元15入力。PB7ピンはピン変化1群割り込みに対する外部割り込み元として扱えます。

• USCK/SCL/PCINT14 - ホートB ビット6: PB6

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

PCINT14: ピン変化割り込み元14入力。PB6ピンはピン変化1群割り込みに対する外部割り込み元として扱えます。

• OC1B/DO/PCINT13 – ポートB ビット5 : PB5

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

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

PCINT13: ピン変化割り込み元13入力。PB5ピンはピン変化1群割り込みに対する外部割り込み元として扱えます。

• OC1A/DI/SDA/PCINT12 - π°-トΒ ビット4 : PB4

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

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

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

PCINT12: ピン変化割り込み元12入力。PB4ピンはピン変化1群割り込みに対する外部割り込み元として扱えます。

• T1/CLKO/PCINT11 - π°-トΒ Ε΄ット3 : PB3

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

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

PCINT11: ピン変化割り込み元11入力。PB3ピンはピン変化1群割り込みに対する外部割り込み元として扱えます。

• OC0B/PCINT10 - π°-\B L\*y\2 : PB2

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

PCINT10: ピン変化割り込み元10入力。PB2ピンはピン変化1群割り込みに対する外部割り込み元として扱えます。





#### • OC0A/PCINT9 - ポートB ビット1 : PB1

OCOA: タイマ/カウンタ0の比較A一致出力。PB1ピンはタイマ/カウンタ0の比較A一致用外部出力として扱えます。この機能を扱うため、この

ピンは出力として設定(DDB1=1)されなければなりません。このOC0Aピンはタイマ機能のPWM動作用出力ピンでもあります。

PCINT9: ピン変化割り込み元9入力。PB1ピンはピン変化1群割り込みに対する外部割り込み元として扱えます。

• T0/PCINT8 - ポートB ビット0 : PB0

T0: タイマ/カウンタ0の外部クロック入力。

PCINT8: ピン変化割り込み元8入力。PB0ピンはピン変化1群割り込みに対する外部割り込み元として扱えます。

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

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

| 信号名   | PB7/INT0/PCINT15       | PB6/USCK/SCL/PCINT14     | PB5/OC1B/DO/PCINT13 | PB4/OC1A/DI/SDA/<br>PCINT12 |
|-------|------------------------|--------------------------|---------------------|-----------------------------|
| PUOE  | 0                      | 0                        | 0                   | 0                           |
| PUOV  | 0                      | 0                        | 0                   | 0                           |
| DDOE  | 0                      | 2線USI                    | 0                   | 2線USI                       |
| DDOV  | 0                      | SCL保持+PORTB6             | 0                   | (SDA+PORTB4)•DDB4           |
| PVOE  | 0                      | 2線USI                    | 3線USI+OC1B許可        | (2線USI·DDB4)+OC1A許可         |
| PVOV  | 0                      | 0                        | 3線USI•DO+3線USI•OC1B | (2線USI·DDB4)·OC1A           |
| PTOE  | 0                      | USI許可                    | 0                   | 0                           |
| DIEOE | (PCIE1 • PCINT15)+INT0 | (PCIE1 • PCINT14)+USISIE | PCIE1 • PCINT13     | (PCIE1 • PCINT12)+USISIE    |
| DIEOV | (PCIE1 • PCINT15)+INT0 | (PCIE1 • PCINT14)+USISIE | PCIE1 • PCINT13     | (PCIE1 • PCINT12)+USISIE    |
| DI    | INT0/PCINT15入力         | USCK/SCL/PCINT14入力       | PCINT13入力           | DI/SDA/PCINT12入力            |
| AIO   | -                      | _                        | _                   | _                           |

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

| 信号名   | PB3/T1/CLKO/PCINT11 | PB2/OC0B/PCINT10 | PB1/OC0A/PCINT9 | PB0/T0/PCINT8  |
|-------|---------------------|------------------|-----------------|----------------|
| PUOE  | CKOUT               | 0                | 0               | 0              |
| PUOV  | 0                   | 0                | 0               | 0              |
| DDOE  | CKOUT               | 0                | 0               | 0              |
| DDOV  | 1                   | 0                | 0               | 0              |
| PVOE  | CKOUT               | OC0B許可           | OC0A許可          | 0              |
| PVOV  | CKOUT・システム クロック     | OC0B             | OC0A            | 0              |
| PTOE  | 0                   | 0                | 0               | 0              |
| DIEOE | PCIE1 • PCINT11     | PCIE1 • PCINT10  | PCIE1 • PCINT9  | PCIE1 • PCINT8 |
| DIEOV | PCIE1 • PCINT11     | PCIE1 • PCINT10  | PCIE1 • PCINT9  | PCIE1 • PCINT8 |
| DI    | T1/PCINT11入力        | PCINT10入力        | PCINT9入力        | T0/PCINT8入力    |
| AIO   | _                   | _                | _               | _              |

(<mark>訳注</mark>) 原書の表11-9.と表11-10.は表11-9.として、表11-11.と表11-12.は表11-10.として纏めました。

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

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

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

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

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

## 11.4.2. ホートA出力レシ、スタ (Port A Data Register) PORTA

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

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

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

## 11.4.4. ホートA入力レジスタ (Port A Input Address) PINA

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

## 11.4.5. ホート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      |       |

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

| ビット           | 7   | 6    | 5    | 4    | 3    | 2    | 1    | 0    |      |
|---------------|-----|------|------|------|------|------|------|------|------|
| \$17 (\$37) D | DB7 | DDB6 | DDB5 | DDB4 | DDB3 | DDB2 | DDB1 | DDB0 | DDRB |
| Read/Write F  | 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.4.7. ホート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   |      |
| 初期値         | 不定    |      |



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

### 12.1. 特徴

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

#### 12.2. 概要

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

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

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



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

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

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

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

#### 12.2.2. 定義

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

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

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

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

### 12.4. 計数器部

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



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

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

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





### 12.5. 比較出力部

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

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

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

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

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



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

### 12.5.1. 強制比較出力

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

#### 12.5.2. TCNTn書き込みによる比較一致妨害

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

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

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

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

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

## 12.6. 比較一致出力部

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



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

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

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

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

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





### 12.7. 動作種別

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

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

### 12.7.1. 標準動作

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

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

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

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

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



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

CTC動作で波形出力を生成するため、OCnA出力は比較出力選択(COMnA1,0)ビットを交互動作(=01)に設定することによって各比較一致での論理レベル交互切り替えに設定できます。OCnA値はそのピンに対するデータ方向が出力(DDR\_OCnA=1)に設定されない限り ポート ピンで見えないでしょう。生成された波形はOCRnAが0(\$00)に設定される時に $f_{OCnA}=f_{clk_L/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)を表します。

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

### 12.7.3. 高速PWM動作

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

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



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

高速PWM動作での比較部はOCnxt°ンでのPWM波形の生成を許します。COMnx1,0t'ットを'10'に設定することは非反転PWM出力を作成し、反転PWM出力はCOMnx1,0を'11'に設定することで生成できます。WGMn2t'ットが設定(1)ならばCOMnA1,0t'ットの'01'設定は比較一致での交互反転をOCnAt°ンに許します。この任意選択はOCnBt°ンに対して利用できません(58頁の表12-3.と59頁の表12-6.をご覧ください)。実際のOCnx値はホ°ート t°ンに対するデータ方向(DDR\_OCnx)が出力として設定される場合にだけ見えるでしょう。PWM波形はTCNTnとOCRnx間の比較一致で、OCnx(内部)レジスタを設定(1)(または解除(0))と、カウンタが解除(\$00,TOPからBOTT OM〜変更)されるタイマ/カウンタ クロック周期でOCnxレジスタを解除(0)または設定(1)することによって生成されます。

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

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

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

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

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





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

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

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



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

位相基準PWM動作での比較部はOCnxt°ンでのPWM波形の生成を許します。COMnx1,0t°ットを'10'に設定することは非反転PWM出力を作成し、反転PWM出力はCOMnx1,0t°ットを'11'に設定することで生成できます。WGMn2t°ットが設定(1)なら、COMnA1,0t°ットの'01'設定は比較一致での交互反転をOCnAt°ンに許します。この任意選択はOCnBt°ンに対して利用できません(58頁の表12-4.と59頁の表12-7.をご覧ください)。実際のOCnx値はそのポート t°ンに対するデータ方向(DDR\_OCnx)が出力として設定される場合だけ見えるでしょう。PWM波形はカウンタが増加する時のTCNTnとOCRnx間の比較一致でOCnx(内部)レジ、スタを設定(1)(または解除(0))と、カウンタが減少する時のTCNTnとOCRnx間の比較一致でOCnxレジ、スタを解除(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)を表します。

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

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

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

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

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



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



図12-10.はCTC動作とOCRnAがTOPのPWM動作を除く全動作種別でのOCFnAと全動作種別でのOCFnBの設定を示します。



図12-11.はOCRnAがTOPの高速PWM動作と、CTC動作でのTCNTnの解除とOCFnAの設定を示します。





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

## 12.9.1. タイマ/カウンタ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     |        |

## 12.9.2. タイマ/カウンタ1制御レジスタA (Timer/Counter 1 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 - COMnA1,0:比較A出力選択 (Compare Match A Output Mode bit 1 and 0)

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

OCnAがピンに接続されるとき、COMnA1,0ビットの機能はWGMn2~0ビット設定に依存します。表12-2.はWGMn2~0ビットが標準動作またはCTC動作(つまりPWM以外)に設定される時のCOMnA1,0ビット機能を示します。

### 表12-2. 非PWM動作比較A出力選択

| COMnA1 | COMnA0 | 意味                      |  |  |  |  |  |
|--------|--------|-------------------------|--|--|--|--|--|
| 0      | 0      | 標準ポート動作 (OCnA切断)        |  |  |  |  |  |
| 0      | 1      | 比較一致でOCnAt゚ン トグル(交互)出力  |  |  |  |  |  |
| 1      | 0      | 比較一致でOCnAt°ン Lowレヘール出力  |  |  |  |  |  |
| 1      | 1      | 比較一致でOCnAt°ン Highレヘール出力 |  |  |  |  |  |

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

### 表12-3. 高速PWM動作比較A出力選択

|   | Z 0,  D] & | 20112  |                                                                                         |  |  |  |  |  |
|---|------------|--------|-----------------------------------------------------------------------------------------|--|--|--|--|--|
|   | COMnA1     | COMnA0 | 意味                                                                                      |  |  |  |  |  |
| ı | 0          | 0      | 標準ポート動作(OCnA切断)                                                                         |  |  |  |  |  |
|   | 0          | 1      | WGMn2= <mark>0</mark> :標準ポート動作(OCnA切断)<br>WGMn2= <mark>1</mark> :比較一致でOCnAピン トグル (交互)出力 |  |  |  |  |  |
|   | 1          | 0      | 比較一致でLow、BOTTOMでHighをOCnAtプンへ出力(非反転動作)                                                  |  |  |  |  |  |
|   | 1          | 1      | 比較一致でHigh、BOTTOMでLowをOCnAピンへ出力(反転動作)                                                    |  |  |  |  |  |

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

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

### 表12-4. 位相基準PWM動作比較A出力選択

| COMnA1 | COMnA0 | 意味                                                                                      |  |  |  |  |  |  |  |  |  |
|--------|--------|-----------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 0      | 0      | 標準ポート動作(OCnA切断)                                                                         |  |  |  |  |  |  |  |  |  |
| 0      | 1      | WGMn2= <mark>0</mark> :標準ポート動作(OCnA切断)<br>WGMn2= <mark>1</mark> :比較一致でOCnAピン トグル (交互)出力 |  |  |  |  |  |  |  |  |  |
| 1      | 0      | 上昇計数時の比較一致でLow、下降計数時の比較一致でHighをOCnAtシへ出力                                                |  |  |  |  |  |  |  |  |  |
| 1      | 1      | 上昇計数時の比較一致でHigh、下降計数時の比較一致でLowをOCnAtシへ出力                                                |  |  |  |  |  |  |  |  |  |

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

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

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

OCnBがピンに接続されるとき、COMnB1,0ピットの機能はWGMn2~0ピット設定に依存します。表12-5.はWGMn2~0ピットが標準動作またはCTC動作(つまりPWM以外)に設定される時のCOMnB1,0ピット機能を示します。

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

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

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

### 表12-6. 高速PWM動作比較B出力選択

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

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

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

表12-7. 位相基準PWM動作比較B出力選択

| COMnB1 | COMnB0 | 意味                                        |
|--------|--------|-------------------------------------------|
| 0      | 0      | 標準ポート動作 (OCnB切断)                          |
| 0      | 1      | (予約)                                      |
| 1      | 0      | 上昇計数時の比較一致でLow、下降計数時の比較一致でHighをOCnBt°ンへ出力 |
| 1      | 1      | 上昇計数時の比較一致でHigh、下降計数時の比較一致でLowをOCnBt°ンへ出力 |

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

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

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

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

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

表12-8. 波形牛成種別選択

| 农12.0. 放形工队性外送价 |       |       |       |                       |       |          |         |  |  |
|-----------------|-------|-------|-------|-----------------------|-------|----------|---------|--|--|
| 番号              | WGMn2 | WGMn1 | WGMn0 | タイマ/カウンタ動作種別          | TOP値  | OCRnx更新時 | TOVn設定時 |  |  |
| 0               | 0     | 0     | 0     | 標準動作                  | \$FF  | 即時       | MAX     |  |  |
| 1               | 0     | 0     | 1     | 8ビット位相基準PWM動作         | \$FF  | TOP      | BOTTOM  |  |  |
| 2               | 0     | 1     | 0     | 比較一致タイマ/カウンタ解除(CTC)動作 | OCRnA | 即時       | MAX     |  |  |
| 3               | 0     | 1     | 1     | 8ビット高速PWM動作           | \$FF  | BOTTOM   | MAX     |  |  |
| 4               | 1     | 0     | 0     | (予約)                  | -     | -        | -       |  |  |
| 5               | 1     | 0     | 1     | 位相基準PWM動作             | OCRnA | TOP      | BOTTOM  |  |  |
| 6               | 1     | 1     | 0     | (予約)                  | -     | _        | _       |  |  |
| 7               | 1     | 1     | 1     | 高速PWM動作               | OCRnA | BOTTOM   | TOP     |  |  |

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





## 12.9.3. タイマ/カウンタ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    |        |

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

| ピット         | 7     | 6     | 5 | 4 | 3     | 2    | 1    | 0    |        |
|-------------|-------|-------|---|---|-------|------|------|------|--------|
| \$2E (\$4E) | FOC1A | FOC1B | - | - | WGM12 | CS12 | CS11 | CS10 | TCCR1B |
| Read/Write  | W     | W     | R | R | R/W   | R/W  | R/W  | R/W  |        |
| 初期値         | 0     | 0     | 0 | 0 | 0     | 0    | 0    | 0    |        |

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

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

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

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

FOCnAtivhは常に0として読まれます。

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

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

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

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

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

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

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

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

58頁の「タイマ/カウンタ制御レシ、スタA(TCCRnA)」のWGMn1,0ビット記述をご覧ください。

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

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

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

| CSn2 | CSn1 | CSn0 | 意味                                |
|------|------|------|-----------------------------------|
| 0    | 0    | 0    | 停止 (タイマ/カウンタn動作停止)                |
| 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    | Tnピンの下降端 (外部クロック)                 |
| 1    | 1    | 1    | Tnピンの上昇端 (外部クロック)                 |

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

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

|                   |     | Ü   | 4   | 3   | 2   | 1   | Ü     |       |
|-------------------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$26 (\$46) (MSB) |     |     |     |     |     |     | (LSB) | TCNT0 |
| Read/Write R/W    | R/W | R/W | R/W | R/W | R/W | R/W | R/W   |       |
| 初期値 0             | 0   | 0   | 0   | 0   | 0   | 0   | 0     |       |

## 

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

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

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

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

## 12.9.8. タイマ/カウンタ1 比較Aレシ、スタ (Timer/Counter1 Output Compare A Register) OCR1A

| t'yh <u>7 6 5 4</u>        | 3 2 1 0         |
|----------------------------|-----------------|
| \$2C (\$4C) (MSB)          | (LSB) OCR1A     |
| Read/Write R/W R/W R/W R/W | R/W R/W R/W R/W |
| 初期値 0 0 0                  | 0 0 0 0         |

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

## 12.9.9. タイマ/カウンタ0 比較Bレシ、スタ (Timer/Counter0 Output Compare B Register) OCR0B

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

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

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

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





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

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

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

| ピット         | 7 | 6 | 5 | 4 | 3 | 2      | 1      | 0     |        |
|-------------|---|---|---|---|---|--------|--------|-------|--------|
| \$0C (\$2C) | _ | - | - | - | - | OCIE1B | OCIE1A | TOIE1 | TIMSK1 |
| Read/Write  | R | R | R | R | R | R/W    | R/W    | R/W   |        |
| 初期値         | 0 | 0 | 0 | 0 | 0 | 0      | 0      | 0     |        |

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

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

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

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

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

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

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

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

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

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

### 12.9.14. タイマ/カウンタ1割り込み要求フラグ レジスタ (Timer/Counter 1 Interrupt Flag Register) TIFR1

| ピット         | 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0    | _     |
|-------------|---|---|---|---|---|-------|-------|------|-------|
| \$0B (\$2B) | _ | - | - | - | - | OCF1B | OCF1A | TOV1 | TIFR1 |
| Read/Write  | R | R | R | R | R | R/W   | R/W   | R/W  |       |
| 初期値         | 0 | 0 | 0 | 0 | 0 | 0     | 0     | 0    |       |

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

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

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

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

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

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



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

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

これらフラグの設定はWGMn2~0ビット設定に依存します。59頁の波形生成種別ビット記述の表12-8.を参照してください。





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

タイマ/カウンタ0とタイマ/カウンタ1は同じ前置分周器部を共用しますが、タイマ/カウンタは異なる前置分周器設定ができます。以下の記述は両タイマ/カウンタに適用します。Tn (n=0,1)は一般名として使われます。

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

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

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

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

## 13.2. 外部クロック元

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

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



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

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

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

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



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

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

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

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

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

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

このビットが1のとき、タイマ/カウンタ0とタイマ/カウンタ1の前置分周器はリセットします。通常、TSMビットが設定(1)されている場合を除いて、このビットはハートウェアによって直ちに解除(0)されます。タイマ/カウンタ0とタイマ/カウンタ1は同じ前置分周器を共用し、この前置分周器のリセットが全てのタイマ/カウンタに影響を及ぼすことに注意してください(訳注:共通性から本行追加)。





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

## 14.1. 特徴

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

### 14.2. 概要

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

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



8ビットのUSIデータ レジスタ(USIDR)は入って来るデータと出て行くデータを含みます。これはデータ バス経由で直接的にアクセス可能ですが、その内容の複製を後で回収できるUSI緩衝レジスタ(USIBR)にも配置されます。直接USIデータ レジスタを読む場合、データが失われないことを保証するためにデータは可能な限り早く読まなければなりません。

最上位ビットは(動作種別設定に依存して)2つの出力ピンの1つに接続されます(**表14-1**.をご覧ください)。 データ入力採取と逆のクロック端にデータ出力の変更を遅らせるのが、USIデータ レジスタと出力ピン間のトランスペアレント(透過型)ラッチです。直列入力は(種別)設定に拘らず常にデータ入力(DI)ピンから採取されます。

4ビット計数器はデータ バス経由で読み書き両方ができ、溢れ割り込みを生成できます。この計数器とUSIデータ レジスタは同じクロック元によって同時にクロック駆動されます。これは受信または送信したビット数を数え、転送完了時に割り込みの生成を計数器に許します。外部クロック元が選択されると、この計数器が両クロック端で計数することに注意してください。これは計数レジスタがデータ ビット数でなく、クロック端数であることを意味します。クロックは3つの異なるクロック元(USCKピン、タイマ/カウンタ0の比較A一致、ソフトウェア)から選択できます。

2線クロック制御部(回路)は2線バスで<mark>開始条件</mark>が検出された時に割り込みを生成する設定にできます。<mark>開始条件</mark>検出後または計数器溢れ後にクロック ピンをLow〜保持することによって待ち状態を生成する設定にもできます。

## 14.3. 機能説明

### 14.3.1. 3線動作

USIの3線動作は直列周辺インターフェース(SPI)の動作種別0と1に準拠していますが、従装置選択(SS)ピン機能を持ちません。けれども、この特性(機能)は必要ならばソフトウェアで実現できます。この動作で使われるピン名はDI,DO,USCKです。



図14-2.は3線動作での2つのUSI部(一方は主装置、他方は従装置)動作を示します。このような方法で連結された2つの移動レジスタは8USCKクロック後、各々のレジスタのデータが交換されます。この同じクロック(USCK)がUSIの4ビット計数器も増加(+1)します。従って計数器溢れ割り込み要求フラグ(USIOIF)は転送が完了される時を決めるのに使えます。このクロックはPORTレジスタ経由USCKピン1/0交互切り替え、またはUSICRのUSITCビットへの1書き込みによる主装置装置ソフトウェアによって生成されます。



3線動作タイミングは図14-3.で示されます。図の最上部はUSCK周期参照基準です。これらの各周期に対して1ビットがUSI移動レシ、スタ (USIDR)に移動されます。USCKタイミングは両方の外部クロック動作について示されます。外部クロック動作0(USICS0=0)でのDIは上昇端で採取され、DOは下降端で変更(USIDRが1つ移動)されます。外部クロック動作1(USICS0=1)は外部クロック動作0に対して逆端を使用、換言すると下降端でデータを採取、上昇端で出力が変更されます。USIクロック動作種別はSPIデータ動作種別0と1に対応します。このタイミング図(図14-3.)を参照すると、バス転送は次の手順を含みます。

- 1. 主装置と従装置はデータ出力を設定し、使用規約に依存して出力駆動部を許可します(AとB)。この出力は直列データレジスタへの送信されるべきデータ書き込みによって設定します。出力の許可はポート方向レジスタの対応するビット設定によって行います。A点とB点はどんな特別な順番もありませんが、両方共にデータが採取されるC点よりも最低1/2USCK周期前でなければならないことに注意してください。これはデータ設定の必要条件を満足させるのを保証するために行わなければなりません。4ビット計数器は0にリセットします。
- 2. 主装置はUSCK線をソフトウェアで2度切り替えることによってクロック パルスを生成します(CとD)。主装置と従装置のデータ入力(DI)ピンの ビット値は最初のエッシ(C)でUSIによって採取され、データ出力は逆端(D)で変更されます。4ビット計数器は両端で計数します。
- 3. レジスタ(バイ)転送完了のために手順2.が8回繰り返されます。
- 4. 8クロック パルス(換言すると16クロック端)後、計数器が溢れて転送完了を示します。USI緩衝レジスタ(USIBR)が使われない場合、転送したバイト データは新規転送が開始され得るのに先立って直ぐに処置されなければなりません。溢れ割り込みはプロセッサがアイドル動作に設定されているなら、プロセッサを起動復帰します。使用規約によって、従装置は直ぐに出力をHi-Z設定にできます。





## 14.3.2. SPI主装置操作例

次のコードはSPI主装置としてのUSI使用法を実際に示します。

```
アセンブリ言語プログラム例
SPIM:
         OUT
                USIDR, R16
                                                                 ;送信データを設定
         LDI
                R16, (1<<USIOIF)
                                                                 ;USIOIFビットのみ1値を取得
         OUT
                                                                 ;フラグ解除/計数器初期化
                USISR, R16
                R16, (1<<USIWMO) | (1<<USICS1) | (1<<USICLK) | (1<<USITC)
         LDI
                                                                 ;3線動作クロック生成値を取得
SPIM_LP:
         OUT
                                                                 ;SCKクロック端発生
                USICR, R16
         SBIS
                USISR, USIOIF
                                                                 ;計数器溢れでスキップ
         RJMP
                SPIM LP
                                                                 ;計数器溢れまで継続
                                                                 ;受信データを取得
         IN
                R16, USIDR
         RET
                                                                 ;呼び出し元へ復帰
```

このコートは8命令(+RET)のみ使用の容量最適化です。このコート例はDOとUSCKピンがDDRBで出力として許可される仮定です。この関数が呼び出される前にR16レジスタへ格納した値は従装置に転送され、転送が完了された時に従装置から受信したデータがR16レジスタに格納されて戻ります。

2行目と3行目の命令は計数器溢れ割り込み要求フラケ (USIOIF)を解除(0)し、USI 4ビット計数器値を解除(=0)します。4行目と6行目の命令は3線動作、上昇端クロック、USITCストロープ計数、SCK出力交互切り替え(PORTB6)を設定します。この繰り返しは16回繰り返されます。

次のコードは最高速( $f_{SCK}=f_{CK}/2$ )でのSPI主装置としてのUSI使用法を実際に示します。

| アセンブリ言語 | 吾プログラム・ | 例                                                                                                            |                 |
|---------|---------|--------------------------------------------------------------------------------------------------------------|-----------------|
| SPIM_F: | OUT     | USIDR, R16                                                                                                   | ;送信データを設定       |
|         | LDI     | R16, (1< <usiwmo) (0<<usicso)="" (1<<usitc)<="" td=""  =""><td>;3線動作初期値を取得</td></usiwmo)>                    | ;3線動作初期値を取得     |
|         | LDI     | R17, (1< <usiwmo) (0<<usicso)="" (1<<usiclk)<="" (1<<usitc)="" td=""  =""><td>;3線動作クロック生成値を取得</td></usiwmo)> | ;3線動作クロック生成値を取得 |
| ;       |         |                                                                                                              |                 |
|         | OUT     | USICR, R16                                                                                                   | ;MSB転送          |
|         | OUT     | USICR, R17                                                                                                   | ;               |
|         | OUT     | USICR, R16                                                                                                   | ;ビット6転送         |
|         | OUT     | USICR, R17                                                                                                   | ;               |
|         | OUT     | USICR, R16                                                                                                   | ;ビット5転送         |
|         | OUT     | USICR, R17                                                                                                   | ;               |
|         | OUT     | USICR, R16                                                                                                   | ;ビット4転送         |
|         | OUT     | USICR, R17                                                                                                   | ;               |
|         | OUT     | USICR, R16                                                                                                   | ;ビット3転送         |
|         | OUT     | USICR, R17                                                                                                   | ;               |
|         | OUT     | USICR, R16                                                                                                   | ;ビット2転送         |
|         | OUT     | USICR, R17                                                                                                   | ;               |
|         | OUT     | USICR, R16                                                                                                   | ;ビット1転送         |
|         | OUT     | USICR, R17                                                                                                   | ;<br>;          |
|         | OUT     | USICR, R16                                                                                                   | ;LSB転送          |
|         | OUT     | USICR, R17                                                                                                   | ;               |
| ;       |         | DAG VOTED                                                                                                    | TEN WERL        |
|         | IN      | R16, USIDR                                                                                                   | ;受信データを取得       |
|         | RET     |                                                                                                              | ;呼び出し元へ復帰       |

### 14.3.3. 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)されるまで繰り返されます。

#### 14.3.4. 2線動作

USIの2線動作はI<sup>2</sup>C(TWI)バス規約に準拠していますが、出力のスリューレート制限と入力雑音濾波器がありません。この動作で使われる ピン名はSCLとSDAです。

図14-4.は2線動作での2つのUSI部(一方は主装置、他方は従装置)動作を示します。システム動作が使用通信構造に大きく依存するために示されるのは物理層のみです。この段階での主装置動作と従装置動作間の主な違いは常に主装置によって行われる直列クロック生成と、従装置だけがクロック制御部(回路)を使うことです。

クロック生成はソフトウェアで実行されなければなりませんが、移動動作は両装置で自動的に行われます。データの移動に関してこの動作種別で下降端でのクロックだけを実際に使うことに注意してください。従装置はSCLクロックをLowに強制することにより、転送の開始と終了で待ち状態(ウェイト ステート)を挿入できます。これは(主装置が)上昇端を生成してしまった後に主装置はSCL線が実際に開放されたかを常に検査しなければならないことを意味します。

このクロックが(4ビット)計数器も増加(+1)するため、計数器溢れ(USIOIF)は転送が完了されたことを示すのに使えます。このクロックは主装置によるPORTBレジスタ経由のSCLピン交互切り替えによって生成されます。



データ方向は物理層によって与えられません。データの流れを制御するためにTWIバスで使用したような或る種の規約が実装されなければなりません。





このタイミンク 図(図14-5.)を参照すると、ハブス転送は次の手順を含みます。

## 図14-5. 代表的な2線動作タイミング



- 1. 開始条件は主装置によるSCL線High中のSDA線Low強制によって生成されます(A)。SDAはUSIデータレジスタ(USIDR)のビット7への 0書き込みか、またはPORTレジスタで対応ビットを0に設定のどちらかによって強制実行できます。出力が許可されるにはデータ方向 (DDR)レジスタのビットが1に設定されなければならないことに注意してください。従装置の開始条件検出器論理回路(図14-6.参照) が開始条件を検出してUSISIFフラグを設定(1)します。このフラグは必要ならば割り込みを発生できます。
- 2. 加えて開始条件検出器は主装置がSCL線で上昇端を強制してしまった後にSCL線をLowに保持します(B)。これはアドレスを受信するために移動レジスタを設定する前に休止形態から起動復帰または他の処理を完了することを従装置に許します。これ(保持解除)は(4ビット)計数器をリセット(=0)して開始条件検出フラグ(USISIF)を解除(0)することによって行われます。
- 3. 主装置は転送されるべき最初のビットを設定してSCL線を開放します(C)。従装置はSCLクロックの上昇端でデータを採取して移動レジスタへ移動します。
- 4. 従装置アドレスとデータ方向(R/W)を含む8ビットが転送された後、従装置の(4ビット)計数器が溢れてSCL線がLowを強制されます(D)。 従装置は主装置の1つがアドレス指定してしまわない場合、SCL線を開放して新規開始条件を待ちます。
- 5. 従装置がアトンス指定されると、再びSCL線をLowに保持する前の応答(ACK)周期の間中、SDA線をLowに保持します(換言すると D点でSCLを開放する前に(4ビット)計数器レジスタは14に設定されなければなりません)。R/Wビットに依存して主装置か従装置は出力を許可します。このビットが設定(1)の場合、主装置読み込み動作が進行中です(換言すると従装置がSDA線を駆動します)。従装置は応答後(E)にSCL線をLowに保持することができます。
- 6. 主装置によって<mark>停止条件(F)</mark>か新規開始条件(<mark>再送開始条件</mark>)が与えられるまで全て同方向で複数バイが直ぐに転送できます。 従装置はより多くのデータを受信できない場合、最後に受信したバイトデータに応答しません。主装置が読み込み動作を行うとき、最後のバイルが転送された後の応答ビットをLowに強制することよってこの動作を終了しなければなりません。

### 14.3.5. 開始条件検出器

開始条件検出器は**図14-6**.で示されます。SDA線はSCL線の有効な採取を保証するために(50~300nsの範囲で)遅延されます。開始条件検出器は2線動作でだけ許可されます。

開始条件検出器は非同期に動作し、従ってパワータウン休止動作からプロセッサを起動できます。けれども使った規約がSCL保持時間で制限を持つかもしれません。従ってこの場合にこの特徴(機能)を使う時にCKSELヒュースによって設定する発振器起動時間(15頁の「クロック元」参照)も考慮に取り入れられなければなりません。より多くの詳細については72頁のUSISIFフラグ記述を参照してください。



### 14.4. USIでの代替使用

USI部を直列通信に使わないなら、柔軟な設計のため、代替処理を行うように設定できます。

**14.4.1. 半二重非同期データ転送** 3線動作で移動レジスタを使うことによってソフトウェアだけよりも簡潔で高性能のUART実装が可能です。

14.4.2. 4ビット計数器 4ビット計数器は溢れ割り込みとの自立型計数器として使えます。この計数器が外部的にクロック

駆動される場合、両クロック端が増加(+1)を発生することに注意してください。

**14.4.3**. **12ビット計数器** USIの4ビット計数器とタイマ/カウンタ0の組み合わせは12ビット計数器としての使用を許します。

14.4.4. **エッジ起動外部割り込み** 4ビット計数器を最大値(\$F)に設定することによって追加外部割り込みとして機能できます。溢れ フラグと割り込み許可ビットはこの外部割り込みに対して使われます。この特徴(機能)はUSICS1 ビットによって選択(=1)されます。

14.4.5. ソフトウェア割り込み 4ビット計数器の溢れ割り込みはクロック ストロープによって起動するソフトウェア割り込みとして使えま

## 14.5. USI用レジスタ

## 14.5.1. 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に設定されている時に保留割り込みありなら、これが直ちに実行されます。より多くの詳細については72頁で記述される開始条件検出割り込み要求フラグ(USISIF)を参照してください。

#### ■ ビット6 - USIOIE: 計数器溢れ割り込み許可 (Counter Overflow Interrupt Enable)

このビットを1に設定することが計数器溢れ割り込みを許可します。ステータス レジスタ(SREG)の全割り込み許可(I)ビットとUSIOIEビットが1に設定されている時に保留割り込みありなら、これが直ちに実行されます。より多くの詳細については72頁で記述される計数器溢れ割り込み要求フラグ(USIOIF)を参照してください。

### ■ ビット5,4 - USIWM1,0: 動作種別選択 (Wire Mode)

これらのビットは使われるべき動作種別(2または3線動作)を設定します。基本的に出力の機能だけがこれらのビットによって影響を及ぼされます。データとクロック入力は選択した動作種別によって影響を及ぼされず、常に同じ機能を持ちます。従って出力が禁止される時でもUSIデータ レジスタ(USIDR)とカウンタは外部的にクロック駆動でき、入力データが採取されます。USIWM1,0とUSI動作間の関連が表14-1.で要約されます。

| 表 1/1-1  | USI操作とUSIWM1.0の関係          |
|----------|----------------------------|
| 7V 14-1. | USII TEC USIMINI UVI 手II 示 |

| USIWM1 | USIWM0 | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | 0      | 出力、クロック保持、開始条件検出器は禁止。ポート ピンは標準として動作。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0      | 1      | 3線動作。DO,DI,USCKピンを使用。<br>データ出力(DO)ピンはこの動作でPORTBレジスタの対応ビットを無視します。けれども対応するDDRBビットは未<br>だデータ方向を制御します。ポート ピンが入力として設定(DDxn=0)されると、そのピンのプルアップはPORTBビット<br>によって制御されます。<br>データ入力(DI)と直列クロック(USCK)ピンは標準ポート操作に影響を及ぼしません。主装置として動作する時の<br>クロック パルスはデータ方向が出力に設定されている(DDxn=1)間のPORTBレジスタの交互切り替えによってソフト<br>ウェアで生成されます。USICRのUSITCピットがこの目的に使えます。                                                                                                                                                                                                   |
| 1      | 0      | 2線動作。SDA(DI)とSCL(USCK)ピンを使用。(注1)<br>直列データ(SDA)と直列クロック(SCL)ピンは双方向でオープントレイン出力駆動を使います。この出力駆動部は<br>DDRBレシ、スタでSDAとSCLに対応するピットの設定(=1)によって許可されます。<br>SDAピンに対して出力駆動部が許可されると、出力駆動部はUSIデータレジ、スタ(USIDR)の出力またはPORTB<br>レジ、スタの対応ピットがOならばSDA線をLowに強制します。さもなければ、SDA線は駆動されません(換言する<br>と開放されます)。SCLピン出力駆動部が許可されると、SCL線はPORTBレジ、スタの対応ピットがOなら、または<br>開始条件検出器によってLowを強制されます。さもなければSCL線は駆動されません。<br>SCL線は出力が許可され、開始条件検出器が開始条件を検出すると、Lowに保持されます。開始条件検<br>出フラク(USISIF)の解除(0)がその線を開放します。SDAとSCLピン入力はこの動作の許可によって影響を及<br>ぼされません。SDAとSCLピンのプルアップは2線動作で禁止されます。 |
| 1      | 1      | 2線動作。SDAとSCLピンを使用。<br>SCL線は計数器溢れが起こる時にも $Low$ 〜保持され、計数器溢れフラグ(USIOIF)が解除( $0$ )されるまで $Low$ に保持されることを除いて、上の2線動作と同じ動作です。                                                                                                                                                                                                                                                                                                                                                                                                              |

注1: DIとUSCKピンは動作種別間での混乱を避けるため、各々直列データ(SDA)と直列クロック(SCL)に改称されます。





#### ■ ビット3.2 - USICS1.0: クロック選択 (Clock Source Select)

これらのビットは移動レジスタと計数器に対するクロック元を設定します。外部クロック元(USCK/SCL)を使う時にデータ出力ラッチはデータ入力 (DI/SDA)の採取の逆端で出力が変更されるのを保証します。タイマ/カウンタ0比較A一致またはソフトウェア ストローブが選択されると、出力ラッチは透過で、従って出力は直ちに変更されます。

USICS1,0ビットの解除(=00)がソフトウェア ストローブ選択を許可します。この選択を使う時のUSICLKビットへの1書き込みはUSIデータ レジスタ (USIDR)と計数器の両方をクロック駆動します。外部クロック元(USICS1=1)に対してUSICLKビットはもはやストローブとして使われませんが、外部クロックとUSITCストローブビットによるソフトウェア クロック間を選択します。

表14-2.はUSIデータレンブタ(USIDR)と4ビット計数器に対して使われるクロック元とUSICS1,0、USICLK設定間の関連を示します。

表14-2. USICS1.0とUSICLK設定との関係

| USICS1 | USICS0 | USICLK | 移動レジスタ クロック元               | 4ビット計数器クロック元                       |  |  |
|--------|--------|--------|----------------------------|------------------------------------|--|--|
|        | 0      | 0      | クロックなし                     | クロックなし                             |  |  |
| 0      | U      | 1      | ソフトウェア クロック ストローフ゛(USICLK) | ソフトウェア クロック ストローフ゛(USICLK)         |  |  |
|        | 1      | X      | タイマ/カウンタ0比較A一致             | タイマ/カウンタ0比較A一致                     |  |  |
|        | 0      | 0      | 外部クロック上昇端                  | 外部クロック両端                           |  |  |
| 1      | 1      |        | 外部クロック下降端                  | クト音D2/ロック m] viii                  |  |  |
| 1      | 0      | 1      | 外部クロック上昇端                  | ソフトウェア クロック ストローフ゛(USITC)          |  |  |
|        | 1      | 1      | 外部クロック下降端                  | // // // // // // // // // (USIIC) |  |  |

### ■ ビット1 - USICLK: クロック ストローフ゛(Clock Strobe)

USICS1,0ビットのゼロ(=00)書き込みによってソフトウェア ストローブ任意選択が選択されたなら、このビット位置への1書き込みはUSIデータ レジスタ(USIDR)を1段移動して計数器を1つ増加します。このクロック ストローブが実行される時、直ちに、換言すると同じ命令周期内で出力が替わります。USIデータ レジスタ(USIDR)内に移動した値は直前の命令周期で採取されます。

外部クロック元が選択される(USICS1=1)と、USICLK機能はクロック ストローブからクロック選択レジスタに変更されます。この場合のUSICLKビットの設定(1)は4ビット計数器に対するクロック元としてのUSITCストローブを選びます(表14-2.参照)。

このビットは0として読まれます。

#### ■ ビット0 - USITC: クロック値切り替え (Toggle Clock Port Pin)

このビット位置に1を書くことはUSCK/SCL値を0から1、または1から0のどちらかへ切り替えます。この切り替えはデータ方向レジスタでの設定と無関係ですが、PORT値がピンで見られるべきなら、DDRビットが出力として設定(=1)されなければなりません。この特徴は主装置を実現する時の容易なクロック生成を許します。

外部クロック元が選択され(USICS1=1)、USICLKビットが1に設定されると、USITCストローブビットへの書き込みは直接的に4ビット計数器をクロック駆動します。これは主装置として動作する時に転送が行われる時の早い検出を許します。

このビットは0として読まれます。

### 14.5.2. 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線動作選択時に開始条件が検出されると、USISIFフラグが設定(1)されます。出力禁止動作または3線動作の選択時、USCKピンのどのエッジもがこのフラグを設定(1)します。

ステータスレジスタ(SREG)の全割り込み許可(I)ビットとUSI制御レジスタ(USICR)で開始条件検出許可(USISIE)ビットが設定(1)の場合にこのフラケが設定(1)されると、割り込みが生成されます。このフラケはUSISIFビットへの論理1書き込みによってのみ解除(0)されます。このビットの解除(0)は2線動作でのSCLの開始条件保持を解除(開放)します。

開始条件検出割り込みは全ての休止形態からプロセッサを起動します。

### ■ ビット6 - USIOIF: 計数器溢れ割り込み要求フラグ(Counter Overflow Interrupt Flag)

このフラグは4ビット計数器が溢れると(換言すると15から0への遷移で)設定(1)されます。SREGの全割り込み許可(I)ビットとUSICRで計数器溢れ割り込み許可(USIOIE)ビットが設定(1)の場合にこのフラグが設定(1)されると、割り込みが生成されます。このフラグはUSIOIFビットへの論理1書き込みによってのみ解除(0)されます。このビットの解除(0)は2線動作でのSCLの計数器溢れ保持を解除(開放)します。

計数器溢れ割り込みはアイドル休止動作からプロセッサを起動します。

#### ■ ビット5 - USIPF: 停止条件検出フラグ(Stop Condition Flag)

2線動作が選択された時に<mark>停止条件</mark>が検出されると、USIPFフラグが設定(1)されます。このフラグはこのビットへの1書き込みによって解除(0)されます。これが割り込み要求フラグでないことに注意してください。この合図は2線バス主装置調停の実装時に有用です。

#### ■ ビット4 - USIDC: 出力データ衝突フラグ(Data Output Collision Flag)

USIデータレジスタ(USIDR)のビット7(MSB)が物理ピン値と異なる時にこのビットは論理1です。このフラグは2線動作が使われる時にだけ有効です。この合図は2線バス主装置調停の実装時に有用です。

#### ■ ビット3~0 - USICNT3~0: 計数器値 (Counter Value)

これらのビットは現在の4ビット計数器値を反映します。この4ビット計数器値はCPUによって直接的に読み書きできます。

この4ビット計数器は外部クロック端検出器、タイマ/カウンタ0比較A一致、USICLKまたはUSITCストロープビットを使うソフトウェアのどれかによって 生成した各クロックに対して1つ増加します。このクロック元はUSICS1,0ビット設定に依存します。

外部クロック動作に対してUSITCストローブビットへの書き込みによって生成されるのをクロックに許す特別な特徴が付加されます。この特徴は外部クロック元(USICS1=1)設定とUSICLKへの1書き込みによって許可されます。

出力禁止動作(USIWM1,0=00)が選択されている時でも、外部クロック入力(USCK/SCL)が未だ計数器によって使われることに注意してください。

## 14.5.3. 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     |       |

データレジスタ(USIDR)は直接アクセスできますが、データの複製がUSI緩衝レジスタ(USIBR)でも得られます。

USI制御レジスタ(USICR)のUSICS1,0ビット設定に応じて(左)移動動作が実行され得ます。この移動動作は外部クロック端、タイマ/カウンタ0比較A一致により、またはUSICLKビット経由のソフトウェア直接で同期化できます。レジスタが書かれるのと同じ周期で直列クロックが起こると、レジスタは書いた値を含み、移動は実行されません。

2または3線動作種別が選択されない(USIWM1,0=00)時でも、外部データ入力(DI/SDA)と外部クロック入力(USCK/SCL)の両方が未だ USIデータ レシブスタによって使われ得ることに注意してください。

出力ピン(DOまたはSDA、動作種別依存)は出力ラッチを経由してデータレジスタの最上位ビット(ビット7)に接続されます。このラッチは逆のクロック端でのデータ入力採取とデータ出力変更を保証します。この出力ラッチは外部クロック元が選択される(USICS1=1)時に直列クロック周期の前半中が透過(トランスペプレント)で、内部クロック元が使われる(USICS1=0)時に定常的な透過です。ラッチが透過である限り、新規MSBが書かれると、出力は直ちに変更されます。

USIデータレジスタからの出力データを許可するために、ピンに対応するデータ方向レジスタ(DDxn)が1に設定されなければならないことに注意してください。

## 14.5.4. USI 緩衝レジスタ (USI Buffer Register) USIBR

| ピット         | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0     | _     |
|-------------|-------|---|---|---|---|---|---|-------|-------|
| \$10 (\$30) | (MSB) |   |   |   |   |   |   | (LSB) | USIBR |
| Read/Write  | R     | R | R | R | R | R | R | R     |       |
| 初期値         | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0     |       |

USIデータレジスタ(USIDR)からデータを読む代わりにUSI緩衝レジスタ(USIBR)が使えます。これはUSI制御の微妙なタイミングをなくして他のプログラム処理を扱うより多くの時間をCPUに与えます。USIのフラグはUSIDRを読む時と同様に設定されます。

USIデータレジスタ(USIDR)の内容は転送が完了される時にUSI緩衝レジスタ(USIBR)へ格納されます。





# 15. アナログ比較器

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

アナログ 比較器 ピン配置については2頁の「ピン配置」と45頁の表11-3.をご覧ください。

ADC入力多重器を使うにはA/D変換器電力削減(PRAD C)ビットが禁止されなけばなりません。これは電力削減レジスタ(PRR)内のPRADCビットを解除(0)することによって行われます。より多くの情報については22頁の「電力削減レジスタ(PRR)」をご覧ください。



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

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

| 表15-1. | 表15-1. アナログ比較器反転入力選択 |        |             |  |  |  |  |  |  |
|--------|----------------------|--------|-------------|--|--|--|--|--|--|
| ACME   | ADEN                 | MUX2~0 | アナログ比較器反転入力 |  |  |  |  |  |  |
| 0      | X                    | ххх    | AIN1        |  |  |  |  |  |  |
|        | 1                    | ххх    | AINI        |  |  |  |  |  |  |
|        | 0                    | 0 0 0  | ADC0        |  |  |  |  |  |  |
| 1      |                      | 0 0 1  | ADC1        |  |  |  |  |  |  |
|        | U                    | 0 1 0  | ADC2        |  |  |  |  |  |  |
|        |                      | 0 1 1  | ADC3        |  |  |  |  |  |  |

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

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

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

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

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

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

| ピット         | 7   | 6    | 5   | 4   | 3    | 2 | 1     | 0     |      |
|-------------|-----|------|-----|-----|------|---|-------|-------|------|
| \$30 (\$50) | ACD | ACBG | ACO | ACI | ACIE | - | ACIS1 | ACIS0 | ACSR |
| Read/Write  | R/W | R/W  | R   | 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がアナログ比較器の非反転入力に印加されます。34頁の「内部基準電圧」をご覧ください(訳注:共通性から本行追加)。

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

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

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

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

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

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

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

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

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

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

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

| 衣15-2. パカリ 比較益制り込み余件選択 |       |               |  |  |  |  |  |
|------------------------|-------|---------------|--|--|--|--|--|
| ACIS1                  | ACIS0 | 割り込み発生条件      |  |  |  |  |  |
| 0                      | 0     | 比較器出力の変移(トグル) |  |  |  |  |  |
| 0                      | 1     | (予約)          |  |  |  |  |  |
| 1                      | 0     | 比較器出力の下降端     |  |  |  |  |  |
| 1                      | 1     | 比較器出力の上昇端     |  |  |  |  |  |

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

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

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

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

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

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





# 16. A/D変換器

## 16.1. 特徴

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

## 16.2. 概要

ATtiny43Uは10tット逐次比較A/D変換器(ADC)が特徴です。A/D変換部の構成図が図16-1.で示されます。



このA/D変換器はA/D変換器への入力電圧が変換中に一定の値で保持されることを保証する採取&保持(S/H)回路を含みます。 アナログ多重器はポートAの下位4ビット、内部温度感知器、内部基準電圧、供給電圧(VBAT)、GNDを含み、ADCに接続される8つのシングルエント、チャネルを許します。

公称1.1Vの内蔵基準電圧がチップ上で提供されます。代わりにVCCをシングルェント、チャネル用の基準電圧として使えます。

# 16.3. ADC操作

A/D変換部は逐次比較を通してアナロケース力電圧を10ビットのデンダル値に変換します。最小値はGNDを表し、最大値は基準電圧を表します。A/D変換器基準電圧はA/D多重器選択レシ、スタ(ADMUX)の基準電圧選択(REFS)ビット書き込みによって選択されます。ADC基準電圧としてVCC電源または1.1V内部基準電圧を選択することができます。

アナログ、入力チャネルはADMUXのチャネル選択(MUX2~0)ビットへの書き込みによって選択されます。4つのADC入力ピン(ADC3~0)とVBAT 入力ピンのどれもがA/D変換器のシングル エンド、入力として選択できます。ADMUXレシ、スタのMUX2~0ビットに'111'を書くことによってチップ上の温度感知器が選択されます。

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

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

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

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

## 16.4. 変換の開始

電力削減レジブスタ(PRR)でA/D変換器電力削減(PRADC)ビットを解除(0)することにり、A/D変換部が給電されるのを保証してください(22 頁の「電力削減レジズタ(PRR)」をご覧ください)。

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

代わりに、変換は様々な起動元によって自動的に起動できます。自動起動はA/D変換制御/状態レシ、スタA(ADCSR A)のA/D変換自動起動許可(ADATE)ヒットの設定(1)によって許可されます。起動元はA/D変換制御/状態レシ、スタB(A DCSRB)のA/D変換起動元選択(ADTS2~0)ヒットの設定によって選択されます(起動元の一覧についてはADTSヒットの記述をご覧ください)。選択した起動信号上に上昇端が起きると、A/D変換用前置分周器がリセットし、変換が開始されます。これは一定間隔で変換を開始する方法を提供します。変換完了時に起動信号が未だ設定(1)されている場



合、新しい変換は開始されません。変換中にこの起動信号上で別の上昇端が起きると、そのエッジは無視されます。指定した割り込みが禁止またはステータス レジスタ(SREG)の全割り込み許可(I)ビットが解除(0)でも、割り込み要求フラグが設定(1)されることに注意してください。従って割り込みを起こさずに変換が起動できます。けれども次の割り込み要因で新規変換を起動するために、割り込み要求フラグは解除(0)されなければなりません。

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

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





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

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

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

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

次頁の表16-1.で要約されるように、通常の変換は13変換クロック周期で行われます。

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





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



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



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



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

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

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

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

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

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

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

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

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

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

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





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

このA/D変換基準電圧(VREF)はA/D変換に対する変換範囲を示します。VREFを越えるシングル エント・入力チャネルは\$3FFで打ち切るコートに帰着します。VREFはVCC、1.1V内部基準電圧のどちらかとして選択できます。1.1V内部基準電圧は内部増幅器と通して内部バント・ギャップ・基準電圧(VBG)から生成されます。

基準電圧源切り替え後の最初のA/D変換結果は不正確かもしれず、使用者はこの結果を破棄することが推奨されます。

## 16.7. 雑音低減機能

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

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

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

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

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

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

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



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

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

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

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

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

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

シングル エント、入力電圧のnビットA/D変換はGNDとVREF間を $2^n$ で直線的に変換します。最低値コート、は0として読み、最高値コート、は $2^n$ -1として読みます。

以下のように各パラメータは理想状態からの偏差を表します。

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

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

#### • 利得誤差 - 図16-10.

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

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

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

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

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

#### • 量子化誤差

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

#### • 絶対精度

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









# 16.11. A/D変換の結果

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

ここでの $V_{IN}$ は選択した入力ピンの電圧で、 $V_{REF}$ は選択した基準電圧です(82頁の表16-3.と表16-4.をご覧ください)。\$000はアナロケ GNDを表し、\$3FFは選択した基準電圧-1LSBを表します。結果は $0(\$000) \sim 1023$  (\$3FF)の符号なし2進数で表されます。

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

## 16.12. 温度測定

温度測定はシングル エント、ADC4チャネルに連結されるチップ上の温度感知器に基きます。A/D多重器選択(ADMUX)レジスタのチャネル選択 (MUX2~0)ビットへの、111、書き込みによるADC4チャネル選択がこの温度感知器を許可します。1.1V内部基準電圧も温度感知器測定で A/D変換器基準電圧源に選択されなければなりません。温度感知器が許可されると、A/D変換器は温度感知器上の電圧測定を単独変換動作(ADATE=0)で使うことができます。

測定した電圧は表16-2.で記述されたように温度に対して直線的関係を持ちます。 感度は概ね $1LSB/\mathbb{C}$ で、精度は使用者校正に依存します。代表的には、室温校正 との仮定で、単独温度校正後の測定精度は $\pm 10\mathbb{C}$ です。より良好な精度は校正に 対して2つの温度点を使うことで達せられます。

| 表16-2. 温度対感知器出力電圧(代表値) |       |      |       |  |
|------------------------|-------|------|-------|--|
| 温度(℃)                  | −40°C | +25℃ | +85°C |  |
| A/D変換値(LSB)            | 230   | 300  | 370   |  |

表16-2.に記載した値は代表値です。然しながら製法変化のため、温度感知器出力電圧は或るチップと別のチップで変化します。より正確な結果達成を可能とするために温度測定は応用ソフトウェアで校正できます。校正ソフトウェアは次式を使って行なえます。

## $T(温度)=k\times(ADCH<<8|ADCL)-TOS$

ここでADCH:ADCLはA/D変換器データレジスタ、kは固定傾斜係数、Tosは温度感知器オフセット値です。代表的に係数kは1.0に大変近く、単点校正ではこの係数を省略できるかもしれません。高精度が要求される場合、傾斜係数は2つ温度での測定を基に評価されるべきです。





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

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

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

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

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

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

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

| 表16-3. A/D変換部の基準電圧選択 |            |  |  |  |  |  |
|----------------------|------------|--|--|--|--|--|
| REFS                 | 基準電圧       |  |  |  |  |  |
| 0                    | 基準電圧にVCC使用 |  |  |  |  |  |
| 1                    | 内部1.1V基準電圧 |  |  |  |  |  |

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

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

■ ビット2~0 - MUX2~0: A/Dチャネル選択 (Analog Channel Selection Bits)

これらのビットの値は表16-4.で示されるようにA/D変換器へどのアナログ入力が接続されるかを選びます。ADC4チャネル選択は温度感知器を許可します。

これらのビットが変換中に変更される場合、その変更は変換が完了する(ADCSRAのADIF=1)まで実施しません。

## 表16-4. アナログ入力チャネル選択

| MUX2~0 | シングル エント・入力                     |
|--------|---------------------------------|
| 0 0 0  | ADC0(PA0)                       |
| 0 0 1  | ADC1(PA1)                       |
| 0 1 0  | ADC2(PA2)                       |
| 0 1 1  | ADC3(PA3)                       |
| 100    | 0V(GND)                         |
| 1 0 1  | 内部1.1V基準電圧 ( <mark>注1</mark> )  |
| 1 1 0  | VBAT ( <mark>注2</mark> )        |
| 111    | ADC4(温度感知器) ( <mark>注3</mark> ) |
|        |                                 |

注1: 内部基準電圧へ切り替えた後でADCは測定が安定するのに先立って1msの安定時間が必要です。これ以前の変換開始は信頼ができないかもしれません。この安定時間中にADCは許可されていなければなりません。

**注2**: 分圧器が存在するため、このチャネルが選択されている限り、100k $\Omega$ の分圧器 経由でVBATからGNDへ電流が流れます。

**注3**: 81頁の「**温度測定**」をご覧ください。

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

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

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

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

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

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

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

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

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

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

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

このビットが1を書かれ、SREGの全割り込み許可(I)ビットが設定(1)されていると、A/D変換完了割り込みが活性に(許可)されます。

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

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

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

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

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

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

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

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

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

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

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

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

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

表16-6. A/D変換自動起動元選択 ADTS2 | ADTS1 | ADTS0 起動元 連続変換動作 0 0 0 0 0 アナログ比較器 0 0 外部割り込み要求0 0 タイマ/カウンタ0比較A一致 0 0 タイマ/カウンタ0溢れ 0 タイマ/カウンタ1比較A一致 0 タイマ/カウンタ1溢れ タイマ/カウンタ1比較B一致





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

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

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

ADCLが読まれると、A/DデータレジスタはADCHが読まれるまで更新されません。従ってこの結果が左揃え、且つ8ビットを越える精度が必要とされないなら、ADCHを読むことで用が足ります。さもなくばADCLが初めに、その後にADCHが読まれなければなりません。

A/D変換制御状態レジスタB(ADCSRB)の左揃え選択(ADLAR)ビットとA/D多重器選択(ADMUX)レジスタのA/Dチャネル選択(MUX2~0)ビットは、本レシ、スタから結果を読む方法に影響を及ぼします。ADLARが設定(1)されると結果は左揃えにされます。ADLARが解除(0)されていると(既定)、結果は右揃えにされます。

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

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

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

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

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

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

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

## 17.1. 特徴

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

## 17.2. 概要

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

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

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

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

デバッグWIREが使われるシステムの設計時、正しい動作のために次の注意点が厳守されなければなりません。



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

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

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

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

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

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

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

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

## 17.6. デバッグWIRE用レジスタ

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

## 17.6.1. ティック WIRE データレジスタ (debugWIRE Data Register) DWDR



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





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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

・ページ書き込み中、CPUは停止されます。

## 18.4. 自己プログラミング中のフラッシュ メモリのアトレス指定

Zポインタ(レジスタ)はSPM命令でのアドレス指定に使われます。

| ピット      | 15  | 14  | 13  | 12  | 11  | 10  | 9  | 8  |
|----------|-----|-----|-----|-----|-----|-----|----|----|
| ZH (R31) | Z15 | Z14 | Z13 | Z12 | Z11 | Z10 | Z9 | Z8 |
| ピット      | 7   | 6   | 5   | 4   | 3   | 2   | 1  | 0  |
| ZL (R30) | Z7  | Z6  | Z5  | Z4  | Z3  | Z2  | Z1 | Z0 |

フラッシュ メモリがページで構成されるため(92頁の**表19-8**.参照)、プログラム カウンタ(アト・レス ポインタ)は2つの違う領域を持つように取り扱われます。1つの領域は下位側ビットから成り、ページ内の語(ワード)をアト・レス指定し、一方上位側ビットはそのページをアト・レス指定します。これは次頁の図18-1.で示されます。 ページ消去とページ書き込み操作が個別にアト・レス指定されることに注意してください。従ってソフトウェアはページ消去とページ書き込み操作の両方で同じページをアト・レス指定することが最も重要です。

LPM命令はアドレスを格納するのにZポインタを使います。この命令はフラッシュ メモリのバイト単位をアドレス指定するので、Zポインタの最下位ビット(Z0)も使われます。



## 18.5. SPM命令での書き込み時のEEPROM書き込みによる妨害

EEPROM書き込み動作がフラッシュ メモリへの全ソフトウェア プログラミングを妨げることに注意してください。ソフトウェアからのヒューズと施錠ビット読み出しもEEPROM書き込み動作中、妨げられます。使用者はEEPROM制御レジスタ(EECR)のEEPROMプログラム許可(EEPE)ビットを検査し、SPM命令制御/状態レジスタ(SPMCSR)へ書く前に、このビットが解除(0)されているのを確認することが推奨されます。

## 18.6. ソフトウェアからの施錠・ヒュース、と識票データの読み出し

ファームウェアに関してデバイスのヒュース'と施錠ビットを読むことが可能です。加えてファームウェアはデバイス識票銘刻部(92頁参照)からデータを読むこともできます。

注: プログラム(0)されたヒューズと施錠ビットは0として読めます。非プログラム(1)にされたヒューズと施錠ビットは1として読めます。

#### 18.6.1. ファームウェアからの施錠ビット読み出し

SPMCSRでフラッシュ/施錠ビット読み込み(RFLB)とSPM操作許可(SPMEN)ビットを設定(1)した後の3CPU周期内でLPM命令が発行された後、転送先レジスタ内に施錠ビット値が返されます。RFLBとSPMENビットは施錠ビット読み出しの完了で、または3CPU周期内にLPM命令が実行されないか、または4CPU周期内にSPM命令が実行されない場合、自動的に解除(0)されます。通常、RFLBとSPMENビットが解除(0)されるのはLPMの作用です。

施錠ビットを読むには以下の手続きに従ってください。

- 1. Zポインタに\$0001を格納してください。
- 2. SPMCSRでRFLBとSPMENtivlを設定(1)してください。
- 3. 3クロック周期内にLPM命令を実行してください。
- 4. LPM転送先レシブスタから施錠ビット値を読んでください。

成功なら、転送先レジスタの内容は次のとおりです。



より多くの情報については90頁の「プログラム メモリとデータ メモリ用施錠ビット」をご覧ください。

## 18.6.2. ファームウェアからのヒュース ビット読み出し

ヒューズバイトを読む方法はアドレスが異なるだけで上記の施錠ビット読み出しと同様です。 ヒューズ下位バイト(FLB)を読むには以下の手続きに従ってください。

- 1. Zポインタに\$0000を格納してください。
- 2. SPMCSRでRFLBとSPMENtットを設定(1)してください。
- 3. 3クロック周期内にLPM命令を実行してください。
- 4. LPM転送先レジスタからFLB値を読んでください。

成功なら、転送先レジスタの内容は次のとおりです。

| ピット | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|------|------|------|------|------|------|------|------|
| Rd  | FLB7 | FLB6 | FLB5 | FLB4 | FLB3 | FLB2 | FLB1 | FLB0 |

ヒュース、下位バイの配置と詳細記述については91頁の表19-5.を参照してください。





ヒューズ上位バイト(FHB)を読むには単にZポインタ内のアドレスを<mark>\$0003</mark>に置き換え、前の手続きを繰り返してください。成功なら、転送先レ ジスタの内容は次のとおりです。

| ピット | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|------|------|------|------|------|------|------|------|
| Rd  | FHB7 | FHB6 | FHB5 | FHB4 | FHB3 | FHB2 | FHB1 | FHB0 |

ヒュース、上位バイの配置と詳細記述については91頁の表19-4.を参照してください。

ヒュース・拡張バイト(FEB)を読むにはZポインタ内のアドレスを\$0002に置き換え、直前の手続きを繰り返してください。成功なら、転送先レジスタの内容は次のとおりです。

| ピット | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|-----|---|---|---|---|---|---|---|------|
| Rd  | _ | - | - | _ | _ | _ | - | FEB0 |

ヒュース、拡張バイトの配置と詳細記述については91頁の表19-3.を参照してください。

#### 18.6.3. ファームウェアからのデバイス識票銘刻読み出し

デバイス識票銘刻部の内容を読むには以下の手続きに従ってください。

- 1. Zポインタに銘刻指示子を格納してください。
- 2. SPMCSRでデハイス識票銘刻読み込み(RSIG)とSPM操作許可(SPMEN)ビットを設定(1)してください。
- 3. 3クロック周期内にLPM命令を実行してください。
- 4. SPMENt ットが解除(0)されるために3クロック周期待機してください。
- 5. LPM転送先レジスタから表データ値を読んでください。

RSIGとSPMENのビットは3 CPU周期後に自動解除(0)されます。RSIGとSPMENが解除されると、LPM命令は「命令要約」の説明で記述されるように動きます。

以下のプログラム例をご覧ください。

## <mark>アセンブリ言語プログラム例</mark> DSIT read: LDI

SIT\_read: LDI ZH,0 LDI ZL,1

LDI R17, (1<<RSIG) | (1<<SPMEN)

OUT SPMCSR, R16

LPM R16, Z

RET

;表指示子上位バイ値設定

;表指示子下位バイト値設定

;RSIG,SPMEN=1値取得 ;RSIG,SPMEN=1設定

;\$0001位置の識票値取得

;呼び出し元へ復帰

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

成功なら、転送先レシ、スタの内容は92頁の「デバイス識票銘刻部」項で記述されたとおりです。

## 18.7. フラッシュ メモリ データ化けの防止

低VCCの期間中、CPUとフラッシュ メモリの正しい動作に対して供給電圧が低すぎるためにフラッシュ メモリのプログラムが不正にされ得ます。 これらの問題はフラッシュ メモリを使う基板段階の装置と同じで、同じ設計上の解決策が適用されるべきです。

フラッシュ メモリのプログラム化けは電圧が低すぎる時の2つの状態によって起こされます。1つ目としてフラッシュ メモリへの通常の書き込み手順は正しく動作するための最低電圧が必要です。2つ目として供給電圧が低すぎると、CPU自身が命令を間違って実行し得ます。

フラッシュ メモリ化けは次の推奨設計によって容易に避けられます(1つは必須)。

- ・不十分な供給電源電圧の期間中、AVR RESETを活性(Low)に保ってください。これは動作電圧が検出電圧と一致するなら、内部 低電圧検出器(BOD)を許可することによって行えます。そうでなければ外部低VCCリセット保護回路が使えます。書き込み操作進 行中にリセットが起こると、その書き込み動作は供給電源電圧が充分であれば完了されます。
- ・低VCCの期間中、AVRコアをパワーダウン休止動作に保ってください。これはCPUが命令の復号と実行を試みるのを防ぎ、SPMCSR 従ってフラッシュ メモリを予期せぬ書き込みから効果的に保護します。

## 18.8. SPM命令使用時のフラッシュ メモリ用プログラミング(書き込み)時間

校正された内蔵RC発振器がフラッシュメモリアクセス時間に使われます。表18-1.はCPUからのフラッシュメモリアクセスに対する代表的なプログラジング時間を示します。

| 項目                                           | 最小    | 最大    |
|----------------------------------------------|-------|-------|
| SPM命令によるフラッシュ書き込み(ヘーシ・消去、ヘーン・書き込み、施錠ビット書き込み) | 3.7ms | 4.5ms |

注: 最小と最大の時間は(項目の)個別操作毎に対してです(<mark>訳注</mark>:共通性から本注追加)。

## 18.9. 自己プログラミング用レジスタ

18.9.1. SPM命令制御/状態レジスタ (Store Program Memory Control and Status Register) SPMCSR

このレジスタはプログラムメモリ操作を制御するために必要とする制御ビットを含みます。

| ピット         | 7 | 6 | 5    | 4    | 3    | 2     | 1     | 0     |        |
|-------------|---|---|------|------|------|-------|-------|-------|--------|
| \$37 (\$57) | _ | - | RSIG | СТРВ | RFLB | PGWRT | PGERS | SPMEN | SPMCSR |
| Read/Write  | R | R | R/W  | R/W  | R/W  | R/W   | R/W   | R/W   |        |
| 初期値         | 0 | 0 | 0    | 0    | 0    | 0     | 0     | 0     |        |

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

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

■ **ビット5 - RSIG**: **デバイス識票銘刻読み込み** (Read Device Signature Imprint Table) (<mark>訳注</mark>:整合性のため本ビット追加) SPMCSRでRSIGとSPMENが設定(1)された後の3クロック周期内のLPM命令実行はデバイス識票銘刻部から(Zポインタ値に依存する)選択

したデータを転送先レシ、スタ内に返します。詳細については92頁の「デバイス識票銘刻部」をご覧ください。

■ ビット4 - CTPB: ページー時緩衝部消去 (Clear Temporary Page Buffer)

ぺーシー時緩衝部を満たしている間にCTPBビットが1を書かれると、ペーシー・中緩衝部は消去され、データが失われます。

■ ビット3 - RFLB: ヒューズ/施錠ビット読み込み (Read Fuse and Lock Bits)

SPMCSRでRFLBとSPMENが設定(1)された後の3クロック周期内のLPM命令は(ZポインタのZ0に依存して)ヒュース、ビットまたは施錠ビットのどちらかを転送先レシ、スタに読みます。詳細については87頁の「ソフトウェアからの施錠、ヒュース、と識票データの読み出し」をご覧ください。

■ ビット2 - PGWRT : ページ書き込み (Page Write)

このビットがSPMENと同時に1を書かれると、次の4クロック周期内のSPM命令は一時緩衝部に格納したデータでページ書き込みを実行します。 ページ アドレスはZポインタの上位部から取得されます。 R1とR0のデータは無視されます。 PGWRTビットはページ書き込みの完了で、または4クロック周期内にSPM命令が実行されない場合、自動的に解除(0)されます。 ページ全体の書き込み動作中に、CPUは停止されます。

■ ビット1 - PGERS: ページ消去 (Page Erase)

このビットがSPMENと同時に1を書かれると、次の4クロック周期内のSPM命令はページ消去を実行します。 ページアドレスはZポインタの上位部から取得されます。R1とR0のデータは無視されます。PGERSビットはページ消去の完了で、または4クロック周期内にSPM命令が実行されない場合、自動的に解除(0)されます。 ページ全体の消去中、CPUは停止されます。

■ ビット0 - SPMEN: SPM操作許可 (Store Program Memory Enable)

このビットは次の4クロック周期間、SPM命令を許可します。このビットがRSIG,CTPB,RFLB,PGWRT,PGERSのどれかと共に1に設定されると、別のところで記述されるように続くSPM命令は特別な意味を持ちます。SPMENだけが書かれると、続くSPM命令はZポインタによってアドレス指定したページ一時緩衝部へR1:R0の値を格納します。Zレジスタの最下位ビットは無視されます。SPMENビットはSPM命令の完了で、または4クロック周期内にSPM命令が実行されない場合、自動的に解除(0)されます。ページ消去とページ書き込み中、SPMENビットはその動作が完了されるまで1に留まります。

下位6ビットに100001, 010001, 001001, 000101, 000011, 000001以外のどんな組み合わせを書いても無効です。





# 19. メモリ プログラミング

本項はATtiny43Uのメモリプログラミングに対する各種方法を記述します。

# 19.1. プログラム メモリとデータ メモリ用施錠ビット

ATtiny43Uは非プログラム(1)のままか、表19-2.で一覧される付加機能を得るためにプログラム(0)できる2つの施錠ビットを提供します。この施錠ビットはチップ消去指令でのみ1に消去できます。

デバイスは独立したブートローダ領域を持ちません。自己プログラミング許可(SELFPRGEN)ヒュースがプログラム(0)される場合にSPM命令はフラッシュメモリ全体に対して許可され、さもなければ禁止されます。

プログラム メモリは例え施錠ビットが設定されていても、デバッグWIRE許可(DWEN)ヒューズがプログラム(0)されていると、デバッグWIREインターフェース経由で読み出せます。従って施錠ビット保護が必要とされる場合、DWENヒューズを解除(1)することによってデバッグWIREが常に禁止されるべきです。

表19-1. 施錠ビット バイトの内容

| 名称  | ピット番号 | 意味                                                                                   | 既定値(注)     |
|-----|-------|--------------------------------------------------------------------------------------|------------|
| _   | 7     |                                                                                      | 1 (非プログラム) |
| _   | 6     |                                                                                      | 1 (非プログラム) |
| _   | 5     |                                                                                      | 1 (非プログラム) |
| _   | 4     |                                                                                      | 1 (非プログラム) |
| _   | 3     |                                                                                      | 1 (非プログラム) |
| _   | 2     |                                                                                      | 1 (非プログラム) |
| LB2 | 1     | フラッシュとEEPROMメモリに対する一般保護用施錠ビット                                                        | 1 (非プログラム) |
| LB1 | 0     | //ツンユ <eepkom (3)="" 9="" th="" モゲ(cx)="" 一放休護用地政にが<=""><th>1 (非プログラム)</th></eepkom> | 1 (非プログラム) |

注: 0はプログラム、1は非プログラムを意味します。

表19-2 施錠ビットの保護種別

| メモリ施錠ビット |     |     | 保護種別                                                                              |
|----------|-----|-----|-----------------------------------------------------------------------------------|
| LB 種別    | LB2 | LB1 | 直列、並列、またはデバッグWIRE経由プログラミングに対する保護                                                  |
| 1        | 1   | 1   | メモリ施錠機能は機能しません。                                                                   |
| 2        | 1   | 0   | フラッシュ、EEPROMの更なるプログラミング(書き込み)が禁止されます。ヒュース、ビットが固定されます。 ( <mark>注1</mark> )         |
| 3        | 0   | 0   | フラッシュ、EEPROMの更なるプログラミング(書き込み)と照合(読み出し)が禁止されます。ヒュース'ヒットが固定されます。( <mark>注1</mark> ) |

注: 0はプログラム、1は非プログラムを意味します。

注1: 施錠ビットを書く前にヒューズビットを書いてください。デバッグWIREは全面的に禁止されます。

施錠ビットはデバイス ファームウェアによって読むこともできます。87頁の「**ソフトウェアからの施錠,ヒューズと識票のデータ読み出し**」項をご覧ください。

## 19.2. ヒュース゛ヒ゛ット

ATtiny43Uには3つのヒュース、ハイトがあります。**表19-3.~5**.は全てのヒュース、の概略機能とヒュース、ハイト内でどのように配置されるかを示します。ヒュース、ログラムされると、論理0として読まれることに注意してください。

## 表19-3. 拡張ヒューズバイト一覧

| 名称             | ピット          | 意味             | 既定値                     |
|----------------|--------------|----------------|-------------------------|
| _              | 7 <b>~</b> 1 |                | 1 (非プログラム)              |
| SELFPRGEN (注1) | 0            | 自己プログラミング機能許可。 | 1 (非プログラム) 自己プログラミング不許可 |

注1: SPM命令許可。86頁の「フラッシュ メモリの自己プログラミング」をご覧ください。

#### 表19-4. ヒュース、上位バイー覧

| 名称                  | ピット | 意味                                           | 既定値                                      |
|---------------------|-----|----------------------------------------------|------------------------------------------|
| RSTDISBL (注1)       | 7   | PB3がI/OピンかまたはRESETピンかを選択します。                 | 1 (非プログラム) PB3はRESETピン                   |
| DWEN ( <b>注2</b> )  | 6   | ディックWIRE機能許可。                                | 1 (非プログラム) ディブックWIRE不許可                  |
| SPIEN ( <b>注3</b> ) | 5   | 直列プログラミング許可。                                 | <ul><li>(プログラム) 低電圧直列プログラミング許可</li></ul> |
| WDTON ( <b>注4</b> ) | 4   | ウォッチドッグタイマ常時有効。                              | 1 (非プログラム) WDTはWDTCSRで許可                 |
| EESAVE              | 3   | チップ消去からEEPROM内容を保護。                          | 1 (非プログラム) EEPROMは未保護                    |
| BODLEVEL2           | 2   |                                              | 1 (非プログラム)                               |
| BODLEVEL1           | 1   | 低電圧検出(BOD)リセットの制御と検出電圧選択。( <mark>注5</mark> ) | 1 (非プログラム)                               |
| BODLEVEL0           | 0   |                                              | 1 (非プログラム)                               |

注1: RSTDISBLヒュース、の記述については47頁の「ポートBの交換機能」をご覧ください。RSTDISBLヒュース、がプログラム(0)された後は ヒュース、を変更して更なるプログラミングを許すのに並列プログラミングが使われなければなりません。

注2: DWENtューズは施錠ビット保護が必要とされる場合、非プログラム(1)にされなければなりません。

注3: SPIENヒュース は直列プログラミングでアクセスできません。

注4: 詳細については34頁の表9-1.をご覧ください。

注5: BODLEVELヒューズの符号化については104頁の表20-5.をご覧ください。

#### 表19-5. ヒューズ下位バイト一覧

| 名称                   | ピット | 意味                          | 既定值                                                |
|----------------------|-----|-----------------------------|----------------------------------------------------|
| CKDIV8 ( <b>注1</b> ) | 7   | システム クロック 8分周選択。            | 0 (プログラム) 8分周                                      |
| CKOUT ( <b>注2</b> )  | 6   | システムクロック出力許可。               | 1 (非プログラム) 不許可                                     |
| SUT1                 | 5   | <br>  起動時間選択。 ( <u>注</u> 3) | 1 (非プログラム)                                         |
| SUT0                 | 4   | 性影   時間送れ。 (注3)             | <mark>0</mark> (プ <sup>°</sup> ログ <sup>*</sup> ラム) |
| CKSEL3               | 3   |                             | <mark>0</mark> (プ <sup>°</sup> ログ <sup>*</sup> ラム) |
| CKSEL2               | 2   | <br>  クロック種別選択。             | <mark>0</mark> (プ <sup>°</sup> ログ <sup>*</sup> ラム) |
| CKSEL1               | 1   | 7 P 7 7 1 1 1 1 1 1 1       | 1 (非プログラム)                                         |
| CKSEL0               | 0   |                             | <mark>0</mark> (プ <sup>°</sup> ロク <sup>*</sup> ラム) |

**注1**: 詳細については17頁の「システム クロック前置分周器」をご覧ください。

注2: CKOUTはポートB3に出力することをシステム クロックに許します。詳細については17頁の「クロック出力緩衝部」をご覧ください。

**注3**: 既定値は既定クロック元に対する最大起動時間になります。詳細については16頁の表6-5.をご覧ください。

注4: 既定設定は8MHz校正付き内蔵RC発振器になります。詳細については15頁の表6-1.をご覧ください。

施錠ビット1(LB1)がプログラム(0)されると、ヒュース゛ビットが固定されることに注意してください。施錠ビットをプログラム(0)する前にヒュース゛ビットをプログラミング(書き込み)してください。ヒュース゛ビットの状態はチップ消去によって影響されません。

ヒュース<sup>\*</sup> ビットはデバイス ファームウェアによって読むこともできます。87頁の「**ソフトウェアからの施錠,ヒューズと識票のデータ読み出し**」項をご覧ください。

## 19.2.1. ヒュース のラッチ

ヒューズ値はデバイスがプログラミング動作へ移行する時にラッチされ、ヒューズ値への変更はデバイスがプログラミング動作を去るまで無効です。 これは一旦プログラム(0)されると直ぐに効果があるEESAVEヒューズには適用されません。ヒューズは電源投入でもラッチされます。





## 19.3. デバイス識票銘刻部

デバイス識票銘刻部はデバイス識票、発振器校正データのような一連の各種デバイス情報に使われる専用のメモリ領域です。表19-6.で略 述されるようにこのメモリ領域の殆どは内部使用に予約されています。

#### 表19-6. デバイス識票銘刻内容

| アト・レス     | 上位小仆                                 |
|-----------|--------------------------------------|
| \$00      | 識票バイト0 ( <mark>注1</mark> )           |
| \$01      | 校正付き内蔵RC発振器用校正データ( <mark>注2</mark> ) |
| \$02      | 識票バイト1 ( <mark>注1</mark> )           |
| \$03      | (内部使用予約)                             |
| \$04      | 識票バイト2 ( <mark>注1</mark> )           |
| \$05~\$2A | (内部使用予約)                             |

注1: より多くの情報については「識票バイ」をご覧ください。 **注2**: より多くの情報については「校正値バイ」をご覧ください。

## 19.3.1. 識票バイ

全てのAtmelマイクロ コントローラはデバイスを識別する3バイトの識票符号を持ちます。この符 号は低電圧直列と高電圧直列の両プログラミング動作で、またデバイスが施錠されていて も読めます。

識票バイトはデバイス ファームウェアによって読むこともできます。 87頁の「**ソフトウェアからの施** 錠、ヒューズと識票のデータ読み出し」項をご覧ください。

この3バイトの識票バイトはデバイス識票銘刻部と呼ばれる分離された空間に存在します。 ATtiny43U用の識票バイトは表19-7.で与えられます。

# 表19-7. デバイスの識別番号(ID)

| 如口来旦      | 識票バイト アドレス |        |        |  |
|-----------|------------|--------|--------|--|
| 部品番号      | \$0000     | \$0001 | \$0002 |  |
| ATtiny43U | \$1E       | \$92   | \$0C   |  |

## 19.3.2. 校正バイ

表19-6.で示されるようにATtiny43Uのデバイス識票銘刻部は内蔵RC発振器用に1バイの校正データを含みます。リセット中、校正付き内 蔵RC発振器の正しい周波数を保証するために、このバ小が発振校正(OSCCAL)レジスタへ自動的に書かれます。

校正バイトはデバイス ファームウェアによって読むこともできます。87頁の「**ソフトウェアからの施錠、ヒューズと識票のデータ読み出し**」項をご覧くだ さい。

# 19.4. へージ 容量 表19-8. フラッシュ メモリのヘージ 数とヘージ の語数

| デバイス      | 全容量            | ページ容量 | PCWORD | ページ数 | PCPAGE | PCMSB |
|-----------|----------------|-------|--------|------|--------|-------|
| ATtiny43U | 2Kワート (4Kハ イト) | 32ワート | PC4∼0  | 64   | PC10∼5 | 10    |

## 表19-9. EEPROMメモリのページ数とページの語数

| テ゛ハ゛イス    | 全容量   | ページ容量 | PCWORD | ページ数 | PCPAGE | EEAMSB |
|-----------|-------|-------|--------|------|--------|--------|
| ATtiny43U | 64バイト | 4バイト  | EEA1∼0 | 16   | EEA5∼2 | 5      |

## 19.5. 並列プログラミング

この項はATtiny43Uのプログラム用フラッシュメモリ、データ用EEPROM、メモリの施錠ビット、ヒューズ ビットの並列プログラミングと照合の方法を記述します。特記事項を除いて、パルス幅は最低250nsと仮定されます。

## 19.5.1. 信号名

本項でATtiny43Uのいくつかのピンは並列プログラミング中の機能を表す信号名で参照されます。図19-1.と表19-10.をご覧ください。後続の表で記載されないピンはピン名によって参照されます。



## 表19-10. 信号名とピン名の関係

| 信号名           | ピン名   | 入出力 | 機能                                                       |  |  |
|---------------|-------|-----|----------------------------------------------------------|--|--|
| WR            | PA0   | 入力  | 書き込みパルス(負論理)                                             |  |  |
| XA0           | PA1   | 入力  | CLKI動作ビット0                                               |  |  |
| XA1/BS2(注)    | PA2   | 入力  | CLKI動作ビット1 / 上位/下位バイト選択2 (0:下位, 1:上位) (ヒューズビット用)         |  |  |
| PAGEL/BS1 (注) | PA3   | 入力  | ページー時緩衝部に設定 / 上位/下位バイ選択1 (0:下位, 1:上位) (一般用)              |  |  |
| ŌĒ            | PA4   | 入力  | 出力許可(負論理)                                                |  |  |
| RDY/BSY       | PA5   | 出力  | <b>0</b> (Low): 多忙(プログラミング中) <b>1</b> (High): 準備可(指令受付可) |  |  |
| DATA          | PB7∼0 | 入出力 | 双方向データ バス (OE=Low時出力)                                    |  |  |

注: このピンは2つの異なる制御信号に対して使われます。以降の記述で、通常1つの信号(名)だけが参照されます。例えば、「BS1に正パルスを与える」は「PAGEL/BS1に正パルスを与える」と同等です。(訳注)共通性から本注追加

#### 表19-11.プログラミング動作移行用のピン値

| ピン名       | シンホ゛ル          | 値 |
|-----------|----------------|---|
| PAGEL/BS1 | Prog_enable[3] | 0 |
| XA1/BS2   | Prog_enable[2] | 0 |
| XA0       | Prog_enable[1] | 0 |
| WR        | Prog_enable[0] | 0 |

XA0とXA1ピンはCLKIピンが正パルスを与えられる時に実行される動作を決めます。このビット符号化は表19-12.で示されます。

#### 表19-12 XA0とXA1の符号化(機能)

| 2411 | Z to the particular to the par |                                     |  |  |  |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--|--|--|
| XA1  | XA0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | CLKIパルス時の動作                         |  |  |  |
| 0    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | フラッシュまたはEEPROMのアトレス取得(上位/下位はBS1で指定) |  |  |  |
| 0    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | テータ取得 (フラッシュ時の上位/下位はBS1で指定)         |  |  |  |
| 1    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 指令取得                                |  |  |  |
| 1    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ア仆ル(動作なし)                           |  |  |  |

#### 表19-13. 指令バイトのビット符号化

| 指令バイ             | 指令の機能         | 指令バイト            | 指令の機能             |
|------------------|---------------|------------------|-------------------|
| \$80 (1000 0000) | チップ。消去        | \$08 (0000 1000) | 識票バイト、校正バイト読み出し   |
| \$40 (0100 0000) | ヒューズビット書き込み   | \$04 (0000 0100) | ヒューズビット、施錠ビット読み出し |
| \$20 (0010 0000) | 施錠ビット書き込み     | \$02 (0000 0010) | フラッシュ メモリ読み出し     |
| \$10 (0001 0000) | フラッシュ メモリ書き込み | \$03 (0000 0011) | EEPROM読み出し        |
| \$11 (0001 0001) | EEPROM書き込み    |                  |                   |





## 19.6. 並列プログラミング手順

## 19.6.1. 並列プログラミング動作への移行

次に示す方法がデバイスを(高電圧)並列プログラミング動作にします。

- ① VCCとGND間に4.5~5.5Vを印加します。
- ② RESETをLow(0)にし、CLKIを少なくとも6回、交互に(High/Low)切り替えます。
- 3 93頁の表19-11.で一覧されるProg\_enablet シを全てLow(0)に設定し、最低100ns待ちます。
- ④ RESETに11.5~12.5Vを印加します。+12VがRESETに印加されてしまった後100ns以内のProg\_enabletプンのどんな動きも、デバイスのプログラミング動作への移行を失敗させます。
- (5) 新規指令送出前に少なくとも50us間待ちます。

## 19.6.2. 効率的なプログラミングへの考慮

設定した指令とアドレスはプログラミング中、維持されます。効率的なプログラミングを行うために次を考慮すべきです。

- ・複数のメモリ領域を読み書きする時に指令設定は一度だけ必要です。
- ・チップ消去後のフラッシュ メモリと(EESAVEヒューズがプログラム(O)されている場合を除き)EEPROM全体の内容は\$FFなので、値が\$FFのデータ書き込みを飛ばします。
- ・アトレス上位バイトはフラッシュ メモリで新規256語(ワート) 枠、EEPROMで新規256バイト枠の読み書き前に一度だけ必要です。この考慮は識票バイ・読み出しにも適用されます。

#### 19.6.3. チップ 消去

チップ消去はフラッシュ メモリ、EEPROM(<mark>注1</mark>)、施錠ビットを消去します。施錠ビットはプログラム メモリが完全に消去されてしまうまでリセット(消去)されません。ヒュース、ビットは変更されません。チップ消去はフラッシュ メモリやEEPROMが再書き込みされる前に実行されなければなりません。

注1: EESAVEヒューズがプログラム(0)されていると、EEPROMはチップ消去中、保護されます。

「チップ消去」指令設定

- ① XA1をHigh(1)、XA0をLow(0)に設定します。これは指令設定を許可します。
- ② BS1をLow(0)に設定します。
- ③ DATAを\$80(1000 0000)に設定します。これはチップ消去指令です。
- ④ CLKIに正パルスを与えます。これはチップ消去指令を設定します。
- ⑤ WRに負パルスを与えます。これはチップ消去を開始します。RDY/BSYがLow(0)になります。
- ⑥ 次の指令を設定する前にRDY/BSYがHigh(1)になるまで待ちます。

## 19.6.4. フラッシュ メモリ書き込み (次頁の図19-3.タイミングを参照)

フラッシュ メモリはヘージで構成されます(92頁の**表19-8.**参照)。フラッシュ メモリへ書く時にプログラム データはヘージ緩衝部にラッチされます。これは同時に書かれることをプログラム データの1ヘージに許します。次の手順は完全なフラッシュ メモリの書き込み方法を記述します。

#### A. 「フラッシュ メモリ書き込み」指令設定

- ① XA1をHigh(1)、XA0をLow(0)に設定します。これは指令設定を許可します。
- **②** BS1をLow(0)に設定します。
- ③ DATAを\$10(0001 0000)に設定します。これはフラッシュ メモリ書き込み指令です。
- ④ CLKIに正パルスを与えます。これはフラッシュ メモリ書き込み指令を設定します。

#### B. アドレス下位バイト設定

- ① XA1をLow(0)、XA0をLow(0)に設定します。これはアドレス設定を許可します。
- ② BS1をLow(0)に設定します。これは下位アドレス(バイト)を選択します。
- ③ DATAにアドレス下位ハイハ(\$00~\$FF)を設定します。
- ④ CLKIに正パルスを与えます。これはアドレス下位バイを設定します。

#### C. データ下位バイト設定

- ① XA1をLow(0)、XA0をHigh(1)に設定します。これはデータ設定を許可します。
- ② DATAにデータ下位バイト(\$00~\$FF)を設定します。
- ③ CLKIに正パルスを与えます。これはデータ下位バイを設定します。

#### D. データ上位バイト設定

- ① BS1をHigh(1)に設定します。これは上位バイを選択します。
- ② XA1をLow(0)、XA0をHigh(1)に設定します。これはデータ設定を許可します。
- ③ DATAにデータ上位ハーイト(\$00~\$FF)を設定します。
- ④ CLKIに正パルスを与えます。これはデータ上位バイを設定します。

#### E. 活動(操作)なし

F. 緩衝部全体が満たされるか、または(必要な)全てのデータが緩衝部内に設定されるまで、B~Eを繰り返し

アト・レス内の下位ビットがページ内の語(ワード)位置を指示する一方、上位ビットがフラッシュ メモリ内のページをアドレス指定します。これは**図 19-2.**で図示されます。ページ内の語アドレスに8ビット未満が必要とされる場合(ページ容量<256)、アドレス下位バイトの最上位(側)ビットが ページ書き込み実行時のページアドレスに使われることに注意してください。

## G. アドレス上位バイ設定

- (1) XA1をLow(0)、XA0をLow(0)に設定します。これはアドレス設定を許可します。
- ② BS1をHigh(1)に設定します。これは上位アドレス(バイト)を選択します。
- ③ DATAにアトレス上位ハイト(\$00~\$03/\$07/\$0F)を設定します。
- ④ CLKIに正パルスを与えます。これはアドレス上位バイを設定します。

## H. ペーシ 書き込み

- (1) BS1をLow(0)に設定します。
- ② WRに負パルスを与えます。これはデータのページ全体の書き込みを開始します。RDY/BSYがLow(0)になります。
- (3) RDY/BSYがHigh(1)になるまで待ちます。
- I. フラッシュ メモリ全部が書かれるか、または(必要な)全データが書かれてしまうまで、B~Hを繰り返し

#### J. ページ書き込み終了

- ① XA1をHigh(1)、XA0をLow(0)に設定します。これは指令設定を許可します。
- ② DATAを\$00(0000 0000)にします。これは無操作指令です。
- ③ CLKIに正パルスを与えます。これは無操作指令を設定し、内部書き込み信号がリセットされます。









## 19.6.5. EEPROM書き込み

EEPROMはペーシで構成されます(92頁の表19-9.参照)。EEPROMを書く時にデータはペーシ、緩衝部にラッチされます。これは同時に書かれることをデータの1ペーシに許します。データ用EEPROMメモリの書き込み方法は次のとおりです。(指令、アトレス、データ設定の詳細については95頁の「フラッシュ メモリの書き込み」を参照。図19-4.タイミング参照。)

- 1. EEPROM書き込み指令\$11(0001 0001)を設定します。(「フラッシュ メモリ書き込み」のAを参照)
- 2. アドレス上位バイト(\$00)を設定します。(「フラッシュ メモリ書き込み」のGを参照)
- 3. アドレス下位バイト(\$00~\$3F)を設定します。(「**フラッシュ メモリ書き込み**」のBを参照)
- **4.** データ バイト(\$00~\$FF)を設定します。(「**フラッシュ メモリ書き込み**」の**○**を参照)
- 5. 活動(操作)なし
- K. 緩衝部全体が満たされるまで3~5を繰り返します。
- L. EEPROMへ ージ 書き込み
  - BS1をLow(0)に設定します。
  - ② WRに負パルスを与えます。これはEEPROMページ書き込みを開始します。RDY/BSYがLow(0)になります。
  - ③ 次のページを書く前に、RDY/BSYがHigh(1)になるまで待ちます。



## 19.6.6. フラッシュ メモリ読み出し

フラッシュ メモリの読み出し方法は次のとおりです。(指令とアドレス設定の詳細については95頁の「**フラッシュ メモリの書き込み**」を参照)

- 1. フラッシュ メモリ読み出し指令\$02(0000 0010)を設定します。(「フラッシュ メモリ書き込み」のAを参照)
- 2. アドレス上位バイト(\$00~\$07)を設定します。(「フラッシュ メモリ書き込み」のGを参照)
- 3. アト・レス下位ハーイト(\$00~\$FF)を設定します。(「フラッシュ メモリ書き込み」のBを参照)
- 4. BS1をLow(0)、OEをLow(0)に設定します。フラッシュ メモリ語(ワート)の下位バイが直ぐにDATAで読めます。
- 5. BS1をHigh(1)に設定します。フラッシュメモリ語(ワート)の上位バイトが直ぐにDATAで読めます。
- 6. OEをHigh(1)に設定します。DATAはHi-Zになります。

## 19.6.7. EEPROM読み出し

データ用EEPROMの読み出し方法は次のとおりです。(指令とアトレス設定の詳細については95頁の「フラッシュ メモリの書き込み」を参照)

- 1. EEPROM読み出し指令\$03(0000 0011)を設定します。(「フラッシュ メモリ書き込み」のAを参照)
- 2. アドレス上位ハイト(\$00)を設定します。(「フラッシュ メモリ書き込み」のGを参照)
- 3. アドレス下位ハイト(\$00~\$3F)を設定します。(「フラッシュ メモリ書き込み」のBを参照)
- **4.** BS1をLow(0)、○EをLow(0)に設定します。EEPROMのハイトデータが直ぐにDATAで読めます。
- 5. OEをHigh(1)に設定します。DATAはHi-Zになります。

## 19.6.8. ヒュース ビット書き込み (訳注:原書での拡張/上位/下位ヒューズ項を1つに纏めました。)

各ヒュース、ハ・イトの書き込み方法は次のとおりです。(指令とデータ設定の詳細については95頁の「フラッシュ メモリの書き込み」を参照)

- 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. ヒューズバ仆対応BS1,BS2設定 |         |         |  |  |  |  |
|-----------------------|---------|---------|--|--|--|--|
| ヒュース゛ハ゛イト             | BS1     | BS2     |  |  |  |  |
| 拡張バイト                 | Low(0)  | High(1) |  |  |  |  |
| 上位バイト                 | High(1) | Low(0)  |  |  |  |  |
| 下位バイト                 | Low(0)  | Low(0)  |  |  |  |  |





## 19.6.9. 施錠ビット書き込み

施錠ビットの書き込み方法は次のとおりです。(指令とデータ設定の詳細については95頁の「フラッシュメモリの書き込み」を参照)

- 1. 施錠ビット書き込み指令\$20(0010 0000)を設定します。(「フラッシュ メモリの書き込み」のAを参照)
- 2. データ下位ハーイト(としてデータ)を設定します。0=プログラム、1=無変化です。LB保護種別3が設定(LB1とLB2がプログラム(0))されると、どの外部的なプログラミング動作種別によってもブート施錠ビットはプログラミングできません。(「フラッシュメモリの書き込み」のCを参照)
- 3. WRに負パルスを与え、RDY/BSYがHighになるまで待ちます。

施錠ビットはチップ消去の実行によってのみ解除(1)できます。

#### 19.6.10. ヒュース゛ビットと施錠ビットの読み出し

ヒュース、ビットと施錠ビットの読み出し方法は次のとおりです。(指令設定の詳細については95頁の「フラッシュ メモリの書き込み」を参照)

- 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になります。



## 19.6.11. 識票バ 小読み出し

識票バイトの読み出し方法は次のとおりです。(指令とアドレス設定の詳細については95頁の「**フラッシュ メモリの書き込み**」を参照)

- 1. 識票バイト読み出し指令\$08(0000 1000)を設定します。(「フラッシュ メモリの書き込み」のAを参照)
- 2. アドレス下位バイト(\$00~\$02)を設定します。(「フラッシュ メモリの書き込み」のBを参照)
- 3. BS1をLow(0)、OEをLow(0)に設定します。選択した識票バイが直ぐにDATAで読めます。
- 4. OEをHigh(1)に設定します。DATAはHi-Zになります。

## 19.6.12. 校正バ 小読み出し

校正バイの読み出し方法は次のとおりです。(指令とアドレス設定の詳細については95頁の「フラッシュ メモリの書き込み」を参照)

- 1. 校正バイト読み出し指令\$08(0000 1000)を設定します。(「フラッシュ メモリの書き込み」のAを参照)
- 2. アドレス下位バイトに\$00を設定します。(「フラッシュ メモリの書き込み」のBを参照)
- 3. BS1をHigh(1)、OEをLow(0)に設定します。校正バイが直ぐにDATAで読めます。
- 4. OEをHigh(1)に設定します。DATAはHi-Zになります。

## 19.7. 直列プログラミング

フラッシュ メモリとEEPROMの両方はRESETがGNDに引かれている間に直列SP In スを使ってプログラミングできます。この直列インターフェースはSCK入力、MOSI 入力、MISO出力から成ります。右の図19-7.をご覧ください。

RESETがLowに設定された後、書き込み/消去操作が実行され得るのに先立って初めにプログラミング許可命令が実行されることを必要とします。

#### 表19-14. 直列プログラミング用ピン配置

| 信号名 ピン名 |     | 入出力 | 機能      |
|---------|-----|-----|---------|
| MOSI    | PB4 | 入力  | 直列データ入力 |
| MISO    | PB5 | 出力  | 直列データ出力 |
| SCK     | PB6 | 入力  | 直列クロック  |



注1: デバイスが内蔵発振器で動作する場合、CLKI ピッパスカウラルを接続する必要はありません。

EEPROMをプログラミングする時に自動消去周期が自動書き込み動作内に組み入れられ(直列プログラミングのみ)、チップ消去命令を先に実行する必要がありません。チップ消去操作はプログラム(フラッシュメモリ)とEEPROM両方の全メモリ位置の内容を\$FFにします。

CKSELヒューズによる有効なクロックが与えられなければなりません。直列クロック (SCK)入力のLowとHighの区間の最小値は次のように定義されます。

 $f_{\rm CK} < 12 {\rm MHz}: Low区間> 2 {\rm CPU}$ クロック周期  $f_{\rm CK} < 12 {\rm MHz}: High区間> 2 {\rm CPU}$ クロック周期  $f_{\rm CK} \ge 12 {\rm MHz}: Low区間> 3 {\rm CPU}$ クロック周期  $f_{\rm CK} \ge 12 {\rm MHz}: High区間> 3 {\rm CPU}$ クロック周期

## 19.7.1. 直列プログラミング手順

ATtiny43Uに直列データを書く時にデータはSCKの上昇端で行われ、ATtiny43Uから読む時にデータはSCKの下降端で行われます。タイミングの詳細については図20-8と図20-9.をご覧ください。

直列プログラミング動作でのATtiny43Uのプログラミングと照合は次の手順が推奨されます(形式は表19-16.参照)。

1. 電源投入手順:

RESETとSCKがLow(0)に設定されている間にVCCとGND間へ電源を印加します。いくつかのシステムで電源投入中、SCKがLowに保持されるのを書き込み器が保証できません。この場合、SCKがLow(0)に設定されてしまった後、RESETは最低2CPUクロック周期幅の正パルスを与えられなければなりません。このパルス時間は最低 $t_{RST}$ +2CPUクロック周期でなければなりません。 $t_{RST}$ (RESETピンの最小パルス幅)の定義については $t_{RST}$ 0つも、このパルスに覧ください。

- 2. 最低20ms待ち、MOSIピンにプログラミング許可命令を送ることによって直列プログラミングを許可してください。
- 3. 通信が同期を外していると、直列プログラミング命令は動作しません。同期していると、プログラミング許可命令の第3㎡小送出時に第2 パイト(\$53)が戻ります。この戻りが正しいかどうかによらず、命令の4㎡小全てが送信されなければなりません。\$53が戻らない場合、RESETに正パルスを与え、新規プログラミング許可命令を行ってください。
- 4. フラッシュ メモリは1ペーシ、単位で書かれます。ページ、容量は92頁の表19-8.で得られます。このメモリページ、はページ、設定命令と共にアドレスの下位5+1ビットとデータを供給することによって1小、イトづつ設定されます。ページが正しく設定されるのを保証するため、与えられたアドレスにデータ上位ハ、イトが適用される前にデータ下位ハ、イトが設定されなければなりません。プログラム メモリのページ、はアドレスの上位6ビットを含むページ、書き込み命令の設定によって(フラッシュ メモリこ)格納されます。ポーリング(BSY/RDY)が使われない場合、使用者は次のページ、を行う前に最低twD\_FLASH(表19-15.参照)待たなければなりません。フラッシュ書き込み操作完了前の(ポーリング、以外の)直列プログラミング、インターフェースでのアクセスは不正な書き込み結果になり得ます。
- 5. EEPROMはペーシー単位かバイト単位のどちらかでプログラミングできます。

**バイト単位**: EEPROMは適切なEEPROM書き込み命令と共にアドレスとデータを供給することによって1バイト単位で書かれます。EEP ROMのメモリ位置は新規データが書かれるのに先立って始めで自動的に消去されます。ポーリング(BSY/RDY)が使われない場合、次のバイトを行う前に最低twp eeprom(表19-15.参照)待たなければなりません。

**ページ単位**: EEPROMの1ページはEEPROMぺージ設定命令と共にアドレスの下位2ビットとデータを供給することによって1バイトづつ設定されます。EEPROMぺージはアドレスの上位4ビットを含むEEPROMぺージ書き込み命令によって(EEPROMに)格納されます。EEPROMぺージ アクセス使用時、EEPROMぺージ設定命令で設定したバイト位置だけが変更されます。残りの位置は無変化で留まります。ポーリング(BSY/RDY)が使われない場合、次のページ(表19-9.参照)を行う前に最低twp\_eeprom(表19-15.参照)待たなければなりません。チップ消去されたデバイスでの\$FFデータは書かれる必要がありません。

- 6. どのメモリ位置も選択したアドレスの内容を直列出力MISOに読み戻す読み出し命令を使うことによって照合できます。
- 7. プログラミング作業終了時、RESETは通常動作を開始するため、High(1)に設定できます。
- 8. 電源OFF手順(必要とされるならば)
  - ・RESETをHigh(1)に設定します。
  - VCC電源をOFFにします。





表19-15. ヒューズ,フラッシュ,EEPROM次位置書き込み前の待機時間

| シンホ゛ル      | 最低待機時間 | 備考            |  |  |  |  |  |
|------------|--------|---------------|--|--|--|--|--|
| two_fuse   | 4.5ms  | ヒュース゛書き込み     |  |  |  |  |  |
| two_flash  | 4.5ms  | フラッシュ メモリ書き込み |  |  |  |  |  |
| twd_eeprom | 4.0ms  | EEPROM書き込み    |  |  |  |  |  |
| two_erase  | 9.0ms  | チップ消去         |  |  |  |  |  |

# 19.7.2. 直列プログラミング命令一式

表19-16.と次頁の図19-8.は命令一式を記述します。

表19-16 直列プログラミング命令一式

| 命令                  |       | 命令     | ·形式    |         | │<br>│      備考                           |
|---------------------|-------|--------|--------|---------|------------------------------------------|
| נד ווו              | 第1バイト | 第2バイト  | 第3バイト  | 第4小小    | 1佣 右                                     |
| プログラミング許可           | \$AC  | \$53   | \$00   | \$00    |                                          |
| チップ消去               | \$AC  | \$80   | \$00   | \$00    |                                          |
| 多忙/準備可検査            | \$F0  | \$00   | \$00   | 状態値     | 最下位ビットが多忙フラグ。                            |
| 設定系命令               |       |        |        |         |                                          |
| 拡張アドレス設定(注1)        | \$4D  | \$00   | 拡張アドレス | \$00    |                                          |
| フラッシュページ内上位バ仆設定     | \$48  | アドレス上位 | アドレス下位 | 上位バイ    |                                          |
| フラッシュ ヘ゜ーシ゛内下位ハ゛仆設定 | \$40  | アドレス上位 | アドレス下位 | 下位バイ    |                                          |
| EEPROMページ内バイ設定      | \$C1  | \$00   | ページ内位置 | バイト     | <b>注</b> :ページ内指示以外のビットは <mark>0</mark> 。 |
| 読み出し命令              |       |        |        |         |                                          |
| フラッシュ メモリ上位バ・仆読み出し  | \$28  | アドレス上位 | アドレス下位 | 上位バイ    |                                          |
| フラッシュ メモリ下位バ・仆読み出し  | \$20  | アドレス上位 | アドレス下位 | 下位バイ    |                                          |
| EEPROM読み出し          | \$A0  | アドレス上位 | アドレス下位 | バイト     |                                          |
| 施錠ビット読み出し           | \$58  | \$00   | \$00   | 施錠ビット値  |                                          |
| 識票バイト読み出し           | \$30  | \$00   | アトレス   | 識票バイト   |                                          |
| ヒューズ下位読み出し          | \$50  | \$00   | \$00   | ヒューズ下位  |                                          |
| ヒューズ上位読み出し          | \$58  | \$08   | \$00   | ヒューズ上位  |                                          |
| 拡張ヒューズ読み出し          | \$50  | \$08   | \$00   | 拡張ヒューズ  |                                          |
| 校正バ仆読み出し            | \$38  | \$00   | \$00   | 校正バイ    |                                          |
| 書き込み命令(注2)          |       |        |        |         |                                          |
| フラッシュ ヘ゜ーシ゛書き込み     | \$4C  | アドレス上位 | アドレス下位 | \$00    |                                          |
| EEPROMバ朴書き込み        | \$C0  | アドレス上位 | アトレス下位 | バイト     |                                          |
| EEPROMページ書き込み       | \$C2  | アドレス上位 | アトレス下位 | \$00    | 注:ページ指示以外のアドレス ビットは0。                    |
| 施錠ビット書き込み           | \$AC  | \$E0   | \$00   | 施錠ビット値  |                                          |
| ヒューズ下位書き込み          | \$AC  | \$A0   | \$00   | ヒュース・下位 |                                          |
| ヒューズ上位書き込み          | \$AC  | \$A8   | \$00   | ヒュース・上位 |                                          |
| 拡張ヒューズ書き込み          | \$AC  | \$A4   | \$00   | 拡張ヒューズ  |                                          |

注1:全命令が全デバイスで利用可能な訳ではありません。

**注2**: プログラム用メモリにアクセスする命令は語(ワート)アトレスを使います。このアトレスはヘージ範囲内で乱順にできます。

**注**:・施錠ビットとヒューズ値はプログラムが0、非プログラムが1です。将来との互換性のため、未使用のヒューズと施錠ビットは非プログラム(1)にすべきです。

- ・ヒュース、施錠ビット、識票バイト、校正バイト、ページ容量については対応項を参照してください。
- ・プログラミングと書き込み器に関する応用記述については http://www.atmel.com/avr をご覧ください。
- ・第4バイトの赤背景はホスト読み込み(デバイス出力)を示します。

多忙/準備可検査バイト データ出力のLSBが1なら、プログラミング操作が未だ保留(動作中)です。次の命令が実行される前に本ビットが0に戻るまで待ってください。

同じページ内で、下位バイトデータは上位バイトデータに先行して格納されなければなりません。

データがヘージ緩衝部に格納された後にEEPROMヘージをプログラムしてください。次頁の図19-8.をご覧ください。



(<mark>訳補</mark>) フラッシュ メモリ、EEPROM、ヘ゜ーシ゛緩衝部内のアト・レス(位置)指定に使われるビットはメモリ容量とヘ゜ーシ゛構成に依存します。 ATtiny43 Uでのこれらの指定方法は次表で要約されます。

# 表19-A. アドレス(第2,3バイト)指定法

| 命令              | 第2小个      | 第3小小      | 備考                           |
|-----------------|-----------|-----------|------------------------------|
| 拡張アドレス設定        |           |           | 該当命令なし                       |
| フラッシュヘ゜ージ内バイト設定 | 0000 0000 | 000L LLLL | ATtiny43U : L=PC4~0          |
| EEPROMページ内バイ設定  | 0000 0000 | 0000 00LL | ATtiny43U : L=EEA1~0         |
| フラッシュメモリ読み出し    | 0000 ОННН | LLLL LLLL | ATtiny43U : H=PC10~8,L=PC7~0 |
| EEPROM読み出し      | 0000 0000 | OOLL LLLL | ATtiny43U : L=EEA5~0         |
| フラッシュヘ゜ージ・書き込み  | 0000 OHHH | LLL0 0000 | ATtiny43U : H=PC10~8,L=PC7~5 |
| EEPROMバイ書き込み    | 0000 0000 | OOLL LLLL | ATtiny43U : L=EEA5~0         |
| EEPROMページ書き込み   | 0000 0000 | 00LL LL00 | ATtiny43U : L=EEA5~2         |





# 20. 電気的特性

## 20.1. 絶対最大定格 (警告)

## (警告)

絶対最大定格を超える負担はデバイスに定常的な損傷を与えます。 絶対最大定格は負担の定格を示すためだけのもので、この値また は、この仕様書の動作特性で示された値を超える条件で動作する ことを示すものではありません。長時間の最大定格での使用はデバイスの信頼性を損なう場合があります。

## 20.2. DC特性

表20-1. DC特性 TA=-40°C~+85°C

| シンボル  | DC特性 TA=-40℃~+85℃<br>項目                   | 条件                 | 最小                   | 代表 (注1)    | 最大                    | 単位    |
|-------|-------------------------------------------|--------------------|----------------------|------------|-----------------------|-------|
| 77111 | - 横口                                      | VCC=1.8~2.4V       | -0.5                 | 1042 (721) | 0.2VCC ( <b>注2</b> )  | 平位    |
| VIL   | Lowレベル入力電圧                                | VCC=2.4~5.5V       | -0.5                 |            | 0.3 VCC ( <b>注2</b> ) |       |
| · IL  | Lowレヘ・ル入力電圧 (RESET) (注3)                  | VCC=1.8~5.5V       | -0.5                 |            | 0.2VCC ( <b>注2</b> )  |       |
|       | Highレヘル入力電圧                               | VCC=1.8~2.4V       | 0.7VCC ( <b>注4</b> ) |            | VCC+0.5               |       |
| Vih   | (RESETを除く)                                | VCC=2.4~5.5V       | 0.6VCC ( <b>注4</b> ) |            | VCC+0.5               |       |
|       | Highレベル入力電圧(RESET) (注3)                   | VCC=1.8∼5.5V       | 0.9VCC ( <b>注4</b> ) |            | VCC+0.5               |       |
|       |                                           | IOL=20mA, VCC=5V   |                      |            | 0.8                   |       |
|       | Lレヘル出力電圧 (注5)<br>(PB1,PB2,PB4,PB5ピン) (注6) | IOL=10mA, VCC=3V   |                      |            | 0.6                   | V     |
| Vor   | (PB1,PB2,PB4,PB5t°ン) ( <b>注6</b> )        | IOL=4mA, VCC=1.8V  |                      |            | 0.5                   |       |
| Vol   | [レヘ・ル出力電圧 ( <b>注5</b> )                   | IOL=10mA, VCC=5V   |                      |            | 0.8                   |       |
|       | Lレベル出力電圧 (注5)<br>(RESETピンを除く全I/Oピン) (注8)  | IOL=5mA, VCC=3V    |                      |            | 0.6                   |       |
|       | (AESETE V 是例(主) (注6)                      | IOL=2mA, VCC=1.8V  |                      |            | 0.5                   |       |
|       | Hレベル出力電圧 (注7) (RESET ピンを除く全I/Oピン) (注8)    | IOH=-10mA, VCC=5V  | 4.0                  |            |                       |       |
| Voh   |                                           | IOH=-5mA, VCC=3V   | 2.3                  |            |                       |       |
|       |                                           | IOH=-2mA, VCC=1.8V | 1.4                  |            |                       |       |
| IIL   | I/OビンLowレベル入力漏れ電流                         | VCC=5.5V           |                      | <0.05      | 1                     | μA    |
| IIH   | I/OビンHighレベル入力漏れ電流                        | 確実なH/L範囲           |                      | <0.05      | 1                     | μει   |
| Rpu   | I/Oピン プルアップ抵抗                             | VCC=5.5V, Low入力    | 20                   |            | 50                    | kΩ    |
| 141 0 | RESETピン プルアップ抵抗                           | VCC=5.5V, Low入力    | 30                   |            | 80                    | 17.52 |
|       | 昇圧変換器なし                                   | VCC=2V, 1MHz       |                      | 0.2        | 0.55                  |       |
|       |                                           | VCC=3V, 4MHz       |                      | 1.3        | 2.5                   |       |
|       | (電力削減レシブスタ(PRR)全ビット=1)                    | VCC=5V, 8MHz       |                      | 4          | 7                     | mA    |
| ICC   | 昇圧変換器なし                                   | VCC=2V, 1MHz       |                      | 0.04       | 0.15                  |       |
|       | アイドル動作消費電流 (注9,10)                        | VCC=3V, 4MHz       |                      | 0.25       | 0.6                   |       |
|       |                                           | VCC=5V, 8MHz       |                      | 1.0        | 2.0                   |       |
|       | 昇圧変換器なし (注10,11)                          | VCC=3V, WDT有効      |                      | 4.5        | 10                    | μA    |
|       | パワーダウン動作消費電流                              | VCC=3V, WDT禁止      |                      | 0.35       | 2                     | •     |

**注1**: 25℃での代表的な値です。

注2: "最大"はピンがLowとして読まれるのを保証される最高値を意味します。

注3: 製造に於いて検査されません。

注4: "最小"はピンがHighとして読まれるのを保証される最低値を意味します。

注5: 各I/Oポートは安定状態(非過渡時)に於いて示されるよりも多くの吸い込み電流を流すことができるとは言え、(全ポートに対して)全IOLの合計が60mAを超えるべきではありません。IOLが検査条件を超える場合、VOLも関連する仕様を超えます。ピンは検査条件で一覧されるよりも大きな吸い込み電流を流すことは保証されません。

**注6**: PB1,PB2,PB4,PB5ピンは高吸い込み(シンク)電流出力I/Oピンです。

注7~注11は次頁へ

注7: 各I/Oポートは安定状態(非過渡時)に於いて示されるよりも多くの吐き出し電流を流すことができるとは言え、(全ポートに対して) 全IOHの合計が60mAを超えるべきではありません。IOHが検査条件を超える場合、VOHも関連する仕様を超えます。ピンは検 査条件で一覧されるよりも大きな吐き出し電流を流すことは保証されません。

注8: RESETピン/はプログラミング動作での操作と移行時に高電圧を許容しなければならず、その結果として標準I/Oピンと比べて弱い駆動能力を持ちます。120頁から始まる図21−31.と図21−32.をご覧ください。

**注9**: 値は21頁の「消費電力の最小化」で記述された方法を用いた外部クロックでです。電力削減が許可(PRR=\$FF)され、I/Oの駆動はありません。

**注10**: 昇圧変換器を含めたデバイス全体の消費電流については105頁の「昇圧変換器特性」をご覧ください。

注11: 低電圧検出器(BOD)禁止です。

## 20.3. 速度



## 20.4. クロック特性

## 20.4.1. 校正付き内蔵RC発振器の精度

工場既定校正よりも高い精度に内蔵発振器を手動校正することが可能です。この発振器周波数が温度と電圧に依存することに注意してください。

## 表20-2. 校正付き内蔵RC発振器の校正精度

| 校正種別  | 周波数               | Vcc            | 温度             | 校正精度(注) |  |
|-------|-------------------|----------------|----------------|---------|--|
| 工場校正  | 8.0MHz            | 3V             | 25°C           | ±10%    |  |
| 使用者校正 | 7.3~8.1MHz内の固定周波数 | 1.8~5.5V内の固定電圧 | -40~+85℃内の固定温度 | ±1%     |  |

注: 校正点での発振器周波数精度(固定温度と固定電圧)

## 20.4.2. 外部クロック信号駆動



## 表20-3. 外部クロック特性

| 2.5.4*0      | シンホ・ル 項目      |     | VCC=1.8∼5.5V |     | VCC=2.7∼5.5V |     |  |
|--------------|---------------|-----|--------------|-----|--------------|-----|--|
| ソンホ ル        | 項目            | 最小  | 最大           | 最小  | 最大           | 単位  |  |
| $1/t_{CLCL}$ | クロック周波数       | 0   | 4            | 0   | 8            | MHz |  |
| tclcl        | クロック周期        | 250 |              | 125 |              |     |  |
| tchcx        | Highレヘル時間     | 100 |              | 50  |              | ns  |  |
| tclcx        | Lowレヘル時間      | 100 |              | 50  |              |     |  |
| tclch        | 上昇時間          |     | 2.0          |     | 1.6          |     |  |
| tchcl        | 下降時間          |     | 2.0          |     | 1.6          | μs  |  |
| ⊿tclcl       | 隣接クロック周期間の変化率 |     | 2            |     | 2            | %   |  |

注: 詳細については15頁の「外部クロック信号」を参照してください。





## 20.5. システムとリセットの特性

## 表20-4. システムとリセットの電気的特性

| シンホ゛ル             | 項目                  | 条件                 | 最小     | 代表  | 最大      | 単位   |
|-------------------|---------------------|--------------------|--------|-----|---------|------|
| V <sub>POT</sub>  | 上昇時電源ONリセット閾値電圧     | TA=-40~85°C        | 1.1    | 1.4 | 1.6     | V    |
| VPOT              | 下降時電源ONリセット閾値電圧(注1) | 1A40, -65 C        | 0.6    | 1.3 | 1.4 1.6 | V    |
| V <sub>PSR</sub>  | 電源投入時上昇率            | TA=-40∼85°C        | 0.01   |     |         | V/ms |
| V <sub>RST</sub>  | RESETt°ン閾値電圧        |                    | 0.2VCC |     | 0.9VCC  | V    |
|                   |                     | VCC=1.8V           |        | 2   |         |      |
| $t_{RST}$         |                     | VCC=3V             |        | 0.7 |         | μs   |
|                   |                     | VCC=5V             |        | 0.4 |         |      |
| V <sub>HYST</sub> | 低電圧検出ヒステリシス電圧       |                    |        | 50  |         | mV   |
| ${ m t_{BOD}}$    | 最小低電圧検出時間           |                    |        | 2   |         | μs   |
| $V_{\mathrm{BG}}$ | 基準電圧                | VCC-9.7V           | 1.0    | 1.1 | 1.2     | V    |
| ${ m t_{BG}}$     | 起動時間                | VCC=2.7V<br>TA=25℃ |        | 40  | 70      | μs   |
| $I_{\mathrm{BG}}$ | 消費電流                | 171 20 0           |        | 15  |         | μА   |

注1: 供給電圧がこの電圧以下にならないと、上昇時の電源ONJセットは動作しません。

## 表20-5. BODLEVELtュース\*(VBOT)設定(注1)

| BODLEVEL2~0 | 最小               | 代表  | 最大  | 単位 |  |  |
|-------------|------------------|-----|-----|----|--|--|
| 111         | 低電圧検出(BOD)リセット禁止 |     |     |    |  |  |
| 1 1 0       | 1.7              | 1.8 | 2.0 |    |  |  |
| 1 0 1       | 2.5              | 2.7 | 2.9 | V  |  |  |
| 1 0 0       | 4.1              | 4.3 | 4.5 |    |  |  |
| 0 x x       | (予約)             |     |     |    |  |  |

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

## 20.6. 外部割り込み特性

## 表20-6. 非同期外部割り込み特性

| シンホ゛ル              | 項目              | 最小 | 代表 | 最大 | 単位 |
|--------------------|-----------------|----|----|----|----|
| $t_{\mathrm{INT}}$ | 非同期外部割り込み最小パルス幅 |    | 50 |    | ns |

# 20.7. 昇圧変換器特性

表20-7. 昇圧変換器特性 (TA=-20℃~85℃、他の注記を除く)

| シンホ゛ル       | 項目                                        | 条件 (注1)                         | 最小   | 代表  | 最大   | 単位   |  |
|-------------|-------------------------------------------|---------------------------------|------|-----|------|------|--|
| VBAT        | 入力電圧                                      |                                 | 0.7  |     | 1.8  |      |  |
| VSTART      | 開始電圧                                      |                                 | 1.0  | 1.2 | 1.35 |      |  |
| VSTOP       | 停止電圧                                      |                                 | (注2) | 0.5 | 0.8  | V    |  |
| VBOOST      | 活動状態移行VCC電圧                               |                                 |      | 1.0 |      | V    |  |
| VCC         | 出力電圧                                      | 活動状態,ILOAD>1mA                  | 2.7  | 3.0 | 3.3  |      |  |
| VCC         |                                           | 低電流動作活動状態                       | 2.0  |     | 3.6  |      |  |
| ILOAD       | 負荷電流                                      | VBAT=0.7V                       | 0    |     | 10   | mA   |  |
| ILOAD       |                                           | VBAT=1.0V                       | 0    |     | 30   |      |  |
| VRPP        | 出力脈流電圧                                    | VBAT=1.0V,ILOAD=30mA,CLOAD=22μF |      | 40  |      | mV   |  |
| tstart      | 始動時間                                      | VBAT=0Vから1.2Vへの段階変化             |      | 2   |      | ms   |  |
|             | デバイス全体の消費電流                               | VBAT=0.4V,変換器停止状態,MCU給電なし       |      | 1   |      | μА   |  |
|             |                                           | VBAT=1.0V,変換器停止状態,MCU給電なし       |      | 2   |      |      |  |
| IIN         |                                           | VBAT=1.2V,低電流動作,MCUパワータウン動作,    |      | 5   |      | μ/-\ |  |
|             |                                           | WDT禁止                           |      | J   |      |      |  |
|             |                                           | VBAT=1.2V,調整動作,MCU活動動作,4MHz     |      | 5   |      | mA   |  |
| <i>f</i> sw | 切り替え周波数                                   |                                 | 75   | 100 | 125  | kHz  |  |
| TSW         | 切り替え周期                                    | TSW=1/fSW                       | 8    | 10  | 13.3 | μs   |  |
| DSW         | デューティ サイクル                                |                                 | 3    |     | 70   | %    |  |
| VBATOL      | 過負荷からのデバイス回復最低電圧                          | 出力過負荷または回路短絡の解消                 |      | 0.9 |      | V    |  |
|             | 負荷安定性<br>VCC(最小負荷)-VCC(最大負荷)              | TA=25℃,VBAT=1.2V,昇圧変換器活動状態      |      | 2.7 |      |      |  |
|             |                                           |                                 |      |     |      |      |  |
|             | 入力安定性                                     |                                 |      |     |      |      |  |
|             | VCC(最大VBAT)-VCC(最小VBAT)<br>VCC(標準VBAT)    | TA=25℃,ILOAD=1mA,昇圧変換器活動状態      |      | 1.0 |      | %    |  |
|             | 温度安定性<br>VCC(最大温度)-VCC(最小温度)<br>VCC(標準温度) | VBAT=1.2V,ILOAD=1mA,昇圧変換器活動状態   |      | 2.3 |      |      |  |

注1: 110頁の「昇圧変換器」項で記述される構成設定とで得られた特性。

**注2**: 最小停止電圧は保証されません。非常に低い電池電圧で論理回路は停止信号を発行する前に動作を中止するかもしれません。応用ファームウェアは定期的な間隔で電池電圧を監視するのにA/D変換器を使い、必要とされる時にファームウェア停止を発行することができます。





# 20.8. A/D変換器特性

表20-8. A/D変換特性 (TA=-40°C~+85°C、昇圧変換器許可)

| シンホ゛ル | 項目                    | 条件                     |               | 最小   | 代表   | 最大   | 単位  |
|-------|-----------------------|------------------------|---------------|------|------|------|-----|
|       | 分解能                   |                        |               |      |      | 10   | ピット |
|       | 絶対精度 (注)              | VCC=3V                 | 変換クロック=200kHz |      | 3.5  |      |     |
|       | (積分非直線性、微分非           | V <sub>REF</sub> =3V   | 変換クロック=1MHz   |      | 4.0  |      |     |
|       | 直線性、量子化、利得、           | 雑音低                    | 変換クロック=200kHz |      | 3.0  |      |     |
|       | オフセットの各誤差を含む)         | 減動作                    | 変換クロック=1MHz   |      | 3.5  |      | LSB |
|       | 積分非直線性誤差 ( <u>注</u> ) |                        |               |      | 1.0  |      | LSD |
|       | 微分非直線性誤差              | VCC=3V,V <sub>RE</sub> |               |      | 0.5  |      |     |
|       | 利得誤差 (注)              | 変換クロック=20              | 0kHz          |      | 5.0  |      |     |
|       | オフセット(セ゛ロ)誤差          |                        |               |      | -3.0 |      |     |
|       | 変換時間                  | 連続変換動作                 | . H           | 14   |      | 280  | μs  |
|       | 変換クロック周波数             |                        |               | 0.05 |      | 1    | MHz |
| VIN   | 入力電圧                  |                        |               | GND  |      | Vref | V   |
|       | 入力周波数帯域               |                        |               |      | 38.4 |      | kHz |
| VINT  | 内蔵基準電圧                |                        |               | 1.0  | 1.1  | 1.2  | V   |
| RAIN  | アナログ入力インピーダンス         |                        |               |      | 100  |      | ΜΩ  |

**注**: 利得誤差は選択した基準供給元の精度にも依存します。基準としてVCC使用時、昇圧変換器の出力電圧が、特に低電流活動動作で広い動的範囲を持つことに注意されるべきです。内部基準電圧は供給電圧での変化にむしろ耐え、従って使われるべき推奨基準供給元です。124頁の「バンドギャップ電圧対動作電圧」をご覧ください。

# 20.9. 並列プログラミング特性











表20-9. 並列プログラミング特性 (VCC=5V±10%)

| シンホ゛ル             | 項目                                                  | 最小               | 代表 | 最大   | 単位  |  |
|-------------------|-----------------------------------------------------|------------------|----|------|-----|--|
| Vpp               | プログラミング許可電圧                                         | 11.5             |    | 12.5 | V   |  |
| Ipp               | プログラミング許可電流                                         |                  |    | 250  | μA  |  |
| t <sub>DVXH</sub> | CLKI↑に対するデータと制御の準備時間                                | 67               |    |      |     |  |
| t <sub>XLXH</sub> | CLKI↓から次XTAL1↑までの待機時間                               | 200              |    |      |     |  |
| txHXL             | CLKI Highハ゜ルス幅                                      | 150              |    |      |     |  |
| txldx             | CLKIパハス↓後のデータと制御の保持時間                               | 67               |    |      |     |  |
| t <sub>XLWL</sub> | CLKIパルス↓後のWR↓待機時間                                   | 0                |    |      |     |  |
| t <sub>BVPH</sub> | PAGELパルス↑に対するBS1準備時間                                | 67               |    |      |     |  |
| tpHPL             | PAGEL Highハ゜ルス幅                                     | 150              |    |      | ns  |  |
| t <sub>PLBX</sub> | PAGELパルス↓後のBS1保持時間                                  | 67               |    |      |     |  |
| twlbx             | WRパルス ↓ 後のBS1,BS2保持時間                               | 後のBS1,BS2保持時間 67 |    |      |     |  |
| t <sub>PLWL</sub> | PAGELパルス↓後のWRパルス↓待機時間                               | 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          | チップ <sup>°</sup> 消去時間 (WR↓からRDY/BSY↑) ( <b>注2</b> ) | 7.5              |    | 9    | ms  |  |
| txlcl             | CLKIパルス↓後のOE√ 待機時間                                  | 0                |    |      |     |  |
| $t_{ m BVDV}$     | BS1有効からのDATA遅延時間                                    | 0                |    | 250  | ns  |  |
| toldv             | OE ↓後のDATA出力遅延時間                                    |                  |    | 250  |     |  |
| tohdz             | OE↑後のDATA Hi-Z遅延時間                                  |                  |    | 250  |     |  |

注1: フラッシュ メモリ、EEPROM、ヒュース ビット、施錠ビット書き込み指令に対して有効です。

注2: チップ消去指令に対して有効です。

# 20.10. 直列プログラミング特性





| 表20-10. 直列プログラミング特性 (特記条件を除いて、TA=-40℃~+85℃, VCC=1.8~5.5V) |                    |          |        |    |     |         |  |
|-----------------------------------------------------------|--------------------|----------|--------|----|-----|---------|--|
| シンホ゛ル                                                     | 項目                 |          | 最小     | 代表 | 最大  | 単位      |  |
| 1/t <sub>CLCL</sub>                                       | <b>発振器周波数</b>      |          | 0      |    | 4   | MHz     |  |
| 1/tCLCL                                                   | 光派品问仪数             | 4.5~5.5V | 0      |    | 8   | IVII IZ |  |
| toror                                                     | 発振器周期              |          | 250    |    |     |         |  |
| tclcl                                                     | <b>光派</b> 奋问别      | 4.5~5.5V | 125    |    |     |         |  |
| tshsl                                                     | SCKパルスHレヘール幅       | (注1)     | 2tclcl |    |     |         |  |
| tslsh                                                     | SCKパルスLレヘブル幅       | (注1)     | 2tclcl |    |     | ns      |  |
| tovsh                                                     | SCK↑に対するMOSI準備時間   |          | tclcl  |    |     |         |  |
| tshox                                                     | SCK↑に対するMOSI保持時間   |          | 2tclcl |    |     |         |  |
| $t_{\mathrm{SLIV}}$                                       | SCK↓に対するMISO出力遅延時間 |          |        |    | 100 |         |  |

注1:  $f_{CK} < 12MHz$ 時2 $t_{CLCL}$ 、 $f_{CK} \ge 12MHz$ 時3 $t_{CLCL}$ 。





# 21. 代表特性

本項内に含まれたデータは主に同じ製法と設計法の類似デバイスの特徴付けとシミュレーションに基いています。従って、このデータはデバイスがどう反応するかについての指標として扱われるべきです。

以下の図は代表的な特性を示します。これらの図は製造中に検査されていません。特性付けの間、デバイスは検査限界よりも高い周波数で動作していますが、それらは注文コードが示すよりも高い周波数での正しい機能が保証される訳ではありません。

全ての消費電流測定は全I/Oピンを入力として設定した内部プルアップ許可で行われています。消費電流は動作電圧、動作周波数、I/Oピンの負荷、I/Oピンの切り替え速度、命令実行、周囲温度のような様々な要素の関数です。支配的な要素は動作電圧と動作周波数です。

電源幅振幅の方形波発振器がクロック源として使われていますが、パワーダウン動作での消費電力はクロック選択と無関係です。ウォッチトック、タイマ許可のパワーダウン動作での消費電流とウォッチトック、タイマ禁止のパワーダウン動作での消費電流間の違いは、ウォッチトック、タイマによって引き込んだ(消費した)差電流を表します。

容量性負荷のピンの引き込み電流は(1つのピンに対して) CL(負荷容量)×VCC(動作電圧)×fSW(I/Oピンの平均切り替え周波数) として推測できます。

# 21.1. 昇圧変換器

以下の特性は表21-1.で一覧にされる部品とで得られました。部品配置については27頁の図8-8.をご覧ください。

表21-1. 昇圧変換器の特性付け中に使われた部品

| 部品 | 型式                | 値                        |
|----|-------------------|--------------------------|
| C1 | JMK212BJ106KD-T×6 | 10μF×6=60μF ( <b>注</b> ) |
| C2 |                   | 0.1µF                    |
| C3 | JMK212BJ226MG-T   | 22μF                     |
| C4 |                   | 0.1µF                    |
| D1 | PMEG2010AEH       | VF=0.35V                 |
| L1 | LPS6235-153MLB    | 15μН                     |
| R1 |                   | 680kΩ                    |

**注**: 測定系にで使われる分路抵抗によって引き起こされる入力脈流を最小にするため、むしろ大きな容量のC1が必要とされました。

測定で使用したATtiny43UデバイスはSOIC外囲器で封印され、100kHzの切り換え周波数を持っていました。





# 21.2. 活動動作消費電流















# 21.3. アイドル動作消費電流















# 21.4. パワーダウン動作消費電流





# 21.5. リセット消費電流









# 21.6. 周辺機能部消費電流





### 21.7. プルアップ 抵抗















# 21.8. 出力駆動部能力





















# **21.9. 入力閾値とヒステリシス** (対I/Oポート)

















# 21.10. 低電圧検出器(BOD)、バント・キ・ャップ、リセット

























# 21.11. 内部発振器











(訳注) 図21-52.は中央付近での重複がないので本文説明と矛盾し、おそらくこの図は誤っているでしょう。



# 22. レジスタ要約

| アト・レス                      | レジスタ略称       | ピット7      | じット6     | じット5          | じット4                            | ピット3            | ピット2                                  | じット1                                  | ピット0           | 頁           |
|----------------------------|--------------|-----------|----------|---------------|---------------------------------|-----------------|---------------------------------------|---------------------------------------|----------------|-------------|
| \$3F (\$5F)                | SREG         | I         | T        | Н             | S                               | V               | N                                     | Z                                     | С              | 6           |
| \$3E (\$5E)                | SPH          | -         | -        | -             | -                               | -               | -                                     | -                                     | SP8            | 8           |
| \$3D (\$5D)                | SPL          | SP7       | SP6      | SP5           | SP4                             | SP3             | SP2                                   | SP1                                   | SP0            |             |
| \$3C (\$5C)                | OCR0B        |           |          |               | タイマ/カウンタ0                       | 比較Bレジスク         | <b>y</b>                              |                                       |                | 61          |
| \$3B (\$5B)                | GIMSK        | _         | INT0     | PCIE1         | PCIE0                           | -               | -                                     | -                                     | -              | 39          |
| \$3A (\$5A)                | GIFR         | -         | INTF0    | PCIF1         | PCIF0                           | -               | -                                     | -                                     | -              | 39          |
| \$39 (\$59)                | TIMSK0       | -         | _        | -             | _                               | -               | OCIE0B                                | OCIE0A                                | TOIE0          | 62          |
| \$38 (\$58)                | TIFR0        | -         | -        | -             | -                               | -               | OCF0B                                 | OCF0A                                 | TOV0           | 62          |
| \$37 (\$57)                | SPMCSR       | -         | -        | RSIG          | CTPB                            | RFLB            | PGWRT                                 | PGERS                                 | SPMEN          | 89          |
| \$36 (\$56)                | OCR0A        |           | 1        |               | タイマ/カウンタ0                       |                 |                                       | <b>.</b>                              |                | 61          |
| \$35 (\$55)                | MCUCR        | BODS      | PUD      | SE            | SM1                             | SM0             | BODSE                                 | ISC01                                 | ISC00          | 49,22,38    |
| \$34 (\$54)                | MCUSR        | -         | _        | -             | _                               | WDRF            | BORF                                  | EXTRF                                 | PORF           | 35          |
| \$33 (\$53)                | TCCR0B       | FOC0A     | FOC0B    | -             | -                               | WGM02           | CS02                                  | CS01                                  | CS00           | 60          |
| \$32 (\$52)                | TCNT0        |           |          |               | タイマ/                            |                 | . %                                   |                                       |                | 61          |
| \$31 (\$51)                | OSCCAL       | ~ ~       | 1        |               | RC発振器 矛                         | を振校止値と          | シスタ                                   |                                       |                | 18          |
| \$30 (\$50)                | TCCR0A       | COM0A1    | COM0A0   | COM0B1        | COM0B0                          | _               | _                                     | WGM01                                 | WGM00          | 58          |
| \$2F (\$4F)                | TCCR1A       | COM1A1    | COM1A0   | COM1B1        | COM1B0                          | -               | - 0010                                | WGM11                                 | WGM10          | 58          |
| \$2E (\$4E)                | TCCR1B       | FOC1A     | FOC1B    | _             | -                               | WGM12           | CS12                                  | CS11                                  | CS10           | 60          |
| \$2D (\$4D)                | TCNT1        |           | 1        | -             | タイマ/)                           |                 | ļ,                                    | -                                     | 1              | 61          |
| \$2C (\$4C)                | OCR1A        |           | 1        |               | タイマ/カウンタ1                       |                 |                                       | -                                     | 1              | 61          |
| \$2B (\$4B)                | OCR1B        |           |          |               | タイマ/カウンタ1                       | レレ事文 ロレン 人      | ,                                     |                                       |                | 61          |
| \$2A (\$4A)<br>\$29 (\$49) | 予約<br><br>予約 |           |          |               |                                 |                 |                                       |                                       |                |             |
|                            |              |           |          |               |                                 |                 |                                       |                                       |                |             |
| \$28 (\$48)<br>\$27 (\$47) | DWDR         |           |          | 3             | !<br>デバックWIRE                   | データコンブフ         | 4                                     |                                       |                | 85          |
| \$26 (\$46)                | CLKPR        | CLKPCE    | _        |               | WIKE                            | CLKPS3          | CLKPS2                                | CLKPS1                                | CLKPS0         | 18          |
| \$25 (\$45)                | 予約           | CLKFCE    | _        | _             | _                               | CLKF33          | CLKF32                                | CLRF31                                | CLKF30         | 10          |
| \$24 (\$44)                | 予約           |           |          |               |                                 |                 |                                       |                                       |                |             |
| \$23 (\$43)                | GTCCR        | TSM       | _        | _             | _                               | _               | _                                     | _                                     | PSR10          | 65          |
| \$23 (\$43)                | 予約           | 1 3101    |          |               |                                 |                 |                                       |                                       | FSIVIO         | 00          |
| \$21 (\$41)                | WDTCSR       | WDIF      | WDIE     | WDP3          | WDCE                            | WDE             | WDP2                                  | WDP1                                  | WDP0           | 36          |
| \$20 (\$40)                | PCMSK1       | PCINT15   | PCINT14  | PCINT13       | PCINT12                         | PCINT11         | PCINT10                               | PCINT9                                | PCINT8         | 40          |
| \$1F (\$3F)                | 予約           | 1 CHVI I3 | 1 CIN114 | 1 CINT 13     | I CHVI12                        | 1 CHVIII        | 1 CHVI IO                             | 1 CHV13                               | 1 CIIV10       | 10          |
| \$1E (\$3E)                | EEAR         | _         | _        |               | EEPE                            | OMアドレスレ         | L<br>ジスタ (EEAF                        | (5~0)                                 |                | 13          |
| \$1D (\$3D)                | EEDR         |           |          |               |                                 | ータ レシ スタ        | · · · · · · · · · · · · · · · · · · · | · · · · · · · · · · · · · · · · · · · | +              | 13          |
| \$1C (\$3C)                | EECR         | _         | _        | EEPM1         | EEPM0                           | EERIE           | EEMPE                                 | EEPE                                  | EERE           | 13          |
| \$1B (\$3B)                | PORTA        | PORTA7    | PORTA6   | PORTA5        | PORTA4                          | PORTA3          | PORTA2                                | PORTA1                                | PORTA0         | 49          |
| \$1A (\$3A)                | DDRA         | DDA7      | DDA6     | DDA5          | DDA4                            | DDA3            | DDA2                                  | DDA1                                  | DDA0           | 49          |
| \$19 (\$39)                | PINA         | PINA7     | PINA6    | PINA5         | PINA4                           | PINA3           | PINA2                                 | PINA1                                 | PINA0          | 49          |
| \$18 (\$38)                | PORTB        | PORTB7    | PORTB6   | PORTB5        | PORTB4                          | PORTB3          | PORTB2                                | PORTB1                                | PORTB0         | 49          |
| \$17 (\$37)                | DDRB         | DDB7      | DDB6     | DDB5          | DDB4                            | DDB3            | DDB2                                  | DDB1                                  | DDB0           | 49          |
| \$16 (\$36)                | PINB         | PINB7     | PINB6    | PINB5         | PINB4                           | PINB3           | PINB2                                 | PINB1                                 | PINB0          | 49          |
| \$15 (\$35)                | GPIOR2       |           |          |               | 汎用I/C                           | シン・スタ2          |                                       |                                       |                | 14          |
| \$14 (\$34)                | GPIOR1       |           |          |               | 汎用I/C                           |                 |                                       |                                       |                | 14          |
| \$13 (\$33)                | GPIOR0       |           |          |               | 汎用I/C                           | レシ゛スタ0          |                                       |                                       |                | 14          |
| \$12 (\$32)                | PCMSK0       | PCINT7    | PCINT6   | PCINT5        | PCINT4                          | PCINT3          | PCINT2                                | PCINT1                                | PCINT0         | 40          |
| \$11 (\$31)                | 予約           |           |          |               |                                 |                 |                                       |                                       |                |             |
| \$10 (\$30)                | USIBR        |           |          |               |                                 | <b>町レシ</b> 、スタ  |                                       |                                       |                | 73          |
| \$0F (\$2F)                | USIDR        | * ***     |          |               |                                 | タレジスタ           |                                       | * * * * * * * * * * * * * * * * * * * | 110101         | 73          |
| \$0E (\$2E)                | USISR        | USISIF    | USIOIF   | USIPF         | USIDC                           | USICNT3         | USICNT2                               | USICNT1                               | USICNT0        | 72          |
| \$0D (\$2D)                | USICR        | USISIE    | USIOIE   | USIWM1        | USIWM0                          | USICS1          | USICS0                                | USICLK                                | USITC          | 71          |
| \$0C (\$2C)                | TIMSK1       | -         | -        | -             | -                               | _               | OCIE1B                                | OCIE1A                                | TOIE1          | 62          |
| \$0B (\$2B)                | TIFR1        | -         | _        | _             | _                               | -               | OCF1B                                 | OCF1A                                 | TOV1           | 62          |
| \$0A (\$2A)                | 予約           |           |          |               |                                 |                 |                                       |                                       |                |             |
| \$09 (\$29)                | 予約           | ACD       | ACDC     | 100           | A CT                            | A CIT           |                                       | A CTC+                                | A CTCo         | 75          |
| \$08 (\$28)                | ACSR         | ACD       | ACBG     | ACO           | ACI                             | ACIE            | - AT IV.                              | ACIS1                                 | ACIS0          | 75          |
| \$07 (\$27)                | ADMUX        | ADDA      | REFS     | A D A TOP     | ADID                            | A D.ID          | MUX2                                  | MUX1                                  | MUX0           | 82          |
| \$06 (\$26)                | ADCSRA       | ADEN      | ADSC     | ADATE         | ADIF                            | ADIE            | ADPS2                                 | ADPS1                                 | ADPS0          | 82          |
| \$05 (\$25)                | ADCH         |           |          | Dデータレジン       |                                 | (ADC9~83        |                                       |                                       | 1              | 84          |
| \$04 (\$24)                | ADCCDD       | DC        | ,        | Dデータ レシン      |                                 | (ADC7~0ま        |                                       |                                       | ADTCO          |             |
| \$03 (\$23)                | ADCSRB       | BS        | ACME     |               | ADLAR                           | -               | ADTS2                                 | ADTS1                                 | ADTS0          | 31,74,83    |
| \$02 (\$22)                | 予約<br>DIDPO  |           |          | AINIID        | VINIOD                          | ADC2D           | ADC2D                                 | ADC1D                                 | ADCOD          | 75.04       |
| \$01 (\$21)<br>\$00 (\$20) | DIDR0<br>PRR | PRE2      | PRE1     | AIN1D<br>PRE0 | AIN0D                           | ADC3D<br>PRTIM1 | ADC2D<br>PRTIM0                       | ADC1D<br>PRUSI                        | ADC0D<br>PRADC | 75,84<br>22 |
|                            | PKK          |           |          |               | ー<br>ハナ. <del>コ・</del> ノ . ^ キ・ |                 |                                       |                                       |                |             |

- 注:・将来のデバイスとの共通性のため、予約ビットへ書く場合は0を書くべきです。予約I/Oメモリ アドレスは決して書かれるべきではありません。
  - ・アドンス範囲\$00~\$1FのI/Oレシ、スタはCBIとSBI命令の使用で直接アクセス可能です。これらのレシ、スタの単一ヒ、ットはCBISとSBIS命令の使用によって検査できます。
  - ・いくつかの状態ビットはそれらへ論理1を書くことによって解除(0)されます。他の多くのAVRと異なり、CBIとSBI命令は指定ビットだけ操作し、従ってこのような状態フラグを含むレジスタで使えることに注意してください。CBIとSBI命令は\$00~\$1Fのレジスタだけで動作します。

# 23. 命令要約

| ニーモニック       | オペラント゛ | 意味                                        | 動作                                                                             | フラク゛                                                    | クロック              |
|--------------|--------|-------------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------|-------------------|
|              |        |                                           | 里演算命令                                                                          |                                                         |                   |
| ADD          | Rd,Rr  | 汎用レジスタ間の加算                                | Rd ← Rd + Rr                                                                   | I,T,H,S,V,N,Z,C                                         | 1                 |
| ADC          | Rd,Rr  | キャリーを含めた汎用レジスタ間の加算                        | $Rd \leftarrow Rd + Rr + C$                                                    | I,T,H,S,V,N,Z,C                                         | 1                 |
| ADIW         | Rd,K6  | 即値の語(ワード)長加算                              | RdH:RdL ← RdH:RdL + K6                                                         | I,T,H,S,V,N,Z,C                                         | 2                 |
| SUB          | Rd,Rr  | 汎用レジスタ間の減算                                | Rd ← Rd − Rr                                                                   | I,T,H,S,V,N,Z,C                                         | 1                 |
| SUBI         | Rd,K   | 汎用レジスタから即値の減算                             | Rd ← Rd − K                                                                    | I,T,H,S,V,N,Z,C                                         | 1                 |
| SBIW         | Rd,K6  | 即値の語(ワード)長減算                              | RdH:RdL ← RdH:RdL - K6                                                         | I,T,H,S,V,N,Z,C                                         | 2                 |
| SBC          | Rd,Rr  | キャリーを含めた汎用レジスタ間の減算                        | $Rd \leftarrow Rd - Rr - C$                                                    | I,T,H,S,V,N,Z,C                                         | 1                 |
| SBCI         | Rd,K   | 汎用レジスタからキャリーと即値の減算                        | $Rd \leftarrow Rd - K - C$                                                     | I,T,H,S,V,N,Z,C                                         | 1                 |
| AND          | Rd,Rr  | 汎用レジスタ間の論理積(AND)                          | Rd ← Rd AND Rr                                                                 | I,T,H,S,0,N,Z,C                                         | 1                 |
| ANDI         | Rd,K   | 汎用レジスタと即値の論理積(AND)                        | Rd ← Rd AND K                                                                  | I,T,H,S,0,N,Z,C                                         | 1                 |
| OR           | Rd,Rr  | 汎用レジスタ間の論理和(OR)                           | Rd ← Rd OR Rr                                                                  | I,T,H,S,0,N,Z,C                                         | 1                 |
| ORI          | Rd,K   | 汎用レジスタと即値の論理和(OR)                         | Rd ← Rd OR K                                                                   | I,T,H,S,0,N,Z,C                                         | 1                 |
| EOR          | Rd,Rr  | 汎用レジスタ間の排他的論理和(Ex-OR)                     | Rd ← Rd EOR Rr                                                                 | I,T,H,S,V,N,Z,C                                         | 1                 |
| COM          | Rd     | 1の補数(論理反転)                                | Rd ← \$FF - Rd                                                                 | I,T,H,S,V,N,Z,C                                         | 1                 |
| NEG          |        | 2の補数(調理及数)                                | $Rd \leftarrow \$rr - Rd$<br>$Rd \leftarrow \$00 - Rd$                         |                                                         |                   |
|              | Rd     |                                           |                                                                                | I,T,H,S,V,N,Z,C                                         | 1                 |
| SBR          | Rd,K   | 汎用レジスタの(複数)ビット設定(1)                       | $Rd \leftarrow Rd OR K$                                                        | I,T,H,S,V,N,Z,C                                         | 1                 |
| CBR          | Rd,K   | 汎用レシ、スタの(複数)ビット解除(0)                      | $Rd \leftarrow Rd \text{ AND (\$FF - K)}$                                      | I,T,H,S,V,N,Z,C                                         | 1                 |
| INC          | Rd     | 汎用レシブスタの増加(+1)                            | $Rd \leftarrow Rd + 1$                                                         | I,T,H,S,V,N,Z,C                                         | 1                 |
| DEC          | Rd     | 汎用レジスタの減少(-1)                             | Rd ← Rd − 1                                                                    | I,T,H,S,V,N,Z,C                                         | 1                 |
| TST          | Rd     | 汎用レジスタのゼロとマイナス検査                          | Rd ← Rd AND Rd                                                                 | I,T,H,S,0,N,Z,C                                         | 1                 |
| CLR          | Rd     | 汎用レシブスタの全0設定(=\$00)                       | Rd ← Rd EOR Rd                                                                 | $I,T,H,\theta,0,0,\mathfrak{A},\mathfrak{X},\mathbb{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                                         | _                 |
| SBRS         | Rr,b   | 汎用レジブスタのビットが設定(1)でスキップ                    | Rr(b)=1なら, PC ← PC + 2or3                                                      | I,T,H,S,V,N,Z,C                                         |                   |
| SBIC         | P,b    | I/Oレシ、スタのヒットが解除(0)でスキップ                   | P(b)=07\$6, PC ← PC + 2or3                                                     | I,T,H,S,V,N,Z,C                                         |                   |
| SBIS         | P,b    | I/Oレシブスタのビットが設定(1)でスキップ                   | P(b)=1/26, PC ← PC + 2013                                                      | I,T,H,S,V,N,Z,C                                         |                   |
| 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                                         | $\frac{1/2}{1/2}$ |
| BREQ         | k      | 一致で分岐                                     | $Z=1$ \$\tilde{c}_{0}\$, PC \leftarrow PC + K + 1                              | I,T,H,S,V,N,Z,C                                         | $\frac{1/2}{1/2}$ |
| BRNE         | k      | 不一致で分岐                                    | Z=0/\$6, PC ← PC + K + 1<br>Z=0/\$6, PC ← PC + K + 1                           | I,T,H,S,V,N,Z,C                                         | $\frac{1/2}{1/2}$ |
|              | k      | キャリー フラグが設定(1)で分岐                         | C=17\$6, PC ← PC + K + 1                                                       | I,T,H,S,V,N,Z,C                                         | $\frac{1/2}{1/2}$ |
| BRCS<br>BRCC | k      | キャリー フラグ が設定(1)で分岐<br>  キャリー フラグが解除(0)で分岐 | $C=1/x$ 6, $PC \leftarrow PC + K + 1$<br>$C=0/x$ 6, $PC \leftarrow PC + K + 1$ | I, I, H, S, V, N, Z, C<br>I, T, H, S, V, N, Z, C        |                   |
|              |        |                                           | 4.27                                                                           |                                                         | -                 |
| BRSH         | k      | 符号なしの≥で分岐                                 | C=0/\$\(\cdot\), PC \(\cdot\) PC + K + 1                                       | I,T,H,S,V,N,Z,C                                         | 1/2               |
| BRLO         | k      | 符号なしのくで分岐                                 | C=1 $\%$ 5, PC $\leftarrow$ PC + K + 1                                         | I,T,H,S,V,N,Z,C                                         | 1/2               |
| BRMI         | k      | -(マイナス)で分岐                                | N=1なら, PC ← PC + K + 1                                                         | I,T,H,S,V,N,Z,C                                         | 1/2               |
| BRPL         | k      | +(プラス)で分岐                                 | N=0736, PC ← PC + K + 1                                                        | I,T,H,S,V,N,Z,C                                         | 1/2               |
| BRGE         | k      | 符号付きの≧で分岐                                 | (N EOR V)=0なら, PC ← PC + K + 1                                                 | I,T,H,S,V,N,Z,C                                         | 1/2               |
| BRLT         | k      | 符号付きの<で分岐                                 | (N EOR V)=1なら, PC ← PC + K + 1                                                 | I,T,H,S,V,N,Z,C                                         | 1/2               |
| BRHS         | k      | ハーフキャリー フラグが設定(1)で分岐                      | H=1なら, PC ← PC + K + 1                                                         | I,T,H,S,V,N,Z,C                                         | 1/2               |
| BRHC         | k      | ハーフキャリー フラグが解除(0)で分岐                      | H=0なら, PC ← PC + K + 1                                                         | I,T,H,S,V,N,Z,C                                         | 1/2               |
| BRTS         | k      | 一時フラグが設定(1)で分岐                            | T=1なら, PC ← PC + K + 1                                                         | I,T,H,S,V,N,Z,C                                         | 1/2               |
| BRTC         | k      | 一時フラグが解除( <mark>0</mark> )で分岐             | T=0なら, PC ← PC + K + 1                                                         | I,T,H,S,V,N,Z,C                                         | 1/2               |
| BRVS         | k      | 2の補数溢れフラグが設定(1)で分岐                        | V=1736, PC ← PC + K + 1                                                        | I,T,H,S,V,N,Z,C                                         | 1/2               |
| BRVC         | k      | 2の補数溢れフラグが解除(0)で分岐                        | V=0なら, PC ← PC + K + 1                                                         | I,T,H,S,V,N,Z,C                                         | 1/2               |
| BRIE         | k      | 割り込み許可で分岐                                 | I=1なら, PC ← PC + K + 1                                                         | I,T,H,S,V,N,Z,C                                         | 1/2               |
| BRID         | k      | 割り込み禁止で分岐                                 | I=07\$\$, PC ← PC + K + 1                                                      | I,T,H,S,V,N,Z,C                                         |                   |
|              |        |                                           |                                                                                | • .                                                     |                   |

K6, K: 6, 8ビット定数 P: I/Oレジスタ Rd, Rr: 汎用レジスタ(R0~R31) X, Y, Z: X, Y, Zレジスタ

b: ビット(0~7) k: アドレス定数(7,12,16ビット) q: 符号なし6ビット定数(変位) s: ステータス フラグ(C,Z,N,V,X,H,T,I)





| ニーモニック       | オペラント゛         | 意味                                                                       | 動作                                                                                 | フラク゛                                             | クロック     |
|--------------|----------------|--------------------------------------------------------------------------|------------------------------------------------------------------------------------|--------------------------------------------------|----------|
| 1.011        | DID            |                                                                          | 動命令                                                                                |                                                  |          |
| MOVW         | Rd,Rr          | 汎用レジスタ間の複写                                                               | Rd ← Rr                                                                            | I,T,H,S,V,N,Z,C                                  | 1<br>1   |
| MOVW<br>LDI  | Rd,Rr<br>Rd,K  | 汎用レジスタ対間の複写   即値の取得                                                      | Rd+1:Rd ← Rr+1:Rr<br>Rd ← K                                                        | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C               | 1        |
| LDI          | Rd,X           | Xレジスタ間接での取得                                                              | $Rd \leftarrow K$<br>$Rd \leftarrow (X)$                                           | I,T,H,S,V,N,Z,C                                  | 2        |
| LD           | Rd,X+          | 事後増加付きXレジスタ間接での取得                                                        | $Rd \leftarrow (X)$<br>$Rd \leftarrow (X)$ , $X \leftarrow X + 1$                  | I,T,H,S,V,N,Z,C                                  | 2        |
| LD           | Rd,-X          | 事前減少付きXレジスタ間接での取得                                                        | $X \leftarrow X - 1$ , $Rd \leftarrow (X)$                                         | I,T,H,S,V,N,Z,C                                  | 2        |
| LD           | Rd,Y           | Yレジスタ間接での取得                                                              | $Rd \leftarrow (Y)$                                                                | I,T,H,S,V,N,Z,C                                  | 2        |
| LD           | Rd,Y+          | 事後増加付きYレジスタ間接での取得                                                        | $Rd \leftarrow (Y), Y \leftarrow Y + 1$                                            | I,T,H,S,V,N,Z,C                                  | 2        |
| LD           | Rd,-Y          | 事前減少付きYレジスタ間接での取得                                                        | $Y \leftarrow Y - 1$ , $Rd \leftarrow (Y)$                                         | I,T,H,S,V,N,Z,C                                  | 2        |
| LDD          | Rd,Y+q         | 変位付きYレジスタ間接での取得                                                          | $Rd \leftarrow (Y + q)$                                                            | I,T,H,S,V,N,Z,C                                  | 2        |
| LD           | Rd,Z           | Zレジスタ間接での取得                                                              | $Rd \leftarrow (Z)$                                                                | I,T,H,S,V,N,Z,C                                  | 2        |
| LD           | 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          | Rd,Z+q         | 変位付きZレジスタ間接での取得                                                          | $Rd \leftarrow (Z + q)$                                                            | I,T,H,S,V,N,Z,C                                  | 2        |
| LDS          | Rd,k           | データ空間(SRAM)から直接取得                                                        | Rd ← (k)                                                                           | I,T,H,S,V,N,Z,C                                  | 2        |
| ST           | X,Rr           | Xレジスタ間接での設定                                                              | $(X) \leftarrow Rr$                                                                | I,T,H,S,V,N,Z,C                                  | 2        |
| ST           | X+,Rr          | 事後増加付きXレシブスタ間接での設定                                                       | $(X) \leftarrow Rr, X \leftarrow X + 1$                                            | I,T,H,S,V,N,Z,C                                  | 2        |
| ST           | -X,Rr          | 事前減少付きXレジスタ間接での設定                                                        | $X \leftarrow X - 1, (X) \leftarrow Rr$                                            | I,T,H,S,V,N,Z,C                                  | 2        |
| ST           | Y,Rr           | Yレジスタ間接での設定                                                              | $(Y) \leftarrow Rr$                                                                | I,T,H,S,V,N,Z,C                                  | 2        |
| ST           | Y+,Rr          | 事後増加付きYレジスタ間接での設定                                                        | $(Y) \leftarrow Rr, Y \leftarrow Y + 1$                                            | I,T,H,S,V,N,Z,C                                  | 2        |
| ST           | -Y,Rr          | 事前減少付きYレジスタ間接での設定                                                        | $Y \leftarrow Y - 1, (Y) \leftarrow Rr$                                            | I,T,H,S,V,N,Z,C                                  | 2        |
| STD          | Y+q,Rr         | 変位付きYレジスタ間接での設定                                                          | $ (Y + q) \leftarrow Rr $ $ (Z) \leftarrow Rr $                                    | I,T,H,S,V,N,Z,C                                  | 2        |
| ST<br>ST     | Z,Rr           | Zレジスタ間接での設定                                                              | $(Z) \leftarrow Rr$<br>$(Z) \leftarrow Rr, Z \leftarrow Z + 1$                     | I,T,H,S,V,N,Z,C                                  | 2        |
| ST           | Z+,Rr<br>-Z,Rr | 事後増加付きZレジスタ間接での設定<br>事前減少付きZレジスタ間接での設定                                   | $(Z) \leftarrow Rr, Z \leftarrow Z + 1$<br>$Z \leftarrow Z - 1, (Z) \leftarrow Rr$ | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C               | 2 2      |
| STD          | Z+q,Rr         | 変位付きZレジスタ間接での設定                                                          | $(Z + q) \leftarrow Rr$                                                            | I.T.H.S.V.N.Z.C                                  | 2        |
| STS          | k,Rr           | 京一夕空間(SRAM)へ直接設定                                                         | $(k) \leftarrow Rr$                                                                | I,T,H,S,V,N,Z,C                                  | 2        |
| LPM          | K,1\(1         | プログラム領域からZレジスタ間接での取得                                                     | $R0 \leftarrow (Z)$                                                                | I,T,H,S,V,N,Z,C                                  | 3        |
| LPM          | Rd,Z           | 同上(任意のレジスタへ)                                                             | $Rd \leftarrow (Z)$                                                                | I,T,H,S,V,N,Z,C                                  | 3        |
| LPM          | Rd,Z+          | 同上(事後増加付き)                                                               | $Rd \leftarrow (Z)$<br>$Rd \leftarrow (Z), Z \leftarrow Z + 1$                     | I,T,H,S,V,N,Z,C                                  | 3        |
| SPM          | rtu,Z          | プログラム領域へZレジスタ間接での設定                                                      | $(Z) \leftarrow R1:R0$                                                             | I,T,H,S,V,N,Z,C                                  | -        |
| IN           | Rd,P           | I/Oレジスタからの入力                                                             | Rd ← P                                                                             | I,T,H,S,V,N,Z,C                                  | 1        |
| OUT          | P,Ŕr           | I/Oレジスタへの出力                                                              | P ← Rr                                                                             | I,T,H,S,V,N,Z,C                                  | 1        |
| PUSH         | Rr             | 汎用レジスタをスタック〜保存                                                           | STACK ← Rr                                                                         | I,T,H,S,V,N,Z,C                                  | 2        |
| POP          | Rd             | スタックから汎用レジスタへ復帰                                                          | Rd ← STACK                                                                         | I,T,H,S,V,N,Z,C                                  | 2        |
|              |                |                                                                          | 係命令                                                                                |                                                  |          |
| SBI          | P,b            | I/Oレジスタのビット設定(1)                                                         | $I/O(P,b) \leftarrow 1$                                                            | I,T,H,S,V,N,Z,C                                  | 2        |
| CBI          | P,b            | I/Oレジスタのビット解除(0)                                                         | $I/O(P,b) \leftarrow 0$                                                            | I,T,H,S,V,N,Z,C                                  | 2        |
| LSL          | Rd             | 論理的左ビット移動                                                                | $Rd(n+1) \leftarrow Rd(n), Rd(0) \leftarrow 0$                                     | I,T,H,S,V,N,Z,C                                  | 1        |
| LSR          | Rd             | 論理的右ビット移動                                                                | $Rd(n) \leftarrow Rd(n+1), Rd(7) \leftarrow 0$                                     | $I,T,H,S,V,\emptyset,Z,C$                        | 1        |
| ROL          | Rd             | キャリーを含めた左回転                                                              | $Rd(0) \leftarrow C, Rd(n+1) \leftarrow Rd(n), C \leftarrow Rd(7)$                 | I,T,H,S,V,N,Z,C                                  | 1        |
| ROR          | Rd             | キャリーを含めた右回転                                                              | $Rd(7) \leftarrow C, Rd(n) \leftarrow Rd(n+1), C \leftarrow Rd(0)$                 | I,T,H,S,V,N,Z,C                                  |          |
| ASR          | Rd             | 算術的右ビット移動                                                                | $Rd(n) \leftarrow Rd(n+1), n=0 \sim 6$                                             | I,T,H,S,V,N,Z,C                                  | 1        |
| SWAP         | Rd             | =ブル(4ビット)上位/下位交換                                                         | $Rd(7\sim4) \Leftrightarrow Rd(3\sim0)$                                            | I,T,H,S,V,N,Z,C                                  | 1        |
| BSET         | S              | ステータス レジスタのビット設定(1)<br>ステータス レジスタのビット解除(0)                               | $ \begin{array}{l} SREG(s) \leftarrow 1 \\ SREG(s) \leftarrow 0 \end{array} $      | 1,T,H,\$,Y,X,\C<br>0,0,\O,0,0,\O,0,0,0           | 1        |
| BCLR         | S<br>D l-      |                                                                          | * *                                                                                |                                                  | 1        |
| BST<br>BLD   | Rr,b<br>Rd,b   | 汎用レジ、スタのビットを一時フラグへ移動   一時フラグを汎用レジ、スタのビットへ移動                              | $T \leftarrow Rr(b)$ $Rd(b) \leftarrow T$                                          | I, <b>T</b> ,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C      | 1        |
| SEC          | ra,o           | 一時/7// を/ル用レン                                                            | $C \leftarrow 1$                                                                   | I, T, H, S, V, N, Z, C<br>I, T, H, S, V, N, Z, C | 1<br>1   |
| CLC          |                | キャリー フラグを解除(0)                                                           | $C \leftarrow 1$<br>$C \leftarrow 0$                                               | I,T,H,S,V,N,Z, <b>0</b>                          | 1        |
| SEN          |                | (1) を呼(の) (2) (1) (2) (2) (2) (3) (4) (4) (4) (4) (4) (4) (4) (4) (4) (4 | $N \leftarrow 1$                                                                   | I,T,H,S,V,N,Z,C                                  | 1        |
| CLN          |                | (1) 負フラグを解除(0)                                                           | $N \leftarrow 0$                                                                   | I,T,H,S,V, <b>0</b> ,Z,C                         | 1        |
| SEZ          |                | ゼロフラグを設定(1)                                                              | $Z \leftarrow 1$                                                                   | I,T,H,S,V,N, <b>I</b> ,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          |                | 全割り込み禁止                                                                  | [ ← 0                                                                              | <b>0</b> ,T,H,S,V,N,Z,C                          | 1        |
| SES          |                | 符号フラグを設定(1)                                                              | S ← 1                                                                              | I,T,H,\$,V,N,Z,C                                 | 1        |
| CLS          |                | 符号フラグを解除( <mark>0</mark> )                                               | S ← 0                                                                              | I,T,H,θ,V,N,Z,C                                  | 1        |
| SEV          |                | 2の補数溢れフラグを設定(1)                                                          | V ← 1                                                                              | I,T,H,S,Y,N,Z,C                                  | 1        |
| CLV          |                | 2の補数溢れフラグを解除(0)                                                          | V ← 0                                                                              | I,T,H,S, <b>0</b> ,N,Z,C                         | 1        |
| SET          |                | 一時フラグを設定( <u>1</u> )                                                     | 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          |                | ハーフキャリー フラグを設定(1)                                                        | H ← 1                                                                              | I,T,H,S,V,N,Z,C                                  | 1        |
| CLH          |                | ハーフキャリー フラグを解除(0)                                                        | $H \leftarrow 0$                                                                   | I,T, <b>10</b> ,S,V,N,Z,C                        | 1        |
|              |                |                                                                          | 御命令                                                                                | V (1) 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2      |          |
| NOP          |                | 無操作                                                                      | 14 J. T. 45 45 107                                                                 | I,T,H,S,V,N,Z,C                                  | 1        |
|              |                | 休止形態開始                                                                   | 休止形態参照                                                                             | I,T,H,S,V,N,Z,C                                  | 1        |
| SLEEP        |                | 占、、・・・・   ケノー・11   上、1                                                   |                                                                                    | ITIICIIIC                                        |          |
| WDR<br>BREAK |                | ウォッチドック゛タイマ リセット<br>一時停止                                                 | ウォッチドッグ タイマ参照<br>内蔵デバッグWIRE機能専用                                                    | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C               | 1<br>N/A |

# 24. 注文情報

| <b>デバイ</b> ス | 速度(MHz) | 電源電圧          | 動作範囲             | 外囲器 (注1) | 注文コード (注2)    |
|--------------|---------|---------------|------------------|----------|---------------|
|              |         |               |                  | 20M1     | ATtiny43U-MU  |
| ATtiny43U    |         | 1.8~5.5V      | 7 工業用 (-40℃~85℃) | 20M1     | ATtiny43U-MUR |
|              |         | ( <b>注3</b> ) |                  | 20S2     | ATtiny43U-SU  |
|              |         | ,             |                  | 2032     | ATtiny43U-SUR |

注1: 全ての外囲器は鉛フリー、ハロケン化合物フリーで完全に安全で、これらは有害物質使用制限に関する欧州指令(RoHS指令)に 適合します。

注2: 符号識別子は次のとおりです。

• F: 半光沢錫。

• R: テープ とリール。

**注3**: VCCピンでの供給電圧、昇圧変換器と無関係。昇圧変換器が活動の時にデバイスはここで示されるよりも低い電圧供給元から動作することができます。より多くの情報については105頁の「昇圧変換器特性」の表をご覧ください。

|      | 外囲器形式                                                 |
|------|-------------------------------------------------------|
| 20M1 | 20パッド4×4×0.8mm 0.5mmピッチ 4方向平板リードなし/小リード枠外囲器 (QFN/MLF) |
| 20S1 | 20リート、300mil幅 プラスティック ガルウィング・小型外形外囲器 (SOIC)           |

# 25. 外囲器情報

### 25.1. 20M1



### **25.2.** 20S1







# 26. 障害情報

この章の改訂番号はATtiny43Uデバイスの改訂版を参照してください。

#### ATtiny43U 改訂A,B

試供されていません。

## ATtiny43U 改訂D~F

既知の障害情報はありません。

### ATtiny43U 改訂C

- ・昇圧変換器の低電流動作活動状態への移行が高まる見込み 43U-C
- 1. 昇圧変換器の低電流動作活動状態への移行が高まる見込み (43U-C)

昇圧変換器はそれらの仕様よりも高い供給電圧と負荷電流で低電流動作活動状態へ移行して留まるかもしれません。これは SOIC外囲器のボンディングワイアでの高切り替え電流のためです。MLF外囲器のデバイスは影響を及ぼされません。

#### 対策/対処

SOIC外囲器のLSWとGNDのピン間に1500pFのコンデンサを追加してください。またはVCCとGNDのピン間の(雑音)迂回コンデンサの容量を最低30 $\mu$ Fに増やしてください。

代わりに、(上記)変更なしでMLFのデバイスを使ってください。

# 27. データシート改訂履歴

### 27.1. 改訂8048A - 2009年2月

1. 初版

# 27.2. 改訂8048B - 2009年5月

- 1. 1頁の「特徴」でデータ保持力告知を更新
- 2. 28頁の「代表的な応用」項を削除。今やこのデータはAVR188応用記述で得られます。

# 27.3. 改訂8048C - 2012年2月

- 1. デバイスの暫定状態を削除
- 2. 昇圧変換器記述更新
  - ・23頁の「8.1. 概要」項の最終節
  - ・28頁の「8.6.4. RC濾波器」項の第2節
  - ・29頁の表8-1.内の昇圧変換器部品値
  - ・33頁の「9.2.3. 低電圧(ブラウンアウト)検出リセット」項の最終節
  - ・102頁の「20.1. 絶対最大定格」項内の昇圧変換器からの電流
  - ・105頁の「20.7. 昇圧変換器特性」項
  - ・106頁の「20.8. A/D変換器特性」項
  - ・110頁の「**21.1**. 昇圧変換器」項

#### 3. 更新

- ・1頁の「特徴」項
- ・80頁の「16.8. アナログ入力回路」項
- ・82頁の表16-4.
- ・99頁の「19.7.1. 直列プログラミング手順」項
- ・102頁の「**20.2**. **DC特性**」項
- ・110頁の「**21**. 代表特性」章
- ・データシート全体を通してビット書式、例えばCSn2:0からCSn[2:0] (訳注:本書は書式が異なるため無視)

### 4. 追加

- ・4頁の「3.3. 容量性接触感知」項
- ・27頁の「8.5.1. 昇圧変換器停止」項内のリセットでの記述
- ・30頁の「8.10. ファームウェア例」項
- ·110頁の「21. 代表特性」章内の特性図
- 131頁の「24. 注文情報」章でのテープとリール。





|     | 特徴 ・・・・・・・ 1                                                                 | 10.2. 外部割り込み・・・・・・・・・・・・3                                                        |
|-----|------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| 1.  | <b>ピン配置 ・・・・・・・・</b> 2                                                       | 10.3. 割り込み用レジスタ・・・・・・・・・・ 3                                                      |
|     | 1.1. L°ン説明 ····································                              | <b>11</b> . 入出力ポート ・・・・・・・・・・・・ 4:                                               |
| 2   | 概要 ••••• 3                                                                   | 11.1. 序説 ・・・・・・・・・・・・・・・・・ 4                                                     |
| ۷.  | 似女                                                                           | 11.2. 標準デジタル入出力としてのポート・・・・・・・・・・・・4                                              |
| 3.  | 一般情報 ••••• 4                                                                 | 11.3. 交換ポート機能 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                               |
|     | 3.1. 資料 · · · · · · 4                                                        | 11.4. I/Oポート用レジスタ ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                           |
|     | 3.2. コート例 ・・・・・・・・・・・・・・・・4                                                  | 10 ロバルイナキのピット カノフノももいか                                                           |
|     | 3.3. 容量性接触感知 •••••• 4                                                        | 12. FWWING COL YF \$187,077                                                      |
|     | 3.4. データ保持力 ・・・・・・・・・・・ 4                                                    | 12. PWM113 さ8 に ット ダイマ/カウンダ<br>(タイマ/カウンタ0とタイマ/カウンタ1) 50                          |
| 4.  | <b>AVR CPU7</b> 5                                                            | 12.1. 行取 ***********************************                                     |
|     | 4.1. 序説 5                                                                    | 12.2. 概要 5                                                                       |
|     | 4.2. 構造概要 ・・・・・・・・ 5                                                         | <b>12.3.</b> タイマ/カウンタのクロック元 ・・・・・・・ 5                                            |
|     | <b>4.3. ALU</b> (Arithmetic Logic Unit)                                      | 12.4. 計数器部                                                                       |
|     | 4.4. ステータス レジスタ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                          | <b>12.5</b> . 比較出力部 ····· 5.                                                     |
|     | 4.5. 汎用レジスタ ファイル・・・・・・・・・・ 7                                                 | 12.6. 比較一致出力部 ・・・・・・・・ 5                                                         |
|     | 4.6. スタック ホ°インタ · · · · · · · · · · · · · · · · · · ·                        | <b>12.7</b> . 動作種別 ····· 5-                                                      |
|     | 4.7. 命令実行タイミング・・・・・・・・・・8                                                    | 12.8. タイマ/カウンタのタイミング・····· 5                                                     |
|     | 4.8. リセットと割り込みの扱い・・・・・・・8                                                    | 12.9. 8ビット タイマ/カウンタ0,1用レジスタ・・・・・・5                                               |
| 5   | メモリ ・・・・・・・・・・・・・・・・・・・・・・10                                                 | 13. タイマ/カウンタの前置分周器・・・・・・・・64                                                     |
| J.  | 5.1. 実装書き換え可能なプログラム用フラッシュメモリ・・・ 10                                           | 13.1. 前置分周器リセット・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                              |
|     | 5.1.                                                                         | 13.2. 外部クロック元・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                 |
|     |                                                                              | 13.3. タイマ/カウンタ前置分周器用レジスタ ・・・・・・・・・ 6:                                            |
|     | <b>5.3.</b> データ用EEPROMメモリ · · · · · · · · · · · · · · · · · · ·              | 14. 多用途直列インターフェース (USI) ・・・・・・・ 60                                               |
|     | 5.5. メモリ関係レジスタ・・・・・・・・・・・13                                                  | 14.1. 特徴・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                     |
|     |                                                                              | 14.2. 概要 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                     |
| 6.  | <b>システム クロックとクロック選択 ・・・・・・・</b> 15                                           | 14.3. 機能説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                  |
|     | 6.1. クロック系統とその配給・・・・・・・15                                                    | 14.4. USIでの代替使用・・・・・・・・・・・・ 70                                                   |
|     | <b>6.2. クロック元</b> ······ 15                                                  | 14.5. USI用レジスタ ・・・・・・・・・・ 7                                                      |
|     | 6.3. システム クロック前置分周器 ・・・・・・・・・ 17                                             |                                                                                  |
|     | 6.4. システム クロック出力緩衝部 ・・・・・・・・・ 17                                             | 15. アナログ比較器 74                                                                   |
|     | 6.5. クロック関係レジスタ・・・・・・18                                                      | 15.1. 7ナログ比較器入力選択 ・・・・・・・・ 7                                                     |
| 7.  | 電力管理と休止形態・・・・・・・・・19                                                         | 15.1. アナログ比較器用レジスタ・・・・・・・・・・ 7.                                                  |
|     | 7.1. 休止形態種別 •••••• 19                                                        | 16. A/D変換器 ····································                                  |
|     | 7.2. ソフトウェア低電圧検出(BOD)禁止 ······ 20                                            | 16.1. 特徴                                                                         |
|     | 7.3. 電力削減レジスタ・・・・・・・・・・・・・・ 20                                               | 16.2. 概要 ・・・・・・・・・・・・・・・・ 70                                                     |
|     | 7.4. 消費電力の最小化 ・・・・・・・・・・ 21                                                  | 16.3. ADC操作 ····································                                 |
|     | 7.5. 電力管理用レジスタ ・・・・・・・・・・・ 22                                                | 16.4. 変換の開始 ・・・・・・・・・・・・ 7                                                       |
| ρ   | 電源と内蔵昇圧変換器・・・・・・・・・・ 23                                                      | <b>16.5</b> . 前置分周と変換タイミング・・・・・・・・ 78                                            |
| Ο.  | <b>8.1.</b> 概要 ···································                           | <b>16.6. チャネル変更と基準電圧選択 ・・・・・・・・</b> 79                                           |
|     | 8.2. 動作の状態 ····································                              | 16.7. 雑音低減機能 ・・・・・・・・・・・・ 8                                                      |
|     | 8.3. 出力電圧 対 負荷電流 ・・・・・・・・・・・26                                               | 16.8. アナログ入力回路・・・・・・・・・・・・80                                                     |
|     | 8.4. 過負荷での動き・・・・・・・・・・・・27                                                   | 16.9. アナログ雑音低減技術 ・・・・・・・・・・・ 8                                                   |
|     |                                                                              | 16.10. A/D変換の精度定義・・・・・・・・・・8                                                     |
|     |                                                                              | 16.11. A/D変換の結果・・・・・・・・・・・8                                                      |
|     |                                                                              | 16.12. 温度測定 ・・・・・・・・・・・・・・ 8.                                                    |
|     |                                                                              | 16.13. A/D変換用レジスタ・・・・・・・・・・ 82                                                   |
|     |                                                                              | 17. デバッグWIRE内蔵デバッグ機能 ・・・・・・・ 85                                                  |
|     | 8.9. 昇圧変換器の迂回       29         8.10. ファームウェア例       30                       | 17.1. 特徴 · · · · · · · · · · · · · · · · · ·                                     |
|     | 8.10. アデームリエア例 ・・・・・・・・・・・・・・・・・・・・ 30<br>8.11. 昇圧変換器関係レジスタ ・・・・・・・・・・・・・ 31 | 17.2. 概要 ・・・・・・・・・・・・・・・・・・・・・・・・8                                               |
| _   | 8.11. 昇上変 <b>楔</b>                                                           | 11 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                                           |
| 9.  | <b>システム制御とリセット・・・・・・・・</b> 32                                                | 17.3. 物理インターフェース ・・・・・・・・・・・・・・・・ 8: 17.4. ソフトウェア中断点 ・・・・・・・・・・・・・・・・・・・・・・・・ 8: |
|     | 9.1. AVRのリセット · · · · · 32                                                   | 17.4. ファウェア中断点<br>17.5. デバック・WIREの制限・・・・・・・・・・・・・・・・・・8                          |
|     | <b>9.2</b> . リセット元 ······ 32                                                 | 17.5. テハック WIREの制限                                                               |
|     | 9.3. 内部基準電圧 ・・・・・・・・・34                                                      | 17.0. 7 / 7 / WIRE用レス A 7 ・・・・・・・・・・・・・・・・ 8:                                    |
|     | <b>9.4.</b> ウォッチト・ック・タイマ · · · · · 34                                        | 18. フラッシュの自己プログラミング ・・・・・・ 86                                                    |
|     | 9.5. リセット関係レシ、スタ・・・・・・・・・35                                                  | 18.1. SPM命令によるページ消去の実行 ······ 8                                                  |
| 10. | <b>割り込み ・・・・・・・・・・・</b> 37                                                   | 18.2. ヘージー時緩衝部設定(ヘージ設定)・・・・・・・8                                                  |
|     | 10.1. ATtiny43Uの割り込みベクタ ・・・・・・・・・・・・ 37                                      | 18.3. ページ書き込みの実行 ・・・・・・・ 8                                                       |

# ATtiny43U

|     | 18.4.       | 自己プログラミングでのフラッシュ アドレス指定 ・・・・・ 86                                                                                                                                                                                                                  |
|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | 18.5.       | SPM書き込み時のEEPROM書き込み妨害 ・・87                                                                                                                                                                                                                        |
|     | 18.6.       | ソフトウェアからの施錠,ヒュース、と識票読み出し・・・ 87                                                                                                                                                                                                                    |
|     | 18.7.       | フラッシュ メモリ データ化けの防止 ・・・・・・88                                                                                                                                                                                                                       |
|     | 18.8.       | SPM使用時のフラッシュ メモリ書き込み時間 ・・・・ 88                                                                                                                                                                                                                    |
|     | 18.9.       | 自己プログラミング 用レジスタ ・・・・・・89                                                                                                                                                                                                                          |
| 19. | メモリ:        | 自己プログラミング用レジスタ ・・・・・・・ 89<br>プログラミング・・・・・・・ 90                                                                                                                                                                                                    |
|     | 404         | -°                                                                                                                                                                                                                                                |
|     | 19.2.       | ヒュース゛ヒ゛ット         91                                                                                                                                                                                                                              |
|     | 19.3.       | <b>デバイス識票銘刻部 ・・・・・・・・・・</b> 92                                                                                                                                                                                                                    |
|     | 19.4.       | <b>^゚ージ容量 ・・・・・・・・・・・・・・・・・・・・・・・・・・・</b> 92                                                                                                                                                                                                      |
|     | 19.5.       | <b>並列プログラミング・・・・・・・・・</b> 93                                                                                                                                                                                                                      |
|     | 19.6.       | <b>並列プログラミング手順・・・・・・・・・・</b> 94                                                                                                                                                                                                                   |
|     | 19.7.       | 直列プログラミング・・・・・・・・・99                                                                                                                                                                                                                              |
| 20. | 電気的         | プログラム メモリとテーダ メモリ用施証と ット       90         ヒュース・ビット       91         デバイス識票銘刻部       92         本列プログラミング       93         並列プログラミング・手順       94         直列プログラミング       99         内特性       102         絶対最大定格       102         POはおけ       102 |
|     | 20.1.       | <b>絶対最大定格</b> 102                                                                                                                                                                                                                                 |
|     | 20.2.       | DC特性 · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                        |
|     | 20.3.       | <b>速度 ······</b> 103                                                                                                                                                                                                                              |
|     | 20.4.       | <b>クロック特性 ・・・・・・・・・・・</b> 103                                                                                                                                                                                                                     |
|     | 20.5.       | システムとリセットの特性 ・・・・・・ 104                                                                                                                                                                                                                           |
|     | 20.6.       | 外部割り込み特性 ・・・・・・ 104                                                                                                                                                                                                                               |
|     | 20.7.       | 昇圧変換器特性 ・・・・・・・・ 105                                                                                                                                                                                                                              |
|     | 20.8.       | A/D変換器特性 · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                    |
|     | 20.9.       | 並列プログラミング特性 ・・・・・・・・ 107                                                                                                                                                                                                                          |
|     | 20.10.      | 外部割り込み特性・・・・・・・・104<br>昇圧変換器特性・・・・・・・・105<br>A/D変換器特性・・・・・・・・106<br>並列プログラミング特性・・・・・・・・107<br>直列プログラミング特性・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                     |
| 21. | 代表特         | 寺性 ・・・・・・・ 110                                                                                                                                                                                                                                    |
|     | 21.1.       |                                                                                                                                                                                                                                                   |
|     | 21.2.       | 活動動作消費電流 ********** 111                                                                                                                                                                                                                           |
|     | 21.3.       | アイドル動作消費電流 ・・・・・・・・ 113                                                                                                                                                                                                                           |
|     | 21.4.       | 対して                                                                                                                                                                                                                                               |
|     | 21.5.       | リセット消費電流 ・・・・・・・・・・ 115                                                                                                                                                                                                                           |
|     | 21.6.       | 周辺機能部消費電流 ・・・・・・・・・ 116                                                                                                                                                                                                                           |
|     | 21.7.       | フルパッフ 抵抗・・・・・・・・・・116                                                                                                                                                                                                                             |
|     | 21.8.       | 出刀駆動部能刀 **************** 118                                                                                                                                                                                                                      |
|     | 21.9.       | <b>入力閾値とヒステリシス</b> (対I/Oポート) ・・・・・・ 121                                                                                                                                                                                                           |
|     | 21.10.      |                                                                                                                                                                                                                                                   |
|     | 21.11.      | 内部発振器 ····································                                                                                                                                                                                                        |
| 22. | レンスタ        | (安約・・・・・・・・・・・・・・・・・ 128                                                                                                                                                                                                                          |
| 23. | 命令          | <b>要約・・・・・・・・・・・・・・・・・</b> 129                                                                                                                                                                                                                    |
| 24. | 注文作         | 青報・・・・・・・・・・・・・・・131                                                                                                                                                                                                                              |
| 25. | 外囲          | 内部発振器 126 7要約 128 要約 129 青報 131 器情報 131 青報 132 /-ト改訂履歴 133                                                                                                                                                                                        |
| 26  | <b>隨害</b> 性 | <b>青報・・・・・・・</b> 132                                                                                                                                                                                                                              |
| 27  | デーか         | ,k改訂履歴192                                                                                                                                                                                                                                         |
| 41. | コープン        | 7 1以口及证 100                                                                                                                                                                                                                                       |





#### 本社

#### Atmel Corporation

2325 Orchard Parkway San Jose, CA 95131 USA

TEL (+1)(408) 441-0311 FAX (+1)(408) 487-2600

### 国外営業拠点

#### Atmel Asia Limited

Unit 01-5 & 16, 19F BEA Tower, Millennium City 5 418 Kwun Tong Road Kwun Tong, Kowloon HONG KONG

TEL (+852) 2245-6100 FAX (+852) 2722-1369

#### Atmel Europe

Business Campus
Parking 4
D-85748 Garching b. Munich
GERMANY

TEL (+49) 89-31970-0 FAX (+49) 89-3194621

#### Atmel Japan

104-0032 東京都品川区 大崎1-6-4 新大崎勧業ビル 16F アトメル ジャハン株式会社 TEL (+81)(3)-6417-0300 FAX (+81)(3)-6417-0370

### 製品窓口

### ウェブサイト

www.atmel.com

# 文献請求

www.atmel.com/literature

# 技術支援

avr@atmel.com

# 販売窓口

www.atmel.com/contacts

お断り:本資料内の情報はAtmel製品と関連して提供されています。本資料またはAtmel製品の販売と関連して承諾される何れの知的所有権も禁反言あるいはその逆によって明示的または暗示的に承諾されるものではありません。Atmelのウェブサイに位置する販売の条件とAtmelの定義での詳しい説明を除いて、商品性、特定目的に関する適合性、または適法性の暗黙保証に制限せず、Atmelはそれらを含むその製品に関連する暗示的、明示的または法令による如何なる保証も否認し、何ら責任がないと認識します。たとえAtmelがそのような損害賠償の可能性を進言されたとしても、本資料を使用できない、または使用以外で発生する(情報の損失、事業中断、または利益の損失に関する制限なしの損害賠償を含み)直接、間接、必然、偶然、特別、または付随して起こる如何なる損害賠償に対しても決してAtmelに責任がないでしょう。Atmelは本資料の内容の正確さまたは完全性に関して断言または保証を行わず、予告なしでいつでも製品内容と仕様の変更を行う権利を保留します。Atmelはここに含まれた情報を更新することに対してどんな公約も行いません。特に別の方法で提供されなければ、Atmel製品は車載応用に対して適当ではなく、使用されるべきではありません。Atmel製品は延命または生命維持を意図した応用での部品としての使用に対して意図、認定、または保証されません。

© Atmel Corporation 2012. 不許複製 Atmel®、ロゴとそれらの組み合わせ、AVR®とその他はAtmel Corporationの登録商標または商標またはその付属物です。他の用語と製品名は一般的に他の商標です。

#### © HERO 2022.

本データシートはAtmelのATtiny43U英語版データシート(改訂8048C-02/12)の翻訳日本語版です。日本語では不自然となる重複する形容表現は省略されている場合があります。日本語では難解となる表現は大幅に意訳されている部分もあります。必要に応じて一部加筆されています。 頁割の変更により、原本より頁数が少なくなっています。

汎用入出力ポートの出力データレジスタとピン入力は、対応関係からの理解の容易さから出力レジスタと入力レジスタで統一表現されています。一部の用語がより適切と思われる名称に変更されています。必要と思われる部分には()内に英語表記や略称などを残す形で表記しています。

青字の部分はリンクとなっています。一般的に<mark>赤字の0.1</mark>は論理0.1を表します。その他の赤字は重要な部分を表します。