

# ATtiny3216/3217

# tinyAVR® 1系統

# 序説

ATtiny3216/3217マイクロ コントローラはハート ウェア乗算器を持つAVR®プロセッサを使い、20,24 ピン外囲器で32Kハ イトのフラッシュ メモリ、2Kハ イトのSRAM、256の イトのEEPROMを持ち、最大20MHzで動くtinyAVR® 1系統のマイクロ コントローラの一員です。tinyAVR® 1系統は事象システム、正確なアナロケ機能、コアから独立した周辺機能(CIPs:Core Independent Peripheral s)を含む柔軟で低電力な基本構造を持つ最新技術を使います。遮蔽駆動+(Driven Shield+)と増加動作技術を持つ容量性接触インターフェースが統合された周辺機能接触制御器(PTC:Peripheral Touch Controller)で支援されます。



注意: 車載製品は独立したデータシートで文書化されています。

(<mark>訳注</mark>)・本書はATtiny3216/3217シリコン障害とデータシート説明(DS80000887B)の内容を含みます。

・原書に対して断りなく最新情報に更新している場合があります。

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

© 2020 Microchip Technology Inc. 完全データシート DS40002205A/J13 - 1頁

# 特徴

- CPU
  - AVR® CPU
  - 最大20MHzで走行
  - 単一周期I/Oアクセス
  - 2段階の割り込み制御器
  - 2周期ハート・ウェア乗算器
- ・メモリ
  - 実装自己書き換え可能な32Kバイト(16K語)のフラッシュメモリ
  - 256バイトのEEPROM
  - 2KバイトのSRAM
  - 書き込み/消去寿命
    - フラッシュ メモリ: 10,000回
    - EEPROM: 100,000回
  - データ保持力
    - ·55℃で40年
- ・システム
  - 電源ONリセット(POR)
  - 低電圧検出器(BOD)
  - クロック任意選択
    - ·16/20MHz低電力内部RC発振器
    - · 32.768kHz超低電力(ULP)内部RC発振器
    - ・32.768kHz外部クリスタル用発振器
    - ・外部クロック入力
  - 単一ピンの統一プログラム/デバッグ インターフェース
  - 3つの休止動作形態
    - ・直ちに起き上がるために全ての周辺機能が動いているアイル
    - ・スタンバイ
      - 選んだ周辺機能の構成設定可能な動作
    - 完全なデータ保持を持つパワーダウン
- 周辺機能
  - 専用の定期レジ、スタと3つの比較チャネルを持つ1つの16ビット タイマ/カウンタA型 (TCA)
  - 捕獲入力を持つ2つの16ビット タイマ/カウンタB型 (TCB)
  - 制御応用に最適化された1つの12ビットタイマ/カウンタD型 (TCD)
  - 外部クリスタル、外部クロック、または内部RC発振器から走行する1つの16ビット実時間計数器 (RTC)
  - 独立したチップ上の発振器を持ち、窓動作を持つウォッチト、ッグ タイマ (WDT)
  - 分数ボーレート生成器、自動ボーレート、フレーム開始検出を持つ1つのUSART
  - 1つの主装置/従装置直列周辺インターフェース (SPI)
  - 2重アドレス一致を持つ1つの2線インターフェース (TWI)
    - Philips I<sup>2</sup>C互換
    - ・標準動作(Sm, 100kHz)
    - · 高速動作 (Fm, 400kHz)
    - ・高速動作プラス (Fm+, 1MHz)
  - 低伝搬遅延を持つ3つのアナログ比較器 (AC)
  - 10ビット、115kspsの2つのA/D変換器 (ADC)
  - 1つの外部チャネルを持つ3つの8ビットD/A変換器 (DAC)
  - 多数の参照基準電圧 (VREF)
    - 0.55V 1.1V 1.5V 2.5V 4.3V
  - CPUから独立して予測可能な周辺機能相互合図のための事象システム (EVSYS)
  - 2つの設定可能な参照表(LUT)を持つ構成設定可能な注文論理回路(CCL)
  - 自動化されたCRCメモリ走査 (CRCSCAN)
  - 周辺機能接触制御器 (PTC)
    - · 容量性接触釦、摺動子、輪、2D表面
    - ・接触での起き上がり
    - ・湿気と雑音の処理性能を改善する遮蔽駆動
    - ・最大14個の自己容量チャネル
    - ・最大49個の相互容量チャネル
  - 全ての汎用ピンでの外部割り込み

- ・I/Oと外囲器
  - 最大22本の設定可能なI/O線
- 温度範囲
  - --40~105°C
  - --40~125°C
- 速度評定
  - $-0\sim5 MHz/1.8\sim5.5 V$
  - $-0\sim10 MHz/2.7\sim5.5 V$
  - $-0\sim20 MHz/4.5\sim5.5 V$

# 目次

|      | 序説 ····································                  |     | 12.3.        |                                                      |            |
|------|----------------------------------------------------------|-----|--------------|------------------------------------------------------|------------|
|      | 特徴                                                       |     |              |                                                      |            |
| 1.   | シリコン障害とデータシート説明文書・・・・・・ 7                                |     |              | レシ、スタ説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・         |            |
|      | tinyAVR® 1系列概要 ····································      | 13. | <b>CPUII</b> | NT - CPU割り込み制御器 ・・・・・                                | • • • 60   |
| ۷.   | <b>2.1.</b> 製品形態要約 ····································  |     | 13.1.        | d I ala                                              | 60         |
| _    |                                                          |     | 13.2.        | 概要 •••••                                             |            |
|      | 構成図8                                                     |     |              | 機能的な説明・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・           |            |
| 4.   | t <sup>°</sup> ン配置 ······ 9                              |     |              | レジスタ要約・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・           |            |
|      | <b>4.1. 20</b> <sup>1</sup> / <sub>2</sub> -             |     |              | レジスタ説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・          |            |
|      | <b>4.2. 24</b> パット VQFN 9                                | 1./ |              | 'S - 事象システム・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・      |            |
| 5    | 入出力多重化と考察 ・・・・・・・・ 10                                    | 14. |              |                                                      | 01         |
| ٥.   | 5.1. 多重化された信号・・・・・・・・・・10                                |     | 14.1.        | 概要・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・              |            |
| 6    | メモリ・・・・・・・・・・・・・・・・・・・・・11                               |     |              |                                                      |            |
| υ.   | ·                                                        |     | 14.3.        | 放眠的な説明   ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・         | 70         |
|      | 6.1. 概要・・・・・・・・・・・ 11<br>6.2. メモリ配置・・・・・・・・・・ 11         |     | 14.4.        | レンス多要約・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・           | 70         |
|      | 6.2. X七9配直 ····································          |     |              | レジ、スタ説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・         |            |
|      | 6.3. 実装書き換え可能なフラッシュ プログラム メモリ・・・・・ 11                    | 15. | PORT         | 「MUX - ポート多重化器 ・・・・・・・・・                             | •••• 74    |
|      | 6.4. SRAM¬¯ -9 X=U                                       |     |              |                                                      |            |
|      | 6.5. EEPROM データ メモリ · · · · · · 12                       |     |              | <b>レジスタ要約・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・</b>    |            |
|      | 6.6. 使用者列 · · · · · · · 12                               |     | 15.3.        | <b>レシ、スタ説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・</b>  | · · · · 76 |
|      | 6.7. 識票列                                                 | 16. | PORT         | ¯ - I/Oピン構成設定 ・・・・・・・・・・・・・・・・                       | · · · · 78 |
|      | <b>6.8.</b> I/Oメモリ · · · · 12                            |     | 16.1.        | d L Mar                                              | •••• 78    |
|      | 6.9. 施錠されたデバイスでの                                         |     |              | 概要                                                   |            |
|      | 6.9. 施錠されたテハイスでの<br>CPUとUPDIからのメモリ領域アクセス                 |     |              |                                                      |            |
|      | 0.10. <b>(FUSE) ・・・・・・</b> 14                            |     |              | レジスタ要約 - PORTx ····································  |            |
| 7.   |                                                          |     | 16.5         | レジスタ説明 - PORTx ····································  | 83         |
|      | <b>7.1</b> . 周辺機能アドレス配置・・・・・・・・・ 21                      |     |              | レジスタ要約 - VPORTx ···································· |            |
|      | 7.2. 割り込みベクタ配置・・・・・・・・・・・ 21                             |     |              | レジスタ説明 - VPORTx ·······                              |            |
|      | <b>7.3.</b> システム構成設定 (SYSCFG) ・・・・・・・・23                 | 17  |              | - 低電圧検出器 ············                                |            |
| g    | AVR® CPU · · · · · · · · · · · · 24                      | 17. |              |                                                      |            |
| ٥.   | 8.1. 特徴 · · · · · · · · · 24                             |     | 17.1.        |                                                      |            |
|      | 8.2. 概要····································              |     | 17.2.        | 機能的な説明・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・           |            |
|      | 8.3. 基本構成                                                |     | 17.3.        |                                                      |            |
|      | 8.4. 算術論理演算部 (ALU) · · · · · · · · · · · · · · · · · · · |     | 17.4.        | レジスタ要約・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・           | 92         |
|      | 8.5. 機能的な説明 · · · · · · · · 25                           |     |              |                                                      |            |
|      | 8.6. レジスタ要約・・・・・・・・・28                                   | 18. | VREF         | - 基準電圧 •••••                                         |            |
|      | 8.7. レジスタ説明 ····································         |     | 18.1.        |                                                      |            |
| ^    | NIVAOTDI                                                 |     |              | 概要 •••••                                             |            |
| 9.   | NVMCTRL - 不揮発性メモリ制御器 ・・・・・・ 31                           |     |              | 機能的な説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・          |            |
|      | 9.1. 特徴       31         9.2. 概要       31                |     |              | レジスタ要約 ······                                        |            |
|      | 9.2. 概要 31                                               |     |              | <b>レシ、スタ説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・</b>  |            |
|      | <b>9.3.</b> 機能的な説明 · · · · · · · · · · · · · · · · · · · | 19. | WDT -        | – ウォッチト´ック´ タイマ ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・  | ••• 100    |
|      | 9.4. レジスタ要約 ・・・・・・・・ 36                                  |     | 19.1.        | 特徴                                                   | ••• 100    |
|      | 9.5. レジスタ説明 · · · · · · · · · · · · · · · · · · ·        |     | 19.2.        | 概要 •••••                                             | ••• 100    |
| 10.  | CLKCTRL - クロック制御器 ・・・・・・・・・ 40                           |     | 19.3.        | 機能的な説明・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・           | ••• 100    |
|      | 10.1. 特徴 40                                              |     | 19.4.        | レジスタ要約 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・          | •••• 103   |
|      | 10.2. 概要 ・・・・・・・・・・・・・・・・ 40                             |     | 19.5.        | レシ、スタ説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・         | 104        |
|      | 10.3. 機能的な説明 ・・・・・・・・・・・・・ 41                            | 20  | TCA -        | - 16ビット タイマ/カウンタA型 ・・・・・・・                           | 105        |
|      | 10.4. レジスタ要約・・・・・・・・・・・・・・・・・・44                         | 20. |              | 特徴・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・               |            |
|      | 10.5. レジスタ説明 ・・・・・・・・・・・・・・・・45                          |     |              | 概要 ••••••                                            |            |
| 11.  | SLPCTRL - 休止制御器 ····· 50                                 |     |              | 機能的な説明・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・           |            |
|      | 11.1. 特徴                                                 |     |              | レジスタ要約-標準動作・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・      |            |
|      | 11.2. 概要                                                 |     |              | レジスタ説明 - 標準動作・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・    |            |
|      | 11.3. 機能的な説明 ······· 50                                  |     |              | レジスタ要約-分割動作・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・      |            |
|      | 11.4. レジスタ要約 ······ 53                                   |     |              | レジスタ説明 - 分割動作・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・    |            |
|      | 11.5. レジスタ説明 ・・・・・・・・・・・54                               | 0.1 |              |                                                      |            |
| 12   | RSTCTRL - リセット制御器 ・・・・・・・・ 55                            | 21. | ICB -        | - 16ビット タイマ/カウンタB型 ・・・・・・・・                          | ••• 130    |
| ٠ ٢. | 12.1. 特徵 · · · · · · · · · · · · · · · · · ·             |     | 21.1.        | 特徴                                                   | 130        |
|      | 12.2. 概要 ・・・・・・・・・・・55                                   |     |              | 概要                                                   |            |
|      | 12.2. 194.女                                              |     | 21.3.        | 機能的な説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・          | •••• 131   |

|             | 21.4. レジスタ要約・・・・・・・・・・135                                                        |     | 30.2. | 概要 ••••••                                                                 | 2       | 52 |
|-------------|----------------------------------------------------------------------------------|-----|-------|---------------------------------------------------------------------------|---------|----|
|             | 21.5. レジスタ説明 ・・・・・・・・・・・ 136                                                     |     | 30.3. | 機能的な説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                               | 2       | 54 |
| 22.         | TCD - 12ビット タイマ/カウンタD型 ・・・・・・・ 141                                               |     | 30.4. | レジスタ要約 ・・・・・・・・・・・・・・・・・・                                                 | 2       | 59 |
|             | 22.1. 特徴                                                                         |     | 30.5. | レシ゛スタ説明 ・・・・・・・・・・・・・・・・・・・・・・                                            | 2       | 60 |
|             | <b>22.2</b> . 概要 ·································141                            | 31. | DAC - | D/A変換器 ······                                                             | 26      | 68 |
|             | <b>22.3</b> . 機能的な説明 ・・・・・・・・・・ 142                                              |     | 31.1. | 特徴 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                   | 2       | 68 |
|             | 22.4. レジスタ要約・・・・・・・・・・・・157                                                      |     | 31.2. | 概要 ••••••                                                                 | 2       | 68 |
|             | 22.5. レジスタ説明 ・・・・・・・・・・・・158                                                     |     | 31.3. | 機能的な説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                               | 2       | 69 |
| 23.         | RTC - 実時間計数器 · · · · · · · · · · · · 168                                         |     |       | レジスタ要約 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                               |         |    |
|             | 23.1. 特徴                                                                         |     |       | レシ゛スタ説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                              |         |    |
|             | <b>23.2</b> . 概要 ························168                                     | 32. | PTC - | 周辺機能接触制御器・・・・・・                                                           | •••• 27 | 72 |
|             | <b>23.3</b> . クロック · · · · · · · · · · · · · · · · · · ·                         |     |       | 特徴 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                   |         |    |
|             | <b>23.4</b> . RTCの機能的な説明・・・・・・・・ 169                                             |     |       | 概要 ••••••                                                                 |         |    |
|             | <b>23.5</b> . <b>PITの機能的な説明・・・・・・・・・</b> 169                                     |     |       | 構成図 ••••••                                                                |         |    |
|             | 23.6. 事象                                                                         |     |       | 信号説明                                                                      |         |    |
|             | 23.7. 割り込み・・・・・・・・・・・・170                                                        |     |       | システム依存性 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                              |         |    |
|             | 23.8. 休止形態動作                                                                     |     |       | 機能的な説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                               |         |    |
|             | 23.9. 同期                                                                         | 33. |       | - <b>統一プログラム/デバッグ インターフ</b> ェ                                             |         |    |
|             | <b>23.10.</b> デバッグ操作 ・・・・・・・・・・・・・ 171 <b>23.11.</b> レジスタ要約 ・・・・・・・・・・・・・・・・ 172 |     |       | 特徴 ····································                                   |         |    |
|             | <b>23.12.</b> レジスタ説明 ····································                        |     |       | 概要                                                                        |         |    |
| 0.4         | USART - 万能同期非同期送受信器 •••• 179                                                     |     |       | 機能的な説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                               |         |    |
| <b>Z4</b> . | <b>24.1.</b> 特徵 ···································                              |     |       | レジスタ要約 ・・・・・・・<br>レジスタ説明 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・             |         |    |
|             | <b>24.1.</b> 村墩 · · · · · · · · · · · · · · · · · ·                              | 24  |       |                                                                           |         |    |
|             | <b>24.3.</b> 機能的な説明 ················· 180                                        |     |       | -式要約 • • • • • • • • • • • • • • • • • • •                                |         |    |
|             | <b>24.4.</b> レジスタ要約 · · · · · · 189                                              | 35. |       |                                                                           |         |    |
|             | 24.5. レジスタ説明・・・・・・・・・190                                                         |     |       | 数字表記法 ************************************                                |         |    |
| 25          | SPI - 直列周辺インターフェース ・・・・・・ 198                                                    |     |       | メモリの大きさと形式 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                           |         |    |
| 20.         | 25.1. 特徵 · · · · · · · 198                                                       |     |       | 周波数と時間・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                |         |    |
|             | <b>25.2.</b> 概要 ······ 198                                                       |     |       | レシ`スタとヒ`ット ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                           |         |    |
|             | <b>25.3.</b> 機能的な説明 ・・・・・・・ 199                                                  | 26  |       | ADOM ルーメ足報 ・・・・・・・・・・・・・・・・・・<br>]特性 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ |         |    |
|             | 25.4. レジスタ要約・・・・・・・・・・・・205                                                      | 30. |       | お断り・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                   |         |    |
|             | 25.5. レシ スタ説明 ・・・・・・・・・・・・・ 206                                                  |     |       | ぬめり<br>絶対最大定格 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                        |         |    |
| 26.         | TWI - 2線インターフェース ・・・・・・・・ 210                                                    |     |       | 全般動作定格 ·····                                                              |         |    |
|             | 26.1. 特徴                                                                         |     |       | エルッパー                                                                     |         |    |
|             | <b>26.2</b> . 概要 ···································                             |     |       | 起き上がり時間 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                              |         |    |
|             | <b>26.3</b> . 機能的な説明 ・・・・・・・・・・ 211                                              |     |       | 周辺機能消費電力 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                             |         |    |
|             | <b>26.4</b> . レジスタ要約 ・・・・・・・・・・・ 219                                             |     | 36.7. | BODとPORの特性・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                            | 3       | 03 |
|             | <b>26.5</b> . レジスタ説明 ····································                        |     | 36.8. | 外部リセット特性・・・・・・・・・                                                         | 3       | 04 |
| 27.         | CRCSCAN - 巡回冗長検査メモリ走査 ・・・・ 229                                                   |     |       | 発振器とクロック ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                              |         |    |
|             | <b>27.1</b> . 特徴 ······· 229                                                     |     |       | 入出力ピン特性 ・・・・・・・・・・・・・・・・・                                                 |         |    |
|             | <b>27.2</b> . 概要 ······· 229                                                     |     |       | TCD · · · · · · · · · · · · · · · · · · ·                                 |         |    |
|             | <b>27.3.</b> 機能的な説明 ············ 229                                             |     |       | USART ·····                                                               |         |    |
|             | 27.4. レジスタ要約 ・・・・・・・・・・・・ 232                                                    |     |       | SPI ·····                                                                 |         |    |
|             | 27.5. レジスタ説明 ・・・・・・・・・・・・・・233                                                   |     |       | TWI                                                                       |         |    |
| 28.         | CCL - 構成設定可能な注文論理回路 ・・・ 235                                                      |     |       | VREF                                                                      |         |    |
|             | 28.1. 特徴                                                                         |     |       | TEMPSENSE ······                                                          |         |    |
|             | 28.2. 概要                                                                         |     |       | DAC·····                                                                  |         |    |
|             | <b>28.3.</b> 機能的な説明 ·················· 236                                       |     |       | AC                                                                        |         |    |
|             | <b>28.4.</b> レジスタ要約 ・・・・・・・・・・・・ 241 <b>28.5.</b> レジスタ説明 ・・・・・・・・・・ 242          |     |       | PTC · · · · · · · · · · · · · · · · · · ·                                 |         |    |
| 20          | 20.J. レン A 7 記し対 242                                                             |     |       | UPDIタイミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                             |         |    |
| 29.         | AC - アナログ比較器 ·············· 246                                                  |     |       | プログラミング時間 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                            |         |    |
|             | <b>29</b> .1. 特徴 · · · · · · · · · · · · · · · · · ·                             | 37  |       | · [                                                                       |         |    |
|             | <b>29.2.</b> 概要 · · · · · · · · · · · · · · · · · ·                              | 57. | 37.1  | 川上<br>消費電力 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                           | 3       | 16 |
|             | <b>29.4.</b> レジスタ要約 ····································                         |     |       | GPIO ····································                                 |         |    |
|             | 29.5. レジスタ説明 ・・・・・・・・・・・・・・・・・・・・・・・ 250                                         |     | 37.3. | VREF特性 • • • • • • • • • • • • • • • • • • •                              | 3       | 26 |
| 30          | ADC - A/D変換器 ·················· 252                                              |     | 37.4. | BOD特性 ······                                                              | 3       | 27 |
| JU.         | <b>30.1.</b> 特徵 · · · · · · · · · · · · · · · · · ·                              |     |       | ADC特性 ······                                                              |         |    |
|             | OO.1. 19 EX                                                                      |     |       |                                                                           |         |    |

|     | 37.6.  | TEMPSENSE特性 · · · · · · 336<br>AC特性 · · · · · · 336     |
|-----|--------|---------------------------------------------------------|
|     | 37.7.  | AC特性 · · · · · · · 336                                  |
|     | 37.8.  | OSC20M特性 · · · · · · · 339                              |
|     | 37.9.  | OSCULP32K特性 · · · · · · 340                             |
|     | 37.10. | TWI SDA保持タイミング · · · · · · · 341                        |
| 38. | 注文     | 青報 342                                                  |
|     | 38.1.  | 製品情報 342                                                |
|     | 38.2.  | 製品識別システム ・・・・・・ 342                                     |
| 39. | 外囲     | <b>器図・・・・・・</b> 343                                     |
|     | 39.1.  | オンライン外囲器図・・・・・・・・・・ 343                                 |
|     | 39.2.  | <b>20'</b> J- <b> -</b> 'SOIC                           |
|     | 39.3.  | <b>24</b> /\(\gamma\)\(\gamma\)\(\frac{1}{VQFN}\)       |
|     | 39.4.  | <b>熱的考察 · · · · · · · · · · · · · · · · · · ·</b>       |
| 40. | 障害性    | 青報・・・・・・・・・・・・・・・・・・・・・ 346                             |
|     | 40.1.  | 障害 - ATtiny3216/3217 · · · · · · 346                    |
| 41. | データシ   | /                                                       |
|     | 41.1.  | 改訂A - 2020年5月 · · · · · · · · · · · · · · · · · 352     |
|     | 41.2.  | 追補 - 廃止された改訂履歴 ・・・・・・・・ 356                             |
| Mic |        | <b>ウェブ サイト ・・・・・・・・・・・</b> 358                          |
|     |        | <b>通知サービス・・・・・・・・・・・・・</b> 358                          |
|     |        | 援······358                                              |
| 製品  | 品識別    | <del>ジステム ・・・・・・・・・・・・・・・・・・ 35</del> 8                 |
|     |        | <mark>デバイス コード保護機能 ・・・・・・・・・</mark> 358                 |
| 注台  | たる 4□  | 358                                                     |
| 本も  | ᄪ      |                                                         |
|     |        |                                                         |
|     |        | <mark>システム • • • • • • • • • • • • • • • • • • •</mark> |
| 世早  | 見的な    | 販売とサービス ・・・・・・・・・・・・ 360                                |

# 1. シリコン障害とデータシート説明文書(訳注:本書は下記の障害情報も含みます。)

MicrochipはMicrochip製品の成功裏の使用を確実にするために可能な最善の資料をお客様を提供することを心がけています。データシート更新の間、シリコン障害とデータシート説明文書がデータシートに対する最新情報を含みます。「ATtiny3216/3217シリコン障害とデータシート説明(www.microchip.com/DS80000887)」はhttps://www.microchip.comのデバイス製品頁で入手可能です。

# 2. tinyAVR® 1系列概要

右図はピン配置変種とメモリ量でtinyAVR 1系列デバイスを示します。

- ・これらのデバイスがピン互換で同じまたはより多くの機能を提供するため、上方向垂直移植はコード変更なしに可能です。下方向移植はより少ない利用可能ないくつかの周辺機能の実体のためにコート変更が必要かもしれません。
- ・左への水平方向移植はピン数、従って利用可能な機能を減らします。

異なるフラッシュ メモリ量を持つデバイスは一般的に異なるSRAMとEEPROMの量を持ちます。



# 2.1. 製品形態要約

# 2.1.1. 周辺機能要約

表2-1. 周辺機能要約

| 機能項目                   | ATtiny3216       | ATtiny3217       |  |  |  |
|------------------------|------------------|------------------|--|--|--|
| ピン数                    | 20               | 24               |  |  |  |
| フラッシュ メモリ量 (Κハ・イト)     | 32               |                  |  |  |  |
| SRAM量 (Kバイト)           | 2                | 2                |  |  |  |
| EEPROM量 (バイト)          | 25               | 56               |  |  |  |
| 最大動作周波数 (MHz)          | 2                | 0                |  |  |  |
| 16ビット タイマ/カウンタA型 (TCA) | :                | 1                |  |  |  |
| 16ビット タイマ/カウンタB型 (TCB) | 62               | 2                |  |  |  |
| 12ビット タイマ/カウンタD型 (TCD) |                  | 1                |  |  |  |
| 実時間計数器 (RTC)           |                  | 1                |  |  |  |
| USART                  |                  | 1                |  |  |  |
| SPI                    |                  | 1                |  |  |  |
| TWI (I <sup>2</sup> C) | 1                |                  |  |  |  |
| ADC                    |                  | 2                |  |  |  |
| ADCチャネル数               | 12+8             | 12+12            |  |  |  |
| DAC                    | 3                |                  |  |  |  |
| アナログ 比較器 (AC)          | · ·              | 3                |  |  |  |
| AC入力数                  | 3p/2n+4p/1n+3p1n | 4p/2n+4p/2n+4p2n |  |  |  |
| 周辺機能接触制御器 (PTC) (注)    |                  | 1                |  |  |  |
| PTC自己容量チャネル数 (注)       | 12               | 14               |  |  |  |
| PTC相互容量チャネル数 (注)       | 36               | 49               |  |  |  |
| 構成設定可能な注文論理回路          |                  | 1                |  |  |  |
| 窓ウォッチドッグ               |                  | 1                |  |  |  |
| 事象システムチャネル数            |                  | 5                |  |  |  |
| 汎用入出力(GPIO)            | 18               | 22               |  |  |  |
| 外部割り込み                 | 18               | 22               |  |  |  |
| CRC走査 (CRCSCAN)        |                  | 1                |  |  |  |

注1: PTCはPTCが使われる間中ADC0の制御を取ります。

# 3. 構成図



注: この構成図はピン数とフラッシュ メモリ量の両方に関してtinyAVR 1系の最大デバイスを表します。このデータシートの特定デバイスの特徴の概要については「2.1. 製品形態要約」と「5.1. 多重化された信号」の項をご覧ください。

# 4. ピン配置

# 4.1. 2011-1 SOIC



# 4.2. 24/\<sup>°</sup>ット VQFN



# 5. 入出力多重化と考察

# 5.1. 多重化された信号

表5-1. ポート機能多重化(注3)

| 100    | 1. qv  | I JOSE HE S |                 | Ξυ)   |       |           |       |       |       |      |                |        |           |      |    |      |      |          |
|--------|--------|-------------|-----------------|-------|-------|-----------|-------|-------|-------|------|----------------|--------|-----------|------|----|------|------|----------|
| VQFN24 | SOIC20 | ピン名         | その他             | ΑI    | С     | PTC       |       | AC    |       | DAC0 | USART0         | SPI0   | TWIO      | TCA0 | TO | СВ   | TCD0 | CCL      |
| ٥<br>٧ | so     | (注1,2)      | /特殊             | 0     | 1     | (注4)      | 0     | 1     | 2     |      | 'SN            | 01 10  |           |      | 0  | 1    |      |          |
| 23     | 16     | PA0         | RESET<br>UPDI   | AIN0  |       |           |       |       |       |      |                |        |           |      |    |      |      | LUT0-IN0 |
| 24     | 17     | PA1         |                 | AIN1  |       |           |       |       |       |      | TxD            | MOSI   | SDA       |      |    |      |      | LUT0-IN1 |
| 1      | 18     | PA2         | EVOUT0          | AIN2  |       |           |       |       |       |      | RxD            | MISO   | SCL       |      |    |      |      | LUT0-IN2 |
| 2      | 19     | PA3         | EXTCLK          | AIN3  |       |           |       |       |       |      | XCK            | SCK    |           | WO3  |    | WO   |      |          |
| 3      | 20     | GND         |                 |       |       |           |       |       |       |      |                |        |           |      |    |      |      |          |
| 4      | 1      | VDD         |                 |       |       |           |       |       |       |      |                |        |           |      |    |      |      |          |
| 5      | 2      | PA4         |                 | AIN4  | AIN0  | X0/Y0     |       |       |       |      | XDIR           | SS     |           | WO4  |    |      | WOA  | LUT0-OUT |
| 6      | 3      | PA5         | VREFA           | AIN5  | AIN1  | X1/Y1     | OUT   | AINN0 |       |      |                |        |           | WO5  | WO |      | WOB  |          |
| 7      | 4      | PA6         |                 | AIN6  | AIN2  | X2/Y2     | AINN0 | AINP1 | AINP0 | OUT  |                |        |           |      |    |      |      |          |
| 8      | 5      | PA7         |                 | AIN7  | AIN3  | X3/Y3     | AINP0 | AINP0 | AINN0 |      |                |        |           |      |    |      |      | LUT1-OUT |
| 9      | -      | PB7         |                 |       | AIN4  |           |       | AINN1 | AINP3 |      |                |        |           |      |    |      |      |          |
| 10     | -      | PB6         |                 |       | AIN5  |           | AINP3 |       | AINN1 |      |                |        |           |      |    |      |      |          |
| 11     | 6      | PB5         | CLKOUT          | AIN8  |       | X12/Y12   |       |       | AINP2 |      |                |        |           | WO2  |    |      |      |          |
| 12     | 7      | PB4         |                 | AIN9  |       | X13/Y13   | AINN1 | AINP3 |       |      |                |        |           | WO1  |    |      |      | LUT0-OUT |
| 13     | 8      | PB3         | TOSC1           |       |       |           |       | OUT   |       |      | RxD            |        |           | WO0  |    |      |      |          |
| 14     | 9      | PB2         | TOSC2<br>EVOUT1 |       |       |           |       |       | OUT   |      | TxD            |        |           | WO2  |    |      |      |          |
| 15     | 10     | PB1         |                 | AIN10 |       | X4/Y4     | AINP2 |       |       |      | XCK            |        | SDA       | WO1  |    |      |      |          |
| 16     | 11     | PB0         |                 | AIN11 |       | X5/Y5     |       | AINP2 | AINP1 |      | XDIR           |        | SCL       | WO0  |    |      |      |          |
| 17     | 12     | PC0         |                 |       | AIN6  | X6/Y6     |       |       |       |      |                | SCK    |           |      | WO |      | WOC  |          |
| 18     | 13     | PC1         |                 |       | AIN7  | X7/Y7     |       |       |       |      |                | MISO   |           |      |    |      | WOD  | LUT1-OUT |
| 19     | 14     | PC2         | EVOUT2          |       | AIN8  | X8/Y8     |       |       |       |      |                | MOSI   |           |      |    |      |      |          |
| 20     | 15     | PC3         |                 |       | AIN9  | X9/Y9     |       |       |       |      |                | SS     |           | WO3  |    |      |      | LUT1-IN0 |
| 21     | -      | PC4         |                 |       | AIN10 | X10/Y10   |       |       |       |      |                |        |           | WO4  |    | WO   |      | LUT1-IN1 |
| 22     | -      | PC5         |                 |       |       | X11/Y11   |       |       |       |      |                |        |           | WO5  |    |      |      | LUT1-IN2 |
|        | , o. A |             | - H-11.1        |       | 1 7   | 1 , 0, 75 | H - 2 |       |       | a 1. | <i>t</i> → . → | ~ + == | VI. > 2 - |      | D  | - 1. | A    | いいままお    |

注1: ピン名はポートの実体(A,B,C)となるxとピン番号のnを持つPxn形式です。信号の表記法はPORTx\_PINnです。全てのピンを事象 システムとして使うことができます。

注2: 全てのピンは外部割り込みとして使うことができ、各ポートのPx2とPx6のピンは完全な非同期検出を持ちます。

注3: 赤文字は代替ピン位置。代替位置選択については「PORTMUX - ポート多重器」章を参照してください。

注4: 全てのPTC線はX線またはY線として構成設定することができます。

# 6. メモリ

# 6.1. 概要

主なメモリはSRAMデータメモリ、EEPROMデータメモリ、フラッシュプログラムメモリです。加えて、周辺機能レジスタがI/Oメモリ空間に置かれます。

表6-1. フラッシュ メモリの物理的な特性

| 特性     | 値      |
|--------|--------|
| 量      | 32Kバイト |
| ページを量  | 128バイト |
| ページ数   | 256    |
| 開始アドレス | \$8000 |

| 表6-2. SRAMの物理的な特性 |        |  |  |  |  |  |  |
|-------------------|--------|--|--|--|--|--|--|
| 特性值               |        |  |  |  |  |  |  |
| 量                 | 2Kバイト  |  |  |  |  |  |  |
| 開始アドレス            | \$3800 |  |  |  |  |  |  |

| 表6-3. EEPROMの物理的な特性 |  |  |  |  |  |  |  |
|---------------------|--|--|--|--|--|--|--|
| 値                   |  |  |  |  |  |  |  |
| 256バイト              |  |  |  |  |  |  |  |
| 64バイト               |  |  |  |  |  |  |  |
| 4                   |  |  |  |  |  |  |  |
| \$1400              |  |  |  |  |  |  |  |
|                     |  |  |  |  |  |  |  |

# 6.2. メモリ配置



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

ATtiny3216/3217はプログラム記憶用に実装書き換え可能なチップ上の16Kバイトのフラッシュメモリを含みます。全てのAVR命令が16または32のビット幅のため、このフラッシュメモリは16K×16として構成されます。書き込み保護のため、フラッシュプログラムメモリ空間はそれらの間に制限されたアクセス権を持つ、ブートローダ領域、応用コード領域、応用データ領域の3つの領域に分けることができます(下図をご覧ください)。

プログラム カウンタ(PC)はプログラム メモリ全体をアトレス指定するために14ビット幅です。フラッシュ メモリを書くための手順は不揮発性メモリ制御器(NVMCTRL)周辺機能の文章内で詳細に記述されます。

フラッシュ メモリ全体がメモリ空間に配置され、LPM命令だけでなく通常のLD/ST命令でもアクセス可能です。LD/ST命令に対して、フラッシュ メモリはアト・レス\$8000から配置されます。LPM命令に対して、フラッシュ メモリ開始アト・レスは\$0000です。

ATtiny3216/3217はバスの主権者であるCRC単位部も持ちます。

#### 図6-2. フラッシュ メモリと3つの領域

プログラム用 フラッシュ メモリ 32Kハ イト 応用コート・ 応用データ

FLASHSTART:\$8000

BOOTEND>0: \$8000+BOOTEND × 256

 $\texttt{APPEND}{>}0:\$8000{+}\texttt{APPEND}{\times}256$ 

FLASHEND: \$FFFF

# 6.4. SRAMデータ メモリ

2KバイトのSRAMはデータ記憶とスタックに使われます。

# 6.5. EEPROMデータ メモリ

ATtiny3216/3217は256バイトのEEPROMデータ メモリを持ちます。「6.2. メモリ配置」項をご覧ください。EEPROMメモリは単一バイトの読み書きを支援します。EEPROMは不揮発性メモリ制御器(NVMCTRL)によって制御されます。

# 6.6. 使用者列

EEPROMに加えて、ATtiny3216/3217はファームウェア設定に使うことができるEEPROMメモリの1つの付加ページである使用者列(USERRO W)を持ちます。このメモリは標準EEPROMとして単一パイトの読み書きを支援します。CPUはこのメモリを標準EEPROMとして読み書きすることができ、UPDIはこの部分が解錠されていれば標準EEPROMメモリとして読み書きすることができます。使用者列はこの部分が施錠されている時にUPDIによって書くこともできます。USERROWはチップ消去によって影響を及ぼされません。

# 6.7. 識票列

全てのtinyAVR®マイクロコントローラはデバイスを識別する3バイトの識票符号を持ちます。この3バイトは独立したアトレス空間に存在します。このデバイス用の識票バイトは右表で与えられます。

注: デバイスが施錠されている時はシステム情報部(SIB:System Information Block)だけを アクセスすることができます。

| 表6-4. テ | 表6-4. デバイスID |            |        |        |  |  |  |  |  |  |  |
|---------|--------------|------------|--------|--------|--|--|--|--|--|--|--|
| ="","   | 仏名           | 識票バイト アドレス |        |        |  |  |  |  |  |  |  |
| ) //    | 1/4          | \$0000     | \$0001 | \$0002 |  |  |  |  |  |  |  |
| ATtin   | y3216        | \$1E       | \$95   | \$21   |  |  |  |  |  |  |  |
| ATtin   | y3217        | \$1E       | \$95   | \$22   |  |  |  |  |  |  |  |

#### 6.8. I/Oメモリ

ATtiny3216/3217の全てのI/Oと周辺機能はI/Oメモリ空間に配置されます。\$00~\$3FのI/Oアドレス範囲はINとOUTの命令を使って単一周期でアクセスすることができます。\$0040~\$0FFFの拡張I/Oメモリ空間は32個の汎用作業レジスタとI/Oメモリ空間の間でデータを転送するLD/LDS/LDDとST/STS/STDの命令によってアクセスすることができます。

アト・レス範囲\$00~\$1F内のI/Oレシ、スタはSBIとCBIの命令を用いて直接ビットアクセス可能です。これらのレシ、スタでは、SBISとSBICの命令を用いることによって単一ビットの値を調べることができます。より多くの詳細については「命令一式要約」章を参照してください。

将来のデバイスとの互換性のため、予約ビットはアクセスされる場合に'0'を書かれなければなりません。予約されたI/Oメモリ アドレスは決して書かれてはなりません。

割り込み要求フラグのいくつかはそれらに'1'を書くことによって解除(0)されます。ATtiny3216/3217デバイスではCBIとSBIの命令が特定ビットでだけ動作し、このような割り込み要求フラグを含むレジスタで使うことができます。CBIとSBIの命令は\$00~\$1Fのレジスタでだけ動きます。

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

ATtiny3216/3217デバイスは4つの汎用I/Oレジスタを提供します。これらのレジスタはどんな情報を格納するのにも使うことができ、それらは全域変数や割り込みフラグを格納するのに特に有用です。アドレス範囲\$1C~\$1Fに属す汎用I/OレジスタはSBI,CBI,SBIS,SBICの命令を用いて直接ビットアクセス可能です。

# 6.8.1. レジスタ要約

| 変位    | 略称     | ビット位置 | ヒ゛ット7 | ピット6 | ピット5 | じット4 | ピット3 | ピット2 | ピット1 | ピット0 |
|-------|--------|-------|-------|------|------|------|------|------|------|------|
| +\$00 | GPIOR0 | 7~0   |       |      | 1    | GPIO | R7~0 |      | 1    |      |
| +\$01 | GPIOR1 | 7~0   |       |      |      | GPIO | R7~0 |      | 1    |      |
| +\$02 | GPIOR2 | 7~0   |       |      | 1    | GPIO | R7~0 |      | 1    |      |
| +\$03 | GPIOR3 | 7~0   |       |      | 1    | GPIO | R7~0 | 1    | 1    |      |

# 6.8.2. レジスタ説明

6.8.2.1. GPIORn - 汎用I/Oレジスタn (General Purpose I/O Register n)

名称: GPIOR0: GPIOR1: GPIOR2: GPIOR3 変位: +\$00: +\$01: +\$02: +\$03

リセット: \$00 特質:-

これらはビット アクセス可能なI/Oメモリ空間で全域変数やフラグのようなデータを格納するのに使うことができる汎用レジスタです。

| ピット    | 7        | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |  |
|--------|----------|-----|-----|-----|-----|-----|-----|-----|--|--|--|--|
|        | GPIOR7~0 |     |     |     |     |     |     |     |  |  |  |  |
| アクセス種別 | 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 - GPIOR7~0: 汎用I/Oレジスタn バイト (GPIO Register byte)

# 6.9. 施錠されたデバイスでのCPUとUPDIからのメモリ領域アクセス

デバイスはメモリがUPDIを用いて読むことができないように施錠することができます。この施錠はフラッシュ メモリ(フェート、応用コート、、応用データの領域の全て)、SRAMとヒュース(FUSE)データを含むEEEPROMの両方を保護します。これはデバッカ インターフェースを用いた応用のデータ やコートの読み込み成功を防ぎます。応用内からの通常のメモリアクセスは未だ許されます。

デバイスは施錠ビット ヒューズ(FUSE.LOCKBIT)の施錠ビット(LOCKBIT)ビット領域にどれかの非有効鍵を書くことによって施錠されます。

表6-5. 解錠動作/施錠動作でのメモリ アクセス (~/~は解錠時/施錠時、注1)

| メモリ領域         | CPU: | アクセス | UPDIアクセス |                   |  |  |
|---------------|------|------|----------|-------------------|--|--|
| アモリ門以         | 読み   | 書き   | 読み       | 書き                |  |  |
| SRAM          | 0/0  | 0/0  | O/X      | O/X               |  |  |
| レジスタ          | 0/0  | 0/0  | O/X      | O/X               |  |  |
| フラッシュ メモリ     | 0/0  | 0/0  | O/X      | O/X               |  |  |
| EEPROM        | 0/0  | 0/0  | O/X      | O/X               |  |  |
| 使用者列(USERROW) | 0/0  | 0/0  | O/X      | ○/○ ( <b>注2</b> ) |  |  |
| 識票列(SIGROW)   | 0/0  | ×/×  | O/X      | ×/×               |  |  |
| 他のヒューズ        | 0/0  | ×/×  | O/X      | O/×               |  |  |

注1:表で×と記された読み込み操作が成功に見えるかもしれませんが、データは有効ではありません。故に、UPDIを通すどのコード確認の試みもこれらのメモリ領域で失敗します。

注2: 施錠動作でUSERROWはヒュース・書き込み指令を用いて書くことはできますが、現在のUSERROW値を読み出すことができません。

(**訳注**) 視認性から原書の表6-5.と表6-6.は表6-5.として纏めました。



重要: デバイスを解錠する唯一の方法はチップ消去(CHIPERASE)を通すことです。 応用データは保持されません。

# 6.10. 構成設定と使用者ヒューズ(FUSE)

ヒューズは不揮発性メモリの一部でデバイス構成設定を保持します。 ヒューズはデバイス電源投入から利用可能です。 ヒューズはCPUまたは UPDIによって読むことができますが、UPDIによってのみ設定または解除を行うことができます。 ヒューズに格納された構成設定値は始動手順の最後でそれら各々の目的対象レジスタに書かれ(転送され)ます。

周辺機能構成設定用ヒューズ(FUSE)は予め設定されますが、使用者によって変えることができます。構成設定ヒューズで変えられた値はリセット後にだけ有効です。

注: ヒューズを書く時に全ての予約ビットは、1'を書かれなければなりません。

# 

| 変位         | 略称         | ビット位置        | ビット7 | ピット6 | ビット5 | ピット4    | ピット3    | ピット2 | ピット1 | ピット0 |
|------------|------------|--------------|------|------|------|---------|---------|------|------|------|
| +\$00      | DEVICEID0  | 7~0          |      |      |      | DEVIC   | EID7~0  |      |      |      |
| +\$01      | DEVICEID1  | 7~0          |      |      |      | DEVIC   | EID7~0  | 1    | 1    |      |
| +\$02      | DEVICEID2  | 7 <b>~</b> 0 |      |      |      | DEVIC   | EID7~0  |      |      |      |
| +\$03      | SERNUM0    | 7 <b>~</b> 0 |      |      |      | SERNU   | JM7∼0   | 1    | 1    |      |
| +\$04      | SERNUM1    | 7 <b>~</b> 0 |      |      |      | SERNU   | JM7∼0   | 1    | 1    |      |
| +\$05      | SERNUM2    | 7 <b>~</b> 0 |      |      |      | SERNU   | JM7∼0   | 1    | 1    |      |
| +\$06      | SERNUM3    | 7 <b>~</b> 0 |      |      |      | SERNU   | JM7∼0   | 1    | 1    |      |
| +\$07      | SERNUM4    | 7 <b>~</b> 0 |      |      |      | SERNU   | JM7∼0   | 1    | 1    |      |
| +\$08      | SERNUM5    | 7 <b>~</b> 0 |      |      |      | SERNU   | JM7∼0   | 1    | 1    |      |
| +\$09      | SERNUM6    | 7 <b>~</b> 0 |      |      |      | SERNU   | JM7∼0   |      |      |      |
| +\$0A      | SERNUM7    | 7~0          |      |      |      | SERNU   | JM7∼0   |      |      |      |
| +\$0B      | SERNUM8    | 7 <b>~</b> 0 |      |      |      | SERNU   | JM7∼0   | 1    |      |      |
| +\$0C      | SERNUM9    | 7 <b>~</b> 0 |      |      |      | SERNU   | JM7∼0   |      |      |      |
| +\$0D<br>∼ | 予約         |              |      |      |      |         |         |      |      |      |
| +\$1F      | 1′         |              |      |      |      |         |         |      |      |      |
| +\$20      | TEMPSENSE0 | 7~0          |      |      |      | TEMPSE  | ENSE7~0 |      |      |      |
| +\$21      | TEMPSENSE1 | 7~0          |      |      |      | TEMPSE  | NSE7~0  |      |      |      |
| +\$22      | OSC16ERR3V | 7~0          |      |      |      | OSC16EI | RR3V7~0 |      |      |      |
| +\$23      | OSC16ERR5V | 7~0          |      |      |      | OSC16EI | RR5V7~0 |      |      |      |
| +\$24      | OSC20ERR3V | 7~0          |      |      |      | OSC20EI | RR3V7~0 |      |      |      |
| +\$25      | OSC20ERR5V | 7~0          |      |      |      | OSC20EI | RR5V7~0 |      |      |      |

# 

6.10.2.1. DEVICEIDn - デバイスIDn (Device ID n)

名称: DEVICEID0: DEVICEID1: DEVICEID2

**変位**:+\$00::+\$01::+\$02

**既定**:[デバイスID]

特質:-

各デバイスはこのデバイスとメモリ量、ピン数、ダイ改訂のようなそれの特性を識別するデバイスIDを持ちます。これはデバイスを識別するのに使うことができ、故にソフトウェアによって利用可能な機能です。デバイスIDはSIGROW.DEVICEID2~0の3バイトから成ります。

| <u> </u> | 7 | 6 | 5 | 4     | 3      | 2 | 1 | 0 |
|----------|---|---|---|-------|--------|---|---|---|
|          |   |   |   | DEVIC | EID7~0 |   |   |   |
| アクセス種別   | R | R | R | R     | R      | R | R | R |
| 既定值      | X | X | X | X     | X      | X | X | X |

• ビット7~0 - DEVICEID7~0: デバイスIDのバイトn (Byte n of the Device ID)

6.10.2.2. SERNUMn - 通番バイトn (Serial Number Byte n)

名称:SERNUM0:SERNUM1:SERNUM2:SERNUM3:SERNUM4:SERNUM5:SERNUM6:SERNUM7:SERNUM8:SERNUM9

**変位**:+\$03 :+\$04 :+\$05 :+\$06 :+\$07 :+\$08 :+\$09 :+\$0A :+\$0B :+\$0C

既定:[デバイス通番]

特質:-

各デバイスは固有のIDを表す個別の通番を持ちます。これは在野で特定デバイスを識別するのに使うことができます。通番はSIGRO W.SERNUM9~0の10バイから成ります。

| <u> </u>  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|-----------|---|---|---|---|---|---|---|---|--|
| SERNUM7~0 |   |   |   |   |   |   |   |   |  |
| アクセス種別    | R | R | R | R | R | R | R | R |  |
| 既定值       | X | X | X | X | X | X | X | X |  |

• ビット7~0 - SERNUM7~0: 通番のバイトn (Serial Number n [n=0~9])

6.10.2.3. TEMPSENSEn - 温度感知器校正n (Temperature Sensor Calibration n)

名称: TEMPSENSE0: TEMPSENSE1

**変位**:+\$20 :+\$21 **既定**:「温度感知器校正値]

特質:-

温度感知器校正レジスタはチップ。上感知器での温度測定に対する修正係数を含みます。SIGROW.TEMPSENSE0は利得/傾斜に対する(符号なし)修正係数で、SIGROW.TEMPSENSE1は変位(オフセット)に対する(符号付き)修正係数です。

| ヒ"ット   | 7 | 6 | 5 | 4      | 3      | 2 | 1 | 0 |
|--------|---|---|---|--------|--------|---|---|---|
|        |   | , |   | TEMPSE | NSE7~0 |   |   |   |
| アクセス種別 | R | R | R | R      | R      | R | R | R |
| 既定值    | X | X | X | X      | X      | X | X | X |

● ビット7~0 - TEMPSENSE7~0:温度感知器校正バイトn (Temperature Sensor Calibration Byte)

このレシブスタの使用方法については「ADC」章の「温度測定」を参照してください。

6.10.2.4. OSC16ERR3V - 3VでのOSC16誤差 (OSC16 error at 3V)

名称: OSC16ERR3V

変位:+\$22

既定:[発振器周波数誤差值]

特質:-

| <u> </u> | 7 | 6 | 5 | 4       | 3       | 2 | 1 | 0 |
|----------|---|---|---|---------|---------|---|---|---|
|          |   |   |   | OSC16EI | RR3V7~0 |   |   |   |
| アクセス種別   | R | R | R | R       | R       | R | R | R |
| 既定値      | X | X | X | X       | X       | X | X | X |

● ビット7~0 - OSC16ERR3V7~0: 3VでのOSC16誤差 (OSC16 error at 3V) (訳注:次頁脚注の訳補参照)

このレジスタは製造中に測定した3V/内部16MHz走行時の標準発振器周波数に相対する符号付き発振器周波数誤差値を含みます。

#### **6.10.2.5. OSC16ERR5V - 5VでのOSC16**誤差 (OSC16 error at 5V)

名称: OSC16ERR5V

変位:+\$23

既定:[発振器周波数誤差值]

特質:-

| ピット    | 7 | 6 | 5 | 4      | 3       | 2 | 1 | 0 |
|--------|---|---|---|--------|---------|---|---|---|
|        |   |   |   | OSC16E | RR5V7~0 |   |   |   |
| アクセス種別 | R | R | R | R      | R       | R | R | R |
| 既定值    | X | X | X | X      | X       | X | X | X |

● ビット7~0 - OSC16ERR5V7~0: 5VでのOSC16誤差 (OSC16 error at 5V) (訳注:脚注の訳補参照)

このレジスタは製造中に測定した5V/内部16MHz走行時の標準発振器周波数に相対する符号付き発振器周波数誤差値を含みます。

#### 6.10.2.6. OSC20ERR3V - 3VでのOSC20誤差 (OSC20 error at 3V)

名称: OSC20ERR3V

変位 : +\$24

既定:[発振器周波数誤差值]

特質:-

|          | 0 | Э | 4       | 3       | 2 | 1 | 0 |
|----------|---|---|---------|---------|---|---|---|
|          | , |   | OSC20EI | RR3V7~0 |   |   |   |
| アクセス種別 R | R | R | R       | R       | R | R | R |
| 既定值 x    | X | X | X       | X       | X | X | X |

● ビット7~0 - OSC20ERR3V7~0: 3VでのOSC20誤差 (OSC20 error at 3V)(訳注:脚注の訳補参照)

このレジスタは製造中に測定した3V/内部20MHz走行時の標準発振器周波数に相対する符号付き発振器周波数誤差値を含みます。

#### **6.10.2.7. OSC20ERR5V - 5VでのOSC20**誤差 (OSC20 error at 5V)

名称: OSC20ERR5V

**変位**:+\$25

既定:[発振器周波数誤差值]

特質:-

| ピット    | 7 | 6 | 5 | 4      | 3       | 2 | 1 | 0 |
|--------|---|---|---|--------|---------|---|---|---|
|        |   |   |   | OSC20E | RR5V7~0 |   |   |   |
| アクセス種別 | R | R | R | R      | R       | R | R | R |
| 既定值    | X | X | X | X      | X       | X | X | X |

● ビット7~0 - OSC20ERR5V7~0:5VでのOSC20誤差(OSC20 error at 5V)(訳注:脚注の訳補参照)

このレジスタは製造中に測定した5V/内部20MHz走行時の標準発振器周波数に相対する符号付き発振器周波数誤差値を含みます。

# 6.10.3. ヒュース 要約

| 変位    | 略称      | ビット位置        | ピット7    | ピット6   | ヒ゛ット5  | ヒ゛ット4    | ピット3   | ピット2   | ヒ゛ット1  | ピット0   |
|-------|---------|--------------|---------|--------|--------|----------|--------|--------|--------|--------|
| +\$00 | WDTCFG  | 7~0          |         | WINDO  | DW3∼0  |          |        | PERIC  | D3~0   |        |
| +\$01 | BODCFG  | 7~0          |         | LVL2~0 |        | SAMPFREQ | ACTI   | VE1,0  | SLEI   | EP1,0  |
| +\$02 | OSCCFG  | 7~0          | OSCLOCK |        |        |          |        |        | FREQ   | SEL1,0 |
| +\$03 | 予約      |              |         |        |        |          |        |        |        |        |
| +\$04 | TCD0CFG | 7~0          | CMPDEN  | CMPCEN | CMPBEN | CMPAEN   | CMPD   | CMPC   | CMPB   | CMPA   |
| +\$05 | SYSCFG0 | 7~0          | CRCS    | RC1,0  |        | TOUTDIS  | RSTPIN | CFG1,0 |        | EESAVE |
| +\$06 | SYSCFG1 | 7 <b>~</b> 0 |         |        |        |          |        |        | SUT2~0 |        |
| +\$07 | APPEND  | 7~0          |         |        |        | APPEN    | ND7∼0  |        |        |        |
| +\$08 | BOOTEND | 7~0          |         |        | 1      | ВООТЕ    | END7∼0 |        |        |        |
| +\$09 | 予約      |              |         |        |        |          |        |        |        |        |
| +\$0A | LOCKBIT | 7~0          |         |        |        | LOCKI    | BIT7∼0 |        |        |        |

(<mark>訳補</mark>) OSCxxERRxVレジスタは「CLKCTRL」章のコート・例に基づくと[(公称周波数-実測周波数)/公称周波数×1024]の符号付き8ビット値で概ね+12.7~-12.8%の誤差を表します。

#### 6.10.4. ヒュース 説明

6.10.4.1. WDTCFG - ウォッチト・ック 構成設定 (Watchdog Configration)

名称:WDTCFG 変位:+\$00 既定:\$00 特質:-

このヒューズ記述で与えられる既定値は工場書き込み値で、リセット値と間違えてはいけません。

| ピット    | 7 | 6     | 5     | 4 | 3 | 2     | 1     | 0 |
|--------|---|-------|-------|---|---|-------|-------|---|
|        |   | WINDO | OW3∼0 |   | · | PERIC | DD3~0 |   |
| アクセス種別 | R | R     | R     | R | R | R     | R     | R |
| 既定值    | 0 | 0     | 0     | 0 | 0 | 0     | 0     | 0 |

● ビット7~4 - WINDOW3~0: ウォッチドック 窓制限時間周期 (Watchdog Window Timeout Period)

この値はリセット中にウォッチドッグ制御A(WDT.CTRLA)レジスタの窓期間(WINDOW)ビット領域に設定されます。

● ビット3~0 - PERIOD3~0: ウォッチドッグ制限時間周期 (Watchdog Timeout Period)

この値はリセット中にウォッチドッグ制御A(WDT.CTRLA)レジスタの制限期間(PERIOD)ビット領域に設定されます。

# 6.10.4.2. BODCFG - BOD構成設定 (BOD Configration)

名称:BODCFG 変位:+\$01 既定:\$00 特質:-

このヒューズ記述で与えられる既定値は工場書き込み値で、リセット値と間違えてはいけません。

このヒューズレジスタのビット値は始動で対応するBOD構成設定レジスタに書かれます。

| ピット    | 7 | 6      | 5 | 4        | 3    | 2     | 1    | 0     |
|--------|---|--------|---|----------|------|-------|------|-------|
|        |   | LVL2~0 |   | SAMPFREQ | ACTI | VE1,0 | SLEE | EP1,0 |
| アクセス種別 | R | R      | R | R        | R    | R     | R    | R     |
| 既定値    | 0 | 0      | 0 | 0        | 0    | 0     | 0    | 0     |

#### ● ビット7~5 - LVL2~0: BOD基準 (BOD Level)

この値はリセット中にBOD制御B(BOD.CTRLB)レシブスタのBOD基準(LVL)ビット領域に設定されます。

| 値  | 0 0 0     | 0 1 0     | 111       |
|----|-----------|-----------|-----------|
| 名称 | BODLEVEL0 | BODLEVEL2 | BODLEVEL7 |
| 説明 | 1.8V      | 2.6V      | 4.2V      |

- 注:・説明内の値は代表値です。
  - ・最小値と最大値については電気的特性でBODとPORの特性 を参照してください。
- ビット4 SAMPFREQ: BOD採取周波数 (BOD Sample Frequency)

この値はリセット中にBOD制御A(BOD.CTRLA)レジスタの採取周波数(SAMPFREQ)ビットに設定されます。

| 値  | 0             | 1              |
|----|---------------|----------------|
| 説明 | 採取周波数は1kHzです。 | 採取周波数は125Hzです。 |

● ビット3,2 - ACTIVE1,0: 活動とアイドルでのBOD動作形態 (BOD Operation Mode in Active and Idle)

この値はリセット中にBOD制御A(BOD.CTRLA)レジスタの活動/アイドル時動作(ACTIVE)ビット領域に設定されます。

| 値  | 0 0 | 0 1 | 1 0  | 11                       |
|----|-----|-----|------|--------------------------|
| 説明 | 禁止  | 許可  | 採取動作 | BODの準備が整うまで停止され、起き上がりで許可 |

● ビット1,0 - SLEEP1,0:休止でのBOD動作形態 (BOD Operation Mode in Sleep)

この値はリセット中にBOD制御A(BOD.CTRLA)レジスタのスタンバイ/パワーダウン時動作(SLEEP)ビット領域に設定されます。

| 値  | 0 0 | 0 1 | 1 0  | 11   |
|----|-----|-----|------|------|
| 説明 | 禁止  | 許可  | 採取動作 | (予約) |

# 6.10.4.3. OSCCFG - 発振器構成設定 (Oscillator Configration)

名称: OSCCFG 変位:+\$02 既定:\$02 特質:-

このヒューズ記述で与えられる既定値は工場書き込み値で、リセット値と間違えてはいけません。

| ピット    | 7       | 6 | 5 | 4 | 3 | 2 | 1    | 0      |
|--------|---------|---|---|---|---|---|------|--------|
|        | OSCLOCK |   |   |   |   |   | FREQ | SEL1,0 |
| アクセス種別 | R       | R | R | R | R | R | R    | R      |
| 既定值    | 0       | 0 | 0 | 0 | 0 | 0 | 1    | 0      |

# ● ビット7 - OSCLOCK:発振器施錠(Oscillator Lock)

このヒューズビットはリセット中にCLKCTRL.OSC20MCALIBBレジスタの施錠(LOCK)ビットに設定されます。

| 値  | 0                          | 1                        |
|----|----------------------------|--------------------------|
| 説明 | OSC20M発振器の校正レジスタはアクセス可能です。 | OSC20M発振器の校正レジスタは施錠されます。 |

#### ● ビット1,0 - FREQSEL1,0: 周波数選択 (Frequency Select)

このビット領域は16/20MHz内部発振器の動作周波数を選び、16/20MHz発振器校正A(CLKCTRL.OSC20MCALIBA)レジスタの校正 (CAL20M)と16/20MHz発振器校正B(CLKCTRL.OSC20MCALIBB)レジスタの温度校正(TEMPCAL20M)に書かれるべき各々の工場校正値を決めます。

| 値  | 0 0  | 0 1                | 1 0                | 1 1  |
|----|------|--------------------|--------------------|------|
| 説明 | (予約) | 対応する工場校正での16MHzで走行 | 対応する工場校正での20MHzで走行 | (予約) |

# 6.10.4.4. TCD0CFG - タイマ/カウンタD型構成設定 (Timer Counter Type D Configration)

名称: TCD0CFG 変位:+\$04 既定:\$00 特質:-

このヒューズ記述で与えられる既定値は工場書き込み値で、リセット値と間違えてはいけません。

このヒューズレジスタのビット値は始動でTCDの障害制御(TCD.FAULTCTRL)レジスタの対応ビットに書かれます。

| ピット    | 7      | 6      | 5      | 4      | 3    | 2    | 1    | 0    |
|--------|--------|--------|--------|--------|------|------|------|------|
|        | CMPDEN | CMPCEN | CMPBEN | CMPAEN | CMPD | CMPC | CMPB | CMPA |
| アクセス種別 | R      | R      | R      | R      | R    | R    | R    | R    |
| 既定値    | 0      | 0      | 0      | 0      | 0    | 0    | 0    | 0    |

# ● ビット4,5,6,7 - CMPAEN,COMBEN,CMPCEN,CMPDEN: 比較x許可(Compare x Enable)

| 値  | 0                 | 1                 |
|----|-------------------|-------------------|
| 説明 | ピンでの比較x出力が禁止されます。 | ピンでの比較x出力が許可されます。 |

# ● ビット0,1,2,3 - CMPA,CMPB,CMPC,CMPD: 比較x (Compare x)

このビットはリセット後または、障害検出(FAULTDET)が'1'の場合にデバッグへ移行する時の比較xの既定状態を選びます。

| 値  | 0              | 1              |
|----|----------------|----------------|
| 説明 | 比較x既定状態は'0'です。 | 比較x既定状態は'1'です。 |

#### 6.10.4.5. SYSCFG0 - システム構成設定0 (System Configration 0)

名称:SYSCFG0 変位:+\$05 既定:\$F6 特質:-

このヒュース、記述で与えられる既定値は工場書き込み値で、リセット値と間違えてはいけません。

| ピット    | 7    | 6     | 5 | 4       | 3      | 2      | 1 | 0      |
|--------|------|-------|---|---------|--------|--------|---|--------|
|        | CRCS | RC1,0 |   | TOUTDIS | RSTPIN | CFG1,0 |   | EESAVE |
| アクセス種別 | R    | R     | R | R       | R      | R      | R | R      |
| 既定值    | 1    | 1     | 1 | 1       | 0      | 1      | 1 | 0      |

# ● ビット7,6 - CRCSRC1,0: CRC供給元 (CRC Source)

機能についてのより多くの情報に関してはCRC記述をご覧ください。

| 値  | 0 0                                  | 0 1       | 1 0                  | 11    |
|----|--------------------------------------|-----------|----------------------|-------|
| 名称 | FLASH                                | BOOT      | BOOTAPP              | NOCRC |
| 説明 | 全フラッシュ メモリ<br>(ブート、応用コート、、応用データ)のCRC | ブート領域のCRC | 応用コードと<br>ブートの領域のCRC | CRCなし |

# ● ビット4 - TOUTDIS: 制限時間禁止 (Time Out Disable)

このビットはPOR後のNVM書き込阻止を禁止することができます。FUSE.SYSCFG0のTOUTDISビットが'0'で、FUSE.SYSCFG0のリセット ピン構成設定(RSTPINCFG)ビット領域がGPIOまたはRESETに構成設定される時に、NVM書き込みを阻止するPOR後の制限時間があります。NVM書き込み阻止はPOR後768 OSC32K周期間続きます。ヘーン、緩衝部が満たされる、またはNVM指令が発行され得る前に、状態(NVMCTRL.STATUS)レジスタのEEPROM多忙(EEBUSY)とフラッシュメモリ多忙(FBUSY)が'0'を読まなければなりません。

| 値  | 0           | 1           |
|----|-------------|-------------|
| 説明 | NVM書き込み阻止許可 | NVM書き込み阻止禁止 |

# ● ビット3,2 - RSTPINCFG1,0: リセット ピン構成設定 (Reset Pin Configuration)

このビット領域はリセット/UPDIピンの構成設定を選びます。

| 値  | 0 0         | 0 1  | 1 0   | 11   |
|----|-------------|------|-------|------|
| 説明 | 汎用入出力(GPIO) | UPDI | RESET | (予約) |

- 注: RESETピンをGPIOとして構成設定すると、活動的なGPIO出力駆動と高電圧UPDI許可手順初期化間で潜在的な衝突があります。これを避けるため、GPIO出力駆動部はシステム リセット後に768 OSC32K周期間禁止されます。このピンに対するどの割り込みもこの期間後にだけ許可してください。
- ビット0 EESAVE: チップ消去中EEPROM保存 (EEPROM Save during chip erase)

デバイスが施錠されている場合、EEPROMはこのビットに関わらずチップ消去によって常に消去されます。

| 値  | 0                      | 1                                    |
|----|------------------------|--------------------------------------|
| 説明 | チップ 消去中にEEPROMが消去されます。 | チップ <sup>°</sup> 消去中にEEPROMは消去されません。 |

#### 6.10.4.6. SYSCFG1 - システム構成設定1 (System Configration 1)

名称: SYSCFG1 変位:+\$06 既定:\$07 特質:-

このヒューズ記述で与えられる既定値は工場書き込み値で、リセット値と間違えてはいけません。

| ビット    | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0 |
|--------|---|---|---|---|---|---|--------|---|
|        |   |   |   |   |   |   | SUT2~0 |   |
| アクセス種別 | R | R | R | R | R | R | R      | R |
| 既定值    | 0 | 0 | 0 | 0 | 0 | 1 | 1      | 1 |

# ● ビット2~0 - SUT2~0: 始動時間設定 (Start Up Time Setting)

これらのビットは電源ONとコード実行間の始動時間を選びます。

| 値  | 0 0 0 | 0 0 1 | 0 1 0 | 0 1 1 | 1 0 0 | 101  | 1 1 0 | 111  |
|----|-------|-------|-------|-------|-------|------|-------|------|
| 説明 | 0ms   | 1ms   | 2ms   | 4ms   | 8ms   | 16ms | 32ms  | 64ms |

#### 6.10.4.7. APPEND - 応用コード領域の最後 (Application Code Section End)

名称: APPEND 変位: +\$07 既定:-特質:-

このヒュース、記述で与えられる既定値は工場書き込み値で、リセット値と間違えてはいけません。

| ピット    | 7         | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|--------|-----------|---|---|---|---|---|---|---|--|--|
|        | APPEND7~0 |   |   |   |   |   |   |   |  |  |
| アクセス種別 | R         | R | R | R | R | R | R | R |  |  |
| 既定值    | 0         | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |

# ● ビット7~0 - APPEND7~0 : 応用コード領域の最後 (Application Code Section End) (訳注:脚注の訳補参照)

このビット領域は応用コード領域の最後を256バイト単位で設定します。応用コード領域の最後は(ブート領域(BOOT)量)+(応用コード量)として設定されます。残りのフラッシュ メモリは応用データです。\$00の値は応用コード領域としてブートの最後(BOOTEND)×256からフラッシュ メモリの最後までを定義します。FUSE.BOOTENDが\$00の時はフラッシュ メモリ全体がブート(BOOT)領域です。

# **6.10.4.8. BOOTEND - ブートの**最後 (Boot End)

名称:BOOTEND 変位:+\$08

変位 . +•0 既定 : -特質 : -

このヒューズ記述で与えられる既定値は工場書き込み値で、リセット値と間違えてはいけません。

| <u> </u>   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------------|---|---|---|---|---|---|---|---|--|
| BOOTEND7~0 |   |   |   |   |   |   |   |   |  |
| アクセス種別     | R | R | R | R | R | R | R | R |  |
| 既定値        | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |

# ● ビット7~0 - BOOTEND7~0: プート領域の最後 (Boot Section End) (訳注:脚注の訳補参照)

このビット領域はブート領域の最後を256バイト単位で設定します。\$00の値はブート領域としてフラッシュ メモリ全体を定義します。FUSE.BOO TENDが\$00の時はフラッシュ メモリ全体がブート(BOOT)領域です。

# **6.10.4.9. LOCKBIT - 施錠ビット** (Lock Bits)

名称: LOCKBIT 変位: +\$0A 既定:-特質:-

このヒューズ記述で与えられる既定値は工場書き込み値で、リセット値と間違えてはいけません。

| ピット        | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|------------|-----|-----|-----|-----|-----|-----|-----|-----|--|--|
| LOCKBIT7~0 |     |     |     |     |     |     |     |     |  |  |
| アクセス種別     | R/W |  |  |
| 既定値        | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |  |  |

#### ● ビット7~0 - LOCKBIT7~0:施錠ビット (Lock Bits)

デバイス施錠時、UPDIはシステムバスをアクセスできず、故にシステム情報部(SIB)以外何も読み出すことができません。

| 値  | \$C5             | その他              |
|----|------------------|------------------|
| 説明 | メモリ アクセスは解錠されます。 | メモリ アクセスは施錠されます。 |

(訳補) APPENDとBOOTENDでの指定値は256バイト単位でのその領域容量を指定します。アドレス的に、上記の記述で「の最後」の記述は不正確で実際には「の最後+1」を指定することになります。

# 7. 周辺機能と基本構造

# 7.1. 周辺機能アドレス配置

アドレス配置は各周辺機能に対する基準アドレスを示します。各周辺機能に対する完全なレジスタ記述と要約については各々の周辺機能章を参照してください。

表7-1. 周辺機能アドレス配置

| 基準アドレス | 名称      | 説明            | 基準アドレス | 名称      | 説明                |
|--------|---------|---------------|--------|---------|-------------------|
| \$0000 | VPORTA  | 仮想ポートA        | \$0600 | ADC0    | A/D変換器0/周辺機能接触制御器 |
| \$0004 | VPORTB  | 仮想ポートB        | \$0640 | ADC1    | A/D変換器1           |
| \$0008 | VPORTC  | 仮想ポートC        | \$0680 | AC0     | アナログ比較器0          |
| \$001C | GPIO    | 汎用I/Oレジスタ     | \$0688 | AC1     | アナログ比較器1          |
| \$0030 | CPU     | CPU           | \$0690 | AC2     | アナログ 比較器2         |
| \$0040 | RSTCTRL | リセット制御器       | \$06A0 | DAC0    | D/A変換器0           |
| \$0050 | SLPCTRL | 休止制御器         | \$06A8 | DAC1    | D/A変換器1           |
| \$0060 | CLKCTRL | クロック制御器       | \$06B0 | DAC2    | D/A変換器2           |
| \$0080 | BOD     | 低電圧検出         | \$0800 | USART0  | 万能同期非同期送受信器       |
| \$00A0 | VREF    | 基準電圧          | \$0810 | TWI0    | 2線インターフェース        |
| \$0100 | WDT     | ウォッチト゛ック゛タイマ  | \$0820 | SPI0    | 直列周辺インターフェース      |
| \$0110 | CPUINT  | 割り込み制御器       | \$0A00 | TCA0    | タイマ/カウンタA型0       |
| \$0120 | CRCSCAN | 巡回冗長検査メモリ走査   | \$0A40 | TCB0    | タイマ/カウンタB型0       |
| \$0140 | RTC     | 実時間計数器        | \$0A50 | TCB1    | タイマ/カウンタB型1       |
| \$0180 | EVSYS   | 事象システム        | \$0A80 | TCD0    | タイマ/カウンタD型        |
| \$01C0 | CCL     | 構成設定可能な注文論理回路 | \$0F00 | SYSCFG  | システム構成設定          |
| \$0200 | PORTMUX | ポート多重器        | \$1000 | NVMCTRL | 不揮発性メモリ制御器        |
| \$0400 | PORTA   | ポートA構成設定      | \$1100 | SIGROW  | 識票列               |
| \$0420 | PORTB   | ポートB構成設定      | \$1280 | FUSES   | デバイス特定ヒューズ        |
| \$0440 | PORTC   | ポートC構成設定      | \$1300 | USERROW | 使用者列              |

# 7.2. 割り込みベクタ配置

割り込みへうりの各々は次表で示されるように1つの周辺機能実体に接続されます。周辺機能は1つまたはもっと多くの割り込み元を持ち得ます。利用可能な割り込み元のより多くの詳細については各々の周辺機能の「機能的な説明」の「割り込み」項をご覧ください。

割り込み条件が起こると、周辺機能の割り込み要求フラグ(周辺機能名.INTFLAGS)レジスタで割り込み要求フラグ(名称IF)が設定(1)されます。

割り込みは周辺機能の割り込み制御(周辺機能名.INTFCTRL)レジスタで対応する割り込み許可(名称IE)ビットを書くことによって許可または禁止にされます。

レジスタの命名はいくつかの周辺機能で僅かに変わるかもしれません。

割り込み要求は対応する割り込みが許可され、割り込み要求フラグが設定(1)される時に生成されます。割り込み要求はその割り込み要求フラグが解除(0)されるまで活性に留まります。割り込み要求フラグを解除(0)する方法の詳細については周辺機能のINTFLAGSレジスタをご覧ください。

割り込みが生成されるには割り込み要求に対して全体的に許可されなければなりません。

# 表7-2.割り込みべか配置

|    | プログラム アドレス(語) | 周辺機能元                | 説明                                      |  |  |  |  |
|----|---------------|----------------------|-----------------------------------------|--|--|--|--|
| 0  | \$00          | RESET                | RESET - リセット                            |  |  |  |  |
| 1  | \$02          | CRCSCAN_NMI          | NMI - CRCからの遮蔽不可割り込み                    |  |  |  |  |
| 2  | \$04          | BOD_VLM              | VLM - 電圧水準監視器                           |  |  |  |  |
| 3  | \$06          | PORTA_PORT           | PORTA − ホ°−トA                           |  |  |  |  |
| 4  | \$08          | PORTB_PORT           | PORTB − ポートB                            |  |  |  |  |
| 5  | \$0A          | PORTC_PORT           | PORTC - ポートC                            |  |  |  |  |
| 6  | \$0C          | RTC_CNT              | RTC - 実時間計数器                            |  |  |  |  |
| 7  | \$0E          | RTC_PIT              | PIT - 周期的割り込み計時器 (RTC周辺機能内)             |  |  |  |  |
| 8  | \$10          | TCA0_LUNF/TCA0_OVF   | TCA0 - タイマ/カウンタA型、LUNF/OVF              |  |  |  |  |
| 9  | \$12          | TCA0_HUNF            | TCA0 - タイマ/カウンタA型、HUNF                  |  |  |  |  |
| 10 | \$14          | TCA0_LCMP0/TCA0_CMP0 | TCA0 - タイマ/カウンタA型、LCMP0/CMP0            |  |  |  |  |
| 11 | \$16          | TCA0_LCMP1/TCA0_CMP1 | TCA0 - タイマ/カウンタA型、LCMP1/CMP1            |  |  |  |  |
| 12 | \$18          | TCA0_LCMP2/TCA0_CMP2 | TCA0 - タイマ/カウンタA型、LCMP2/CMP2            |  |  |  |  |
| 13 | \$1A          | TCB0_INT             | TCB0 - タイマ/カウンタB型                       |  |  |  |  |
| 14 | \$1C          | TCB1_INT             | TCB1 - タイマ/カウンタB型                       |  |  |  |  |
| 15 | \$1E          | TCD0_OVF             | TCD0 - タイマ/カウンタD型、OVF                   |  |  |  |  |
| 16 | \$20          | TCD0_TRIG            | TCD0 - タイマ/カウンタD型、TRIG                  |  |  |  |  |
| 17 | \$22          | AC0_AC               | AC0 - アナログ 比較器                          |  |  |  |  |
| 18 | \$24          | AC1_AC               | AC1 - アナログ 比較器                          |  |  |  |  |
| 19 | \$26          | AC2_AC               | AC2 - アナログ 比較器                          |  |  |  |  |
| 20 | \$28          | ADC0_RESRDY          | ADC0 - A/D変換器、RESRDY                    |  |  |  |  |
| 21 | \$2A          | ADC0_WCOMP           | ADC0 - A/D変換器、WCOMP                     |  |  |  |  |
| 22 | \$2C          | ADC1_RESRDY          | ADC1 - A/D変換器、RESRDY                    |  |  |  |  |
| 23 | \$2E          | ADC1_WCOMP           | ADC1 - A/D変換器、WCOMP                     |  |  |  |  |
| 24 | \$30          | TWI0_TWIS            | TWIO - 2線インターフェース/I <sup>2</sup> C、TWIS |  |  |  |  |
| 25 | \$32          | TWI0_TWIM            | TWIO - 2線インターフェース/I <sup>2</sup> C、TWIM |  |  |  |  |
| 26 | \$34          | SPI0_INT             | SPIO - 直列周辺インターフェース                     |  |  |  |  |
| 27 | \$36          | USART0_RXC           | USARTO - 万能同期非同期送受信器、RXC                |  |  |  |  |
| 28 | \$38          | USART0_DRE           | USARTO - 万能同期非同期送受信器、DRE                |  |  |  |  |
| 29 | \$3A          | USART0_TXC           | USARTO - 万能同期非同期送受信器、TXC                |  |  |  |  |
| 30 | \$3C          | NVMCTRL_EE           | NVM - 不揮発性メモリ                           |  |  |  |  |

# 7.3. システム構成設定 (SYSCFG)

システム構成設定は部品の改訂IDを含みます。この改訂IDはCPUから読め、部品の改訂間での応用変更の実装に対してそれを有用にします。

# 7.3.1. レジスタ要約

| 変位    | 略称    | ビット位置        | ヒ゛ット7    | ピット6 | ピット5 | ピット4 | ピット3 | ピット2 | ピット1 | ピット0 |  |
|-------|-------|--------------|----------|------|------|------|------|------|------|------|--|
| +\$00 | 予約    |              |          |      |      |      |      |      |      |      |  |
| +\$01 | REVID | 7 <b>~</b> 0 | REVID7~0 |      |      |      |      |      |      |      |  |

# 7.3.2. レジスタ説明

7.3.2.1. REVID - デバイス改訂IDレジスタ (Device Revision ID Register)

名称: REVID 変位:+\$01 リセット: [改訂ID]

特質:-

このレシブスタは読み込み専用でデバイス改訂IDを与えます。

| ピット    | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|--------|----------|---|---|---|---|---|---|---|--|--|
|        | REVID7~0 |   |   |   |   |   |   |   |  |  |
| アクセス種別 | R        | R | R | R | R | R | R | R |  |  |
| リセット値  | X        | X | X | X | X | X | X | X |  |  |

● ビット7~0 - REVID7~0: 改訂ID (Revision ID)

このビット領域はデバイス改訂を含みます。\$00=A、\$01=B、以下同様です。

# 8. AVR® CPU

# 8.1. 特徴

- ・8ビット、高性能AVR RISC CPU
  - 135個の命令
  - ハート・ウェア乗算器
- ・ALUに直接続される32個の8ビット レジスタ
- ・ RAM内のスタック
- I/Oメモリ空間でアクセス可能なスタック ポインタ
- ・64Kバイナまでの統一されたメモリの直接アドレス指定
- ・8,16,32ビット演算に対する効率的な支援
- ・システムの危険に対する構成設定変更保護機能
- ・生来のチップ。上デバッカ (OCD:On Chip Debugger)支援
  - 2つのハート・ウェア中断点(ブレークホペイント)
  - 流れ変更、割り込みとソフトウェア中断点
  - スタック ポーインタ(SP)レシ スタ、プログラム カウンタ(PC)、ステータス レシ スタ(SREG)の走行時読み出し
  - 停止動作でレジスタファイル読み書き可能

# 8.2. 概要

全てのAVRデバイスはAVR 8ビットCPUを使います。CPUはメモリをアクセスし、計算を実行し、周辺機能を制御し、そしてプログラム メモリ上の命令を実行することができます。割り込み処理は独立した章で記述されます。

# 8.3. 基本構成

性能と並列処理を最大化するため、AVR CPUはプログラムとデータに対して独立したバスを持つハーバート、基本設計を使います。プログラムメモリ内の命令は単一段のパイプラインで実行されます。1つの命令が実行されつつあるのと同時に、次の命令がプログラムメモリから予め取得されます。これはクロック周期毎に実行されることを命令に許します。

全てのAVR命令の要約については「命令一式要約」章を参照してください。



# 8.4. 算術論理演算部 (ALU)

算術論理演算部(ALU)は作業レシ、スタ間または定数と作業レシ、スタ間の演算と論理の操作を支援します。また、単一レシ、スタ操作を実行することができます。

ALUはレジスタファイル内の32個全ての汎用作業レジスタと直結で動きます。作業レジスタ間または、作業レジスタと即値被演算子間の算術操作が単一クロック周期で実行され、結果がレジスタファイルに格納されます。算術または論理の操作後、ステータスレジスタ(CPU.SREG)は操作の結果についての情報を反映するように更新されます。

ALU操作は算術、論理、ビット操作の3つの主な分野に分けられます。8ビットと16ビットの両方の算術演算が支援され、命令一式は効率的な32ビット算術演算の実装を許します。ハードウェア乗算器は符号付きと符号なしの乗算そして固定小数点形式を支援します。

#### 8.4.1. ハート・ウェア乗算器

乗算器は2つの8ビット数値を16ビットの結果に乗算する能力です。ハードウェア乗算器は符号付きと符号なしの整数と固定小数点数の種々の変種を支援します。

- ・ 符号付き/符号なし整数の乗算
- ・符号付き/符号なし固定小数点数の乗算
- 符号付きと符号なしの整数乗算
- ・符号付きと符号なしの固定小数点数乗算

乗算は2 CPUクロック周期かかります。

# 8.5. 機能的な説明

# 8.5.1. プログラムの流れ

リセット後、CPUはフラッシュ プログラム メモリ内の最下位アトレスの\$0000から命令を実行します。 プログラム カウンタ(PC)は取得されるべき次の命令をアトレス指定します。

プログラムの流れはアドレス空間全体を直接位置指定できる条件付きと条件なしの流れ変更命令によって支援されます。殆どのAVR命令は16ビット語形式を使い、限定数(の命令)は32ビット形式を使います。

割り込みとサブルーチン呼び出しの間、復帰アドレスのPC(値)が語ポインタとしてスタックに格納されます。スタックは一般的なデータSRAMに置かれ、必然的にスタック量は総SRAM量とSRAMの使い方によってのみ制限されます。スタック ポインタ(SP)がリセットされた後は内部SRAMの最上位アドレスを指し示します。SPはI/Oメモリ空間で読み書きアクセス可能で、多数のスタックまたはスタック領域の容易な実装を許します。データSRAMはAVR CPUで支援される5つの異なるアドレス指定形式を通して容易にアクセスすることができます。

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

AVR CPUはCPUクロック(CLK\_CPU)によってクロック駆動されます。内部クロック分周は全く適用されません。右図はハーバード基本構造と高速アクセス レジスタ ファイルの概念によって許される、並列での命令の取得と実行を示します。これは高い効率を持つ最大1 MIPS/MHzの性能を許す基本的なパイプラ インの概念です。

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





#### 8.5.3. ステータス レシ スタ

ステータス レジスタ(CPU.SREG)は最も直前に実行した算術または論理の命令の結果についての情報を含みます。この情報は条件付き操作を実行するためプログラムの流れを変えるのに使うことができます。

CPU.SREGは「命令一式要約」章で詳述されるように、全てのALU操作後に更新されます。これは多くの場合で専用比較命令を使う必要を取り去り、高速でもっと簡潔なコードに帰着します。CPU.SREGは割り込み処理ルーチン(ISR)への移行や復帰の時に自動的に保存や回復が行われません。従って、CPU(流れ)状態切り替え間でのステータスレジスタ維持は使用者定義ソフトウェアによって処理されなければなりません。CPU.SREGはI/Oメモリ空間でアクセス可能です。

#### 8.5.4. スタックとスタック ホペインタ

スタックは割り込みとサブルーチン呼び出し後の復帰アトンスの格納に使われます。一時データを格納するのにも使うことができます。スタック ポペク(SP)は常にスタックの先頭(<mark>訳注</mark>:次に使われるべき位置)を指し示します。SPはスタック ポペンタ(CPU.SP)レシ、スタのスタック ポインタ ビットによって定義されます。CPU.SPはI/Oメモリ空間でアクセス可能な2つの8ビット レシ、スタとして実装されます。

データはPUSHとPOPの命令を用いてスタックに対して押し込みと取り出しが行われます。スタックは上位から下位のメモリ位置へ伸びます。これはスタックへのデータ押し込みがSPを減らし、スタックからのデータ取り出しがSPを増すことを意味します。SPはリセット後に内部SRAMの最上位アトンスへ自動的に設定されます。スタックが変更される場合、SRAM開始アトンス以上を指し示すように設定されなければならず、何れかのサブルーチン呼び出しが実行される前と割り込みが許可される前に定義されなければなりません(SRAM開始アトンスについてはメモリ章のSRAMデータメモリ部分をご覧ください)。SPの詳細については下表をご覧ください。

表8-1. スタック ポインタ命令

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

割り込みまたはサブルーチン呼び出しの間、復帰アドレスが語ポインタとして自動的にスタックへ格納され、SPは'2'減少されます。復帰アドレスは2ハーイから成り、下位ハーイト(LSB)がスタック(の上位側番地)で最初に押し込まれます。例として、\$0006のハーイトポインタ復帰アドレスはスタック上に(1ビット右移動した)\$0003として保存され、プログラム メモリ内の4番目の16ビット命令を指し示します。復帰アドレスは(割り込みからの復帰時に)RETIと(サブルーチン呼び出しからの復帰時に)RETの命令でスタックから取り出され、SPは'2'増やされます。

データがPUSH命令でスタックに押し込まれる時にSPは'1'減らされ、POP命令を使ってスタックからデータが取り出される時に'1'増やされます。

ソフトウェアからSPを更新する時の破損を防ぐため、SPL書き込みは最大4命令間または次のI/Oメモリ書き込みまでのどちらか速い方で自動的に割り込みを禁止します。

#### 8.5.5. レジスタ ファイル

レジスタファイルはCPUによって使われる32個の8ビット汎用作業レジスタから成ります。レジスタファイルはデータメモリから独立したアドレス空間に置かれます。

作業レジスタで動く全てのCPU命令はレジスタファイルに対して直接 且つ単一のアクセスを持ちます。定数の算術と論理の演算命令 (SBCI、SUBI、CPI、ANDI、ORI、LDI)のような命令によってアクセスすることができる作業レジスタにいくつかの制限が適用されます。これらの命令はレジスタファイルの後半の作業レジスタ(R16~R31)に適用します。更なる詳細についてはAVR命令一式手引書をご覧ください。



#### 8.5.5.1. X.Y.Z レジスタ

R26~R31の作業レジスタはそれらの汎用の使い方に属する付加機能を持ちます。

これらのレシ、スタはテ・ータ メモリの間接アト・レス指定用の16ピット アト・レス ポインタ形式にすることができます。これら3つのアト・レス レシ、スタはXレシ、スタ、Yレシ、スタ、Zレシ、スタと呼ばれます。 Zレシ、スタはプログラムメモリ用アト・レス ポインタとして使うこともできます。

下位側レシ、スタのアト・レスは最下位ハイト(LSB)を保持し、上位側レシ、スタのアト・レスは最上位ハイト(MSB)を保持します。各種LD/ST系命令で、これらのアト・レスレシ、スタは固定変位、自動増加、自動減少として機能することができます。詳細については「命令一式要約」章をご覧ください。

| 図8-5. X,Y,Zレ | ジスタ |         |   |   |         |   |
|--------------|-----|---------|---|---|---------|---|
| ビット(個別)      | 7   | R27     | 0 | 7 | R26     | 0 |
| X レジスタ       |     | XH (上位) |   |   | XL (下位) |   |
| ビット(Xレジスタ)   | 15  |         | 8 | 7 |         | 0 |
| ビット(個別)      | 7   | R29     | 0 | 7 | R28     | 0 |
| Yレジスタ        |     | YH (上位) |   |   | YL (下位) |   |
| ビット(Xレジスタ)   | 15  |         | 8 | 7 |         | 0 |
| ビット(個別)      | 7   | R31     | 0 | 7 | R30     | 0 |
| Z レジスタ       |     | ZH (上位) |   |   | ZL (下位) |   |
| ビット(Xレジスタ)   | 15  |         | 8 | 7 |         | 0 |

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

ATtiny3216/3217デバイス用のレジスタの殆どは8ビット レジスタですが、このデバイスは少数の16ビット レジスタも特徴です。AVRデータ バスが8 ビットの幅を持つため、16ビットのアクセスは2つの読みまたは書きの操作を必要とします。ATtiny3216/3217デバイスの全ての16ビット レジス タは一時(TEMP)レジスタを通して8ビット バスに接続されます。

16ビット書き込み操作については、16ビットレジスタの下位バイトレジスタ(例えば、DAT AL)が上位バイトレジスタ(例えば、DATAH)に先立って書かれなければなりません。下位バイトレジスタ書き込みは図8-6.の左側で示されるように、下位バイトレジスタの代わりに一時(TEMP)レジスタへの書き込みに帰着します。16ビットレジスタの上位バイトレジスタが書かれると、図8-6.の右側で示されるように、同じクロック周期でTEMPが16ビットレジスタの下位バイトに複写されます。

16ビット読み込み操作については、16ビットレジスタの下位バイトレジスタ(例えば、DAT AL)が上位バイトレジスタ(例えば、DATAH)に先立って読まれなければなりません。下位バイトレジスタが読まれると、図8-7.の左側で示されるように、同じクロック周期で16ビットレジスタの上位バイトレジスタがTEMPに複写されます。上位バイトレジスタ読み込みは図8-7.の右側で示されるように、上位バイトレジスタの代わりに一時(TEMP)レジスタからの読み込みに帰着します。

記述された機構はレジスタが読みまたは書きされた時に16ビットレジスタの上位と下位のバイトが常に同時にアクセスされることを保証します。

16ビット読み書き操作の間に割り込みが起動され、割り込み処理ルーチンで同じ周辺機能内の16ビット レジスタがアクセスされる場合、割り込みは時限手順を不正にし得ます。これを防ぐため、16ビット レジスタを読みまたは書きする時に割り込みが禁止されるべきです。代わりに、割り込み処理ルーチンで一時レジスタを先に読んで、16ビット アク セス後に復元することができます。





#### 8.5.6.1. 24E'ットレシ スタのアクセス

24ビットレジスタに対しては24ビットレジスタに2つの一時レジスタがあることを除き、読み書きアクセスは16ビットレジスタ用に記述されるのと同じ方法で行われます。レジスタに書く時は最上位バイトが最後に書かれ、レジスタを読む時は最下位バイトが先に読まれねばなりません。

# 8.5.7. 構成設定変更保護 (CCP) (Configuration Change Protection)

システムの重要なI/Oレジスタ設定は予期せぬ変更から保護されます。(NVM制御器への格納経由の)フラッシュ自己プログラミングが予期せぬ実行から保護されます。これは構成設定変更保護(CCP)レジスタによって全体的に処理されます。

保護されたI/Oレジスタまたはビットへの変更や、保護された命令の実行は、CPUがCCPレジスタへ識票を書いた後でだけ可能です。各種識票はCCP(CPU.CCP)レジスタの説明で一覧にされます。

I/Oレジスタ保護に関する1つと自己プログラミング保護に関する1つで2つの動作形態があります。

# 8.5.7.1. 構成設定保護されたI/Oレジスタへの書き込み操作手順

CCPによって保護されたI/Oレジスタへ書くにはこれらの手順が必要とされます。

- 1. ソフトウェアはCPU、CCPレジスタのCCPビット領域に保護されたI/Oレジスタの変更を許可する識票を書きます。
- 2.4命令内で、ソフトウェアは保護されたレジスタに適切なデータを書かなければなりません。

**注**: 殆どの保護されたレシ、スタは書き込み許可/変更許可/施錠のビットも含みます。このビットはデータが書かれるのと同じ操作内で1 を書かれなければなりません。

保護された変更はCPUがI/Oレジスタまたはデータ メモリに書き込み操作を実行する場合、フラッシュ メモリ、NVM制御器(NVMCTRL)、EEPROMに対する取得または格納のアクセスが行われる場合、またはSLEEP命令が実行される場合、直ちに禁止されます。

# 8.5.7.2. 自己プログラミングの実行手順

自己プログラミングを実行する(NVM制御器の指令レシブスタへの書き込みの実行)には以下の手順が必要とされます。

- 1. ソフトウェアはCCP(CPU.CCP)レジスタにSPM識票を書くことによって自己プログミングを一時的に許可します。
- 2. 4命令内で、ソフトウェアは適切な命令を実行しなければなりません。保護された変更はCPUがフラッシュメモリ、NVMCTRL、EEPROMへのアクセスを実行する場合、またはSLEEP命令が実行される場合、直ちに禁止されます。

CPUによって一旦正しい識票が書かれると、割り込みは構成設定変更許可期間の間無視されます。CCP期間の間の(遮蔽不可割り込みを含む)どの割り込み要求も通常様に対応する割り込み要求フラグを設定(1)し、その要求は保留に保たれます。CCP期間完了後、どの保留割り込みもそれらのレベルと優先権に従って実行されます。

# 8.5.8. チップ 上デバッグ能力

AVR CPUは生来のチップとデバック(OCD)支援を含みます。これはCPU状態についての特性分析と詳細な情報を許すためのいくつかの強力なデバッグ能力を含みます。CPU状態を変えてコート、実行を再開することが可能です。また、ハート・ウェアプログラム カウンタ中断点、命令の流れ変更での中断点、割り込みでの中断点、ソフトウェア中断点(BREAK命令)のような通常のデバッグ能力が存在します。OCDについての詳細に関しては「統一プログラム/デバッグインターフェース」章を参照してください。

# 8.6. レジスタ要約

| 変位                  | 略称    | ビット位置 | ビット7 | ピット6 | ビット5 | ヒ゛ット4 | ピット3 | ピット2 | ピット1 | ピット0 |
|---------------------|-------|-------|------|------|------|-------|------|------|------|------|
| +\$00<br>~          | 予約    |       |      |      |      |       |      |      |      |      |
| +\$03               | 1, wa |       |      |      |      |       |      |      |      |      |
| +\$04               | CCP   | 7~0   |      |      |      | CCF   | 7~0  |      |      |      |
| +\$05<br>~<br>+\$0C | 予約    |       |      |      |      |       |      |      |      |      |
| +\$0D               | SP    | 7~0   |      |      |      | SP7   | 7~0  |      |      |      |
| +\$0E               | 51    | 15~8  |      |      |      | SP1   | 5~8  | 1    |      |      |
| +\$0F               | SREG  | 7~0   | I    | Т    | Н    | S     | V    | N    | Z    | С    |

# 8.7. レジスタ説明

# 8.7.1. CCP - 構成設定変更保護レジスタ (Configuration Change Protection register)

名称: CCP 変位:+\$04 リセット: \$00 特質:-

| ピット    | 7   | 6      | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |
|--------|-----|--------|-----|-----|-----|-----|-----|-----|--|--|--|
|        |     | CCP7~0 |     |     |     |     |     |     |  |  |  |
| アクセス種別 | 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 - CCP7~0: 構成設定変更保護 (Configuration Change Protection)

このビット領域への正しい識票書き込みは次の4 CPU命令実行内での保護されたI/Oレジスタの変更または保護された命令の実行を許します。

これらの周期の間は全ての割り込みが無視されます。これらの周期完了後、割り込みはCPUによって自動的に再び処理され、どの保留割り込みもそれらのレベルと優先権に従って実行されます。

保護されたI/Oレジスタの識票が書かれると、CCP0は保護機能が許可されている限り、1'として読みます。

保護された自己プログラミング識票が書かれると、CCP1は保護機能が許可されている限り、1'として読みます。

CCP7~2は常に'0'として読みます。

| 値    | 名称    | 説明             |
|------|-------|----------------|
| \$9D | SPM   | 自己プログラミング許可    |
| \$D8 | IOREG | 保護されたI/Oレジスタ解錠 |

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

名称: SP(SPH,SPL)

変位:+\$0D リセット:\$3FFF 特質:-

CPU.SPレシ、スタはスタックの先頭を指示するスタック ポインタを保持します。 リセット後、SPは内部SRAM最高アトレスを指示します。

各デバイスに対して外部メモリを含み(64Kバイルまでで)利用可能なデータ メモリをアドレス指定するのに必要とされるビット数だけが実装されます。未使用ビットは常に'0'として読みます。

CPU.SPHとCPU.SPLのレジスタ対は16ビット値のCPU.SPを表します。下位バイト[7~0](接尾辞L)は変位原点でアクセス可能です。上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

ソフトウェアからSPを更新する時の破損を防ぐため、CPU.SPLへの書き込みは次の4命令間、または次のI/Oメモリ書き込みまでのどちらか速い方で割り込みを自動的に禁止します。

| ピット    | 15  | 14  | 13     | 12  | 11  | 10  | 9   | 8   |  |  |  |  |
|--------|-----|-----|--------|-----|-----|-----|-----|-----|--|--|--|--|
|        |     |     | SP13~8 |     |     |     |     |     |  |  |  |  |
| アクセス種別 | R   | R   | R/W    | R/W | R/W | R/W | R/W | R/W |  |  |  |  |
| リセット値  | 0   | 0   | 1      | 1   | 1   | 1   | 1   | 1   |  |  |  |  |
| ピット    | 7   | 6   | 5      | 4   | 3   | 2   | 1   | 0   |  |  |  |  |
|        |     |     |        | SP7 | 7~0 |     |     |     |  |  |  |  |
| アクセス種別 | R/W | R/W | R/W    | R/W | R/W | R/W | R/W | R/W |  |  |  |  |
| リセット値  | 1   | 1   | 1      | 1   | 1   | 1   | 1   | 1   |  |  |  |  |
|        |     |     |        |     |     |     |     |     |  |  |  |  |

• ビット14~8 - SP14~8: スタック ポインタ上位バイト (Stack Pointer high byte)

これらのビットは16ビット レジスタの上位バイトを保持します。

● ビット7~0 - SP7~0: スタック ポインタ下位バイト (Stack Pointer low byte)

これらのビットは16ビット レジスタの下位バイトを保持します。

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

名称: SREG 変位: \$0F リセット: \$00 特質:-

ステータス レシ スタは最も直前に実行した算術または論理の命令の結果についての情報を含みます。このレシ スタ内のビットとそれらが各種命令によってどう影響されるかについての詳細に関しては「命令一式要約」章をご覧ください。

| ピット _  | 7 6 |     | 7 6 5 4 |     | 4   | 3   | 2   | 1 0 |  |  |
|--------|-----|-----|---------|-----|-----|-----|-----|-----|--|--|
|        | I   | Т   | Н       | S   | V   | N   | Z   | С   |  |  |
| アクセス種別 | 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 - I: 全体割り込み許可 (Global Interrupt Enable Bit)

このビットへの'1'書き込みはデバイスでの割り込みを許可します。

このビットへの'0'書き込みは周辺機能の個別割り込み許可設定に関わらず、デバイスでの割り込みを禁止します。

このビットは割り込み処理ルーチン(ISR)移行中にハードウェアによって解除(0)されず、RETI命令が実行される時に設定(1)されません。 このビットはSEIとCLIの命令でソフトウェアによって設定(1)と解除(0)を行うことができます。

I/Oレジスタを通したIビットの変更はそのアクセスでの1周期の待ち状態に帰着します。

#### ● ビット6 - T: 転送ビット (Transfer Bit)

ビット複写命令のビット取得(BLD)とビット格納(BST)は操作するための転送元または転送先としてTビットを使います。

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

このフラグはこれを支援する算術操作でハーフキャリーがある時に設定(1)されます。 ハーフキャリーはBCD演算に有用です。

# ビット4 - S: 符号フラク (Sign Flag)

このフラグは常に負(N)フラグと2の補数溢れ(V)フラグ間の排他的論理和(XOR)です。

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

このフラグはこれを支援する算術操作で溢れがある時に設定(1)され、さもなければ解除(0)されます。

# ヒット2 - N: 負フラク (Negative Flag)

このフラグは算術及び論理の操作で負の結果の時に設定(1)され、さもなければ解除(0)されます。

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

このフラグは算術及び論理の操作でゼロ(0)の結果の時に設定(1)され、さもなければ解除(0)されます。

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

このフラグは算術及び論理の操作でキャリー(またはボロー)がある時に設定(1)され、さもなければ解除(0)されます。

# 9. NVMCTRL - 不揮発性メモリ制御器

# 9.1. 特徴

- 統一されたメモリ
- ・実装プログラミング可能
- ・自己プログラミングとブートローダ支援
- ・書き込み保護に対して構成設定可能な領域
  - ブートローダ コート または応用コート 用のブート領域
  - 応用コート・用の応用コート・領域
  - 応用コート、またはデータ記憶用の応用データ領域
- ・工場書き込みされたデータ用の識票列
  - 各デバイス型式用のID
  - 各デバイス用の通番
  - 工場校正された周辺機能用の校正バイ
- ・応用データ用の使用者列
  - ソフトウェアから読み書き可能
  - 施錠されたデバイスでUPDIから書き込み可能
  - チップ消去後も保持される内容

# 9.2. 概要

NVM制御器(NVMCTRL)はCPUと不揮発性メモリ(フラッシュ メモリ、EEPROM、識票列、使用者列、ヒューズ)間のインターフェースです。これらは例え給電されない時もそれらの値を保持する再書き込み可能なメモリ部です。フラッシュ メモリは主にプログラム記憶に使われ、データ記録に使うこともできます。EEPROMはデータ記憶に使われ、CPUがフラッシュ メモリからのプログラムを走っているのと同時に書くことができます。

#### 9.2.1. 構成図



# 9.3. 機能的な説明

# 9.3.1. メモリ構成

# 9.3.1.1. フラッシュ メモリ

フラッシュ メモリはページの組に分けられます。ページはフラッシュ メモリをプログラミングする時にアトレス指定される基本単位です。それは一度にページ全体を書くまたは消去することだけが可能です。1ページは多数の語から成ります。

フラッシュ メモリは異なる安全保障のために256バイトの塊単位で3つの領域に分けることができます。この3つの異なる領域は、ブート(BOOT)、応用コート (APPCODE)、応用データ(APPDATA)です。



# 領域容量

これらの領域の大きさはブート領域の最後(FUSE.BOOTEND)ヒュース」と応用コート、領域の最後(FUSE.APPEND)ヒュース。によって設定されます。

このヒュース、は256小小の塊単位で領域容量を選びます。BOOT領域はフラッシュメモリの始めからBOOTENDまでに及びます。APPCOD E領域はBOOTEND直後からAPPENDまでを走行します。残りの領域がAPPDATA領域です。APPENDが'0'を書かれた場合、APPC ODE領域はBOOTENDから(APPDATA領域を除去して)フラッシュメモリの最後まで走行します。BOOTENDとAPPENDが'0'を書かれた場合、フラッシュメモリ全体がBOOT領域と見做されます。APPENDはおそらく'0'またはBOOTEND以上のどちらかに設定されます。

#### 表9-1. フラッシュ領域の構成設定

| BOOTEND | APPEND   | BOOT領域        | APPCODE領域              | APPDATA領域            |
|---------|----------|---------------|------------------------|----------------------|
| 0       | 0        | 0∼FLASHEND    | _                      | _                    |
| >0      | 0        | 0~256×BOOTEND | 256×BOOTEND~FLASHEND   | -                    |
| >0      | =BOOTEND | 0~256×BOOTEND | -                      | 256×BOOTEND∼FLASHEND |
| >0      | >BOOTEND | 0~256×BOOTEND | 256×BOOTEND~256×APPEND | 256×APPEND∼FLASHEND  |

# 注: 1. BOOTENDとAPPENDの説明もご覧ください。

2. 割り込みへ、クタは既定でBOOT領域の後に置かれます。これは割り込み制御器で変更することができます。

FUSE.BOOTENDが\$04を書かれ、FUSE.APPEDが\$08を書かれた場合、最初の4×256が小がBOOTで、次の4×256が小がAPPCODE、そして残りのフラッシュメモリがAPPDATAです。

#### 領域間の書き込み保護

3つの領域間では、以下の方向性の書き込み保護が実装されます。

- BOOT領域のコートはAPPCODEとAPPDATAに書くことができます。
- APPCODE領域のコートはAPPDATAに書くことができます。
- ・ APPDATA領域のコードはフラッシュ メモリやEEPROMに書くことができません。

#### ブート領域施錠と応用コート 領域書き込み保護

2つの施錠ビット(制御Bレジスタ(NVMCTRL.CTRLB)の応用コード領域書き込み保護(APCWP)とブート領域施錠(BOOTLOCK))は、次のリセットまでAPPCODEとBOOTの領域の各々の更なる更新を施錠するために設定(1)することができます。

CPUはBOOT領域に決して書くことができません。NVMCTRL\_CTRLB.BOOTLOCKはBOOT領域からのコードの読み込みと実行を防ぎます。

#### 9.3.1.2. EEPROM

EEPROMは1つのページが多数のバイトから成るページの組に分けられます。EEPROMは消去/書き込みでバイトの粒度を持ちます。1 ページ内で、更新されるべく記されたバイトだけが消去されて書かれます。バイトはそのアドレス位置に対してページ緩衝部へ新しい値を書くことによって記されます。

#### 9.3.1.3. 使用者列

使用者列はEEPROMの1つの付加ペーシです。このページは校正/構成設定のデータや通番のような様々なデータを格納するのに使うことができます。このページはチップ消去によって消去されません。使用者列は標準EEPROMとして書かれますが、それに加えて施錠されたデバイスに於いてUPDIを通して書くことができます。

#### 9.3.2. メモリ アクセス

#### 9.3.2.1. 読み込み

フラッシュ メモリとEEPROMの読み込みはメモリ配置に従ったアドレスを持つ取得(LD系)命令を用いて行われます。書き込みまたは消去が進行中と同時に配列の何れかを読むことはバス待ちに帰着し、その命令は進行中の操作が完了するまで中断されます。

# 9.3.2.2. ページ緩衝部設定

へーシ・緩衝部はメモリ配置で定義されるようにメモリへ直接書くことによって設定されます。フラッシュメモリ、EEPROM、使用者列は同じへーシ・緩衝部を共用し、故に一度に1つの領域だけをプログラミングする(書く)ことができます。アトレスの下位(LSB)側ビットはデータが書かれるヘーン・緩衝部内の場所を選ぶのに使われます。結果のデータはヘーン・緩衝部の新旧内容間のビット単位論理積(AND)操作です。ヘーン・緩衝部は以下の後で自動的に消去(全ビットが設定(1))されます。

- ・デバイスリセット
- ・どれかのページ書き込みまたは消去の操作
- ・ ページ緩衝部消去指令
- どれかの休止動作形態からのデバイス起き上がり

#### 9.3.2.3. プログラミング(書き込み)

ペーシ・書き込み(プログラミング)に関して、ペーシ・緩衝部を満たしてペーシ・緩衝部をフラッシュメモリ、使用者列、EEPROM内へ書くのは2つの独立した操作です。

ページ緩衝部内のデータでフラッシュページをプログラミングする(書く)前に、フラッシュページが消去されなければなりません。ページ緩衝部はデバイスが休止動作形態へ移行する時にも消去されます。未消去のフラッシュページブログラミングはその内容を不正にします。

フラッシュ メモリは消去と書き込みを独立して、または以下の両方を処理する1つの指令でのどちらかで書くことができます。

#### 代替手段1:

- 1. ページ緩衝部を満たしてください。
- 2. ページ消去/書き込み(ERWP)指令でページ緩衝部をフラッシュ メモリに書いてください。

#### 代替手段2:

- 1. アドレスを提供するためにページ内の位置へ書いてください。
- 2. ページ消去(ER)指令を実行してください。
- 3. ページ緩衝部を満たしてください。
- 4. ページ書き込み(WP)指令を実行してください。

NVM指令一式は単一の消去と書き込みの操作(ERWP)、分離した消去(ER)とページ書き込み(WP)の指令の両方を支援します。この分離命令は各指令に対してより短いプログラミング時間を許し、プログラミング実行の時間が重要でない間に消去操作を行うことができます。

EEPROMプログラミングも同様ですが、ペーン、緩衝部内で更新されるバイトがEEPROMで書かれるまたは消去されるだけです。

#### 9.3.2.4. 指令

フラッシュ メモリ/EEPROM読み込みとページ緩衝部書き込みは通常の取得(LD系)/格納(ST系)命令で処理されます。メモリ配列の書き込みや消去のような他の操作はNVMでの指令によって処理されます。

NVMで指令を実行するには、

- 1. 状態(NVMCTRL.STATUS)レシブスタの多忙フラケ(EEBUSYとFBUSY)を読むことによってどの直前の操作も完了されていることを確認してください。
- 2. CPUの構成設定変更保護(CPU.CCP)レジスタにNVM指令解錠を書いてください。
- 3. 次の4命令以内に制御A(NVMCTRL.CTRLA)レジスタの指令(CMD)ビットに望む指令値を書いてください。

#### 9.3.2.4.1. 書き込み指令

フラッシュ制御器のページ書き込み(WP)指令はページ緩衝部の内容をフラッシュ メモリまたはEEPROMに書きます。

その書き込みがフラッシュ メモリに対する場合、CPUはその書き込み操作でフラッシュ メモリが多忙である限りコードの実行を停止します。書き込みがEEPROMに対する場合、CPUはその操作が進行中の間にコードの実行を続けることができます。

ページ緩衝部は操作が終了された後で自動的に解消されます。

# 9.3.2.4.2. 消去指令

ページ消去(ER)指令は現在のページを消去します。効力を発するにはページ消去(ER)指令に対してページ緩衝部に1バイトが書かれなければなりません。

フラッシュ メモリ消去に対して、最初に望むページ内の或るアドレスに書き、その後に指令を実行してください。フラッシュ メモリ内のそのページ全体がその後に消去されます。CPUは消去が進行中の間停止されます。

EEPROMに対して、この指令が実行される時にページ緩衝部内に書かれたバイだけが消去されます。特定バイを消去するには、この指令を実行する前にそれに対応するアドレスに(何かを)書いてください。ページ全体を消去するには、この指令が実行される前にページ緩衝部内の全バイが更新されなければなりません。CPUはこの操作が進行中の間にコードの実行を続けることができます。

ページ緩衝部は操作が終了された後で自動的に解消されます。

#### 9.3.2.4.3. 消去-書き込み操作

ペーシ消去/書き込み(ERWP)指令はペーシ消去(ER)とペーシ書き込み(WP)の指令の組み合わせですが、ペーシ消去指令後のペーシ 緩衝部解消を除きます。ペーシ消去/書き込み操作は最初に選択されたページを消去し、その後にページ緩衝部の内容を同じページに 書きます。

フラッシュ メモリで実行されると、CPUはその操作が進行中の間停止されます。EEPROMで実行されると、CPUはコート・実行を続けることができます。

ページ緩衝部は操作が終了された後で自動的に解消されます。

#### 9.3.2.4.4. ペ-ジ緩衝部解消指令

ページ<mark>緩衝部解消</mark>(PBC)指令はページ緩衝部を解消します。ページ緩衝部の内容はこの操作後に全て'1'です。この操作実行時に CPUは(7 CPU周期)停止されます。

#### 9.3.2.4.5. チップ 消去指令

チップ消去(CHER)指令はフラッシュ メモリとEEPROMを消去します。EEPROMはシステム構成設定の(FUSE.SYSCFG0)のチップ消去中EEPROM保存(EESAVE)ヒュースが設定(1)される場合に不変です。フラッシュ メモリは制御B(NVMCTRL.CTRLB)レシブスタのフェト領域施錠(BOOTL OCK)や応用コート領域書き込み保護(APCWP)によって保護されません。メモリはこの操作後に全て'1'です。

#### 9.3.2.4.6. EEPROM消去指令

EEPROM消去(EEER)指令はEEPROMを消去します。EEPROMはこの操作後に全て'1'です。CPUはEEPROMが消去されつつある間停止されます。

#### 9.3.2.4.7. ヒュース 書き込み指令

とユーズ書き込み(WFU)指令はヒューズを書きます。これはUPDIによってのみ使うことができ、CPUはこの指令を開始することができません。

ヒューズ書き込み指令を使うには以下のこの手順に従ってください。

- 1. アト・レス(NVMCTRL.ADDR)レシ、スタにヒュース、のアト・レスを書いてください。
- 2. データ(NVMCTRL.DATA)レシブスタにヒュース、に書かれるべきデータを書いてください。
- 3. ヒューズ書き込み指令を実行してください。
- 4. ヒューズ書き込み後、効力を発するには更新された値のためにリセットが必要とされます。

ヒューズ読み込みに対してはメモリ位置で通常の読み込みを使ってください。

# 9.3.2.5. リセット後の書き込みアクセス

電源ONJセット(POR)後、NVMCTRLは一定時間の間、NVMへのどの書き込みの試みも拒否します。この期間の間、状態(STATUS)レジスタのフラッシュメモリ多忙(FBUSY)とEEPROM多忙(EEBUSY)のビットは'1'を読みます。 へージ緩衝部が満たされ得る、またはNVM指令が発行され得るのに先立って、EEBUSYとFBUSYは'0'を読まなくてはなりません。

この制限時間期間はシステム構成設定の(FUSE.SYSCFG0)ヒュース・の制限時間禁止(TOUTDIS)ヒ・ットを書くこと、またはFUSE.SYSCFG0のリセット ピン構成設定(RSTPINCFG)ヒ・ットをUPDIに構成設定することのどちらかによって禁止されます。

# 9.3.3. フラッシュ メモリ/EEPROM化け防止

低いVDDの期間中、CPUとフラッシュ メモリ/EEPROMに対して正しく動作するための供給電圧が低すぎる場合に、フラッシュ プログラム メモリとEEPROMで、Pタが化け得ます。これらの問題はフラッシュ メモリ/EEPROMを使う基板上の段階と同じで、おそらく同じ設計上の解決策を適用することができます。

フラッシュ メモリ/EEPROM化けは電圧が低すぎる時の以下の2つの状態によって起こされ得ます。

- 1. フラッシュ メモリ/EEPROMへの通常の書き込み手順は正しく動作するための最低電圧を必要とします。
- 2. 供給電圧が低すぎると、CPU自身が命令を間違って実行し得ます。

最大周波数対VDDについては「電気的特性」章をご覧ください。



注意: フラッシュ メモリ/EEPROM化けは以下のこれらの対策を取ることによって避けることができます。

- 1. 不十分な供給電源電圧の期間中、デバイスをリセットに保ってください。内部低電圧検出器(BOD)を許可することによって行うことができます。
- 2. BOD基準近くでEEPROMへの書き込み開始を防ぐのにBODでの電圧水準監視部を使うことができます。
- 3. 内部BODの検出基準が必要とする検出基準と一致しない場合、外部の低VDDリセット保護回路を使うことができます。書き込み操作が進行中の間にリセットが起こる場合、その書き込み操作は中止されます。

#### 9.3.4. 割り込み

# 表9-2. 利用可能な割り込みベクタと供給元

| 衣9-2. 利用中 | 夜9 <sup>-</sup> 2. 利用可能な割り込みへりと供稿ル |                             |  |  |  |  |  |  |  |  |
|-----------|------------------------------------|-----------------------------|--|--|--|--|--|--|--|--|
| 名称        | ベクタ説明                              | 条件                          |  |  |  |  |  |  |  |  |
| EEREADY   | NVM                                | 新規の書き込み/消去の操作に対してEEPROMが準備可 |  |  |  |  |  |  |  |  |

割り込み条件が起こると、周辺機能の割り込み要求フラグ(NVMCTRL.INTFLAGS)レジスタで対応する割り込み要求フラグが設定(1)されます。

割り込み元は周辺機能の割り込み許可(NVMCTRL.INTCTRL)レジスタで対応するビットに書くことによって許可または禁止にされます。 割り込み要求は対応する割り込み元が許可され、割り込み要求フラケが設定(1)される時に生成されます。割り込み要求は割り込み要求フラケが解除(0)されるまで活性に留まります。割り込み要求フラケを解除する方法の詳細についてはNVMCTRL.INTFLAGSレジスタをご覧ください。

# 9.3.5. 休止形態動作

進行中の書き込み操作が全くなければ、NVMCTRLはシステムが休止動作形態へ移行する時に休止動作形態へ移行します。

システムが休止動作形態へ移行する時に書き込み操作が進行中の場合、NVM部、NVM制御器、システム クロックはその書き込みが終了されるまでONに留まります。これはパワーダウン休止動作を含む全ての休止動作形態に対して有効です。

EEPROM準備可割り込みはアイドル休止動作からだけデバイスを起き上がらせます。

ヘージ緩衝部は休止から起き上がる時に解消されます。

# 9.3.6. 構成設定変更保護

この周辺機能は構成設定変更保護(CCP)下にあるレジスタを持ちます。これらのレジスタへ書くには、最初に構成設定変更保護(CPU.C CP)レジスタへ或る鍵が書かれ、4 CPU命令以内に保護されたビットへの書き込みアクセスが後続しなければなりません。

適切なCCP解錠手順に従わずに保護されたレジスタへの書き込みを試みることは保護されたレジスタを無変化のままにします。

右のレシスタがCCP下です。

| 表9-3. NVMCTRL - 構成設定変更保護下のレジスタ |
|--------------------------------|
|--------------------------------|

| レシ、スタ         | 鍵種別 |
|---------------|-----|
| NVMCTRL.CTRLA | SPM |

# 9.4. レジスタ要約

| 変位    | 略称       | ビット位置        | ヒ゛ットフ | ピット6 | ピット5 | じット4 | ヒ゛ット3 | ビット2    | ピット1     | ピット0    |
|-------|----------|--------------|-------|------|------|------|-------|---------|----------|---------|
| +\$00 | CTRLA    | 7~0          |       |      |      |      |       |         | CMD2~0   |         |
| +\$01 | CTRLB    | 7 <b>~</b> 0 |       |      |      |      |       |         | BOOTLOCK | APCWP   |
| +\$02 | STATUS   | 7 <b>~</b> 0 |       |      |      |      |       | WRERROR | EEBUSY   | FBUSY   |
| +\$03 | INTCTRL  | 7 <b>~</b> 0 |       |      |      |      |       |         |          | EEREADY |
| +\$04 | INTFLAGS | 7 <b>~</b> 0 |       |      |      |      |       |         |          | EEREADY |
| +\$05 | 予約       |              |       |      |      |      |       |         |          |         |
| +\$06 | DATA     | 7 <b>~</b> 0 |       |      |      | DAT. | A7~0  | 1       |          |         |
| +\$07 | DATA     | 15~8         |       |      |      | DATA | 15~8  | 1       |          |         |
| +\$08 | ADDR     | 7~0          |       |      |      | ADD  | R7∼0  | 1       |          |         |
| +\$09 | ADDR     | 15~8         |       |      |      | ADDI | R15~8 |         |          |         |

# 9.5. レジスタ説明

# **9.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位: +\$00 リセット: \$00

特質:構成設定変更保護

| ピット    | 7 | 6 | 5 | 4 | 3 | 2   | 1      | 0   |
|--------|---|---|---|---|---|-----|--------|-----|
|        |   |   |   |   |   |     | CMD2~0 |     |
| アクセス種別 | R | R | R | R | R | R/W | R/W    | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0   | 0      | 0   |

# ● ビット2~0 - CMD2~0: 指令 (Command)

指令を発行するにはこのビット領域に書いてください。この書き込み前の4命令以内に自己プログラミング用の構成設定変更保護鍵(SPM)が書かれなければなりません。

| / <del>±</del> | D II | =2.00                                                       |
|----------------|------|-------------------------------------------------------------|
| 値              | 名称   | 説明                                                          |
| 000            | _    | 指令なし                                                        |
| 001            | WP   | へ゜ーシ゛緩衝部をメモリに書き込み(NVMCTRL.ADDRがどのメモリかを選択)                   |
| 010            | ER   | へ <sup>^</sup> ーシ <sup>†</sup> 消去 (NVMCTRL.ADDRがどのメモリカかを選択) |
| 011            | ERWP | ~~シ゛の消去と書き込み(NVMCTRL.ADDRがどのメモリかを選択)                        |
| 100            | PBC  | ヘージ後衝部解消                                                    |
| 101            | CHER | チップ消去:フラッシュ メモリと(FUSE.SYSCFG0のEESAVEが'1'でない限り)EEPROMを消去     |
| 110            | EEER | EEPROM消去                                                    |
| 111            | WFU  | ヒューズ書き込み (UPDIを通してのみアクセス可能)                                 |

# **9.5.2. CTRLB - 制御B** (Control B)

名称: CTRLB 変位: +\$01 リセット: \$00 特質: -

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1        | 0     |
|--------|---|---|---|---|---|---|----------|-------|
|        |   |   |   |   |   |   | BOOTLOCK | APCWP |
| アクセス種別 | R | R | R | R | R | R | R/W      | R/W   |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0        | 0     |

# ● ビット1 - BOOTLOCK : プート領域施錠 (Boot Section Lock)

このビットへの'1'書き込みは読み込みと命令取得からブート領域を施錠します。

このビットが、1、の場合、ブート領域からの読み込みは、0、を返します。ブート領域からの取得も命令として0を返します。

このビットはブート領域からだけ書くことができます。 リセットによってだけ解除(0)することができます。

このビットはこのビットが書かれた後で初めてブート領域から去られる時にだけ効力を発します。

## ● ビット0 - APCWP:応用コード領域書き込み保護 (Application Code Section Write Protection)

このビットへの'1'書き込みは更なる書き込みから応用コード領域を保護します。

このビットは'1'に書くことだけができ、リセットによってのみ解除(0)されます。

## 9.5.3. STATUS - 状態 (Status)

名称: STATUS 変位: +\$02 リセット: \$00 特質:-

| ヒ゛ット   | 7 | 6 | 5 | 4 | 4 3 2 |         | 1      | 0     |
|--------|---|---|---|---|-------|---------|--------|-------|
|        |   |   |   |   |       | WRERROR | EEBUSY | FBUSY |
| アクセス種別 | R | R | R | R | R     | R       | R      | R     |
| リセット値  | 0 | 0 | 0 | 0 | 0     | 0       | 0      | 0     |

#### ● ビット2 - WRERROR: 書き込み異常 (Write Error)

このビットは書き込み異常が起きた時に'1'を読みます。書き込み異常はページ書き込みを行う前に異なる領域へ書く、または保護された領域へ書くことで有り得ます。このビットは最後の操作に対して有効です。

# ● ビット1 - EEBUSY: EEPROM多忙 (EEPROM Busy)

このビットは指令でEEPROMが多忙の時に'1'を読みます。

## ● ビット0 - FBUSY: フラッシュ メモリ多忙 (Flash Busy)

このビットは指令でフラッシュメモリが多忙の時に'1'を読みます。

# 9.5.4. INTCTRL - 割り込み制御 (Interrupt Control)

名称:INTCTRL 変位:+\$03 リセット:\$00 特質:-

| アカセフ番目 D D D D D D D D D D D D D D D D D D D | EEREADY     |
|----------------------------------------------|-------------|
| 7/11/14 0 0 0 0 0 0 0 0                      | DDI(D) ID I |
| アクセス種別 R R R R R                             | R/W         |
| リセット値 0 0 0 0 0 0                            | 0           |

# ● ビット0 - EEREADY: EEPROM準備可割り込み許可(EEPROM Ready Interrupt)

このビットへの'1'書き込みはEEPROMが新しい書き込み/消去操作の準備が整ったことを示す割り込みを許可します。

これは割り込み要求フラグ(INTFLAGS)レジスタのEEPROM準備可割り込み要求(EEREADY)フラグが゚0゚に設定されている時にだけ起動されるレベル割り込みです。 故に、NVM指令発行前にEEREADYフラグが設定(1)されないように、この割り込みはNVM指令起動前に起動されてはなりません。この割り込みはおそらく割り込み処理部で禁止されます。

# 9.5.5. INTFLAGS - 割り込み要求フラグ (Interrupt Flags)

名称: INTFLAGS 変位: +\$04 リセット: \$00 特質: -

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|--------|---|---|---|---|---|---|---|---------|
|        |   |   |   |   |   |   |   | EEREADY |
| アクセス種別 | R | R | R | R | R | R | R | R/W     |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0       |

#### ● ビット0 - EEREADY: EEPROM準備可割り込み要求フラグ(EEREADY Interrupt Flag)

このフラグはEEPROMが多忙でない限り継続的に設定(1)されます。このフラグはこれに'1'を書くことによって解除(0)されます。

# 9.5.6. DATA – $\bar{\tau}$ – $\bar{\tau}$ (Data)

名称: DATA (DATAH, DATAL)

変位:+\$06 リセット:\$0000 特質:-

NVNCTRL.DATAHとNVMCTRL.DATALのレジスタ対は16ビット値のNVMCTRL.DATAを表します。下位ハイト[7~0](接尾辞L)は変位原点でアクセス可能です。上位ハイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

| ピット    | 15  | 14  | 13  | 12           | 11            | 10  | 9          | 8   |
|--------|-----|-----|-----|--------------|---------------|-----|------------|-----|
|        |     |     |     | DATA         | <b>\</b> 15∼8 | ,   |            |     |
| アクセス種別 | 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   | _   | 4            | 2             | 0   | 1          | 0   |
| L 7/r  | - 1 | . 6 | 5   | <u>4</u>     |               |     | <u>. I</u> | . 0 |
|        |     |     |     | <u>, DAT</u> | <u>A1~0</u>   |     |            |     |
| アクセス種別 | R/W | R/W | R/W | R/W          | R/W           | R/W | R/W        | R/W |
| リセット値  | 0   | 0   | 0   | 0            | 0             | 0   | 0          | 0   |
| リセット値  | 0   | 0   | 0   | 0            | 0             | 0   | 0          | 0   |

## • ビット15~0 - DATA15~0: データ値 (Data Register)

このレシ、スタはヒュース、書き込み操作のためにUPDIによって使われます。

#### 9.5.7. ADDR - アトレス (Address)

名称: ADDR (ADDRH, ADDRL)

変位:+\$08 リセット:\$0000 特質:-

NVNCTRL.ADDRHとNVMCTRL.ADDRLのレジスタ対は16ビット値のNVMCTRL.ADDRを表します。下位バイト[7~0](接尾辞L)は変位 原点でアクセス可能です。上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

|        |     |     |          | •    |       | · - |     |     |
|--------|-----|-----|----------|------|-------|-----|-----|-----|
| ピット    | 15  | 14  | 13       | 12   | 11    | 10  | 9   | 8   |
|        |     |     |          | ADDI | R15~8 |     |     |     |
| アクセス種別 | 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   | C   | _        | 4    | 2     | 9   | 1   | 0   |
|        |     | 6   | <u>.</u> | 4    | J     | 2   | 1   | . 0 |
|        |     |     |          | ADD  | R7~0  |     |     |     |
| アクセス種別 | R/W | R/W | R/W      | R/W  | R/W   | R/W | R/W | R/W |
| リセット値  | 0   | 0   | 0        | 0    | 0     | 0   | 0   | 0   |
|        |     |     |          |      |       |     |     |     |

#### ビット15~0 - ADDR15~0: アトレス値 (Address)

アドレス レジスタは更新される最後のメモリ位置に対するアドレスを含みます。

# 10. CLKCTRL - クロック制御器

#### 10.1. 特徴

- ・周辺機能によって要求される時に自動的に許可される全てのクロックとクロック元
- 内部発振器
  - 16/20MHz発振器(OSC20M)
  - 32.768kHz超低電力発振器(OSCULP32K)
- ・外部クロック任意選択
  - 32.768kHzクリスタル用発振器(XOSC32K)
  - 外部クロック
- ・主なクロック機能
  - 安全な走行時切り替え
  - 12種の設定で1~64の分周を持つ前置分周器

## 10.2. 概要

クロック制御(CLKCTRL)周辺機能は利用可能な発振器からのクロック信号を制御、分配、前置分周します。 CLKCTRLは内部と外部のクロック元を支援します。

CLKCTRLはデバイス上の全ての周辺機能に実装された自動クロック要求システムに基づきます。周辺機能は必要とされるクロックを自動的に要求します。多数のクロック元が利用可能な場合、その要求は正しいクロック元に配線されます。

主クロック(CLK\_MAIN)はCPU、SRAM、それとI/Oバスによって使われます。主クロック元を選んで前置分周することができます。いくつかの周辺機能は主クロックと同じクロック元を共用し、また主クロック領域と非同期に動きます。

#### 10.2.1. 構成図 - CLKCTRL



クロックシステムは主クロックと他の非同期クロックから成ります。

主クロック

このクロックはCPU、SRAM、フラッシュ メモリ、I/Oバス、それとI/Oバスに接続された全ての周辺機能によって使われます。これは常に活動とアイドル休止動作で動き、必要とされる場合はスタンバイ休止動作で動くことができます。

主クロック(CLK\_MAIN)はクロック制御器によって前置分周されて分配されます。

- CLK\_CPUはCPU、SRAMと不揮発性メモリにアクセスするためのNVMCTRL周辺機能によって使われます。
- CLK PERは非同期クロック下で一覧にされない全ての周辺機能によって使われます。

- ・ 主クロック領域に対して非同期に動くクロック
  - CLK\_RTCは実時間計数器/周期的割り込み計時器(RTC/PIT)に使われます。RTC/PITが許可される時に要求されます。CL K\_RTC用のクロック元はこの周辺機能が禁止されている場合にだけ変更されなければなりません。
  - CLK\_WDTはウォッチドッグタイマ(WDT)によって使われます。WDTが許可される時に要求されます。
  - CLK\_BODは低電圧検出器(BOD)によって使われます。BODが採取動作で許可される時に要求されます。
  - CLK\_TCDはタイマ/カウンタD型(TCD)によって使われます。TCDが許可される時に要求されます。このクロック元はこの周辺機能が禁止されている場合にだけ変更することができます。

主クロック領域用のクロック元は主クロック制御A(CLKCTRL.MCLKCTRLA)レジ、スタのクロック選択(CLKSEL)ヒ、ットに書くことによって構成設定されます。非同期クロック元は各々の周辺機能内のレジ、スタによって構成設定されます。

## 10.2.2. 信号説明

| 信号     | 形式     | 説明        |
|--------|--------|-----------|
| CLKOUT | デジタル出力 | CLK_PER出力 |

# 10.3. 機能的な説明

#### 10.3.1. 休止形態動作

クロック元が使用/要求されない時にそれは止まります。各々の周辺機能の制御A(CLKCTRL.[発振器種別名]CTRLA)レジスタのスタンバイ時走行(RUNSTDBY)ビットに'1'を書くことによって直接クロック元を要求することが可能です。これはパワーダウン休止動作形態を除き、その発振器を絶えず走行させます。加えて、このビットが'1'を書かれると、クロック元が周辺機能によって要求される時に、発振器の始動時間が除去されます。

主クロックは活動とアイドル休止の動作形態で常に走行します。スタンバイ休止動作形態では、どれかの周辺機能がこれを要求する、または各々の発振器の制御A(CLKCTRL.[発振器種別名]CTRLA)レジスタのスタンバイ時走行(RUNSTDBY)ビットが゚1゚を書かれる場合にだけ主クロックが走行します。

パワーダウン休止動作形態ではNVM操作が完了された後に主クロックが停止します。

## 10.3.2. 主クロック選択と前置分周器

全ての内部発振器はCLK\_MAIN用の主クロック元として使うことができます。主クロック元はソフトウェアから選択可能で、標準動作の間に安全に変更することができます。

組み込みハードウェア保護は安全でないクロック切り替えを防ぎます。

外部クロック元の選択では選んだクロック元への切り替えはその外部クロックで安定を示すエッジ(端)が検出される場合だけに起こります。充分なクロック端数が検出されるまで、切り替えは起きず、リセットを実行することなしに再び別のクロック元へ変更することはできません。

進行中のクロック元切り替えは主クロック状態(CLKCTRL.MCLKSTATUS)レシ、スタのシステム発振器変更(SOSC)フラク、によって示されます。外部クロック元の安定性は各々の状態フラク、(CLKCTRL.MCLKSTATUSの外部クロック状態(EXTS)と32.768kHzクリスタル用発振器状態(XOSC32KS))によって示されます。

グ注意 外部クロック元がCLK\_MAIN供給元として使われる間に機能しなくなる場合、ウォッチドッグ タイマ(WDT)だけがシステム リセット経由で切り替え戻すための機構を提供することができます。

CLK\_MAINはデバイスの周辺機能(CLK\_PER)によって使われる前に前置分周器へ供給されます。前置分周器は1段だけを持ち、1~64の係数でCLK MAINを分周することができます。



主クロックと前置分周器の構成設定レジスタ(CLKCTRL.MCLKCTRLAとCLKCTRL.MCLKCTRLB)は、これらのレジスタを変更するのに 時間制限書き込み手順を使う構成設定変更保護機構によって保護されます。

#### 10.3.3. リセット後の主クロック

どのリセット後でも、CLK\_MAINは前置分周器の分周係数6と共に16/20MHz発振器(OSC20M)によって提供されます。OSC20Mの実際の周波数は発振器構成設定(FUSE.OSCCFG)ヒューズの周波数選択(FREQSEL)ビットによって決められ、これらの周波数はリセット後に受け入れられます。

更なる詳細についてはOSC20M記述をご覧ください。

| 表10-1. リセット後の周辺機能クロック周波数       |            |  |  |  |  |  |  |
|--------------------------------|------------|--|--|--|--|--|--|
| FUSE.OSCCFGのFREQSELによるCLK_MAIN | 結果のCLK_PER |  |  |  |  |  |  |
| 16MHz                          | 2.66MHz    |  |  |  |  |  |  |
| 20MHz                          | 3.33MHz    |  |  |  |  |  |  |

#### 10.3.4. クロック元

全ての内部クロック元はそれらが周辺機能によって要求される時に自動的に許可されます。外部クリスタルに基づくクリスタル用発振器はそれがクロック元として扱われるのに先立って32.768kHzクリスタル用発振器制御A(CLKCTRL.XOSC32KCTRLA)レジスタの許可(ENABLE) ビットに'1'を書くことによって許可されなければなりません。

主クロック状態(CLKCTRL.MCLKSTATUS)レシ、スタの各々の状態ビットはクロック元が走行中で安定かどうかを示します。

#### 10.3.4.1. 内部発振器

内部発振器は走行するのにどんな外部部品も必要としません。

#### 10.3.4.1.1. 16/20MHz発振器 (OSC20M)

この発振器は発振器構成設定(FUSE.OSCCFG)ヒューズの周波数選択(FREQSEL)ビットの値によって選択される複数の周波数で動作することができます。中心周波数は次のとおりです。

- 16MHz
- 20MHz

システム リセット後、FUSE.OSCCFGはCLK\_MAINの初期周波数を決めます。

リセットの間にヒュース、からOSC20M用の校正値が設定されます。2つの異なる校正ビット領域があります。

- ・校正A(CLKCTRL.OSC20MCALIBA)レジスタの校正(CAL20M)ビット領域は現在の中心周波数近辺への校正を許します。
- ・校正B(CLKCTRL.OSC20MCALIBB)レシブスタの発振器温度係数校正(TEMPCAL20M)ビット領域は温度変動補償の傾斜の調整を 許します。

発振器校正が提供するよりももっと微調整された周波数設定が必要な応用については、校正後に工場で格納された周波数誤差が利用可能です。

発振器校正は発振器構成設定(FUSE.OSCCFG)の発振器施錠(OSCLOCK)ヒュース、によって施錠することができます。このヒュースが '1'の時に校正変更が不能です。この発振器が主クロック元として使われ、主クロック施錠(CLKCTRL.MCLKLOCK)レジスタの施錠許可(LOCKEN)ビットが'1'の場合にも校正が施錠されます。

校正ビットは主クロックと前置分周器の設定を変更するために時間制限書き込み手順を必要とする構成設定変更保護機構によって保護されます。

この発振器の始動時間はアナログ始動時間+4発振器周期です。始動時間については「電気的特性」章を参照してください。

発振器校正値変更時、周波数は行き過ぎるかもしれません。発振器が主クロック(CLK\_MAIN)として使われる場合、「全般動作定格」項で記述されるように主クロック周波数が主クロック最大動作周波数の1/4を超えないように主クロック前置分周器を変更することが推奨されます。システム クロック前置分周器は発振器校正値が更新されてしまった後で戻すことができます。

#### 10.3.4.1.1.1. OSC20M格納された周波数誤差補償

この発振器はリセット後に発振器構成設定(FUSE.OSCCFG)ヒューズの周波数選択(FREQSEL)ビットの値によって選択される複数の周波数で動作することができます。前で言及したように、(OSC20Mの)周波数を中心に調整するために適切な校正値が設定され、温度変動補償(TEMPCAL20M)が内部発振器特性で定義される仕様に合わせます。より広い動作範囲が必要な応用については、校正後に工場で格納した相対的な周波数誤差を使うことができます。異なる設定で4つの誤差が測定され、識票列で符号付きバイ値として利用可能です。

- 3VでのOSC16誤差(SIGROW,OSC16ERR3V)は3Vで測定された16MHzからの周波数誤差です。
- 5VでのOSC16誤差(SIGROW.OSC16ERR5V)は5Vで測定された16MHzからの周波数誤差です。
- ・3VでのOSC20誤差(SIGROW.OSC20ERR3V)は3Vで測定された20MHzからの周波数誤差です。
- ・5VでのOSC20誤差(SIGROW.OSC20ERR5V)は5Vで測定された20MHzからの周波数誤差です。

分解能を失わないために誤差は圧縮されたQ1.10固定小数点8ビット値として格納され、ここで最上位ビットは符号ビットで下位7ビットは Q.10の下位側ビットです。

実際のBAUD =  $\left($ 理想BAUD +  $\frac{理想BAUD \times SIGROW誤差}{1024}\right)$ 

正当な最小BAUDレジスタ値は\$40で、従って、例え負の補償値を持つデバイスに対しても補償したBAUD値が正当な範囲内に留まることを保証するために、目的対象BAUDレジスタ値は\$4Aよりも低くしてはなりません。次の例のコードはより正確なUSARTボーレートのためにこの値をどう適用するかを実演します。

```
#include <assert.h>
/* 工場で格納された周波数誤差でのボーレート補償
/* 自動ボーレート(同期領域)なしでの非同期通信
                                   */
/* 16MHzクロック、3Vで600ボー
                                   */
int8_t sigrow_val = SIGROW. OSC16ERR3V;
                                        // 符号付き誤差取得
int32_t baud_reg_val = 600;
                                        // 理想ボーレート
                                        // 負の最大比較で正当な最小BAUDレジスタ値を確認
assert (baud reg val >= 0x4A);
baud reg val *= (1024 + sigrow val);
                                        // (分解能+誤差)で乗算
baud reg val /= 1024;
                                        // 分解能で除算
                                        // 補正したボーレート設定
USARTO.BAUD = (int16_t) baud_reg_val;
```

### 10.3.4.1.2. 32.768kHz発振器 (OSCULP32K)

32.768kHz発振器は超低電力(ULP)動作に最適化されます。外部クリスタル用発振器に比べて減らされた精度を犠牲にして消費電力が減らされます。

この発振器は実時間計数器(RTC)、ウォッチドッグタイマ(WDT)、低電圧検出器(BOD)に1.024kHzの信号を提供します。

この発振器の始動時間はアナログ始動時間+4発振器周期です。始動時間については「電気的特性」章を参照してください。

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

これらの外部クロック元が利用可能です。

- ・ ピンからの外部クロック (EXTCLK)
- ・TOSC1とTOSC2のピンでの32.768kHzクリスタル用発振器
- TOSC1ピンでの32.768kHz外部クロック

#### 10.3.4.2.1. 外部クロック (EXTCLK)

EXTCLKはピンから直接的に取られます。この汎用入出力(GPIO)ピンは何れかの周辺機能がこのクロックを要求した場合にEXTCLK用に構成設定されます。

このクロック元は最初に要求された時に2周期の始動時間を持ちます。

# 10.3.4.2.2. 32.768kHzクリスタル用発振器(XOSC32K)

この発振器は、クリスタルがTOSC1とTOSC2のピンに接続される、または32.768kHzで走行する外部クロックがTOSC1に接続されるのどちらかの2つの入力任意選択を支援します。この入力任意選択はXOSC32K制御A(CLKCTRL.XOSC32KCTRLA)レジスタの供給元選択(SEL)ビットの書き込みによって構成設定されなければなりません。

XOSC32KはCLKCTRL.XOSC32KCTRLAのそれの許可(ENABLE)ビットに'1'を書くことによって許可されます。許可されると、XOSC 32Kによって使われる汎用入出力(GPIO)ピンの構成設定はTOSC1とTOSC2のピンとなることで無効にされます。要求された時に走行を開始する発振器に対して許可(ENABLE)ビットが設定(1)されることが必要です。与えられたクリスタルでのクリスタル用発振器の始動時間はCLKCTRL.XOSC32KCTRLAのクリスタル始動時間(CSUT)ビットへの書き込みによって調節することができます。

XOSC32KがTOSC1での外部クロック使用に構成設定されると、始動時間は2周期に固定されます。

## 10.3.5. 構成設定変更保護

この周辺機能は構成設定変更保護(CCP)下にあるレジスタを持ちます。これらのレジスタへ書くには、最初に構成設定変更保護(CPU.CCP)レジスタへ或る鍵が書かれ、4 CPU命令以内に保護されたビットへの書き込みアクセスが後続しなければなりません。

適切なCCP解錠手順に従わずに保護されたレジスタへの書き込みを試みることは保護されたレジスタを無変化のままにします。

右のレシブスタがCCP下です。

| 表10-2. CLKCTRL - 構成設定変更 | 保護下のレシスタ |
|-------------------------|----------|
| レシ゛スタ                   | 鍵種別      |
| CLKCTRL.MCLKCTRLB       |          |
| CLKCTRL.MCLKLOCK        |          |
| CLKCTRL.XOSC32KCTRLA    |          |
| CLKCTRL.MCLKCTRLA       | IOREG    |
| CLKCTRL.OSC20MCTRLA     | IOREG    |
| CLKCTRL.OSC20MCALIBA    |          |
| CLKCTRL.OSC20MCALIBB    |          |

CLKCTRL.OSC32KCTRLA

# 10.4. レジスタ要約

| 変位                  | 略称           | ビット位置        | ヒ゛ット7  | じット6     | ピット5    | ピット4    | じット3  | じット2   | ヒ゛ット1    | ピット0   |
|---------------------|--------------|--------------|--------|----------|---------|---------|-------|--------|----------|--------|
| +\$00               | MCLKCTRLA    | 7~0          | CLKOUT |          |         |         |       |        | CLKS     | EL1,0  |
| +\$01               | MCLKCTRLB    | 7 <b>~</b> 0 |        |          |         |         | PDIV  | √3~0   |          | PEN    |
| +\$02               | MCLKLOCK     | 7 <b>~</b> 0 |        |          |         |         |       |        |          | LOCKEN |
| +\$03               | MCLKSTATUS   | 7 <b>~</b> 0 | EXTS   | XOSC32KS | OSC32KS | OSC20MS |       |        |          | SOSC   |
| +\$04<br>+\$0F      | 予約           |              |        |          |         |         |       |        |          |        |
| +\$10               | OSC20MCTRLA  | 7 <b>~</b> 0 |        |          |         |         |       |        | RUNSTDBY |        |
| +\$11               | OSC20MCALIBA | 7 <b>~</b> 0 |        |          |         |         | CAL20 | 0M5~0  |          |        |
| +\$12               | OSC20MCALIBB | 7 <b>~</b> 0 | LOCK   |          |         |         |       | TEMPCA | L20M3~0  |        |
| +\$13<br>+\$17      | 予約           |              |        |          |         |         |       |        |          |        |
| +\$18               | OSC32KCTRLA  | 7 <b>~</b> 0 |        |          |         |         |       |        | RUNSTDBY |        |
| +\$19<br>-<br>+\$1B | 予約           |              |        |          |         |         |       |        |          |        |
| +\$1C               | XOSC32KCTRLA | 7 <b>~</b> 0 |        |          | CSU     | T1,0    |       | SEL    | RUNSTDBY | ENABLE |

# 10.5. レジスタ説明

10.5.1. MCLKCTRLA - 主クロック制御A (Main Clock Control A)

名称: MCLKCTRLA

**変位**:+\$00 リセット:\$00

特質:構成設定変更保護

| ヒ゛ット _ | 7      | 6 | 5 | 4 | 3 | 2 | 1         | 0   |
|--------|--------|---|---|---|---|---|-----------|-----|
|        | CLKOUT |   |   |   |   |   | CLKSEL1,0 |     |
| アクセス種別 | R/W    | R | R | R | R | R | R/W       | R/W |
| リセット値  | 0      | 0 | 0 | 0 | 0 | 0 | 0         | 0   |

# ビット7 - CLKOUT: システム クロック出力 (System Clock Out)

このビットが'1'を書かれると、システムクロックがCLKOUTピンに出力されます。

デバイスが休止動作形態の時には、周辺機能がシステムクロックを使っていない限り、クロック出力は全くありません。

#### ビット1,0 - CLKSEL1,0:クロック選択(Clock Select)

このビット領域は主クロック(CLK MAIN)用の供給元を選びます。

| 値  | 0 0 0 1           |                        | 1 0                                                               | 11     |
|----|-------------------|------------------------|-------------------------------------------------------------------|--------|
| 名称 | OSC20M            | OSCULP32K              | XOSC32K                                                           | EXTCLK |
| 説明 | 16/20MHz<br>内部発振器 | 32.768kHz内部<br>超低電力発振器 | XOSC32KCTRLAのSELビットに応じて32.768kHz<br>外部クロックまたは32.768kHz外部クリスタル用発振器 | 外部クロック |

# 10.5.2. MCLKCTRLB - 主クロック制御B (Main Clock Control B)

名称: MCLKCTRLB

**変位**:+\$01 リセット:\$11

特質:構成設定変更保護

| ピット    | 7 | 6 | 5 | 4   | 3       | 2   | 1   | 0   |
|--------|---|---|---|-----|---------|-----|-----|-----|
|        |   |   |   |     | PDIV3~0 |     |     | PEN |
| アクセス種別 | R | R | R | R/W | R/W     | R/W | R/W | R/W |
| リセット値  | 0 | 0 | 0 | 1   | 0       | 0   | 0   | 1   |

# ● ビット4~1 - PDIV3~0:前置分周器分周値 (Prescaler Division)

前置分周器許可(PEN)ビットが、1、を書かれると、このビット領域は主クロック前置分周器の分周比を定義します。

このビット領域は応用の必要条件に適合させるようにシステムのクロック周波数を変えるために走行時の間に書くことができます。

使用者ソフトウェアは結果のCLK\_PER周波数が許された最大(電気的特性をご覧ください)を決して超えないような、正しい入力周波数 (CLK\_MAIN)の構成設定と前置分周器設定を保証しなければなりません。

| 値       | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 |
|---------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| 説明(分周数) | 2    | 4    | 8    | 16   | 32   | 64   | (予   | 約)   | 6    | 10   | 12   | 24   | 48   |      | (予約) |      |

#### ● ビット0 - PEN:前置分周器許可(Prescaler Enable)

前置分周器が許可されるにはこのビットが'1'を書かれなければなりません。 許可されると、前置分周器分周値(PDIV)ビット領域によって分周比が選ばれます。

このビットが'0'を書かれると、主クロックはPDIVの値に関わらず、分周なしを通して渡されます(CLK\_PER=CLK\_MAIN)。

#### 10.5.3. MCLKLOCK - 主クロック施錠 (Main Clock Lock)

名称: MCLKLOCK

変位:+\$02

リセット: '0000000x': 発振器構成設定(FUSE.OSCCFG)ヒュース'の発振器施錠(OSCLOCK)に基づきます。

特質:構成設定変更保護

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|--------|---|---|---|---|---|---|---|--------|
|        |   |   |   |   |   |   |   | LOCKEN |
| アクセス種別 | R | R | R | R | R | R | R | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | X      |

#### ● ビット0 - LOCKEN: 施錠許可(Lock Enable)

このビットへの'1'書き込みは主クロック制御A(CLKCTRL.MCLKCTRLA)と主クロック制御B(CLKCTRL.MCLKCTRLB)のレジスタと、適用可能ならば更なるソフトウェア更新から現在の主クロック元に対する校正設定を施錠します。一旦施錠されると、CLKCTRL.MCLKLOCKレジスタは次のハードウェア リセットまでアクセスすることができません。

これはソフトッウェアによる予期せぬ変更からCLKCTRL.MCLKCTRLAとCLKCTRL.MCLKCTRLBのレシ、スタと主クロック元に対する校正設定を保護します。

## 10.5.4. MCLKSTATUS - 主クロック状態 (Main Clock Status)

名称: MCLKSTATUS

変位:+\$03 リセット:\$00 特質:-

| ピット    | 7    | 6        | 5       | 4       | 3 | 2 | 1 | 0    |
|--------|------|----------|---------|---------|---|---|---|------|
|        | EXTS | XOSC32KS | OSC32KS | OSC20MS |   |   |   | SOSC |
| アクセス種別 | R    | R        | R       | R       | R | R | R | R    |
| リセット値  | 0    | 0        | 0       | 0       | 0 | 0 | 0 | 0    |

#### ● ビット7 - EXTS:外部クロック状態(External Clock Status)

| 値  | 0                | 1               |
|----|------------------|-----------------|
| 説明 | EXTCLKは開始していません。 | EXTCLKは開始しています。 |

# ● ビット6 - XOSC32KS: 32.768kHzクリスタル用発振器状態(XOSC32K Status)

この状態ビットはこの供給元が主クロックとして、または別の周辺機能によって要求された場合にだけ利用可能です。この発振器のスタンバイ時走行(RUNSTDBY)ビットが設定(1)であるけれども発振器が未使用/要求なしの場合、このビットは'0'になります。

| 値  | 0                  | 1             |
|----|--------------------|---------------|
| 説明 | XOSC32Kは安定ではありません。 | XOSC32Kは安定です。 |

#### ● ビット5 - OSC32KS:内部32.768kHz超低電力発振器状態(OSCULP32K Status)

この状態ビットはこの供給元が主クロックとして、または別の周辺機能によって要求された場合にだけ利用可能です。この発振器のスタンバイ時走行(RUNSTDBY)ビットが設定(1)であるけれども発振器が未使用/要求なしの場合、このビットは'0'になります。

| 値  | 0                    | 1               |
|----|----------------------|-----------------|
| 説明 | OSCULP32Kは安定ではありません。 | OSCULP32Kは安定です。 |

#### ● ビット4 - OSC20MS:内部16/20MHz発振器状態(OSC20M Status)

この状態ビットはこの供給元が主クロックとして、または別の周辺機能によって要求された場合にだけ利用可能です。この発振器のスタン バイ時走行(RUNSTDBY)ビットが設定(1)であるけれども発振器が未使用/要求なしの場合、このビットは'0'になります。

| 値  | 0                 | 1            |
|----|-------------------|--------------|
| 説明 | OSC20Mは安定ではありません。 | OSC20Mは安定です。 |

## ● ビット0 - SOSC: 主クロック発振器変更 (Main Clock Oscillator Changing)

| 値  | 0                             | 1                                               |
|----|-------------------------------|-------------------------------------------------|
| 説明 | CLK_MAIN用クロック元は切り替えを体験していません。 | CLK_MAIN用クロック元は切り替えを体験し、<br>新供給元が安定すると直ぐに変更します。 |

## 10.5.5. OSC20MCTRLA - 16/20MHz発振器制御A (16/20MHz Oscillator Control A)

名称: OSC20MCTRLA

変位 : +\$10 リセット : \$00

特質:構成設定変更保護

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1        | 0 |
|--------|---|---|---|---|---|---|----------|---|
|        |   |   |   |   |   |   | RUNSTDBY |   |
| アクセス種別 | R | R | R | R | R | R | R/W      | R |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0        | 0 |

#### • ビット1 - RUNSTDBY: スタンバイ時走行 (Run in Standby)

このビットは例えシステムによって未使用の時でも全ての動作形態でこの発振器を強制します。 スタンバイ休止動作形態に於いて、これは発振器始動時間を待つことなく直ちに起き上がることを保証するのに使うことができます。

周辺機能によって要求されない時は発振器出力が全く提供されません。

要求後にクロック開閉部を開くのに4発振器周期かかりますが、このビットが設定(1)されると、発振器アナログ始動時間が除去されます。

# 10.5.6. OSC20MCALIBA - 16/20MHz発振器校正A (16/20MHz Oscillator Calibration A)

名称: OSC20MCALIBA

変位:+\$11

リセット: FUSE.OSCCFG内のFREQSELヒュース に基づきます。

特質:構成設定変更保護

|          |   |     |     |       |       | · · |     |
|----------|---|-----|-----|-------|-------|-----|-----|
|          |   |     |     | CAL20 | )M5∼0 |     |     |
| アクセス種別 R | R | R/W | R/W | R/W   | R/W   | R/W | R/W |
| リセット値 0  | 0 | X   | X   | X     | X     | X   | X   |

#### ● ビット5~0 - CAL20M5~0: 校正値 (Calibration)

このビット領域は微調整のために周波数を現在の中心周波数近辺に変更します。

リセット後に発振器構成設定(FUSE.OSCCFG)ヒューズの周波数選択(FREQSEL)ビットに基づいて工場校正値が設定されます。

#### 10.5.7. OSC20MCALIBB - 16/20MHz発振器校正B (16/20MHz Oscillator Calibration B)

名称: OSC20MCALIBB

**変位**:+\$12

リセット: FUSE.OSCCFGヒュースに基づきます。

特質:構成設定変更保護

| ピット _  | 7    | 6 | 5 | 4 | 3   | 2      | 1       | 0   |
|--------|------|---|---|---|-----|--------|---------|-----|
|        | LOCK |   |   |   |     | TEMPCA | L20M3~0 |     |
| アクセス種別 | R    | R | R | R | R/W | R/W    | R/W     | R/W |
| リセット値  | X    | 0 | 0 | 0 | 0   | 0      | 0       | 0   |

## ● ビット7 - LOCK: ヒューズによる発振器校正施錠(Oscillator Calibration Locked by Fuse)

このビットが設定(1)されると、校正A(CLKCTRL.OSC20MCALIBA)と校正B(CLKCTRL.OSC20MCALIBB)のレジスタの校正設定は変更することができません。

リセット値は発振器構成設定(FUSE.OSCCFG)ヒューズの発振器施錠(OSCLOCK)ビットから取得/設定されます。

# ● ビット3~0 - TEMPCAL20M3~0:発振器温度係数校正 (Oscillator Temperrature Coefficient Calibration)

このビット領域は温度補償の傾斜を調整します。

リセット後に発振器構成設定(FUSE.OSCCFG)ヒューズの周波数選択(FREQSEL)ビットに基づいて工場校正値が設定されます。

## 10.5.8. OSC32KCTRLA - 32.768kHz発振器制御A(32.768kHz Oscillator Control A)

名称: OSC32KCTRLA

**変位**:+\$18 リセット:\$00

特質:構成設定変更保護

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1        | 0 |
|--------|---|---|---|---|---|---|----------|---|
|        |   |   |   |   |   |   | RUNSTDBY |   |
| アクセス種別 | R | R | R | R | R | R | R/W      | R |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0        | 0 |

#### • ビット1 - RUNSTDBY: スタンバイ時走行 (Run in Standby)

このビットは例えシステムによって未使用の時でも全ての動作形態でこの発振器を強制します。スタンバイ休止動作形態に於いて、これは発振器始動時間を待つことなく直ちに起き上がることを保証するのに使うことができます。

周辺機能によって要求されない時は発振器出力が全く提供されません。

要求後にクロック開閉部を開くのに4発振器周期かかりますが、このビットが設定(1)されると、発振器アナログ始動時間が除去されます。

# 10.5.9. XOSC32KCTRLA - 32.768kHzクリスタル用発振器制御A(32.768kHz Crystal Oscillator Control A)

名称: XOSC32KCTRLA

**変位**:+\$1C リセット:\$00

特質:構成設定変更保護

供給元選択(SEL)とクリスタル始動時間(CSUT)のビットは許可(ENABLE)ビットが設定(1)される、または主クロック状態(CLKCTRL.MCLKST ATUS)レジスタの32.768kHzクリスタル用発振器状態安定(XOSC32KS)ビットが'1'である限り、変更することができません。

設定を安全に変更するには、ENABLEビットに'0'を書き、新設定でXOSC32Kを許可する前に、XOSC32KSが'0'になるまで待ってください。

| ピット    | 7 | 6 | 5   | 4     | 3 | 2   | 1        | 0      |
|--------|---|---|-----|-------|---|-----|----------|--------|
|        |   |   | CSU | JT1,0 |   | SEL | RUNSTDBY | ENABLE |
| アクセス種別 | R | R | R/W | R/W   | R | R/W | R/W      | R/W    |
| リセット値  | 0 | 0 | 0   | 0     | 0 | 0   | 0        | 0      |

#### ● ビット5,4 - CSUT1,0: クリスタル始動時間 (Crystal Start-Up Time)

このビット領域は32.768kHzクリスタル用発振器(XOSC32K)に対する始動時間を選びます。この発振器が許可される(ENABLE=1の)時に書き込み保護にされます。

供給元選択(SEL)=1の場合、始動時間は適用されません。

| 値  | 0 0  | 0 1   | 1 0   | 11    |
|----|------|-------|-------|-------|
| 名称 | 1K   | 16K   | 32K   | 64K   |
| 説明 | 1K周期 | 16K周期 | 32K周期 | 64K周期 |

#### ● ビット2 - SEL: 供給元選択 (Source Select)

このビットは外部供給元形式を選びます。この発振器が許可される(ENABLE=1の)時に書き込み保護にされます。

| 値  | 0       | 1               |
|----|---------|-----------------|
| 説明 | 外部クリスタル | TOSC1ピンでの外部クロック |

# ● ビット1 - RUNSTDBY: スタンバイ時走行(Run in Standby)

このビットは例えENABLEビットが設定(1)されている場合にシステムによって未使用の時でも、全ての動作形態でこの発振器を強制します。スタンバイ休止動作形態に於いてこれは発振器始動時間を待つことなく直ちに起き上がることを保証するのに使うことができます。このビットが゙0゚の時に、クリスタル用発振器はENABLEビットが設定(1)されて、要求された時にだけ走行します。

1つ以上の周辺機能によって要求されない限り、XOSC32Kの出力は他の周辺機能に全く送られません。

RUNSTDBYピットが設定(1)されると、この発振器出力を受け取るまでに、初期クリスタル始動時間が既に完了されていれば、要求した後で2から3のクリスタル用発振器周期の遅延だけがあります。

RUNSTDBYビットに応じて、この発振器はデバイスが活動、アイドルまたはスタンバイの休止動作形態、または要求された時にだけ許可される場合、全ての時間で活性(ON)にされます。

このビットはこの発振器のどんな意図せぬ許可も防ぐためにI/O保護されます。

#### ● ビット0 - ENABLE:許可 (Enable)

このビットが'1'を書かれると、TOSC1とTOSC2に対する各々の入力ピンの構成設定が無効にされます。また、供給元選択(SEL)とクリス タル始動時間(CSUT)のビットは読み込み専用になります。

このビットはこの発振器のどんな意図せぬ許可も防ぐためにI/O保護されます。

# 11. SLPCTRL - 休止制御器

#### 11.1. 特徴

- ・消費電力と機能を調整するための電力管理
- ・3つの休止動作形態
  - アイドル
  - スタンバイ
  - ハ<sup>°</sup>ワータ゛ウン
- ・周辺機能をONまたはOFFとして構成設定できる、構成設定可能なスタンバイ動作

## 11.2. 概要

休止動作は節電のためにデバイス内の周辺機能とクロック領域を停止するのに使われます。休止制御器(SLPCTRL)は活動動作と休止動作間の移行を制御して処理します。

ソフトウェアが実行される1つの活動動作と3つの休止動作で利用可能な合計4つの動作形態があります。利用可能な休止動作形態はアイト・ル、スタンハイ、パワーダウンです。

全ての休止動作は活動動作から移行することができます。活動動作ではCPUが応用コードを実行しています。デバイスが休止動作形態へ移行すると、プログラム実行が停止されます。応用コードはどの休止動作に移行するかとその時を決めます。

休止からデバイスを起き上がらせるのに割り込みが使われます。利用可能な割り込み起動元は構成設定された休止動作形態に依存します。割り込みが起こると、デバイスが起き上がり、SLEEP命令の後の最初の命令から通常のプログラム実行を続ける前に、割り込み処理ルーチンを実行します。どのリセットもデバイスを休止動作形態の外へ連れ出します。

レシ、スタファイル、SRAM、レシ、スタの内容は休止の間、保持されます。休止中にリセットが起きた場合、デバイスはリセットして開始し、リセット ベクタから実行します。

#### 11.2.1. 構成図



#### 11.3. 機能的な説明

# 11.3.1. 初期化

デバイスを休止動作形態に置くには以下のこれらの手順に従ってください。

1. 休止からデバイスを起き上がらせることができる割り込みを構成設定して許可してください。全体割り込みも許可してください。

☆警告 休止へ行く時に許可された割り込みが全くない場合、デバイスは再び起き上がることができません。リセットだけがデバイスに動作の継続を許します。

2. 制御A(SLPCTRL.CTRLA)レジスタの休止動作形態(SMODE)ビット領域と休止許可(SEN)ビットを書くことによって、移行する休止動作を選んで休止制御器を許可してください。

デバイスを休止にするにはSLEEP命令が実行されなければなりません。

#### 11.3.2. 動作

#### 11.3.2.1. 休止動作

活動動作に加えて、消費電力と機能を減らした3つの異なる休止動作形態があります。

74い CPUはコート、実行を停止します。禁止される周辺機能はなく、全ての割り込み元はデバイスを起こすことができます。

**スタンバイ** 使用者は各々のスタンハイ時走行(RUNSTDBY)ビットを使って許可されるべき、またはされないべき周辺機能を構成設定することができます。これは消費電力が何の機能が許可されるかに高く依存し、故にアイドルとパワーダウンの基準間で変わるかも、しれません

A/D変換器(ADC)単位部に対して休止歩行が利用可能です。

パプーダウン 低電圧検出器(BOD)、ウォッチト、ック、タイマ(WDT)、(RTC周辺機能内の)周期的割り込み計時器(PIT)だけが活性です。起き上がり供給元はピン変化割り込み、PTT、VLM、TWIアトレス一致、CCLだけです。

表11-1. 周辺機能に対する休止動作活動概要

| 周辺機能                  |      | 休止動作で活動 |                                    |
|-----------------------|------|---------|------------------------------------|
| 同 <b>少</b> 機能<br>     | アイドル | スタンバイ   | ハ <sup>°</sup> ワータ <sup>゛</sup> ウン |
| CPU                   | ×    | ×       | ×                                  |
| RTC                   | 0    | 〇 (注1)  | ○ (注2)                             |
| WDT, BOD, EVSYS       | 0    | 0       | 0                                  |
| CCL、ACn、ADCn/PTC、TCBn | 0    | 〇 (注1)  | ×                                  |
| 他の全ての周辺機能             | 0    | ×       | ×                                  |

注1:活動状態に入るには対応する周辺機能のスタンバイ時走行(RUNSTDBY)ビットを設定(1)してください。

注2: PITのみ。

# 表11-2. クロック元に対する休止動作活動概要

| クロック元                      |      | 休止動作で活動 |                                    |
|----------------------------|------|---------|------------------------------------|
| グロググプし                     | アイドル | スタンバイ   | ハ <sup>°</sup> ワータ <sup>゛</sup> ウン |
| 主クロック元                     | 0    | 〇 (注1)  | ×                                  |
| RTCクロック元                   | 0    | 〇 (注1)  | ○ (注2)                             |
| WDT発振器、BOD発振器( <b>注3</b> ) | 0    | 0       | 0                                  |
| CCLクロック元                   | 0    | 〇 (注1)  | ×                                  |
| TCDクロック元                   | 0    | ×       | ×                                  |

注1:活動状態に入るには対応する周辺機能のスタンバイ時走行(RUNSTDBY)ビットを設定(1)してください。

注2: PITのみ。

注3: BOD発振器は採取動作でだけ動きます。

# 表11-3. 休止動作起こし元

| 松口 0. 下正切下起この2            |       |         |                                    |
|---------------------------|-------|---------|------------------------------------|
| 起こし元                      |       | 休止動作で活動 |                                    |
| 性にした                      | アイト・ル | スタンバイ   | ハ <sup>°</sup> ワータ <sup>*</sup> ウン |
| PORTピン割り込み                | 0     | 0       | 〇 (注1)                             |
| TWIアドレス一致割り込み、BOD VLM割り込み | 0     | 0       | 0                                  |
| RTC割り込み                   | 0     | ○ (注2)  | ○ (注3)                             |
| TCBn割り込み、ADCn/PTC割り込み     | 0     | ○ (注2)  | ×                                  |
| ACn割り込み                   | 0     | ○ (注4)  | ×                                  |
| USARTフレーム開始割り込み           | ×     | 0       | ×                                  |
| 他の全ての割り込み                 | 0     | ×       | ×                                  |

注1:「PORT」章の「非同期感知ピン特性」に従って入出力ピンを構成設定してください。

注2: 活動状態に入るには対応する周辺機能のスタンバイ時走行(RUNSTDBY)ビットを設定(1)してください。

注3: PITのみ。

注4: RUNSTDBYビットが設定(1)されると、ACは状態レジスタの更新や割り込みの起動なしで動きます。別の周辺機能がCLK\_PERを要求した場合、ACは状態レジスタを更新するのと割り込みを起動するのにこのクロックを使います。

#### 11.3.2.2. 起き上がり時間

このデバイスに対する標準起き上がり時間は6主クロック周期(CLK\_PER)と加えて主クロック元が始動するのにかかる時間です。

- ・アイドル動作では追加の起き上がり時間をなくすために主クロック元が走行を保ちます。
- ・スタンバイ動作では主クロックが走行するかもしれず、故に周辺機能構成設定に依存します。
- ・パワーダウン動作では、低電圧検出器(BOD)またはウォッチトック タイマ(WDT)によって使われる場合に、内部32.768kHz低電力発振器と実時間計数器(RTC)クロックだけが走行するかもしれません。

各種クロック元に対する始動時間はクロック制御器(CLKCTRL)章で記述されます。

標準起き上がり時間に加えて、コードを実行するのに先立ってBODが準備を整えるまでデバイスを待たせることが可能です。これはBOD構成設定(FUSE.BODCFG)ヒュースで活動とアイドルでのBOD動作形態(ACTIVE)ヒットに、11、を書くことによって行われます。標準起き上がり時間の前にBODが準備を整える場合、最終的な起き上がり時間は同じです。BODが標準起き上がり時間よりも長くかかる場合、起き上がり時間はBODが準備を整えるまで延長されます。これはいつコードが実行されようとも正しい供給電圧を保証します。

| 表11-4. 休山 | 表11-4. 休止動作と始動時間 |  |  |  |  |  |  |
|-----------|------------------|--|--|--|--|--|--|
| 休止動作 始動時間 |                  |  |  |  |  |  |  |
| アイドル      | 6 CLK            |  |  |  |  |  |  |
| スタンバイ     | 6 CLK + OSC始動時間  |  |  |  |  |  |  |
| ハ。ワータ・ウン  | 6 CLK + OSC始動時間  |  |  |  |  |  |  |

## 11.3.3. デバッグ操作

走行時のデバッグ間、この周辺機能は標準動作を続けます。SLPCTRLはデバッグ操作の中断によってのみ影響を及ぼされます。中断が起きた時にSLPCTRLが休止動作形態の場合、例え保留割り込み要求が全くなくても、デバイスは起き上がってSLPCTRLは活動動作になります。

周辺機能が割り込みまたは同様のものを通してCPUによる定期的な助けを必要とするように構成設定された場合、停止したデバックでの間に不適切な動作やデータ損失の可能性があります。

# 11.4. レジスタ要約

| 変位    | 略称    | ピット位置 | ピット7 | ピット6 | ピット5 | ピット4 | ピット3 | ピット2 | ピット1  | ピット0 |
|-------|-------|-------|------|------|------|------|------|------|-------|------|
| +\$00 | CTRLA | 7~0   |      |      |      |      |      | SMOI | DE1,0 | SEN  |

# 11.5. レジスタ説明

# **11.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位:+\$00 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2    | 1     | 0   |
|--------|---|---|---|---|---|------|-------|-----|
|        |   |   |   |   |   | SMOI | DE1,0 | SEN |
| アクセス種別 | R | R | R | R | R | R/W  | R/W   | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0    | 0     | 0   |

# ● ビット2,1 - SMODE1,0 : 休止動作形態 (Sleep Mode)

これらのビット書き込みは休止許可(SEN)ビットが'1'を書かれ、SLEEP命令が実行される時に移行される休止動作形態を選びます。

| 値  | 0 0        | 0 1         | 1 0          | 11   |
|----|------------|-------------|--------------|------|
| 名称 | IDLE       | STANDBY     | PDOWN        | -    |
| 説明 | アイドル休止動作許可 | スタンバイ休止動作許可 | パプーダウン休止動作許可 | (予約) |

# ● ビット0 - SEN: 休止許可 (Sleep Enable)

選択された休止動作にMCUを移行するためにSLEEP命令が実行される前に、このビットは'1'を書かれなけばなりません。

# 12. RSTCTRL - リセット制御器

# 12.1. 特徴

- ・デバイスをリセット後の初期状態に復帰
- ・直前のリセット元を識別
- 電源リセット元:
  - 電源ONリセット(POR)
  - 低電圧検出器(BOD) リセット
- ・使用者リセット元
  - 外部リセット(RESET)
  - ウォッチット・ック タイマ(WDT) リセット
  - ソフトウェア リセット(SWRST)
  - 統一プログラム/デ・バック インターフェース(UPDI) リセット

## 12.2. 概要

リセット制御器(RSTCTRL)はデバイスのリセットを管理します。これはデバイスにリセットを発行し、デバイスをその初期状態に設定し、そしてソフトウェアによる識別をリセット元に許します。

#### 12.2.1. 構成図



# 12.2.2. 信号説明

| 信号   | Ļ | 形式     | 説明            |
|------|---|--------|---------------|
| RESE | T | デジタル入力 | 外部リセット(Low活性) |

# 12.3. 機能的な説明

## 12.3.1. 初期化

RSTCTRLは常に許可されますが、リセット元のいくつかはそれらがリセットを要求し得る前に(ヒュース'またはソフトウェアのどちらかによって)許可されなければなりません。

ヒュース、または識票列から自動的に設定されるデバイスのレジスタが更新されます。どの供給元からのリセット後も、プログラム カクンタは\$0000に設定されます。

#### 12.3.2. 動作

# 12.3.2.1. リセット元

どれかのリセット後、リセットを起こした供給元はリセット フラグ(RSTCTRL.RSTFR)レジスタで見つかります。ソフトウェア応用でこのレジスタを読むことによって直前のリセット元を識別することができます。

供給元に基づいて次のように2つのリセット形式があります。

- 電源リセット元:
  - 電源ONリセット (POR)
  - 低電圧検出器 (BOD) リセット
- ・使用者リセット元:
  - 外部リセット (RESET)
  - ウォッチト`ック` タイマ (WDT) リセット
  - ソフトウェア リセット (SWRST)
  - 統一プログラム/デ・バッグ インターフェース (UPDI) リセット

#### 12.3.2.1.1. 電源ONリセット(POR)

電源ONリセット(POR)の目的は論理回路とメモリの安全な始動を保証することです。PORは電圧水準が充分高くなるまでデバイスをリセットに保ちます。PORはチップ上の検出回路によって生成されます。PORは常に許可され、VDDが閾値電圧未満の時に活性にされます。





#### 12.3.2.1.2. 低電圧検出器 (BOD) リセット

低電圧検出器(BOD)回路はそれを一定の起動水準と比較することによって動作中にVDD水準を監視します。BODに対する起動水準はヒューズによって選ぶことができます。BODが応用で使われない場合、内部リセットとチップ消去の間の安全な動作を保証するため、最小水準を強制されます。



#### 12.3.2.1.3. ソフトウェア リセット

ソフトウェア リセットはソフトウェアからシステム リセットを発行することを可能にします。ソフトウェア リセット レジスタ(RSTCTRL.SWRR)のソフトウェア リセット許可(SWRST)ビットへの'1'書き込みがリセットを生成します。

ビットが書かれた後にリセットが直ちに起こり、リセット手順が完了されるまでデバイスはリセットを保ちます。

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

外部リセットはヒュース、によって許可されます。システム構成設定の(FUS E.SYSCFG0)ヒュース、のリセット ピン構成設定(RSTPINCFG)ビット領域をご覧ください。

許可されると、外部リセットはRESETt°ンがLowである限り、リセットを要求します。デバイスはRESETが再びHighになるまでリセットに留まります。UPDIとBOD構成設定を除き、外部リセットで全ての論理回路がリセットされます。リセットが解放された後に全てのヒュースが再設定されます。



#### 12.3.2.1.5. ウォッチト ック タイマ (WDT) リセット

ウォッチト、ック、タイマ(WDT)はプログラムの動作を監視するシステム機能です。ソフトウェアが設定された制限時間期間に従ってWDTを処理しなければ、ウォッチト、ック、リセットが発行されます。「WDT - ウォッチト、ック、タイマ」章でより多くの詳細を見つけてください。

#### 12.3.2.1.6. 統一プログラム/デバッグ インターフェース (UPDI) リセット

統一プログラム/デ・バッグ・インターフェース(UPDI)は外部的なプログラミングとデ・バッグを行う間にデ・バイスをリセットするのに使われる独立したリセット元を含みます。このリセット元は外部のデ・バッガと書き込み器からだけアクセス可能です。「UPDI - 統一プログラム/デ・バッグ・インターフェース」章でより多くの詳細を見つけてください。

#### 12.3.2.1.7. リセットによって影響を及ぼされる領域

以下の論理回路領域が様々なリセットによって影響を及ぼされます。

表12-1. 様々なリセットによって影響を及ぼされる論理回路領域

| 以下 1. ボマスケン 11-05 フマが自己人15 C 17 0 0 mm - 1 口面 快 - 3 |     |     |             |        |         |          |  |  |  |  |  |
|-----------------------------------------------------|-----|-----|-------------|--------|---------|----------|--|--|--|--|--|
| リセット形式                                              | POR | BOD | ソフトウェア リセット | 外部リセット | WDTリセット | UPDIリセット |  |  |  |  |  |
| ヒューズ再設定                                             | 0   | 0   | 0           | 0      | 0       | 0        |  |  |  |  |  |
| TCDピン上書き機能利用可                                       | ×   | 0   | 0           | 0      | 0       | 0        |  |  |  |  |  |
| TCDピン上書き設定のリセット                                     | 0   | ×   | ×           | ×      | ×       | ×        |  |  |  |  |  |
| BOD構成設定のリセット                                        | 0   | ×   | ×           | ×      | ×       | ×        |  |  |  |  |  |
| UPDIのリセット                                           | 0   | 0   | ×           | ×      | ×       | ×        |  |  |  |  |  |
| 他の揮発性論理回路のリセット                                      | 0   | 0   | 0           | 0      | 0       | 0        |  |  |  |  |  |

#### 12.3.2.2. リセット時間

リセット時間は2つの部分に分けることができます。

最初の部分はリセット元のどれかが活性の時です。この部分はリセット元の入力に依存します。外部リセットはRESET ピンがLowである限り活性です。電源ONリセット(POR)と低電圧リセット(BOD)は供給電圧がリセット元閾値未満の時に活性です。

2つ目の部分は全てのリセット元が解放される時で、デバイスの内部リセット初期化が行われます。電源リセット元がリセットを引き起こした場合、この時間はシステム構成設定1(FUSE.SYSCFG1)ヒューズの始動時間(SUT)ピット領域設定によって与えられる始動時間で増されます。内部リセット初期化時間は巡回冗長検査メモリ走査(CRCSCAN)が始動で動くように構成設定される場合にも増やされます。この構成設定はシステム構成設定0(FUSE.SYSCFG0)ヒューズのCRC元(CRCSRC)ビット領域で変更することができます。

#### 12.3.3. 休止形態動作

RSTCTRLは活動動作と全ての休止動作で動作します。

#### 12.3.4. 構成設定変更保護

この周辺機能は構成設定変更保護(CCP)下にあるレジスタを持ちます。これらへ書くには最初に構成設定変更保護(CPU.CCP)レジスタ へ与えられた鍵が書かれ、4 CPU命令以内に保護されたビットへの書き込みアクセスが後続しなければなりません。

適切なCCP解錠手順に従わずに保護されたレジスタ~書こうとすると、それを無変化のままにします。

右のレシブスタがCCP下です。

表12-2. RSTCTRL - 構成設定変更保護下のレジスタ

| レジスタ         | 鍵種別   |
|--------------|-------|
| RSTCTRL.SWRR | IOREG |

# 12.4. レジスタ要約

| 変位    | 略称    | ピット位置 | ヒ゛ットフ | ピット6 | ピット5   | ピット4 | ピット3 | ピット2  | ヒ゛ット1 | ピット0 |
|-------|-------|-------|-------|------|--------|------|------|-------|-------|------|
| +\$00 | RSTFR | 7~0   |       |      | UPDIRF | SWRF | WDRF | EXTRF | BORF  | PORF |
| +\$01 | SWRR  | 7~0   |       |      |        |      |      |       |       | SWRE |

# 12.5. レジスタ説明

12.5.1. RSTFR - リセット フラク・レシ スタ (Reset Flag Register)

名称: RSTFR 変位: +\$00

リセット: '00xx xxxx'

特質:-

全てのフラグはそれらへ'1'を書くことによって解除(0)されます。それらは電源ONリセット フラグ(PORF)の例外を除いて、電源ONリセット (POR)によっても解除(0)されます。

| ピット    | 7 | 6 | 5      | 4    | 3    | 2     | 1    | 0    |
|--------|---|---|--------|------|------|-------|------|------|
|        |   |   | UPDIRF | SWRF | WDRF | EXTRF | BORF | PORF |
| アクセス種別 | R | R | R/W    | R/W  | R/W  | R/W   | R/W  | R/W  |
| リセット値  | 0 | 0 | X      | X    | X    | X     | X    | X    |

ビット5 - UPDIRF: UPDIリセット フラク (UPDI Reset Flag)
 このビットはUPDIリセットが起きた場合に設定(1)されます。

• ビット4 - SWRF: ソフトウェア リセット フラケ (Software Reset Flag) このビットはソフトウェア リセットが起きた場合に設定(1)されます。

● **ビット3 - WDRF**: ウォッチドッグ リセット フラグ(Watchdog Reset Flag) このビットはウォッチドッグ リセットが起きた場合に設定(1)されます。

ビット2 - EXTRF:外部リセット フラク\*(External Reset Flag)
 このビットは外部リセットが起きた場合に設定(1)されます。

ビット1 - BORF: 低電圧検出リセット フラク (Brownout Reset Flag)
 このビットは低電圧検出リセットが起きた場合に設定(1)されます。

• **ビット0 - PORF**: **電源ONJセット フラグ** (Power-On Reset Flag) このビットはPORJセットが起きた場合に設定(1)されます。

POR後、POR7ラグだけが設定(1)され、他の全てのフラグは解除(0)されます。POR後に完全なシステム起動が走行する前に他のフラグは全く設定(1)され得ません。

12.5.2. SWRR - ソフトウェア リセット レシ スタ (Software Reset Register)

名称: SWRR 変位:+\$01 リセット: \$00

特質:構成設定変更保護

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|--------|---|---|---|---|---|---|---|------|
|        |   |   |   |   |   |   |   | SWRE |
| アクセス種別 | R | R | R | R | R | R | R | R/W  |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    |

ビット0 - SWRE: ソフトウェア リセット許可 (Software Reset Enable)

このビットが'1'を書かかれると、ソフトウェア リセットが起こります。

このビットは常に'0'として読みます。

# 13. CPUINT - CPU割り込み制御器

#### 13.1. 特徴

- ・短くて予測可能な割り込み応答時間
- ・各割り込みに対する独立した構成設定とベクタ アドレス
- ・段位とベクタ アドレスによる割り込み優先順位付け
- ・2つの割り込み優先段位:0(標準)と1(高)
  - 割り込み要求の1つを優先段位1割り込みとして割り当て可能
  - 優先段位0割り込みに対する任意選択のラウンドロビン優先機構
- ・ 重要な機能用の遮蔽不可割り込み(NMI:Non-Maskable Interrupt)
- ・応用領域またはブートローダ領域に任意選択で配置される割り込みへりタ
- ・選択可能な簡潔ベクタ表(CVT)

# 13.2. 概要

割り込み要求は周辺機能内側の状態の変化を合図し、プログラム実行を変えるのに使うことができます。周辺機能は1つ以上の割り込みを持ちます。全てが個別に許可されて構成設定されます。

割り込みが許可されて構成設定されると、割り込み条件が発生する時に割り込み要求を生成します。

CPU割り込み制御器(CPUINT)は割り込み要求を優先順位付けして処理します。割り込みが許可されて割り込み条件が起こると、CPUINTはその割り込み要求を受け取ります。その割り込みの優先段位と何れかの進行中の割り込みの優先段位に基づいて、割り込み要求は応答されるか、またはそれが優先権を持つまで保留を保たれるかのどちらかです。割り込み処理部から戻った後、プログラム実行は割り込みが起きた前の場所から続け、どの保留割り込みも1つの命令が実行された後に扱われます。

CPUINTは重要な機能に対するNMI、1つの選択可能な高優先権割り込み、標準優先権割り込みに対する任意選択のラウント・ロビン計画機構を提供します。ラウント・ロビン計画は一定時間内で全ての割り込みが処理されることを保証します。

## 13.2.1. 構成図



#### 13.3. 機能的な説明

#### 13.3.1. 初期化

割り込みは以下の順で初期化されなければなりません。

- 1. 既定構成設定が適切でない場合はCPUINTを構成設定してください(任意選択)。
  - ベクタの取り扱いは制御A(CPUINT.CTRLA)レジスタの各々(割り込みペクタ選択(IVSEL)と簡潔ベクタ表(CVT))のビットに書くことによって構成設定されます。
  - ラウント・ロヒンによるへ、クタの優先順位付けはCPUINT.CTRLAのラウント・ロヒン優先権許可(LVLORR)ヒットに、1、を書くことによって許可されます。
  - 段位1優先権保持割り込みベクタ(CPUINT.LVL1VEC)レジスタの段位1優先権保持割り込みベクタ(LVL1VEC)に割り込みベクタ番号を書くことによって優先段位1のベクタを選んでください。
- 2. 周辺機能内で割り込み条件を構成設定し、周辺機能の割り込みを許可してください。
- 3. CPUステータス レシ、スタ(CPU.SREG)の全体割り込み許可(I)ビットに'1'を書くことによって全体的な割り込みを許可してください。

#### 13.3.2. 動作

#### 13.3.2.1. 許可、禁止とリセット

割り込みの全体許可はCPUステータスレジ、スタ(CPU.SREG)の全体割り込み許可(I)ビットに'1'を書くことによって行われます。割り込みを全体的に禁止するには、CPU.SREGのビットに'0'を書いてください。

望む割り込み線は周辺機能の割り込み制御([周辺機能名].INTCTRL)レジスタに書くことによって各々の周辺機能でも許可されなければなりません。

割り込み要求フラグは割り込みが実行された後で自動的に解除(0)されません。各々の割り込み要求フラグ(INTFLAGS)レジスタ記述が特定のフラグをどう解除(0)するかの情報を提供します。

## 13.3.2.2. 割り込みべりり位置

割り込みへ、クタ配置は制御A(CPUINT.CTRLA)レシ、スタの割り込みへ、クタ選択(IVSEL)ビットに依存します。可能な位置についてはCPUIN T.CTRLAのIVSEL記述を参照してください。

プログラムが決して割り込み元を許可しなければ、割り込みへつりなけれず、それらの場所に通常のプログラムコートを置くことができます。

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

最小割り込み応答時間は右表で表されます。

スタックにプログラム カウンタが押し込まれた後、割り込み用のプログラム ベクタが実行されます。以下の図をご覧ください。

| 表13-1. 最小割り込み応答時間                        |           |            |  |  |  |  |  |  |  |
|------------------------------------------|-----------|------------|--|--|--|--|--|--|--|
| 進行処理内容 フラッシュ メモリ量>8Kバイト フラッシュ メモリ量≦8Kバイト |           |            |  |  |  |  |  |  |  |
| 進行中の命令終了                                 | 1周期       | 1周期        |  |  |  |  |  |  |  |
| PCをスタックに格納                               | 2周期       | 2周期        |  |  |  |  |  |  |  |
| 割り込み処理部へ飛ぶ                               | 3周期 (JMP) | 2周期 (RJMP) |  |  |  |  |  |  |  |



複数周期命令の実行中に割り込みが起きる場合、次図で示されるように、割り込みが処理される前にこの命令が完了されます。



デバイスが休止動作形態の時に割り込みが起こる場合、次図で示されるように、割り込み実行応答時間は5クロック周期増やされます。 また、応答時間は選んだ休止動作からの始動時間によっても増やされます。



プログラム カウンタの大きさに依存して、割り込み処理ルーチンからの復帰は4~5クロック周期かかります。これらのクロック周期の間、プログラム カウンタがスタックから取り出され、スタック ポインタが増やされます。

注: 8Kバイト以下のフラッシュ メモリを持つデバイスはJMPの代わりにRJMPを使い、2クロック周期だけかかります。

#### 13.3.2.4. 割り込み優先権

全ての割り込みベクタは次表で示されるように、3つの可能な優先段位の1つに割り当てられます。高優先元からの割り込み要求は標準優先元からのどの進行中の割り込み処理部にも割り込みます。高優先割り込み処理部から戻ると、標準優先割り込み処理部の実行が再開します。

#### 表13-2. 割り込み優先段位

| 優先権    | 段位             | 供給元                       |
|--------|----------------|---------------------------|
| 最高     | 遮蔽不可割り込み (NMI) | デバイス依存で静的割り当て             |
| $\sim$ | 段位1(高優先権)      | 1つのペクタが段位1として任意選択で使用者選択可能 |
| 最低     | 段位0 (標準優先権)    | 残りの割り込みベクタ                |

#### 13.3.2.4.1. NMI - 遮蔽不可割り込み

NMIはCPUステータスレジスタ(CPU.SREG)の全体割り込み許可(I)ビット設定に関わらず実行されます。NMIは決してIビットを変えません。他の割り込みがNMI処理部に割り込むことはできません。複数のNMIが同時に要求された場合、優先権は最下位アドレスが最高優先権を持つ割り込みへ、クタアドレスに従った静的優先権です。

どの割り込みが遮蔽不可かはデバイス依存で、構成設定の対象ではありません。遮蔽不可割り込みはそれらが使われ得る前に許可されなければなりません。利用可能なNMI元についてはデバイスの割り込みベクタ配置表を参照してください。

#### 13.3.2.4.2. 高優先割り込み

優先段位1保持割り込みベクタ(CPUINT.LVL1VEC)レジスタに割り込みベクタ番号を書くことによって1つの割り込み要求を段位1(高優先)に割り当てることが可能です。この割り込み要求は他の(標準優先)割り込み要求よりも高い優先権を持ちます。優先段位1割り込みは段位0割り込み処理部に割り込みます。

#### 13.3.2.4.3. 標準優先割り込み

NMI以外の全ての割り込みへうりは既定で優先段位0(標準)に割り当てられます。これらのへうりの1つを高優先へうりとして割り当てることによってこれを覆すかもしれません。デバイスは多くの標準優先へうりを持ち、それらのいくつかが同時に保留中かもしれません。どの保留中標準優先割り込みを先に処理するかを選ぶために静的とラウントロビンの異なる2つの計画機構が利用可能です。

IVECは「周辺機能と基本構造」章で一覧にされるような割り込みへ、クタ割り当てです。以下の項は計画機構を説明するのにIVECを使います。IVEC0はリセットへ、クタ、IVEC1はNMIへ、クタ、以下同様です。n+1要素を持つへ、クタ表では最高へ、クタ番号を持つへ、クタがIVECnと示されます。リセット、遮蔽不可割り込み、それと高段位割り込みはIVEC割り当てに含まれますが、常に標準優先割り込みを超えて優先されます。

#### 13.3.2.4.3.1. 静的計画

いくつかの段位0割り込み要求が同時に保留中の場合、最高優先権を持つ1つが 先行する実行のために計画されます。右図は最低アドレスを持つ割り込みへクタが最 高優先権を持つ既定構成設定を説明します。



# 13.3.2.4.3.2. 変更した静的計画

既定優先権は割り込み優先段位の(CPUINT.LVL0PRI)レシ、スタにへ、クタ番号を書くことによって変更することができます。右図で示されるように、次の割り込みへ、クタがLVL 0割り込み内で最高優先権を持ちます。

ここで、値YはY+1の割り込みへ、クタが最高優先権を持つようにCPUINT.LVL0PRIへ書かれています。この場合、優先権はもはや最低アトレスが最高優先権を持たないように丸めることに注意してください。これは常に最高優先権を持つRESETとNMIを含めません。

利用可能な割り込み要求とそれらの割り込みへ、クタ番号についてはデバイスの「割り込みへ、クタ配置」を参照してください。

#### 

#### 13.3.2.4.3.3. ラウント ロビン計画

静的計画は処理されることからいくつかの割り込み要求を妨げるかもしれません。これを避けるため、CPUINTは標準優先(LVL0)割り込みに対してラウント・ロビン計画を提供します。ラウント・ロビン計画ではCPUINT.LVL0PRIレジスタが最後に応答した割り込みへ、クタ番号を格納します。このレジスタは最後に応答した割り込みへ、クタが最低優先権を持ち、ハート・ウェアによって自動的に更新されます。以下の図はIVEC Y応答後とIVEC Y+1応答後の優先順を説明します。

LVL0割り込み要求に対するラウント・ロヒン計画は制御A(CPUINT.C TRLA)レシ、スタのラウント・ロヒン優先権許可(LVL0RR)ヒットに'1'を書くことによって許可されます。



#### 13.3.2.5. 簡潔ベクタ表

簡潔ベクタ表(CVT)は全ての段位0割り込みが同じベクタ番号を共用することによって簡潔なコード書きを許すための機能です。従って、割り込みは同じ割り込み処理ルーチン(ISR)を共用します。これは割り込み処理部を減らし、それによって応用コードに使うことができるメモ リを開放します

制御A(CPUINT.CTRLA)レシ、スタの簡潔へ、クタ表(CVT)ヒ、ットに、1、を書くことによってCVTが許可されると、ヘ、クタ表は以下のこれら3つの割り込みへ、クタを含みます。

- 1. ベクタ アドレス1の遮蔽不可割り込み(NMI)
- 2. ベクタ アドレス2の優先段位1(LVL1)割り込み
- 3. ベクタ アドレス3の全ての優先段位0(LVL0)割り込み

この機能は限定されたメモリを持つデバイスと少数の割り込み生成部を使う応用に最適です。

# 13.3.3. デバッグ操作

段位1割り込み使用時、段位1優先権を持つ割り込みの繰り返しで応用を立往生させるかもしれないため、割り込み処理ルーチンが正し く構成設定される事を確実にすることが重要です。

CPUINT状態(CPUINT.STATUS)レジスタを読むことにより、応用が正しいRETI(割り込み復帰)命令を実行されているか知ることが可能です。CPUINT.STATUSレジスタは割り込み処理部の最後でRETI命令が実行される時にCPUINTが正しい割り込み段位に戻ることを保証する状態情報を含みます。割り込みからの復帰はCPUINTを割り込みに入る前に持っていた状態に戻します。

#### 13.3.4. 構成設定変更保護

この周辺機能は構成設定変更保護(CCP)下にあるレジスタを持ちます。これらへ書くには最初に構成設定変更保護(CPU.CCP)レジスタへ或る鍵が書かれ、4 CPU命令以内に保護されたビットへの書き込みアクセスが後続しなければなりません。

適切なCCP解錠手順に従わずに保護されたレジスタへ書こうとすると、保護されたレジスタを無変化のままにします。

右のレシブスタがCCP下です。

| 表13-3. CPUINT - 構成設定変更係 | <b>髹護下のレジスタ</b> |
|-------------------------|-----------------|
| レジ、スタ                   | 鍵種別             |
| CPUINT.CTRLAのIVSEL      | IOREG           |
| CPUINT.CTRLAのCVT        | IOREG           |

# 13.4. レジスタ要約

| 変位    | 略称      | ピット位置 | ヒ゛ット7 | ピット6  | ピット5 | じット4  | ピット3   | ピット2 | ピット1   | ピット0   |
|-------|---------|-------|-------|-------|------|-------|--------|------|--------|--------|
| +\$00 | CTRLA   | 7~0   |       | IVSEL | CVT  |       |        |      |        | LVL0RR |
| +\$01 | STATUS  | 7~0   | NMIEX |       |      |       |        |      | LVL1EX | LVL0EX |
| +\$02 | LVL0PRI | 7~0   |       |       |      | LVL0F | PRI7~0 | 1    | 1      |        |
| +\$03 | LVL1VEC | 7~0   |       |       |      | LVL1V | EC7~0  |      |        |        |

# 13.5. レジスタ説明

**13.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位: +\$00 リセット: \$00

特質:構成設定変更保護

| ピット    | 7 | 6     | 5   | 4 | 3 | 2 | 1 | 0      |
|--------|---|-------|-----|---|---|---|---|--------|
|        |   | IVSEL | CVT |   |   |   |   | LVL0RR |
| アクセス種別 | R | R/W   | R/W | R | R | R | R | R/W    |
| リセット値  | 0 | 0     | 0   | 0 | 0 | 0 | 0 | 0      |

● ビット6 - IVSEL: 割り込みベクタ選択 (Interrupt Vector Select)

このビットは構成設定変更保護機構によって保護されます。

| 値  | 0                            | 1                         |
|----|------------------------------|---------------------------|
| 説明 | 割り込みベクタはフラッシュのブート領域の後ろに配置(注) | 割り込みベクタはフラッシュのブート領域の先頭に配置 |

注: フラッシュ メモリ全体がブート領域として構成設定されると、このビットは無視されます。

● ビット5 - CVT: 簡潔ベクタ表 (Compact Vector Table)

このビットは構成設定変更保護機構によって保護されます。

| 値  | 0          | 1          |
|----|------------|------------|
| 説明 | 簡潔ベクタ表機能禁止 | 簡潔ベクタ表機能許可 |

● ビット0 - LVLORR: ラウンドロビン優先権許可 (Round-Robin Priority Enable)

このビットは構成設定変更保護機構によって保護されません。

| 値  | 0                                             | 1                                      |
|----|-----------------------------------------------|----------------------------------------|
| 説明 | 優先権は優先段位0割り込みに対して固定、最下位割り込み要求アドレスが最高優先権を持ちます。 | 優先段位0割り込み要求に対してラウンドロビン優先機<br>構が許可されます。 |

#### 13.5.2. STATUS - 状態 (Status)

名称: STATUS 変位:+\$01 リセット: \$00 特質:-

| ピット    | 7     | 6 | 5 | 4 | 3 | 2 | 1      | 0      |
|--------|-------|---|---|---|---|---|--------|--------|
|        | NMIEX |   |   |   |   |   | LVL1EX | LVL0EX |
| アクセス種別 | R/W   | R | R | R | R | R | R/W    | R/W    |
| リセット値  | 0     | 0 | 0 | 0 | 0 | 0 | 0      | 0      |

● ビット7 - NMIEX: 遮蔽不可割り込み実行中 (Non-Maskable Interrupt Executing)

このフラグは遮蔽不可割り込みが実行中の場合に設定(1)されます。このフラグは割り込み処理部から(RETIで)戻る時に解除(0)されます。

● ビット1 - LVL1EX: 段位1割り込み実行中 (Level 1 Interrupt Executing)

このフラグは優先段位1割り込みが実行中の時か、またはその割り込み処理部がNMIによって割り込まれている時に設定(1)されます。このフラグは割り込み処理部から(RETIで)戻る時に解除(0)されます。

● ビット0 - LVL0EX: 段位0割り込み実行中 (Level 0 Interrupt Executing)

このフラグは優先段位0割り込みが実行中の時か、またはその割り込み処理部が優先段位1割り込みかNMIによって割り込まれている時に設定(1)されます。このフラグは割り込み処理部から(RETIで)戻る時に解除(0)されます。

# 13.5.3. LVLOPRI - 割り込み優先段位0 (Interrupt Priority Level 0)

名称: LVLOPRI 変位:+\$02 リセット: \$00 特質:-

| <u> </u> | 7   | 6   | 5   | 4     | 3      | 2   | 1   | 0   |
|----------|-----|-----|-----|-------|--------|-----|-----|-----|
|          |     |     |     | LVL0I | PRI7~0 |     |     |     |
| アクセス種別   | 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 - LVL0PRI7~0:割り込み優先段位0 (Interrupt Priority Level 0)

このレジスタはLVL0割り込みの優先権を変更するのに使われます。より多くの情報については「標準優先割り込み」項をご覧ください。

# 13.5.4. LVL1VEC - 優先段位1保持割り込みへり (Interrupt Vector with Priority Level 1)

名称: LVL1VEC 変位: +\$03 リセット: \$00 特質:-

| ピット    | 7   | 6          | 5   | 4   | 3   | 2   | 1   | 0   |  |
|--------|-----|------------|-----|-----|-----|-----|-----|-----|--|
|        |     | LVL1VEC7~0 |     |     |     |     |     |     |  |
| アクセス種別 | 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 - LVL1VEC7~0: 優先段位1保持割り込みベクタ (Interrupt Vector with Priority Level 1)

このビット領域は高められた優先段位1(LVL1)を持つ単一ベクタの番号を含みます。このビット領域が\$00の値を持つ場合、ベクタはLVL1を持ちません。その結果として、LVL1割り込みは禁止されます。

# 14. EVSYS - 事象システム

## 14.1. 特徴

- ・周辺機能から周辺機能への直接的な合図のためのシステム
- ・周辺機能は周辺機能事象への直接的な生成、使用、反応が可能
- ・ 短い応答時間
- ・4つの並列非同期事象チャネル利用可能
- ・2つの並列同期事象チャネル利用可能
- ・チャネルは1つの周辺機能活動起動と複数の周辺機能使用部を持つように構成設定可能
- ・周辺機能は他の周辺機能からの事象に対して直接的な起動と反応が可能
- ・事象は殆どの周辺機能とソフトウェアによって送ることや受け取ることが可能
- ・活動動作とスタンバイ休止動作で動作

# 14.2. 概要

事象システム(EVSYS)は周辺機能から周辺機能への直接的な合図を許します。それはCPUを使うことなく、事象チャネルを通して或る周辺機能(事象生成部)での変化で別の周辺機能(事象使用部)での活動を起動することを許します。それは自律の周辺機能制御と相互作用、そして多数の周辺機能単位部での活動の同期タイングをも許す、周辺機能間の短くて予測可能な応答時間を提供するように設計されます。故にそれはソフトウェアの複雑さ、大きさ、実行時間を減らすための強力な道具です。

事象生成部の状態の変化は事象として参照され、通常、周辺機能の割り込み条件の1つに対応します。事象は専用の事象経路網を用いて他の周辺機能へ直接送ることができます。各チャネルの配線は事象生成と使用を含め、ソフトウェアで構成設定されます。

各チャネルでは事象生成部の周辺機能からの1つの起動だけを配線することができますが、同じ生成部の供給元を複数のチャネルが使用できます。複数の周辺機能が同じチャネルからの事象を使うことができます。

チャネル経路は主クロックに対して非同期または同期のどちらかにすることができます。この動作形態は応用の必要条件に基づいて選ばれなければなりません。

事象システムはA/D変換器、アナログ比較器、入出力ポート ピン、実時間計数器、タイマ/カウンタ、構成設定可能な注文論理回路周辺機能を直接的に接続することができます。事象はソフトウェアと周辺機能クロックから生成することもできます。

#### 14.2.1. 構成図





- 注: 1. 事象を支援する周辺機能の概要についてはデバイスの構成図を参照してください。
  - 2. 事象生成部の一覧についてはチャネルn生成部選択レシ、スタ(EVSYS.SYNCCHnとEVSYS.ASYNCCHn)を参照してください。
  - 3. 事象使用部の一覧については使用部チャネル入力選択nレジスタ(EVSYS.SYNCUSERnとEVSYS.ASYNCUSERn)を参照してください。

#### 14.2.2. 信号説明

#### 内部事象信号

事象信号は主クロック(CLK\_MAIN)に対して同期または非同期のどちらかで発生することができます。

元となる事象に依存して、事象信号は1クロック周期の持続時間を持つパルスカン、または(状態フラグと同様な)レベル信号になり得ます。

| 信号       | 形式     | 説明   |
|----------|--------|------|
| EVOUT2~0 | デジタル出力 | 事象出力 |

#### 14.2.3. システム依存性

この周辺機能を使うには、右で記述されるように、システムの他の部分が正しく構成設定されなければなりません。

| 表14-1. EVSYS | らシステム依存り | 生       |  |  |  |  |  |  |  |
|--------------|----------|---------|--|--|--|--|--|--|--|
| 依存性 適用性 周辺機能 |          |         |  |  |  |  |  |  |  |
| クロック         | 0        | CLKCTRL |  |  |  |  |  |  |  |
| I/O線と接続      | 0        | PORTMUX |  |  |  |  |  |  |  |
| 割り込み         | ×        | _       |  |  |  |  |  |  |  |
| 事象           | 0        | EVSYS   |  |  |  |  |  |  |  |
| デバッグ         | 0        | UPDI    |  |  |  |  |  |  |  |

#### 14.2.3.1. クロック

EVSYSはI/Oレジスタと発動信号のために周辺機能クロックを使います。正しく構成設定されると、配線網はどのクロックもなしに休止動作形態でも使うことができます。ソフトウェア事象は周辺機能クロックが停止される休止動作では動作しません。

#### 14.2.3.2. I/O線

EVSYSはピンで3つの事象チャネルを非同期に出力することができます。この出力信号はEVOUT2~0と呼ばれます。

- 1. 非同期使用部チャネル入力選択(EVSYS.ASYNCUSER10、EVSYS.ASYNCUSER9、EVSYS.ASYNCUSER8)レジスタの各々を書くことによってどのEVOUTnにどの事象チャネル(SYNCCH1~0またはASYNCCH3~0の1つ)が出力されるかを構成設定してください。
- 2. 任意選択: PORT周辺機能を用いてピン特性を構成設定してください。
- 3. ポート多重化(PORTMUX)周辺機能の制御A(PORTMUX.CTRLA)レジスタの各々の事象出力n(EVOUTn)ビットに'1'を書くことによってピン出力を許可してください。

# 14.3. 機能的な説明

## 14.3.1. 初期化

デバイス内で事象を許可する前に、事象使用部多重器と事象チャネルが構成設定されなければなりません。

#### 14.3.2. 動作

#### 14.3.2.1. 事象使用部多重器構成設定

事象使用部多重器はその事象使用部に対してチャネルを選びます。各事象使用部は1つの専用事象使用部多重器を持ちます。各多 重器は支援される事象チャネル出力に接続され、それらのチャネルの1つを選ぶように構成設定することができます。

非同期事象を支援する事象使用部は同期事象も支援します。同期事象だけを支援する事象使用部もあります。事象使用部多重器は対応するレシ、スタを書くことによって構成設定されます。

- ・同期と非同期の両事象を支援する事象使用部は各々の非同期使用部チャネルn入力選択(EVSYS.ASYNCUSERn)レジスタを書くことによって構成設定されます。
- ・同期事象専用の使用部は各々の同期使用部チャネルn入力選択(EVSYS.SYNCUSERn)レジブスタを書くことによって構成設定されます。

全ての使用部多重器の既定構成設定はOFFです。

#### 14.3.2.2. 事象システム チャネル

事象チャネルは事象生成部の1つに接続することができます。事象チャネルは非同期生成部または同期生成部のどちらかを支援します。 各非同期事象チャネルの供給元は各々の非同期チャネルn入力選択(EVSYS.ASYNCCHn)レジスタを書くことによって構成設定されます。 各同期事象チャネルの供給元は各々の同期チャネルn入力選択(EVSYS.SYNCCHn)レジスタを書くことによって構成設定されます。

#### 14.3.2.3. 事象生成部

各事象チャネルは様々な事象生成部からの事象を受け取ることができます。事象生成の詳細については対応する周辺機能の記述を参照してください。

各事象チャネルに対して、いくつかの可能な事象生成部があり、同時にどれか1つだけを選ぶことができます。事象生成部の起動元は各々のチャネルn生成部選択(EVSYS.ASYNCCHn、EVSYS.SYNCCHn)レジスタを書くことによって各チャネルに対して選択されます。既定では、チャネルがどの事象生成部にも接続されません。

#### 14.3.2.4. ソフトウェア事象

ソフトウェア事象では、1システム クロック周期間現在の値を反転することによって事象チャネルを"ストローフ (パルスで発動)"します。 ソフトウェア事象は適切なチャネル発動レジスタ内の各々の発動ビットに'1'を書くことによってそのチャネル上で起動されます。

- ・非同期チャネルIでのソフトウェア事象は非同期チャネル発動(EVSYS.ASYNCSTROBE)レジスタの非同期発動(ASYNCSTROBE)ルジットに'1' を書くことによって開始されます。
- ・同期チャネルkでのソフトウェア事象は同期チャネル発動(EVSYS.SYNCSTROBE)レジ、スタの同期発動(SYNCSTROBE)kビットに'1'を書くことによって開始されます。

ソフトウェア事象は事象使用部に関して事象生成部の周辺機能によって生成されたそれらと違わず、(上記のように)ビットが'1'を書かれると、各々のチャネルで事象が生成され、事象使用部によって受け取られて処理されます。

#### 14.3.3. 割り込み

該当なし

#### 14.3.4. 休止形態動作

構成設定されると、事象システムは全ての休止動作形態で動作します。1つの例外はシステム クロックを必要とするソフトウェア事象です。

#### 14.3.5. デバッグ動作

この周辺機能はデバッグ動作へ移行することによって影響を及ぼされません。

#### 14.3.6. 同期化

非同期事象は同期化されて適合する事象使用部によって扱われます。非同期事象に適合しない事象使用部の周辺機能は同期事象チャネル対してだけ傾聴するように構成設定することができます。

## 14.3.7. 構成設定変更保護

該当なし

# 14.4. レジスタ要約

| 変位                  | 略称          | ビット位置        | ピット7 | ピット6 | ピット5 | じット4   | ヒ゛ット3   | ピット2    | ピット1    | ピット0    |
|---------------------|-------------|--------------|------|------|------|--------|---------|---------|---------|---------|
| +\$00               | ASYNCSTROBE | 7~0          |      |      |      |        |         | ASYNCST | ROBE3~0 |         |
| +\$01               | SYNCSTROBE  | 7~0          |      |      |      |        |         |         | SYNCST  | ROBE1,0 |
| +\$02               | ASYNCCH0    | 7 <b>~</b> 0 |      |      |      | ASYNC  | CH7~0   |         |         |         |
| +\$03               | ASYNCCH1    | 7 <b>~</b> 0 |      |      |      | ASYNC  | CH7~0   |         | !       |         |
| +\$04               | ASYNCCH2    | 7 <b>~</b> 0 |      |      |      | ASYNC  | CH7~0   | '       |         |         |
| +\$05               | ASYNCCH3    | 7 <b>~</b> 0 |      |      |      | ASYNC  | CH7~0   |         |         |         |
| +\$06<br>           | 予約          |              |      |      |      |        |         |         |         |         |
| +\$0A               | SYNCCH0     | 7 <b>~</b> 0 |      |      |      | SYNC   | CH7∼0   | 1       | 1       |         |
| +\$0B               | SYNCCH1     | 7 <b>~</b> 0 |      |      |      | SYNC   | CH7∼0   |         |         |         |
| +\$0C<br>+\$11      | 予約          |              |      |      |      |        |         |         |         |         |
| +\$12               | ASYNCUSER0  | 7 <b>~</b> 0 |      |      |      | ASYNCU | JSER7∼0 | 1       |         |         |
| ~                   | $\sim$      | ~            |      |      |      |        | <u></u> | !       |         |         |
| +\$1E               | ASYNCUSER12 | 7 <b>~</b> 0 |      |      |      | ASYNCU | JSER7∼0 |         | !       |         |
| +\$1F<br>~<br>+\$21 | 予約          |              |      |      |      |        |         |         |         |         |
| +\$22               | SYNCUSER0   | 7 <b>~</b> 0 |      |      |      | SYNCU  | SER7~0  | ·       |         |         |
| +\$23               | SYNCUSER1   | 7 <b>~</b> 0 |      |      |      | SYNCU  | SER7~0  |         |         |         |

# 14.5. レジスタ説明

# 14.5.1. ASYNCSTROBE - 非同期チャネル発動 (Asynchronous Channel Strobe)

名称: ASYNCSTROBE

変位:+\$00 リセット:\$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3   | 2       | 1       | 0   |
|--------|---|---|---|---|-----|---------|---------|-----|
|        |   |   |   |   |     | ASYNCST | ROBE3~0 |     |
| アクセス種別 | R | R | R | R | R/W | R/W     | R/W     | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0   | 0       | 0       | 0   |

# ● ビット3~0 - ASYNCSTROBE3~0: 非同期チャネル発動 (Asynchronous Channel Strobe)

発動レジスタ位置が、1、を書かれる場合、各事象チャネルは1システム クロック周期間、反転(即ち、単発事象が生成)されます。

# 14.5.2. SYNCSTROBE - 同期チャネル発動 (Synchronous Channel Strobe)

名称: SYNCSTROBE

変位:+\$01 リセット:\$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0       |
|--------|---|---|---|---|---|---|--------|---------|
|        |   |   |   |   |   |   | SYNCST | ROBE1,0 |
| アクセス種別 | R | R | R | R | R | R | R/W    | R/W     |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0      | 0       |

# • ビット1,0 - SYNCSTROBE1,0: 同期チャネル発動 (Synchronous Channel Strobe)

発動レシ、スタ位置が、1、を書かれる場合、各事象チャネルは1システム クロック周期間、反転(即ち、単発事象が生成)されます。

# 14.5.3. ASYNCCHn - 非同期チャネルn発生部選択 (Asynchronous Channel n Generator Selection)

名称: ASYNCCH0: ASYNCCH1: ASYNCCH2: ASYNCCH3

変位:+\$02:+\$03:+\$04::+\$05

リセット:\$00 特質 :-

| ピット    | 7   | 6          | 5   | 4   | 3   | 2   | 1   | 0   |  |
|--------|-----|------------|-----|-----|-----|-----|-----|-----|--|
|        |     | ASYNCCH7~0 |     |     |     |     |     |     |  |
| アクセス種別 | 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 - ASYNCCH7~0: 非同期チャネル生成部選択(Asynchronous Channel Generator Selection)

次頁の表を参照

| 値    | ASYNCCH0   | ASYNCCH1           | ASYNCCH2              | ASYNCCH3    |  |  |
|------|------------|--------------------|-----------------------|-------------|--|--|
| \$00 |            | OI                 |                       |             |  |  |
| \$01 |            | CCL_               |                       |             |  |  |
| \$02 |            | CCL_               | CCL_LUT1              |             |  |  |
| \$03 |            | AC0_               |                       |             |  |  |
| \$04 |            | TCD0_C1            |                       |             |  |  |
| \$05 |            | TCD0_C             |                       |             |  |  |
| \$06 |            | TCD0_C             |                       |             |  |  |
| \$07 |            | TCD0_P             |                       |             |  |  |
| \$08 |            | RTC_               |                       |             |  |  |
| \$09 |            | RTC_               |                       |             |  |  |
| \$0A | PORTA_PIN0 | PORTB_PIN0         | PORTC_PIN0            | PIT_DIV8192 |  |  |
| \$0B | PORTA_PIN1 | PORTB_PIN1         | PORTC_PIN1            | PIT_DIV4096 |  |  |
| \$0C | PORTA_PIN2 | PORTB_PIN2         | PORTC_PIN2            | PIT_DIV2048 |  |  |
| \$0D | PORTA_PIN3 | PORTB_PIN3         | PORTC_PIN3            | PIT_DIV1024 |  |  |
| \$0E | PORTA_PIN4 | PORTB_PIN4         | PORTC_PIN4            | PIT_DIV512  |  |  |
| \$0F | PORTA_PIN5 | PORTB_PIN5         | PORTB_PIN5 PORTC_PIN5 |             |  |  |
| \$10 | PORTA_PIN6 | PORTB_PIN6 AC1_OUT |                       | PIT_DIV128  |  |  |
| \$11 | PORTA_PIN7 | PORTB_PIN7 AC2_OUT |                       | PIT_DIV64   |  |  |
| \$12 | UPDI       | AC1_OUT            | (予約)                  | AC1_OUT     |  |  |
| \$13 | AC1_OUT    | AC2_OUT            | (予約)                  | AC2_OUT     |  |  |
| \$14 | AC2_OUT    | (予約)               | (予約)                  | (予約)        |  |  |
| その他  | (予約)       | (予約)               | (予約)                  | (予約)        |  |  |

注: 少ピン数デバイスで全てのポート ピンが利用可能とは限りません。詳細についてはピン配置図やI/O多重化表を調べてください。

# 14.5.4. SYNCCHn - 同期チャネルn発生部選択 (Synchronous Channel n Generator Selection)

名称: SYNCCH0: SYNCCH1 変位: +\$0A: +\$0B

リセット: \$00 特質:-

| ピット    | 7   | 6   | 5         | 4   | 3   | 2   | 1   | 0   |  |
|--------|-----|-----|-----------|-----|-----|-----|-----|-----|--|
|        |     |     | SYNCCH7~0 |     |     |     |     |     |  |
| アクセス種別 | R/W | R/W | R/W       | R/W | R/W | R/W | R/W | R/W |  |
| リセット値  |     |     |           |     |     |     |     |     |  |

# ● ビット7~0 - SYNCCH7~0: 同期チャネル生成部選択 (Synchronous Channel Generator Selection)

| 値    | SYNCCH0    | SYNCCH1    | 値          | SYNCCH0    | SYNCCH1    |
|------|------------|------------|------------|------------|------------|
| \$00 | OI         | FF         | \$0C       | PORTC_PIN5 | PORTB_PIN4 |
| \$01 | TC         | \$0D       | PORTA_PIN0 | PORTB_PIN5 |            |
| \$02 | TCA0_O\    | /F_LUNF    | \$0E       | PORTA_PIN1 | PORTB_PIN6 |
| \$03 | TCA0_HUNF  |            | \$0F       | PORTA_PIN2 | PORTB_PIN7 |
| \$04 | TCA0_      | CMP0       | \$10       | PORTA_PIN3 | TCB1       |
| \$05 | TCA0_      | CMP1       | \$11       | PORTA_PIN4 |            |
| \$06 | TCA0_CMP2  |            | \$12       | PORTA_PIN5 |            |
| \$07 | PORTC_PIN0 | (予約)       | \$13       | PORTA_PIN6 | (予約)       |
| \$08 | PORTC_PIN1 | PORTB_PIN0 | \$14       | PORTA_PIN7 |            |
| \$09 | PORTC_PIN2 | PORTB_PIN1 | \$15       | TCB1       |            |
| \$0A | PORTC_PIN3 | PORTB_PIN2 | その他        | (3,        | 約)         |
| \$0B | PORTC_PIN4 | PORTB_PIN3 | rC VJ¶E    | (1)        | <i>ዂህ/</i> |

注: 少ピン数デバイスで全てのポート ピンが利用可能とは限りません。詳細についてはピン配置図やI/O多重化表を調べてください。

# 14.5.5. ASYNCUSERn - 非同期使用部チャネルn入力選択 (Asynchronous User Channel n Input Selection)

名称:ASYNCUSER0 : ASYNCUSER1 : ASYNCUSER2 : ASYNCUSER3 : ASYNCUSER4 : ASYNCUSER5 : ASYNCUSER6

: ASYNCUSER7 : ASYNCUSER8 : ASYNCUSER9 : ASYNCUSER10 : ASYNCUSER11 : ASYNCUSER12

**変位**:+\$12~\$1E [\$12+n(n=0~12)]

リセット:\$00 特質 :-

| ピット    | 7   | 6   | 5   | 4      | 3       | 2   | 1   | 0   |
|--------|-----|-----|-----|--------|---------|-----|-----|-----|
|        |     |     |     | ASYNCU | JSER7∼0 |     |     |     |
| アクセス種別 | 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 - ASYNCUSER7~0: 非同期使用部チャネル選択 (Asynchronous User Channel Selection)

| レジスタ名 | ASYNCUSER0   | AS  | YNCUSER1  | ASYNCU  | JSER2 | ASYNCUSE    | ER3 | ASYNCUSER4 | ASYNCUSER5    |
|-------|--------------|-----|-----------|---------|-------|-------------|-----|------------|---------------|
| 使用部   | TCB0         |     | ADC0      | CCL_LU  | Γ0ΕV0 | CCL_LUT1EV0 |     | CCL_LUT0EV | CCL_LUT1EV1   |
| 説明    | タイマ/カウンタB 0  |     | ADC 0     | CCL LUT | 0事象0  | CCL LUT1事   | 事象0 | CCL LUT0事象 | 1 CCL LUT1事象1 |
| レジスタ名 | ASYNCUSER6   | 3   | ASYNCU    | JSER7   | ASY   | NCUSER8     | A   | SYNCUSER9  | ASYNCUSER10   |
| 使用部   | TCD0事象0      |     | TCD0事象1   |         | E'    | VOUT0       |     | EVOUT1     | EVOUT2        |
| 説明    | タイマ/カウンタD 0事 | 象0  | タイマ/カウンタ] | 0 事象1   | 事     | 象出力0        |     | 事象出力1      | 事象出力2         |
| レジスタ名 | ASYNCUSER11  | ASY | NCUSER12  |         |       |             |     |            |               |
| 使用部   | TCB1         |     | ADC1      |         |       |             |     | _          |               |
| 説明    | タイマ/カウンタB 1  |     | ADC 1     |         |       |             |     |            |               |

| 値  | \$00 | \$01    | \$02    | <b>\$</b> 03 | \$04     | \$05     | \$06     | その他  |
|----|------|---------|---------|--------------|----------|----------|----------|------|
| 説明 | OFF  | SYNCCH0 | SYNCCH1 | ASYNCCH0     | ASYNCCH1 | ASYNCCH2 | ASYNCCH3 | (予約) |

# 14.5.6. SYNCUSERn - 同期使用部チャネルn入力選択 (Synchronous User Channel n Input Selection)

名称:SYNCUSER0:SYNCUSER1

**変位**:+\$22 :+\$23

リセット: \$00 特質:-

| <u> </u> | 7   | 6   | 5   | 4     | 3      | 2   | 1   | 0   |
|----------|-----|-----|-----|-------|--------|-----|-----|-----|
|          |     |     |     | SYNCU | SER7~0 |     |     |     |
| アクセス種別   | 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 - SYNCUSER7~0: 同期使用部チャネル選択 (Synchronous User Channel Selection)

| レジスタ名 | SYNCUSER0   | SYNCUSER1 |
|-------|-------------|-----------|
| 使用部   | TCA0        | USART0    |
| 説明    | タイマ/カウンタA 0 | USART 0   |

| 値  | \$00 | \$01    | \$02    | その他  |
|----|------|---------|---------|------|
| 説明 | OFF  | SYNCCH0 | SYNCCH1 | (予約) |

# 15. PORTMUX - ポート多重器

# 15.1. 概要

ポート多重器(PORTMUX)はピンの機能を許可または禁止、または既定と代替のピン位置の変更のどちらも行うことができます。これは実際のピンと特性に依存し、PORTMUXレジスタ配置の詳細で記述されます。

利用可能な機能については表5-1.を参照してください。

# 15.2. レジスタ要約

| 変位    | 略称    | ピット位置 | ヒ゛ット7 | ヒ゛ット6 | ピット5  | ピット4  | ピット3  | ピット2   | ピット1   | ピット0   |
|-------|-------|-------|-------|-------|-------|-------|-------|--------|--------|--------|
| +\$00 | CTRLA | 7~0   |       |       | LUT1  | LUT0  |       | EVOUT2 | EVOUT1 | EVOUT0 |
| +\$01 | CTRLB | 7~0   |       |       |       | TWI0  |       | SPI0   |        | USART0 |
| +\$02 | CTRLC | 7~0   |       |       | TCA05 | TCA04 | TCA03 | TCA02  | TCA01  | TCA00  |
| +\$03 | CTRLD | 7~0   |       |       |       |       |       |        | TCB1   | TCB0   |

# 15.3. レジスタ説明

**15.3.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位:+\$00 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5    | 4    | 3 | 2      | 1      | 0      |
|--------|---|---|------|------|---|--------|--------|--------|
|        |   |   | LUT1 | LUT0 |   | EVOUT2 | EVOUT1 | EVOUT0 |
| アクセス種別 | R | R | R/W  | R/W  | R | R/W    | R/W    | R/W    |
| リセット値  | 0 | 0 | 0    | 0    | 0 | 0      | 0      | 0      |

● ビット5 - LUT1: CCL LUT1出力代替 (CCL LUT 1 output)

構成設定可能な注文論理回路(CCL)の参照表(LUT)1に対して代替ピン位置を選ぶにはこのビットに'1'を書いてください。

● ビット4 - LUT0: CCL LUT0出力代替(CCL LUT 0 output)

CCLのLUT0に対して代替ピン位置を選ぶにはこのビットに'1'を書いてください。

● ビット2 - EVOUT2: 事象出力2許可 (Event Output 2)

事象出力2を許可するにはこのビットに'1'を書いてください。

● ビット1 - EVOUT1: 事象出力1許可(Event Output 1)

事象出力1を許可するにはこのビットに'1'を書いてください。

● ビット0 - EVOUT0: 事象出力0許可(Event Output 0)

事象出力0を許可するにはこのビットに'1'を書いてください。

**15.3.2. CTRLB - 制御B** (Control B)

名称: CTRLB 変位: +\$01 リセット: \$00 特質: -

| ピット    | 7 | 6 | 5 | 4    | 3 | 2    | 1 | 0      |
|--------|---|---|---|------|---|------|---|--------|
|        |   |   |   | TWI0 |   | SPI0 |   | USART0 |
| アクセス種別 | R | R | R | R/W  | R | R/W  | R | R/W    |
| リセット値  | 0 | 0 | 0 | 0    | 0 | 0    | 0 | 0      |

● ビット4 - TWIO: TWIO通信ピン代替 (TWI 0 communication)

TWIに対して代替通信ピンを選ぶにはこのビットに'1'を書いてください。

● ビット2 - SPIO: SPIO通信ピン代替 (SPI 0 communication)

SPIに対して代替通信ピンを選ぶにはこのビットに'1'を書いてください。

● ビット0 - USART0 : USART0通信ピン代替 (USART 0 communication)

USARTに対して代替通信ピンを選ぶにはこのビットに'1'を書いてください。

# **15.3.3. CTRLC - 制御C** (Control C)

名称: CTRLC 変位:+\$02 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5     | 4     | 3     | 2     | 1     | 0     |
|--------|---|---|-------|-------|-------|-------|-------|-------|
|        |   |   | TCA05 | TCA04 | TCA03 | TCA02 | TCA01 | TCA00 |
| アクセス種別 | R | R | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| リセット値  | 0 | 0 | 0     | 0     | 0     | 0     | 0     | 0     |

● ビット5 - TCA05: TCA0波形出力5代替 (TCA0 Waveform output 5)

分割動作でのタイマ/カウンタA型(TCA)波形出力5に対して代替出力ピンを選ぶにはこのビットに'1'を書いてください。 標準動作でのTCA時は適用不可

● ビット4 - TCA04: TCA0波形出力4代替 (TCA0 Waveform output 4)

分割動作でのTCA波形出力4に対して代替出力ピンを選ぶにはこのビットに'1'を書いてください。 標準動作でのTCA時は適用不可

● ビット3 - TCA03: TCA0波形出力3代替 (TCA0 Waveform output 3)

分割動作でのTCA波形出力3に対して代替出力ピンを選ぶにはこのビットに'1'を書いてください。 標準動作でのTCA時は適用不可

● ビット2 - TCA02: TCA0波形出力2代替 (TCA0 Waveform output 2)

TCA波形出力2に対して代替出力ピンを選ぶにはこのビットに'1'を書いてください。 分割動作では、このビットが比較チャネル2の下位バイトからの出力を制御します。

● ビット1 - TCA01: TCA0波形出力1代替 (TCA0 Waveform output 1)

TCA波形出力1に対して代替出力ピンを選ぶにはこのビットに'1'を書いてください。 分割動作では、このビットが比較チャネル1の下位ハイトからの出力を制御します。

● ビット0 - TCA00: TCA0波形出力0代替 (TCA0 Waveform output 0)

TCA波形出力0に対して代替出力ピンを選ぶにはこのビットに'1'を書いてください。 分割動作では、このビットが比較チャネル0の下位バイトからの出力を制御します。

#### **15.3.4. CTRLD - 制御D** (Control D)

名称: CTRLD 変位:+\$03 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    |
|--------|---|---|---|---|---|---|------|------|
|        |   |   |   |   |   |   | TCB1 | TCB0 |
| アクセス種別 | R | R | R | R | R | R | R/W  | R/W  |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    |

#### ● ビット1 - TCB1: TCB1出力代替 (TCB0 output)

16ビットタイマ/カウンタB型1(TCB1)に対して代替出力を選ぶにはこのビットに'1'を書いてください。

● ビット0 - TCB0: TCB0出力代替 (TCB0 output)

16ビット タイマ/カウンタB型0(TCB0)に対して代替出力を選ぶにはこのビットに'1'を書いてください。

# 16. PORT - I/Oピン構成設定

## 16.1. 特徴

- ・個別構成設定を持つ汎用入出力ピン
  - プ<sup>°</sup>ルアップ<sup>°</sup>
  - 反転I/O
- ・割り込みと事象を持つ入力
  - 両端感知
  - 上昇端感知
  - 下降端感知
  - Lowレベル感知
- ・全休止動作形態からデバイスを起き上がらせることができる非同期ピン変化感知
- ・ポートピンへの効率的で安全なアクセス
  - 専用の切り換え、解除(0)、設定(1)用レジスタ通したハードウェア読み-変更-書き(RMW)
  - ビット アクセス可能なI/Oメモリ空間への度々使われるポート レジスタ割り当て(仮想ポート)

#### 16.2. 概要

デバイスの入出力ピンはPORT周辺機能レジスタの実体によって制御されます。各PORT実体は最大8つの入出力ピンを持ちます。PORT はPORTA、PORTB、PORTCなどと名付けられます。どのピンが何のPORTの実体によって制御されるかを見るには「入出力多重化と考察」章を参照してください。PORT実体と対応する仮想PORT実体の基準アドレスは「周辺機能と基本構造」章で一覧にされます。

各ポート ピンは出力としてそのピンを許可して出力状態を定義するためにデータ方向(PORTx.DIR)とデータ出力値(PORTx.OUT)のレジスタで対応するビットを持ちます。例えば、PORTA実体のDIR3とOUT3はPA3ピンを制御します。

PORTピンの入力値は周辺機能クロック(CLK\_PER)に同期され、その後にデータ入力値(PORTx.IN)としてアクセス可能にされます。ピンが入力または出力のどちらとして構成設定されても、このピンの値は常に読むことができます。

PORTは選択可能なピン変化条件に対して割り込みと事象と共に非同期の入力感知も支援します。非同期ピン変化感知はCLK\_PERが停止される休止動作を含み、割り込みを起動して休止からデバイスを起き上がらせることができることを意味します。

全てのピン機能はピン毎に個別に構成設定可能です。ピンは駆動値や入力と感知の構成設定の安全で正しい変更のためにハードウェア読み-変更-書き(RMW:Read-Modify-Write)機能を持ちます。

PORTビン構成設定は他のデバイス機能の入力と出力の選択も制御します。

## 16.2.1. 構成図



# 16.2.2. 信号説明

| 信号  | 形式  | 説明           |
|-----|-----|--------------|
| Pxn | 入出力 | PORTxのn入出力ピン |

# 16.3. 機能的な説明

#### 16.3.1. 初期化

リセット後、例えクロック走行がなくても、全ての出力がトライステート(Hi-Z)にされ、デジタル入力緩衝部が許可されます。

ポート動作を初期化する時に以下の手順は全て任意選択です。

- ・データ方向設定(PORTx.DIRSET)またはデータ方向解除(PORTx.DIRCLR)のレジスタのビットに各々'1'を書くことによってPxnピンに対して出力駆動部を許可または禁止にしてください。
- ・出力値設定(PORTx.OUTSET)または出力値解除(PORTx.OUTCLR)のレジスタのビットに'1'を書くことによってPxnピンに対する出力駆動部を各々HighまたはLowの水準に設定してください。
- ・ 入力値(PORTx.IN)レジスタのビットnを読むことによってPxnピンの入力を読んでください。
- ・ピンn制御(PORTx.PINnCTRL)レジスタでPxnピンに対して個別ピン構成設定と割り込み制御を構成設定してください。



重要: 最低消費電力のため、未使用ピンとアナログ入力または出力として使われるピンのデジタル入力緩衝部を禁止してください。

デバッガに接続するのに使われるそれらのような特定ピンは、それらの特殊機能によって必要とされるため、違う様に構成設定されるでしょう。

## 16.3.2. 動作

#### 16.3.2.1. 基本機能

各ピン群(x)はそれ自身のPORTレジスター式を持ちます。入出力(Pxn)ピンはPORTx内のレジスタによって制御することができます。

出力としてピン番号nを使うには、データ方向(PORTx.DIR)レジスタのビットnに'1'を書いてください。これはデータ方向設定(PORTx.DIRSE T)レジスタのビットnに'1'を書くことによっても行うことができ、これはその群内の他のピンの構成設定の妨害を避けます。出力値(PORT x.OUT)レジスタのビットnは望む出力値が書かれなければなりません。

同様に、出力値設定(PORTx.OUTSET)レジスタのビットへの'1'書き込みはPORTx.OUTレジスタの対応するビットを'1'に設定します。出力値解除(PORTx.OUTCLR)レジスタのビットへの'1'書き込みはPORTx.OUTレジスタのどットを'0'に解除します。出力値切り替え(PORTx.OUTTGL)または入力値(PORTx.IN)のレジスタのビットへ'1'書き込みはPORTx.OUTレジスタ内のそのビットを論理反転します。

ピンを入力として使うには出力駆動部を禁止するためにPORTx.DIRレジスタのビットnが'0'を書かれなければなりません。これはデータ方向解除(PORTx.DIRCLR)レジスタのビットnに'1'を書くことによっても行うことができ、これはその群内の他のピンの構成設定の妨害を避けます。入力値はピンn制御(PORTx.PINnCTRL)レジスタの入力/感知構成設定(ISC)ビット領域が入力禁止(INPUT\_DISABLE)に設定されない限り、PORTx.INレジスタのビットnから読むことができます。

データ方向切り替え(PORTx.DIRTGL)での'1'書き込みはPORTx.DIRでそのビットを切り替え、対応するピンの方向を切り替えます。

# 16.3.2.2. ピン構成設定

ピンn制御(PORTx.PINnCTRL)レジスタはピンの反転I/O、プルアップ、入力感知を構成設定するのに使われます。ピンn用の制御レジスタはバイトアドレスのPORTx+\$10+nです。

各々のn番ピンの全ての入力と出力はPORTx.PINnCTRLの反転I/O許可(INVEN)ビットに'1'を書くことによって反転することができます。INVENが'1'の時は、このピンに対してPORTx.IN/OUT/OUTSET/OUTCLRレジスタが反転操作になります。

INVENt'ットの交互切り替えは、このピンを使う全ての周辺機能によって検出することができるピンでの変化端(エッジ)を引き起こし、許可されていれば割り込みまたは事象によって見られます。

ピンnの入力プルアップ゚はPORTx.PINnCTRLのプルアップ。許可(PULLUPEN)ビットに'1'を書くことによって許可されます。プルアップ゚は例え PULLUPENビットが'1'でも、ピンが出力として構成設定されると、切断されます。

ピン割り込みはPORTx.PINnCTRLの入力/感知構成設定(ISC)ビット領域に書くことによってピンnに対して許可されます。更なる詳細については「16.3.3. 割り込み」を参照してください。

ピンn用のデジタル入力緩衝部はISCビット領域にINPUT\_DISABLE設定を書くことによって禁止することができます。これは消費電力を減らしてピンがアナログ入力として使われる場合に雑音を減らすでしょう。INPUT\_DISABLEに構成設定されている間、PORTx.INのビットnは入力同期部が禁止されるため変わりません。

# 16.3.2.3. 仮想ポート

仮想ポートレジスタは最も頻繁に使われる通常のポートレジスタを単一周期ビットアクセスを持つI/Oレジスタ空間に割り当てます。仮想ポートレジスタへのアクセスは普通のレジスタへのアクセスと同じ結果を持ち、通常のポートレジスタが属す拡張I/Oレジスタ空間で使うことができないビット操作命令のようなメモリ特定命令を許します。右表はPORTとVPORTのレジスタ間の割り当てを示します。

| 表16-1. 仮想ポート割  | り当て               |
|----------------|-------------------|
| 通常ポート レジスタ     | 割り当てられる仮想ポート レジスタ |
| PORTx.DIR      | VPORTx.DIR        |
| PORTx.OUT      | VPORTx.OUT        |
| PORTx.IN       | VPORTx.IN         |
| PORTx.INTFLAGS | VPORTx.INTFLAGS   |

#### 16.3.2.4. 周辺機能優先

USART、ADC、計時器のような周辺機能は入出力ピンに接続されるでしょう。このような周辺機能は通常、ポート多重器(PORTMUX)またはその周辺機能内の多重器よって選択可能な基本と任意選択の1つ以上の代替入出力ピン接続を持ちます。このような周辺機能を構成設定して許可することにより、I/Oピン構成設定(PORT)によって制御される通常の汎用入出力ピンの動きは周辺機能に依存する方法で覆されます。いくつかの周辺機能はPORTレジスタの全てを覆さないかもしれず、入出力ピン操作のいくつかの面の制御をPORT単位部に残します。

周辺機能優先の情報については各周辺機能の記述を参照してください。周辺機能によって覆されないポートのどのピンも汎用入出力ピンとしての動作を続けます。

#### 16.3.3. 割り込み

#### 表16-2. 利用可能な割り込みべりなと供給元

| 名称    | ベクタ説明        | 条件                                                                         |
|-------|--------------|----------------------------------------------------------------------------|
| PORTx | PORT<br>割り込み | PORTx.INTFLAGSのINTnはPORTx.PINnCTRLの入力/感知構成設定(ISC)ビットによって構成設定されるとおりに掲げられます。 |

各PORTピンnは割り込み元として構成設定することができます。各割り込みはピンn制御(PORTx.PINnCTRL)レジスタの入力/感知構成設定(ISC)へ書くことによって個別に許可または禁止することができます。

割り込み条件が起こると、周辺機能の割り込み要求フラグ(PORTx.INTFLAGS)レジスタで対応する割り込み要求(INTn)フラグが設定(1)されます。

割り込み要求は対応する割り込み元が許可され、割り込み要求フラグが設定(1)される時に生成されます。割り込み要求は割り込み要求フラグが解除(0)されるまで活性に留まります。割り込み要求フラグを解除する方法の詳細については周辺機能のINTFLAGSレジスタをご覧ください。

割り込み設定の設定または変更時、以下のこれらの点を考慮してください。

- ・入力/感知構成設定(ISC)が変更されるのと同じ周期で反転I/O許可(INVEN)ビットが切り替えられる場合、反転切り替えによって引き起こされる端は割り込み要求を引き起こさないかもしれません。
- ・割り込み同期中にISCへ書くことによって入力が禁止される場合、例えそれが違う割り込み設定で再許可されても、その割り込みが再許可で要求されるかもしれません。
- ・割り込み同期中にISCへ書くことによって割り込み設定が変更される場合、その割り込みが要求されないかもしれません。

#### 16.3.3.1. 非同期感知ピン特性

全てのポート ピンは選択可能なピン変化条件に対する割り込みを持つ非同期入力感知を支援します。完全な非同期ピン変化感知は割り込みを起動して、周辺機能クロック(CLK\_PER)が停止される動作形態を含めて全ての休止動作からデバイスを起き上がらせることができますが、一方で下表により部分的非同期ピン変化感知が制限されます。どのピンが完全な同期ピン変化感知を支援するかの更なる詳細については「入出力多重化と考察」章をご覧ください。

# 表16-3. 感知ピンの動き比較

| 衣 10-3. 窓加し 200g        | 切ぐに収 |                                      |               |
|-------------------------|------|--------------------------------------|---------------|
| 特性                      |      | 部分的非同期ピン                             | 完全な非同期ピン      |
| CLK_PER走行のケ<br>からデバイス起き |      | 全ての割り込み感知構成設定から                      | 全ての割り込み構成設定   |
| CLK_PER停止のからデバイス起き      |      | BOTHEDGESまたはLEVELの割り込み感知構成設定からだけ     | から            |
| CLK_PER走行で割起動するための最近    |      | 最小1 CLK_PER周期                        |               |
| CLK_PER停止で割起動するための最     |      | ピン値はCLK_PERが再開されるまで維持されなければなりません。(注) | 1 CLK_PER周期未満 |
| 割り込み"沈黙                 | 時間"  | 前回から3 CLK_PER周期間、新しい割り込みはありません。      |               |

注: 部分的非同期入力ピンがCLK\_PER停止での休止からの起き上がりに使われる場合、要求されたレベルは割り込みを起動するための起き上がりを完了するため、MCUに対して充分長く保持されなければなりません。レベルが消滅した場合、MCUはどの生成した割り込みもなしに起き上がり得ます。

#### 16.3.4. 事象

PORTは以下の事象を生成することができます。

# 表16-4. PORTxの事象生成部

| 生          | 成部名 | 説明    | 事象型 | 生成する   | 事象の長さ            |  |
|------------|-----|-------|-----|--------|------------------|--|
| 周辺機能       | 事象  | a元 ツカ | 尹豕至 | クロック領域 |                  |  |
| PORTx PINn |     | ピンレベル | レベル | 非同期    | ピンレベルによって与えられます。 |  |

全てのポート ピンが非同期事象システム生成部です。ポートはデバイスにあるポート ピンの数の事象生成部を持ちます。ポートからの各事象システム出力はデジタル入力駆動部が許可される場合に対応するピンに存在する値です。ピン入力駆動部が禁止される場合、対応する事象システム出力は、0、です。

ポートは事象入力を持ちません。事象型と事象システム構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照してください。

#### 16.3.5. 休止形態動作

割り込みと入力の同期化の例外を除き、全てのピン構成設定は休止動作と無関係です。全てのピンはデバイスを休止から起き上がらせることができ、更なる詳細についてはポート割り込み部分をご覧ください。

ポートに接続された周辺機能は各々の周辺機能のデータシート部分で記述される休止動作によって影響を及ぼされ得ます。



重要: ポートは常に周辺機能クロック(CLK\_PER)を使います。このクロックが止まる時に入力同期化は停止します。

#### 16.3.6. デバッグ操作

ポートはデバッグ動作でのCPU停止時に通常動作を続けます。ポートが割り込みまたは同様のものを通してCPUによって定期的に処理されるのを必要とするように構成設定する場合、デバッグ中に不正な動作やデータ損失になるかもしれません。

# 16.4. レシ、スタ要約 - PORTx

| 変位        | 略称       | ピット位置        | ヒ゛ット7 | ピット6 | ピット5   | じット4  | ピット3     | ピット2  | ピット1   | ピット0 |
|-----------|----------|--------------|-------|------|--------|-------|----------|-------|--------|------|
| +\$00     | DIR      | 7~0          |       |      |        | DIR   | 7~0      |       |        |      |
| +\$01     | DIRSET   | 7~0          |       | 1    |        | DIRSE | ET7~0    |       |        |      |
| +\$02     | DIRCLR   | 7~0          |       | 1    |        | DIRCI | LR7∼0    |       |        |      |
| +\$03     | DIRTGL   | 7 <b>~</b> 0 |       | 1    |        | DIRTO | GL7~0    |       |        |      |
| +\$04     | OUT      | 7 <b>~</b> 0 |       |      |        | OUT   | Γ7~0     | !     | !      |      |
| +\$05     | OUTSET   | 7 <b>~</b> 0 |       |      | !<br>! | OUTS  | ET7~0    | !<br> |        |      |
| +\$06     | OUTCLR   | 7 <b>~</b> 0 |       |      |        | OUTC  | LR7∼0    | !     |        |      |
| +\$07     | OUTTGL   | 7 <b>~</b> 0 |       |      |        | OUTT  | GL7~0    |       |        |      |
| +\$08     | IN       | 7 <b>~</b> 0 |       | 1    | 1      | IN    | 7~0      |       |        |      |
| +\$09     | INTFLAGS | 7 <b>~</b> 0 |       |      | 1      | INT   | 7~0      |       |        |      |
| +\$0A<br> | 予約       |              |       |      |        |       |          |       |        |      |
| +\$10     | PIN0CTRL | 7~0          | INVEN |      |        |       | PULLUPEN |       | ISC2~0 |      |
| +\$11     | PIN1CTRL | 7~0          | INVEN |      |        |       | PULLUPEN |       | ISC2~0 |      |
| +\$12     | PIN2CTRL | 7~0          | INVEN |      |        |       | PULLUPEN |       | ISC2~0 |      |
| +\$13     | PIN3CTRL | 7~0          | INVEN |      |        |       | PULLUPEN |       | ISC2~0 |      |
| +\$14     | PIN4CTRL | 7~0          | INVEN |      |        |       | PULLUPEN |       | ISC2~0 |      |
| +\$15     | PIN5CTRL | 7~0          | INVEN |      |        |       | PULLUPEN |       | ISC2~0 |      |
| +\$16     | PIN6CTRL | 7~0          | INVEN |      |        |       | PULLUPEN |       | ISC2~0 |      |
| +\$17     | PIN7CTRL | 7 <b>~</b> 0 | INVEN |      |        |       | PULLUPEN |       | ISC2~0 |      |

# 16.5. レシ、スタ説明 - PORTx

**16.5.1. DIR** - データ方向 (Data Direction)

名称: DIR 変位:+\$00 リセット: \$00 特質:-

| ピット    | 7      | 6   | 5   | 4      | 3      | 2   | 1   | 0      |
|--------|--------|-----|-----|--------|--------|-----|-----|--------|
|        | DIR7~0 |     |     |        |        |     |     |        |
| アクセス種別 | R/W    | R/W | R/W | R/W    | R/W    | R/W | R/W | R/W    |
| リセット値  | ,      | 14, | 14, | 10/ 11 | 10, 11 | 14, | 14, | 14, 11 |

# ● ビット7~0 - DIR7~0: データ方向 (Data Direction)

このビット領域は各PORTxピンに対する出力駆動部を制御します。

このビット領域はデジタル入力緩衝部を制御しません。ピンn(Pxn)用のデジタル入力緩衝部はピンn制御(PORTx.PINnCTRL)の割り込み/感知構成設定(ISC)ビット領域で構成設定することができます。

このビット領域で各ビットnに対して利用可能な構成設定が下表で示されます。

| 値  | 0                        | 1                      |
|----|--------------------------|------------------------|
| 説明 | Pxnは入力専用ピンとして構成、出力駆動部は禁止 | Pxnは出力ピンとして構成、出力駆動部は許可 |

# 16.5.2. DIRSET - データ方向設定 (Data Direction Set)

名称 : DIRSET 変位 : +\$01 リセット : \$00 特質 : -

| <b>ビット</b> | 7         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|-----------|-----|-----|-----|-----|-----|-----|-----|
|            | DIRSET7~0 |     |     |     |     |     |     |     |
| アクセス種別     | 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 - DIRSET7~0: データ方向設定 (Data Direction Set)

このビット領域は読み-変更-書き操作を使わず、各PORTxピンに対する出力駆動部を制御します。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みはデータ方向(PORTx.DIR)の対応するビットを設定(1)し、ピンn(Pxn)を出力ピンとして構成設定して出力駆動部を許可します。

このビット領域の読み込みはPORTx.DIRの値を返します。

# 16.5.3. DIRCLR - データ方向解除 (Data Direction Clear)

名称: DIRCLR 変位: +\$02 リセット: \$00 特質: -

| ヒ゛ット   | 7         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----------|-----|-----|-----|-----|-----|-----|-----|
|        | DIRCLR7~0 |     |     |     |     |     |     |     |
| アクセス種別 | 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 - DIRCLR7~0: データ方向解除 (Data Direction Clear)

このビット領域は読み-変更-書き操作を使わず、各PORTxピンに対する出力駆動部を制御します。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みはデータ方向(PORTx.DIR)の対応するビットを解除( $\frac{0}{0}$ )し、ピンn(Pxn)を入力専用ピンとして構成設定して出力駆動部を禁止します。

このビット領域の読み込みはPORTx.DIRの値を返します。

# 16.5.4. DIRTGL - データ方向切り替え (Data Direction Toggle)

名称: DIRTGL 変位: +\$03 リセット: \$00 特質: -

| <u> </u> | 7   | 6   | 5   | 4     | 3     | 2   | 1   | 0   |
|----------|-----|-----|-----|-------|-------|-----|-----|-----|
|          |     |     |     | DIRTO | GL7∼0 |     |     |     |
| アクセス種別   | 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 - DIRTGL7~0: データ方向切り替え (Data Direction Toggle)

このビット領域は読み-変更-書き操作を使わず、各PORTxピンに対する出力駆動部を制御します。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みはデータ方向(PORTx.DIR)の対応するビットを反転切り替えします。

このビット領域の読み込みはPORTx.DIRの値を返します。

# **16.5.5**. **OUT - 出力値** (Output Value)

名称: OUT 変位:+\$04 リセット: \$00 特質:-

| ピット    | 7   | 6   | 5   | 4   | 3    | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|------|-----|-----|-----|
|        |     |     |     | OU  | Γ7~0 |     |     |     |
| アクセス種別 | R/W | R/W | R/W | R/W | R/W  | R/W | R/W | R/W |
| リセット値  | Λ   | 0   | 0   | 0   | 0    | 0   | 0   | 0   |

#### ● ビット7~0 - OUT7~0: 出力値 (Output Value)

このビット領域は各PORTxピンに対する出力駆動部レベルを制御します。

この構成設定は対応するピンに対して駆動部(PORTx.DIR)が許可される時にだけ出力に影響を及ぼします。

このビット領域の各ビットnに対して利用可能な構成設定が下表で示されます。

| 値  | 0                      | 1                  |
|----|------------------------|--------------------|
| 説明 | ピンn(Pxn)出力はLowに駆動されます。 | Pxn出力はHighに駆動されます。 |

#### 16.5.6. OUTSET - 出力値設定 (Output Value Set)

名称: OUTSET 変位: +\$05 リセット: \$00 特質:-

| ピット    | 7   | 6   | 5   | 4    | 3     | 2   | 1   | 0   |
|--------|-----|-----|-----|------|-------|-----|-----|-----|
|        |     |     |     | OUTS | ET7~0 |     |     |     |
| アクセス種別 | 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 - OUTSET7~0: 出力値設定 (Output Value Set)

このビット領域は読みー変更ー書き操作を使わず、各PORTxピンに対する出力駆動部レベルを制御します。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みは出力値(PORTx.OUT)の対応するビットを設定(1)し、ピンn(Pxn)に対する出力をHighに駆動するように構成設定します。

このビット領域の読み込みはPORTx.OUTの値を返します。

#### 16.5.7. OUTCLR - 出力値解除 (Output Value Clear)

名称 : OUTCLR 変位 : +\$06 リセット : \$00 特質 : -

| <b>ビット</b> | 7   | 6   | 5   | 4    | 3     | 2   | 1   | 0   |
|------------|-----|-----|-----|------|-------|-----|-----|-----|
|            |     |     |     | OUTC | LR7~0 |     |     |     |
| アクセス種別     | 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 - OUTCLR7~0: 出力値解除 (Output Value Clear)

このビット領域は読み-変更-書き操作を使わず、各PORTxピンに対する出力駆動部レベルを制御します。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みは出力値(PORTx.OUT)の対応するビットを解除(0)し、ピンn(Pxn)に対する出力をLowに駆動するように構成設定します。

このビット領域の読み込みはPORTx.OUTの値を返します。

# 16.5.8. OUTTGL - 出力値切り替え (Output Value Toggle)

名称: OUTTGL 変位: +\$07 リセット: \$00 特質:-

| ピット    | 7   | 6   | 5   | 4    | 3     | 2   | 1   | 0   |
|--------|-----|-----|-----|------|-------|-----|-----|-----|
|        |     |     |     | OUTT | GL7~0 |     |     |     |
| アクセス種別 | R/W | R/W | R/W | R/W  | R/W   | R/W | R/W | R/W |
| リセット値  |     |     |     |      |       |     |     |     |

#### ● ビット7~0 - OUTTGL7~0: 出力値切り替え(Output Value)

このビット領域は読み-変更-書き操作を使わず、各PORTxピンに対する出力駆動部レベルを制御します。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みは出力値(PORTx.OUT)の対応するビットを反転切り替えします。

このビット領域の読み込みはPORTx.OUTの値を返します。

# **16.5.9. IN - 入力値** (Input Value)

名称:IN 変位:+\$08 リセット:\$00 特質:-



# ┗ ビット7~0 - IN7~0: 入力値 (Input Value)

このビット領域はデジタル入力緩衝部が許可される時ににPORTxピンの状態を示します。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みは出力値(PORTx.OUT)の対応するビットを反転切り替えします。

デジタル入力緩衝部が禁止される場合、入力は採取されず、ビット値は変わりません。ピンn(Pxn)用のデジタル入力緩衝部はピンn制御(PORTx.PINnCTRL)レジスタの入力/感知構成設定(ISC)ビット領域で構成設定することができます。

このビット領域の各ビットnの利用可能な状態が下表で示されます。

| 値  | 0                | 1                 |
|----|------------------|-------------------|
| 説明 | Pxnでの電圧水準はLowです。 | Pxnでの電圧水準はHighです。 |

## 16.5.10. INTFLAGS - 割り込み要求フラク (Interrupt Flags)

名称: INTFLAGS 変位:+\$09 リセット: \$00 特質:-

| ピット    | 7   | 6   | 5   | 4   | 3    | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|------|-----|-----|-----|
|        |     |     |     | INT | .7~0 |     |     |     |
| アクセス種別 | R/W | R/W | R/W | R/W | R/W  | R/W | R/W | R/W |
|        |     |     | ,   | ,   | ,    | ,   |     | ,   |

# ● ビット7~0 - INT7~0 : ピン割り込み要求フラグ (Interrupt Pin Flag)

ピン割り込み要求フラグはそれに'1'を書くことによって解除(0)されます。

ピン割り込み要求フラグはピンn(Pxn)の変化または状態がピンn制御(PORTx.PINnCTRL)のそのピンの入力/感知構成設定(ISC)に一致する時に設定(1)されます。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みはピンn割り込み要求フラグを解除(0)します。

#### 16.5.11. PINnCTRL - ピンn制御 (Pin n Control)

名称:PINOCTRL:PIN1CTRL:PIN2CTRL:PIN3CTRL:PIN4CTRL:PIN5CTRL:PIN6CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL:PIN7CTRL

リセット:\$00 特質 :-

| ピット   | 7     | 6 | 5 | 4 | 3        | 2   | 1      | 0   |
|-------|-------|---|---|---|----------|-----|--------|-----|
|       | INVEN |   |   |   | PULLUPEN |     | ISC2∼0 |     |
| アクセス種 | 別 R/W | R | R | R | R/W      | R/W | R/W    | R/W |
| リセット征 | 1 0   | 0 | 0 | 0 | 0        | 0   | 0      | 0   |

#### ● ビット7 - INVEN: 反転I/O許可 (Inverted I/O Enable)

このビットはピンnに対する入力と出力が反転されるか否かを制御します。

| 値  | 0             | 1            |
|----|---------------|--------------|
| 説明 | 入出力値は反転されません。 | 入出力値は反転されます。 |

#### • ビット3 - PULLUPEN : プルアップ許可 (Pullup Enable)

このビットはピンが入力専用として構成設定される時にピンnの内部プルアップが許可される否かを制御します。

| 値  | 0       | 1       |
|----|---------|---------|
| 説明 | プルアップ禁止 | プルアップ許可 |

#### ● ビット2~0 - ISC2~0:入力/感知構成設定 (Input/Sense Configuration)

このビット領域はピンnの入力と感知の構成設定を制御します。感知構成設定はポート割り込みを起動するピン条件を決めます。

| 値   | 名称            | 説明                     |
|-----|---------------|------------------------|
| 000 | INTDISABLE    | 割り込み禁止、けれどもデジタル入力緩衝部許可 |
| 001 | BOTHEDGES     | 両端感知で割り込み許可            |
| 010 | RISING        | 上昇端感知で割り込み許可           |
| 011 | FALLING       | 下降端感知で割り込み許可           |
| 100 | INPUT_DISABLE | 割り込みとデジタル入力緩衝部を禁止(注1)  |
| 101 | LEVEL         | Lowレヘブル感知で割り込み許可 (注2)  |
| 11x | -             | (予約)                   |

注1: ピンnのデジタル入力緩衝部が禁止される場合、入力値(PORTx.IN)レジスタのビットnは更新されません。

注2: LEVEL割り込みはピンがLowに留まる限り継続的に起動し続けます。

# 16.6. レジスタ要約 - VPORTx

| 変位    | 略称       | ビット位置        | ヒ゛ット7 | ピット6 | ピット5 | じット4 | ピット3 | ピット2 | ピット1 | ピット0 |
|-------|----------|--------------|-------|------|------|------|------|------|------|------|
| +\$00 | DIR      | 7 <b>~</b> 0 |       |      |      | DIR  | 7~0  |      | 1    |      |
| +\$01 | OUT      | 7 <b>~</b> 0 |       |      | 1    | OU7  | 7~0  |      | 1    |      |
| +\$02 | IN       | 7 <b>~</b> 0 |       |      | 1    | IN7  | 7~0  |      | 1    |      |
| +\$03 | INTFLAGS | 7 <b>~</b> 0 |       |      |      | INT  | 7~0  | 1    |      |      |

## 16.7. レシ スタ説明 - VPORTx

## 16.7.1. DIR - データ方向 (Data Direction)

名称: DIR 変位:+\$00 リセット: \$00 特質:-

仮想ポートレジスタへのアクセスは普通のレジスタへのアクセスと同じ結果を持ち、通常のポートレジスタが属す拡張I/Oレジスタ空間で使うことができないビット操作命令のようなメモリ特定命令を許します。

| <u> </u> | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------|-----|-----|-----|-----|-----|-----|-----|-----|
|          |     |     |     | DIR | 7~0 |     |     |     |
| アクセス種別   | R/W |
| リセット値    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

#### ヒット7~0 - DIR7~0: データ方向 (Data Direction)

このビット領域は各PORTxピンに対する出力駆動部を制御します。

このビット領域はデジタル入力緩衝部を制御しません。ピンn(Pxn)用のデジタル入力緩衝部はピンn制御(PORTx.PINnCTRL)レジスタの割り込み/感知構成設定(ISC)ビット領域で構成設定することができます。

下表はこのビット領域の各ビットnに対して利用可能な構成設定を示します。

| 値  | 0                        | 1                      |
|----|--------------------------|------------------------|
| 説明 | Pxnは入力専用ピンとして構成、出力駆動部は禁止 | Pxnは出力ピンとして構成、出力駆動部は許可 |

# **16.7.2**. **OUT** - 出力値 (Output Value)

名称: OUT 変位:+\$01 リセット: \$00 特質:-

仮想ポートレジスタへのアクセスは普通のレジスタへのアクセスと同じ結果を持ち、通常のポートレジスタが属す拡張I/Oレジスタ空間で使うことができないビット操作命令のようなメモリ特定命令を許します。

| ピット    | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|--|
| OUT7~0 |     |     |     |     |     |     |     |     |  |
| アクセス種別 | R/W |  |
| リセット値  |     |     |     | 0   | 0   | 0   | 0   | 0   |  |

#### ● ビット7~0 - OUT7~0: 出力値 (Output Value)

このビット領域は各PORTxピンに対する出力駆動部レベルを制御します。

この構成設定は対応するピンに対して駆動部(PORTx.DIR)が許可される時にだけ出力に影響を及ぼします。

下表はこのビット領域の各ビットnに対して利用可能な構成設定を示します。

| 値  | 0                      | 1                  |
|----|------------------------|--------------------|
| 説明 | ピンn(Pxn)出力はLowに駆動されます。 | Pxn出力はHighに駆動されます。 |

#### **16.7.3. IN - 入力値** (Input Value)

名称:IN 変位:+\$02 リセット:\$00 特質:-

仮想ポートレジスタへのアクセスは普通のレジスタへのアクセスと同じ結果を持ち、通常のポートレジスタが属す拡張I/Oレジスタ空間で使うことができないビット操作命令のようなメモリ特定命令を許します。

| <u> </u> | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|----------|-------|-----|-----|-----|-----|-----|-----|-----|--|--|
|          | IN7~0 |     |     |     |     |     |     |     |  |  |
| アクセス種別   | 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 - IN7~0: 入力値 (Input Value)

このビット領域はデジタル入力緩衝部が許可される時ににPORTxピンの状態を示します。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みは出力値(PORTx.OUT)の対応するビットを反転切り替えします。

デジタル入力緩衝部が禁止される場合、入力は採取されず、ビット値は変わりません。ピンn(Pxn)用のデジタル入力緩衝部はピンn制御(PORTx.PINnCTRL)ルジスタの入力/感知構成設定(ISC)ビット領域で構成設定することができます。

下表はこのビット領域の各ビットnに対して利用可能な構成設定を示します。

| 値  | 0                | 1                 |
|----|------------------|-------------------|
| 説明 | Pxnでの電圧水準はLowです。 | Pxnでの電圧水準はHighです。 |

# 16.7.4. INTFLAGS - 割り込み要求フラグ (Interrupt Flag)

名称: INTFLAGS 変位:+\$03 リセット: \$00 特質:-

仮想ポート レジスタへのアクセスは普通のレジスタへのアクセスと同じ結果を持ち、通常のポート レジスタが属す拡張I/Oレジスタ空間で使うことができないビット操作命令のようなメモリ特定命令を許します。

| INT7~0  アクセス種別 R/W | ピット    | 7       | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |
|--------------------------------------------------------|--------|---------|-----|-----|-----|-----|-----|-----|-----|--|--|--|
|                                                        |        | INT,7~0 |     |     |     |     |     |     |     |  |  |  |
|                                                        | アクセス種別 | 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 - INT7~0: ピン割り込み要求フラグ (Interrupt Pin Flag)

ピン割り込み要求フラグはそれに'1'を書くことによって解除(0)されます。

ピン割り込み要求フラグはピンn(Pxn)の変化または状態がピンn制御(PORTx.PINnCTRL)のそのピンの入力/感知構成設定(ISC)に一致する時に設定(1)されます。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みはピンn割り込み要求フラグを解除(0)します。

# 17. BOD - 低電圧検出器 (BOD:Brownout Detector)

#### 17.1. 特徴

- ・低電圧検出は設定可能な基準未満での動作を避けるために電源を監視します。
- ・利用可能な3つの動作形態
  - 許可動作(継続的に活動)
  - 採取動作
  - 禁止
- 活動動作と休止動作に対して独立した動作形態を選択
- ・割り込みを持つ電圧水準監視部(VLM)
- ・BOD基準に比例した設定可能なVLM基準

# 17.2. 概要

低電圧検出器(BOD)は電源を監視して供給電圧を設定可能な低電圧閾値基準と比べます。低電圧閾値基準はシステム リセットを生成する時を定義します。電圧水準監視部(VLM)も電源を監視してそれをBOD閾値よりも高い閾値と比べます。そしてVLMは供給電圧がBOD閾値に近づいている時に"早期警告"として割り込み要求を生成することができます。VLM閾値基準はBOD閾値基準の%超えとして表現されます。

BODは主にヒューズによって制御され、使用者によって許可されなければなりません。スタンハブイ休止動作とパワーダウン休止動作で使われる動作形態は標準プログラム実行で変えることができます。VLMは更にI/Oレジスタによっても制御されます。

有効にされると、BODはBODが継続的に活動する許可動作形態で、またはBODが供給電圧水準を検査するのに与えられた周期で一時的に活動にされる採取動作形態で動作することができます。

#### 17.2.1. 構成図



#### 17.3. 機能的な説明

# 17.3.1. 初期化

BOD設定はリセットの間にヒュース、から設定されます。活動動作とアイトル休止動作でのBOD基準と動作形態はヒュース、によって設定され、ソフトウェアによって変更することができません。スタンハ、イ休止動作とパワータ・ウン休止動作での動作形態はヒュース、によって設定され、ソフトウェアによって変更することができます。

電圧水準監視部機能は割り込み制御(BOD.INTCTRL)レジスタのVLM割り込み許可(VLMIE)ビットに'1'を書くことによって許可することができます。VLM割り込みはBOD.INTCTRLレジスタのVLM構成設定(VLMCFG)ビットを書くことによって構成設定されます。割り込みは供給電圧が上または下のどちらかから、または何れかの方向でVLM閾値を横切る時に要求されます。

VLM機能はBOD動作に従います。BODが禁止された場合、VLMは例えVLMIEが'1'でも許可されません。BODが採取動作を使う場合、VLMも採取にされます。VLM割り込み許可時、割り込み要求フラグは電圧水準がVLM基準を横切る時にVLMCFGに従って設定(1)されます。

VLM閾値は制御A(BOD.VLMCTRLA)レジスタのVLM基準(VLMLVL)ビットを書くことによって定義されます。

#### 17.3.2. 割り込み

# 表17-1. 利用可能な割り込みへうタと供給元 名称 へうタ説明 条件 VLM 電圧水準監視部 割り込み制御(BOD.INTCTRL)レシ、スタのVLM構成設定(VLMCFG)ヒ、ットによって構成されるように供給電圧がVLM閾値を横断

VLM割り込みはCPUがデバッグ動作で停止されている場合に実行されません。

割り込み条件が起こると、周辺機能の割り込み要求フラケ(BOD.INTFLAGS)レシ、スタで対応する割り込み要求フラケが設定(1)されます。割り込み元は周辺機能の割り込み制御(BOD.INTCTRL)レシ、スタで対応する許可ビットを書くことによって許可または禁止にされます。

割り込み要求は対応する割り込み元が許可され、割り込み要求フラグが設定(1)される時に生成されます。割り込み要求は割り込み要求フラグが解除(0)されるまで活性に留まります。割り込み要求フラグを解除する方法の詳細については周辺機能のINTFLAGSレジスタをご覧ください。

#### 17.3.3. 休止形態動作

異なる休止動作形態でのBOD構成設定はヒュース、によって定義されます。活動動作とアイ・ル休止動作で使われる動作形態はFUSE.B ODCFGのACTIVEヒュース、によって定義され、制御A(BOD.CTRLA)レジスタの活動/アイ・ル時動作(ACTIVE)ビット領域に設定されます。 スタンバイ休止動作とパワーダウン休止動作で使われる動作形態はFUSE.BODCFGのSLEEPヒューズによって定義され、制御A(BOD.CTR LA)レジスタのスタンバイ/パワーダウン時動作(SLEEP)ビット領域に設定されます。

活動動作とアイドル休止動作(即ち、BOD.CTRLAのACTIVE)での動作形態はソフトウェアによって変えることができません。スタンバイ休止動作とパワーダウン休止動作での動作形態は制御A(BOD.CTRLA)レジスタの休止(SLEEP)ビット領域への書き込みによって変えることができます。

デバイスがスタンバイ休止動作またはパワーダウン休止動作へ行く時に、BODはBOD.CTRLAのSLEEPによって定義されるように動作形態を変更します。デバイスがスタンバイまたはパワーダウンの休止動作から起き上がる時に、BODは制御A(BOD.CTRLA)レジスタのACTIVEビット領域によって定義される動作形態で動きます。

## 17.3.4. 構成設定変更保護

この周辺機能は構成設定変更保護(CCP)下にあるレジスタを持ちます。これらへ書くには最初に構成設定変更保護(CPU.CCP)レジスタ へ与えられた鍵が書かれ、4 CPU命令以内に保護されたビットへの書き込みアクセスが後続しなければなりません。

適切なCCP解錠手順に従わずに保護されたレジスタへ書こうとすると、それを無変化のままにします。

右のレシブスタがCCP下です。

| レシ、スタ           | 鍵種別   |
|-----------------|-------|
| BOD.CTRLAØSLEEP | IOREG |

# 17.4. レジスタ要約

| 変位                  | 略称       | ビット位置 | ヒ゛ット7 | ピット6 | ピット5 | ピット4     | ピット3 | ピット2  | ピット1   | ピット0  |
|---------------------|----------|-------|-------|------|------|----------|------|-------|--------|-------|
| +\$00               | CTRLA    | 7~0   |       |      |      | SAMPFREQ | ACTI | VE1,0 | SLEI   | EP1,0 |
| +\$01               | CTRLB    | 7~0   |       |      |      |          |      |       | LVL2~0 |       |
| +\$02<br>-<br>+\$07 | 予約       |       |       |      |      |          |      |       |        |       |
|                     | VLMCTRLA | 7~0   |       |      |      |          |      |       | VLML   | VL1,0 |
| +\$09               | INTCTRL  | 7~0   |       |      |      |          |      | VLMC  | FG1,0  | VLMIE |
| +\$0A               | INTFLAGS | 7~0   |       |      |      |          |      |       |        | VLMIF |
| +\$0B               | STATUS   | 7~0   |       |      |      |          |      |       |        | VLMS  |

# 17.5. レジスタ説明

# **17.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位:+\$00

リセット: FUSE.BODCFGヒュース から設定

特質:構成設定変更保護

| ピット    | 7 | 6 | 5 | 4        | 3    | 2      | 1    | 0     |
|--------|---|---|---|----------|------|--------|------|-------|
|        |   |   |   | SAMPFREQ | ACT: | IVE1,0 | SLEI | EP1,0 |
| アクセス種別 | R | R | R | R        | R    | R      | R/W  | R/W   |
| リセット値  | 0 | 0 | 0 | X        | X    | X      | X    | X     |

#### ● ビット4 - SAMPFREQ:採取周波数(Sample Frequency)

このビットはBOD採取周波数を制御します。

リセット値はFUSE.BODCFGのBOD採取周波数(SAMPFREQ)ビットから取得/設定されます。

このビットは構成設定保護(CCP)下ではありません。

| 値  | 0             | 1              |
|----|---------------|----------------|
| 説明 | 採取周波数は1kHzです。 | 採取周波数は125Hzです。 |

# ● ビット3,2 - ACTIVE1.0:活動/アイドル時動作(Active)

これらのビットはデバイスが活動動作とアイドル休止動作の時のBOD動作形態を選びます。

リセット値はFUSE.BODCFGの活動とアイドルでのBOD動作形態(ACTIVE)ビット領域から取得/設定されます。

このビット領域は構成設定変更保護(CCP)下ではありません。

| 値  | 0 0 | 0 1     | 1 0     | 11                          |
|----|-----|---------|---------|-----------------------------|
| 名称 | DIS | ENABLED | SAMPLED | ENWAIT                      |
| 説明 | 禁止  | 継続動作で許可 | 採取動作で許可 | 継続動作で許可。実行は起き上がりでBODが動くまで停止 |

#### ビット1,0 - SLEEP1,0: スタンハ・イ/パワーダ・ウン時動作(Sleep)

これらのビットはデバイスがスタンバイとパワーダウンの休止動作の時のBOD動作形態を選びます。

リセット値はFUSE.BODCFGの休止でのBOD動作形態(SLEEP)ビット領域から取得/設定されます。

| 値  | 0 0 | 0 1     | 1 0     | 11   |
|----|-----|---------|---------|------|
| 名称 | DIS | ENABLED | SAMPLED | _    |
| 説明 | 禁止  | 継続動作で許可 | 採取動作で許可 | (予約) |

#### **17.5.2. CTRLB - 制御B** (Control B)

名称 : CTRLB 変位 : +\$01

リセット: FUSE.BODCFGヒュース から設定

特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0 |
|--------|---|---|---|---|---|---|--------|---|
|        |   |   |   |   |   |   | LVL2~0 |   |
| アクセス種別 | R | R | R | R | R | R | R      | R |
| リセット値  | 0 | 0 | 0 | 0 | 0 | X | X      | X |

# ● ビット2~0 - LVL2~0: BOD基準 (BOD Level)

このビット領域はBOD閾値基準を制御します。

リセット値はBOD構成設定(FUSE.BODCFG)ヒュース、のBOD基準(LVL)ヒットから取得/設定されます。

| 値  | 0 0 0     | 0 1 0     | 111       |
|----|-----------|-----------|-----------|
| 名称 | BODLEVEL0 | BODLEVEL2 | BODLEVEL7 |
| 説明 | 1.8V      | 2.6V      | 4.2V      |

- 注:・更なる詳細については電気的特性でBODとPORの特性を参照してください。
  - ・説明内の値は代表値です。

# 17.5.3. VLMCTRLA - VLM制御A (VLM Control A)

名称: VLMCTRLA

変位:+\$08 リセット:\$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1         | 0   |
|--------|---|---|---|---|---|---|-----------|-----|
|        |   |   |   |   |   |   | VLMLVL1,0 |     |
| アクセス種別 | R | R | R | R | R | R | R/W       | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0         | 0   |

#### ● ビット1,0 - VLMLVL1,0: VLM基準 (VLM Level)

これらのビットはBOD閾値(BOD.CTRLBのLVL)に相対する電圧水準監視部(VLM)閾値を選びます。

| 値  | 0 0            | 0 1             | 1 0             | 11   |
|----|----------------|-----------------|-----------------|------|
| 説明 | BOD閾値+5%がVLM閾値 | BOD閾値+15%がVLM閾値 | BOD閾値+25%がVLM閾値 | (予約) |

# 17.5.4. INTCTRL - 割り込み制御 (Interrupt Control)

名称: INTCTRL 変位: +\$09 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2    | 1     | 0     |
|--------|---|---|---|---|---|------|-------|-------|
|        |   |   |   |   |   | VLMC | FG1,0 | VLMIE |
| アクセス種別 | R | R | R | R | R | R/W  | R/W   | R/W   |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0    | 0     | 0     |

## ● ビット2,1 - VLMCFG1,0: VLM構成設定 (VLM Configuration)

これらのビットはどの出来事がVLM割り込みを起動するかを選びます。

| 値  | 0 0            | 0 1            | 10            | 1 1  |
|----|----------------|----------------|---------------|------|
| 名称 | BELOW          | ABOVE          | CROSS         | _    |
| 説明 | VDDがVLM閾値未満へ下降 | VDDがVLM閾値越えへ上昇 | VDDがVLM閾値を横切る | (予約) |

#### ● ビット0 - VLMIE: VLM割り込み許可(VLM Interrupt Enable)

このビットへの'1'書き込みは電圧水準監視部(VLM)割り込みを許可します。

## 17.5.5. INTFLAGS - VLM割り込み要求フラク (VLM Interrupt Flag)

名称: INTFLAGS 変位:+\$0A リセット: \$00 特質:-

| ピット _  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
|--------|---|---|---|---|---|---|---|-------|
|        |   |   |   |   |   |   |   | VLMIF |
| アクセス種別 | R | R | R | R | R | R | R | R/W   |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0     |

#### ● ビット0 - VLMIF: VLM割り込み要求フラグ(VLM Interrupt Flag)

このフラグは割り込み制御(BOD.INTCTRL)レジスタのVLM構成設定(VLMCFG)ビットによって構成設定されるように、VLMからの起動が与えられる時に設定(1)されます。このフラグはBODが許可されている時にだけ更新されます。

# 17.5.6. STATUS - VLM状態 (VLM Status)

名称: STATUS 変位:+\$0B リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|--------|---|---|---|---|---|---|---|------|
|        |   |   |   |   |   |   |   | VLMS |
| アクセス種別 | R | R | R | R | R | R | R | R/W  |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    |

# ● ビット0 - VLMS: VLM状態 (VLM Status)

このビットはBODが許可されている時にだけ有効です。

| 値  | 0                | 1                |
|----|------------------|------------------|
| 説明 | 電圧はVLM閾値レベル以上です。 | 電圧はVLM閾値レヘル以下です。 |

# 18. VREF - 基準電圧

## 18.1. 特徴

- ・ 設定可能な基準電圧源
  - 各A/D変換器(ADC)周辺機能用に1つ
  - 各アナログ比較器(AC)及びD/A変換器(DAC)周辺機能用に1つ
- ・各基準元は以下の5つの異なる電圧を支援
  - -0.55V
  - 1.1V
  - 1.5V
  - 2.5V
  - 4.3V

# 18.2. 概要

基準電圧(VREF)周辺機能は様々な周辺機能によって使われる基準電圧源に対する制御レジスタを提供します。使用者は制御A(VR EF.CTRLx)レジスタのADCn基準選択(ADCnREFSEL)ビット領域に書くことによってADCn用の、VREF.CTRLxレジスタのACn/DACn基準選択(DACnREFSEL)ビット領域に書くことによってACnとDACn両方用の基準電圧を選ぶことができます。

基準電圧源は周辺機能によって要求される時に自動的に許可されます。使用者は制御B(VREF.CTRLB)レジスタの各々の強制許可 (ADCnREFENとDACnREFEN)ビットへ書くことによって基準電圧源を許可(故に未使用供給元の自動禁止を無効に)することができます。これは消費電力の増加を犠牲にして始動時間を減らすために行われるかもしれません。

#### 18.2.1. 構成図



## 18.3. 機能的な説明

## 18.3.1. 初期化

既定構成設定はADCn、ACn、またはDACnが基準電圧を要求する時に各々の供給元を許可します。既定基準電圧は0.55Vですが、制御A/C(VREF.CTRLA/C)レジスタの各々の基準選択(ADCnREFSELとDACnREFSEL)のビット領域に書くことによって構成設定することができます。

# 18.4. レジスタ要約

| 変位    | 略称    | ピット位置 | ヒ゛ット7 | ピット6          | ピット5      | じット4      | ピット3      | ヒット2 | ピット1        | ピット0      |  |
|-------|-------|-------|-------|---------------|-----------|-----------|-----------|------|-------------|-----------|--|
| +\$00 | CTRLA | 7~0   |       | ADC0REFSEL2~0 |           |           |           | DA   | COREFSEL2~0 |           |  |
| +\$01 | CTRLB | 7~0   |       |               | DAC2REFEN | ADC1REFEN | DAC1REFEN |      | ADC0REFEN   | DAC0REFEN |  |
| +\$02 | CTRLC | 7~0   |       | AD            | C1REFSEL2 | ~0        |           | DA   | C1REFSEL2   | 2~0       |  |
| +\$03 | CTRLD | 7~0   |       |               |           |           |           | DA   | C2REFSEL2   | 2~0       |  |

# 18.5. レジスタ説明

**18.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位:+\$00 リセット: \$00 特質:-

| ピット    | 7 | 6   | 5         | 4   | 3 | 2             | 1   | 0   |  |
|--------|---|-----|-----------|-----|---|---------------|-----|-----|--|
|        |   | AI  | COREFSEL2 | ~0  |   | DAC0REFSEL2~0 |     |     |  |
| アクセス種別 | R | R/W | R/W       | R/W | R | R/W           | R/W | R/W |  |
| リセット値  | 0 | 0   | 0         | 0   | 0 | 0             | 0   | 0   |  |

● ビット6~4 - ADC0REFSEL2~0: ADC0基準選択 (ADC0 Reference Select)

このビット領域はA/D変換器(ADC0)用の基準電圧を選びます。

| 値  | 0 0 0 | 0 0 1 | 0 1 0 | 0 1 1 | 100  | 101  | 1 1 0 | 111 |
|----|-------|-------|-------|-------|------|------|-------|-----|
| 説明 | 0.55V | 1.1V  | 2.5V  | 4.3V  | 1.5V | (予約) |       |     |

● ビット2~0 - DACOREFSEL2~0: ACOとDACO基準選択 (DACO and ACO Reference Select)

このビット領域はD/A変換器(DAC0)とアナログ比較器(AC0)用の基準電圧を選びます。

| 値  | 0 0 0 | 0 0 1 | 0 1 0 | 0 1 1 | 100  | 101 | 1 1 0 | 111 |
|----|-------|-------|-------|-------|------|-----|-------|-----|
| 説明 | 0.55V | 1.1V  | 2.5V  | 4.3V  | 1.5V |     | (予約)  |     |

# **18.5.2. CTRLB - 制御B** (Control B)

名称: CTRLB 変位:+\$01 リセット: \$00 特質:-

| <b>ビット</b> | 7 | 6 | 5         | 4         | 3         | 2 | 1         | 0         |
|------------|---|---|-----------|-----------|-----------|---|-----------|-----------|
|            |   |   | DAC2REFEN | ADC1REFEN | DAC1REFEN |   | ADC0REFEN | DAC0REFEN |
| アクセス種別     | R | R | R/W       | R/W       | R/W       | R | R/W       | R/W       |
| リセット値      | 0 | 0 | 0         | 0         | 0         | 0 | 0         | 0         |

- ビット5 DAC2REFEN: AC2とDAC2基準電圧強制許可(DAC2 and AC2 Reference Force Enable)
- このビットへの'1'書き込みは、例えそれが要求されなくても、D/A変換器(DAC2)とアナログ比較器(AC2)用の基準電圧を強制します。 このビットへの'0'書き込みは周辺機能による基準源の自動許可/禁止を許します。
- ビット4 ADC1REFEN: ADC1基準電圧強制許可(ADC1 Reference Force Enable)
- このビットへの'1'書き込みは、例えそれが要求されなくても、A/D変換器(ADC1)用の基準電圧を強制します。
- このビットへの'0'書き込みは周辺機能による基準源の自動許可/禁止を許します。
- 注: ADCが(ADC.CTRLCのREFSELビット領域で)外部参照基準を使っている時に内部参照基準の許可(VREF.CTRLBのADCnREFE N=1)を強制しないでください。
- ビット3 DAC1REFEN: AC1とDAC1基準電圧強制許可(DAC1 and AC1 Reference Force Enable)
- このビットへの'1'書き込みは、例えそれが要求されなくても、D/A変換器(DAC1)とアナログ比較器(AC1)用の基準電圧を強制します。 このビットへの'0'書き込みは周辺機能による基準源の自動許可/禁止を許します。
- ビット1 ADCOREFEN: ADCO基準電圧強制許可(ADCO Reference Force Enable)
- このビットへの'1'書き込みは、例えそれが要求されなくても、A/D変換器(ADC0)用の基準電圧を強制します。
- このビットへの'0'書き込みは周辺機能による基準源の自動許可/禁止を許します。
- 注: ADCが(ADC.CTRLCのREFSELt'ット領域で)外部参照基準を使っている時に内部参照基準の許可(VREF.CTRLBのADCnREFE N=1)を強制しないでください。
- ビット0 DACOREFEN: ACOとDACO基準電圧強制許可 (DACO and ACO Reference Force Enable)

このビットへの'1'書き込みは、例えそれが要求されなくても、D/A変換器(DAC0)とアナログ比較器(AC0)用の基準電圧を強制します。このビットへの'0'書き込みは周辺機能による基準源の自動許可/禁止を許します。

# **18.5.3. CTRLC - 制御C** (Control C)

名称: CTRLC 変位:+\$02 リセット: \$00 特質:-

| ADC1REFSEL2~0 DAC1REFSEL2~0 Tクセス種別 R R/W R/W R/W R R/W R/W R/W | ピット    | 7 | 6   | 5         | 4   | 3 | 2   | 1          | 0   |
|----------------------------------------------------------------|--------|---|-----|-----------|-----|---|-----|------------|-----|
|                                                                |        |   | Αİ  | C1REFSEL2 | ~0  |   | D.  | AC1REFSEL2 | ~0  |
|                                                                | アクセス種別 | R | R/W | R/W       | R/W | R | R/W | R/W        | R/W |
| リセット値 0 0 0 0 0 0 0 0                                          | リセット値  | 0 | 0   | 0         | 0   | 0 | 0   | 0          | 0   |

## ● ビット6~4 - ADC1REFSEL2~0: ADC1基準選択 (ADC1 Reference Select)

このビット領域はA/D変換器(ADC1)用の基準電圧を選びます。

| 値  | 0 0 0 | 0 0 1 | 0 1 0 | 0 1 1 | 100  | 101  | 110 | 111 |  |
|----|-------|-------|-------|-------|------|------|-----|-----|--|
| 説明 | 0.55V | 1.1V  | 2.5V  | 4.3V  | 1.5V | (予約) |     |     |  |

# ● ビット2~0 - DAC1REFSEL2~0: AC1とDAC1基準選択 (DAC1 and AC1 Reference Select)

このビット領域はD/A変換器(DAC1)とアナログ比較器(AC1)用の基準電圧を選びます。

| 値  | 0 0 0 | 0 0 1 | 0 1 0 | 0 1 1 | 1 0 0 | 1 0 1 | 1 1 0 | 111 |
|----|-------|-------|-------|-------|-------|-------|-------|-----|
| 説明 | 0.55V | 1.1V  | 2.5V  | 4.3V  | 1.5V  |       | (予約)  |     |

# **18.5.4. CTRLD - 制御D** (Control D)

名称: CTRLD 変位: +\$03 リセット: \$00 特質: -

| ヒ"ット   | 7 | 6 | 5 | 4 | 3 | 2   | 1          | 0   |
|--------|---|---|---|---|---|-----|------------|-----|
|        |   |   |   |   |   | D/  | AC2REFSEL2 | ~0  |
| アクセス種別 | R | R | R | R | R | R/W | R/W        | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0   | 0          | 0   |

## ● ビット2~0 - DAC2REFSEL2~0: AC2とDAC2基準選択 (DAC2 and AC2 Reference Select)

このビット領域はD/A変換器(DAC2)とアナログ比較器(AC2)用の基準電圧を選びます。

| 値  | 0 0 0 | 0 0 1 | 010  | 0 1 1 | 100  | 101  | 1 1 0 | 111 |
|----|-------|-------|------|-------|------|------|-------|-----|
| 説明 | 0.55V | 1.1V  | 2.5V | 4.3V  | 1.5V | (予約) |       |     |

# 19. WDT - ウォッチト゛ック゛ タイマ

#### 19.1. 特徴

- ・時間超過前にウォッチドッグタイマが解消されない場合にシステム リセットを発行
- ・独立した発振器を用いるシステムクロックからの非同期動作
- ・32.768kHz超低電力発振器(OSCULP32K)の1.024kHz出力を使用
- ・8msから8sまで11種の選択可能な時間超過制限期間
- 2つの動作形態
  - 標準動作
  - 窓動作
- ・望まれない変更を防ぐための構成設定施錠
- ・容易な構成設定のための初回WDT命令後の閉鎖期間計時器活性化

# 19.2. 概要

ウォッチト、ック、タイマ(WDT)は正しいプログラム動作を監視するためのシステム機能です。リセットを発行することによって、暴走や停滞されたコートのような状況からの回復をシステムに許します。許可されると、WDTは予め定義された制限期間に構成設定されて定常的に走行する計時器です。WDTが制限期間内にリセットされなければ、システム リセットを発行します。WDTはソフトウェアからウォッチト、ック、タイマ リセット(WDR)命令を実行することによってリセットされます。

WDTは標準動作と窓動作の2つの動作形態を持ちます。制御A(WDT.CTRLA)レジスタの設定がこの動作形態を決めます。

窓動作はWDTがリセットされなければならない間の制限時間内側の時間幅または窓を定義します。WDTが速すぎまたは遅すぎでこの窓の外側でリセットされた場合、システム リセットが発行されます。標準動作に比べ、窓動作はコート、異常が一定のWDR実行を引き起こす状況を捕らえることができます。

許可されると、WDTは活動動作と全ての休止動作で動きます。これは非同期で、即ちCPUと無関係なクロック元で動きます。この理由のため、例え主クロックが動かなくても、動作を継続してシステム リセットを発行することができます。

構成設定変更保護機構(CCP)はWDT設定が事故によって変更され得ないことを保証します。安全性を増すため、WDT設定を施錠するための構成設定が利用可能です。

## 19.2.1. 構成図



#### 19.3. 機能的な説明

#### 19.3.1. 初期化

- ・WDTは制御A(WDT.CTRLA)レジスタの期間(PERIOD)ビットに0以外の値が書かれる時に許可されます。
- ・任意選択:窓形態動作を許可するにはWDT.CTRLAレジスタの窓(WINDOW)ビットに0以外の値を書いてください。

制御A(WDT.CTRLA)の全ビットと状態(WDT.STATUS)レジスタの施錠(LOCK)ビットは構成設定変更保護機構によって書き込み保護されます。

WDT.CTRLAレジ、スタのリセット値はFUSE.WDTCFGヒュース。によって定義され、故にWDTはブート時に許可することができます。これがその場合なら、WDT.STATUSレジ、スタのLOCKビットはブート時に設定(1)されます。

#### 19.3.2. クロック

1.024kHz発振器クロック(CLK\_WDT\_OSC)は内部超低電力発振器(OSCULP32K)から供給されます。超低電力設計のため、この発振器は全く正確ではなく、故に正確な制限時間はデバイス毎に変わり得ます。全てのデバイスに対して使われる制限時間が有効なことを保証するためにWDTを使うソフトウェア設計時、この変化が念頭に置かれなければなりません。

1.024kHz計数器クロックのCLK\_WDT\_OSCはシステム クロックに対して非同期です。この非同期性のため、WDT制御レジスタへの書き込みはクロック領域間の同期が必要です。

#### 19.3.3. 動作

#### 19.3.3.1. 標準動作

標準動作では、WDTに単一制限期間が設定されます。時間超過が起きる前のどの時でもWDTがWDR命令を用いてソフトウェアからリセットされない場合、WDTはシステム リセットを発行します。

新しいWDT制限期間はWDR命令によってWDTがリセットされる毎に開始されます。

制御A(WDT.CTRLA)レジスタの期間(PERIOD)ビット領域に書くことによって8msから8sまで選択可能な11種の可能なWDT制限期間(TOWDT)があります。

標準動作は制御A(WDT.CTRLA)レジスタの窓(WINDOW)ビット領域が'0000'である限り許可されます。



#### 19.3.3.2. 窓動作

窓動作では2つの異なる制限期間、WDTが標準制限期間(TOWDT)と閉鎖窓制限期間(TOWDTW)を使います。

- ・閉鎖窓制限期間はWDTをリセットすることができない8msから8sまでの持続期間を定義します。この期間の間にWDTがリセットされた場合、WDTはシステム リセットを発行します。
- ・標準WDT制限期間も8msから8sで、WDTをリセットすることができる(必要がある)間の開放持続期間を定義します。開放期間は常に閉鎖期間に続き、故に総制限期間持続期間は閉鎖窓と開放窓の制限期間の合計です。

窓動作許可時、またはデバッグ動作の外に出る時に、最初の閉鎖期間は最初のWDR命令後に活性(有効)にされます。

前のWDRが同期されつつある間に2つ目のWDRが発行された場合、2つ目のものは無視されます。

窓動作は制御A(WDT.CTRLA)レシブスタの窓(WINDOW)ビット領域 に0以外の値を書くことによって許可され、それに\$0を書くことに よって禁止されます。



#### 19.3.3.3. 構成設定保護と施錠

WDTはWDT設定に対して意図せぬ変更を避けるために2つの安全機構を提供します。

最初の機構はWDT制御レジスタ変更のために制限時間書き込み手順を使う構成設定変更保護機構です。

2つ目の機構は状態(WDT.STATUS)レジスタの施錠(LOCK)ビットに'1'を書くことによって構成設定を施錠します。このビットが'1'の時に制御A(WDT.CTRLA)レジスタは変更することができません。結果としてWDTはソフトウェアから禁止することができません。

WDT.STATUSレシ、スタのLOCKビットは'1'を書くことだけできます。デバッグ動作でだけ解除(0)することができます。

WDT構成設定がヒューズから取得/設定される場合、LOCKビットはWDT.STATUSレジスタで自動的に設定(1)されます。

# 19.3.4. 休止形態動作

WDTは供給元クロックが活性であるどの休止動作形態でも動作を続けます。

#### 19.3.5. デバッグ操作

デバッグ動作形態でのCPU停止時、WDT計数器はリセットされます。

WDTが窓動作で動いていてCPUを再び開始すると、最初の閉鎖窓制限時間は禁止され、標準動作制限時間が実行されます。

# 19.3.6. 同期

主クロック領域と周辺機能クロック領域間が非同期なため、制御A(WDT.CTRLA)レン゙スタは書かれた時に同期されます。状態(WDT.STAT US)レジスタの同期化多忙(SYNCBUSY)フラグは進行中の同期化があるかを示します。

SYNCBUSY=1の間のWDT.CTRLAレジスタ書き込みは許されません。

以下のレジスタ ビットが書かれた時に同期化されます。

- ・制御A(WDT.CTRLA)レシブスタの期間(PERIOD)ビット
- ・WDT.CTRLAレジスタの窓期間(WINDOW)ビット

WDR命令は同期するのに2~3周期のWDTクロックが必要です。WDR命令が同期されつつある間の新しいWDR命令は無視されます。

## 19.3.7. 構成設定変更保護

この周辺機能は構成設定変更保護(CCP)下にあるレジスタを持ちます。これらへ書くには最初に構成設定変更保護(CPU.CCP)レジスタへ与えられた鍵が書かれ、4 CPU命令以内に保護されたビットへの書き込みアクセスが後続しなければなりません。

適切なCCP解錠手順に従わずに保護されたレジスタへ書こうとすると、それを無変化のままにします。

右のレシブスタがCCP下です。

CCPによって保護されるビット/レジスタの一覧は以下です。

- ・制御A(WDT.CTRLA)レシ、スタの期間(PERIOD)ビット
- ・制御A(WDT.CTRLA)レジスタの窓期間(WINDOW)ビット
- ・状態(WDT.STATUS)レシブスタの施錠(LOCK)ビット

| 鍵種別   |
|-------|
| IOREG |
| IOREG |
|       |

# 19.4. レジスタ要約

| 変位    | 略称     | ピット位置 | ヒ゛ット7 | ピット6  | ピット5 | ピット4 | ピット3      | ピット2 | ピット1 | ビット0     |  |  |
|-------|--------|-------|-------|-------|------|------|-----------|------|------|----------|--|--|
| +\$00 | CTRLA  | 7~0   |       | WINDO | W3∼0 |      | PERIOD3~0 |      |      |          |  |  |
| +\$01 | STATUS | 7~0   | LOCK  |       |      |      |           |      |      | SYNCBUSY |  |  |

# 19.5. レジスタ説明

## **19.5.1. CTRLA - 制御A** (Control A)

名称 : CTRLA 変位 : +\$00

リセット: FUSE.WDTCFGからの値 特質:構成設定変更保護

| ピット    | 7   | 6    | 5     | 4   | 3   | 2     | 1     | 0   |
|--------|-----|------|-------|-----|-----|-------|-------|-----|
|        |     | WIND | OW3∼0 |     |     | PERIC | )D3~0 |     |
| アクセス種別 | R/W | R/W  | R/W   | R/W | R/W | R/W   | R/W   | R/W |
| リセット値  | X   | X    | X     | X   | X   | X     | X     | X   |

# ビット7~4 - WINDOW3~0:窓期間 (Window)

これらのビットへの0以外の値の書き込みが窓動作を許可し、それに応じて閉鎖期間の持続期間を選びます。

このビットは以下のように任意選択で施錠保護されます。

- ・状態(WDT.STATUS)レシ、スタの施錠(LOCK)ビットが、1、の場合、全ビットが変更保護されます(アクセス=R)。
- ・WDT.STATUSレシ、スタのLOCKビットが'0'の場合、全ビットを変更することができます(アクセス=R/W)。

| 値  | 0000 | 0001   | 0010   | 0011   | 0100   | 0101   | 0110   | 0111   | 1000  | 1001  | 1010  | 1011  | その他  |
|----|------|--------|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|------|
| 名称 | OFF  | 8CLK   | 16CLK  | 32CLK  | 64CLK  | 128CLK | 256CLK | 512CLK | 1KCLK | 2KCLK | 4KCLK | 8KCLK | _    |
| 説明 | 1    | 0.008s | 0.016s | 0.031s | 0.063s | 0.125s | 0.25s  | 0.5s   | 1s    | 2s    | 4s    | 8s    | (予約) |

#### ビット3~0 - PERIOD3~0:制限期間(Period)

これらのビットへの0以外の値の書き込みがWDTを許可し、それに応じて標準動作での制限期間を選びます。窓動作でのこれらのビッ トは開放窓の持続期間を選びます。

このビットは以下のように任意選択で施錠保護されます。

- ・状態(WDT.STATUS)レシ、スタの施錠(LOCK)ヒットが、1、の場合、全ビットが変更保護されます(アクセス=R)。
- ・WDT.STATUSレシ、スタのLOCKビットが'0'の場合、全ビットを変更することができます(アクセス=R/W)。

| 値  | 0000 | 0001   | 0010   | 0011   | 0100   | 0101   | 0110   | 0111   | 1000  | 1001  | 1010  | 1011  | その他  |
|----|------|--------|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|------|
| 名称 | OFF  | 8CLK   | 16CLK  | 32CLK  | 64CLK  | 128CLK | 256CLK | 512CLK | 1KCLK | 2KCLK | 4KCLK | 8KCLK | -    |
| 説明 | -    | 0.008s | 0.016s | 0.031s | 0.063s | 0.125s | 0.25s  | 0.5s   | 1s    | 2s    | 4s    | 8s    | (予約) |

# **19.5.2**. **STATUS** - 状態 (Status)

名称: STATUS 変位:+\$01 リセット: \$00

特質:LOCKビットは構成設定変更保護

| ピット    | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0        |
|--------|------|---|---|---|---|---|---|----------|
|        | LCOK |   |   |   |   |   |   | SYNCBUSY |
| アクセス種別 | R/W  | R | R | R | R | R | R | R        |
| リセット値  | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0        |

#### ビット7 - LOCK: 施錠(Lock)

このビットの'1'書き込みは制御A(WDT.CTRLA)レジスタを書き込み保護します。

このビットに'1'を書くことだけが可能です。このビットはディック動作でだけ解除(0)することができます。

ウォッチト、ック、タイマ構成設定(WDTCFG)ヒュース、のウォッチト、ック、制限時間周期(PERIOD)値が0と違う場合、自動的に施錠が設定されます。 このビットは構成設定変更保護(CCP)下です。

#### ● ビット0 - SYNCBUSY: 同期化多忙 (Synchronization Busy)

このビットはWDT.CTRLAレジスタを書いた後にデータがシステム クロック領域からWDTクロック領域へ同期化されつつある間、設定(1)されます。

このビットは同期化終了後に解除(0)されます

このビットは構成設定変更保護(CCP)下ではありません。

# 20. TCA - 16ビット タイマ/カウンタA型

#### 20.1. 特徴

- ・ 16ビット タイマ/カウンタ
- ・3つの比較チャネル
- ・2重緩衝されたタイマ定期間設定
- ・2重緩衝された比較チャネル
- 波形生成:
  - 周波数生成
  - 単一傾斜PWM(パルス幅変調)
  - 2傾斜PWM
- ・ 事象での計数
- ・計時器溢れ割り込み/事象
- ・比較チャネル当たり1つの比較一致
- ・分割動作での2つの8ビットタイマ/カウンタ

#### 20.2. 概要

柔軟な16ビット タイマ/カウンタA型(TCA)は正確なプログラム実行タイミング、周波数と波形の生成、指令実行を提供します。

TCAは基本計数器と比較チャネルの組から成ります。基本計数器はクロック周期または事象を計数するのに使うことができ、またクロック周期をどう計数するかを事象に制御させます。それは方向制御を持ち、タイミングに周期設定を使うことができます。比較チャネルは基本計数器と共に、比較一致制御、周波数生成、プルス幅波形変調を実行するのに使うことができます。

動作形態に依存して、計数器は各タイマ/カウンタクロックまたは事象入力で解消、再設定、増加、減少されます。

タイマ/カウンタは任意選択の前置分周を持つ周辺機能クロックから、または事象システムからクロック駆動と計時をすることができます。事象システムは方向制御または動作の同期にも使うことができます。

既定で、TCAは16ビット タイマ/カウンタです。このタイマ/カウンタは各々3つの比較チャネルを持つ2つの8ビット タイマ/カウンタに分割する分割動作機能を持ちます。使う動作形態に応じて、レジスタのアドレス付けや、ビット遮蔽と群構成設定の使用は以降のように、レジスタに対してTCAn.SINGLE.REGISTERまたはTCAn.SPLIT.REGISTER、ビット遮蔽と群構成設定の例としてTCA\_SINGLE\_CLKSEL\_DIV1\_gcまたはTCA\_SPLIT\_CLKSEL\_DIV1\_gcのどちらかとして行われます。

本章でレシブスタはTCAn.REGISTERとしてアトブレス付けされます。

下図は密接に関連する(青枠の(訳注:原書は灰色の))周辺機能単位部を伴う16ビット タイマ/カウンタの構成図を示します。



#### 20.2.1. 構成図

下図はこのタイマ/カウンタの詳細な構成図を示します。



計数(TCAn.CNT)レジネタ、定期と比較(TCAn.PERとTCAn.CMPn)のレジネタ、それらに対応する(TCAn.PERBUFとTCAn.CMPnBUF)の 緩衝レジスタは16ビット レジスタです。全ての緩衝レジスタは緩衝部が新しい値を含む時を示す緩衝有効(BV)フラグを持ちます。

標準動作の間、計数器値は計数器がTOPまたはBOTTOMに達したかどうかを決めるために0と定期(PER)値と継続的に比較されます。計数器値はTCAn.CMPnレシブタとも比較されます。

タイマ/カウンタは割り込み要求、事象を生成したり、計数器(TCAn.CNT)レジスタがTOP、BOTTOM、またはCMPnに達することによって起動された後に波形出力を変更することができます。起動後、割り込み要求、事象、波形出力変更は次のCLK\_TCA周期で起こります。

下図で示されるように、CLK\_TCAは前置分周された周辺機能クロックカン、または事象システムからの事象のどちらかです。



# 20.2.2. 信号説明

| 信号  | 形式     | 説明   |
|-----|--------|------|
| WOn | デジタル出力 | 波形出力 |

#### 20.3. 機能的な説明

#### 20.3.1. 定義

以下の定義は文書全体を通して使われます。

| 表20-1. タイマ/カウンタ定義 |                                                                                                                             |  |  |  |  |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 名称                | 説明                                                                                                                          |  |  |  |  |
| BOTTOM            | 計数器が底(BOTTOM)に到達し、それが\$0000になる時                                                                                             |  |  |  |  |
| MAX               | 計数器が最大(MAXimum)に到達し、それが全て1になる時                                                                                              |  |  |  |  |
| TOP               | 計数器が頂上(TOP)に到達し、それが計数の流れで最高値と等しくなる時                                                                                         |  |  |  |  |
| UPDATE            | 更新条件一致、波形生成動作に依存してタイマ/カウンタがBOTTOMまたはTOPに到達する時。有効な緩衝値を持つ<br>緩衝されるレジスタは制御E(TCAn.CTRLE)レジスタの更新施錠(LUPD)ビットが設定(1)されていない限り更新されます。 |  |  |  |  |
| CNT               | 計数器レジスタ値                                                                                                                    |  |  |  |  |
| CMP               | 比較レジスタ値                                                                                                                     |  |  |  |  |
| PER               | 定期(周期)レシブスタ値                                                                                                                |  |  |  |  |

一般的に用語の計時器はタイマ/カウンタが周期的クロック刻みを計数する時に使われます。用語の計数器は入力信号が散発的または不規則なクロック刻みを持つ時に使われます。後者は事象計数時の場合に有り得ます。

#### 20.3.2. 初期化

基本動作でタイマ/カウンタの使用を開始するには以下のようにこれらの手順に従ってください。

- 1. 定期(TCAn.PER)レシブスタにTOP値を書いてください。
- 2. 制御A(TCAn.CTRLA)レジスタの許可(ENABLE)ビットに'1'を書くことによって周辺機能を許可してください。 計数器はTCAn.CTRL Aレジスタのクロック選択(CLKSEL)ビット領域で設定した前置分周器に従ったクロック刻みの計数を開始します。
- 3. 任意選択: 事象制御(TCAn.EVCTRL)レジスタの事象入力で計数許可(CNTEI)ビットに'1'を書くことにより、クロック刻みに代わって事象が計数されます。
- 4. 計数値は計数(TCAn.CNT)レシブスタの計数(CNT)ビット領域から読むことができます。

#### 20.3.3. 動作

#### 20.3.3.1. 標準動作

標準動作では計数器がTOPまたはBOTTOMに達するまで、制御E(TCAn.CTRLE)レジスタの方向(DIR)ビットによって選ばれる方向でクロック刻みを計数します。制御A(TCAn.CTRLA)レジスタのクロック選択(CLKSEL)ビット領域に従って前置分周した周辺機能クロック(CLK\_PE R)がクロック刻みを与えます。

計数器が上昇計数中にTOPに達すると、計数器は次のクロック刻みで'0'に丸められます。下降計数時、計数器はBOTTOMに達した時に定期(TCAn.PER)レジスタ値で再設定されます。

計数器が走行している時に計数(TCAn.CNT)レジスタの計数値を変更することが可能です。TCAn.CNTへの書き込みアクセスは計数、解消、再設定よりも高い優先権を持ち、直ちに行われます。計数器の方向はTCAn.CTRLEレジスタのDIRビットに書くことによって標準動作の間でも変更することができます。



#### 20.3.3.2. 2重緩衝

定期(TCAn.PER)レシブスタ値と比較n(TCAn.CMPn)レシブスタ値は全て2重緩衝(TCAn.PERBUFとTCAn.CMPnBUF)されます。

各々の緩衝レジスタは緩衝レジスタが対応する定期または比較のレジスタ内に複写することができる有効な(新しい)値を含むことを示す、制御F(TCAn.CTRLF)レジスタ内の緩衝有効(BV)フラグ(PERBVとCMPnBV)を持ちます。定期レジスタと比較nレジスタが比較動作に使われる時に、BVフラグはデータが緩衝レジスタに書かれる時に設定(1)され、UPDATE条件で解除(0)されます。この図は比較レジスタに関して示します。

TCAn.CMPnとTCAn.CMPnBUFのレシブスタはI/Oレシブスタとして利用可能で、緩衝レシブスタの初期化と迂回、2重緩衝機能を許します。



#### 20.3.3.3. 周期変更

計数器の周期は新しいTOP値を定期(TCAn.PER)レジスタ へ書くことによって変更されます。

**緩衝なし**: 2重緩衝を使わない場合、どんな周期変更も 直ちに行われます。

図20-6. 緩衝なし周期変更

現CNTより高い新TOP値PER書き込み 計数器丸め MAX O "更新"
CNT TOP BOTTOM 現CNTより低い新TOP値PER書き込み

計数(TCAn.CNT)と定期(TCAn.PER)のレシ、スタが継続的に 比較されるため、計数器丸めは緩衝なしでの上昇計数時 のどの動作形態でも起こり得ます。現在のTCAn.CNTより も低い新しいTOP値をTCAn.PERに書く場合、計数器は 比較一致が起こるのに先立って先に丸めを行うでしょう。



緩衝有り: 2重緩衝を使うと、緩衝部は何時でも書けて、 未だ正しい動作を維持します。右図の2傾斜 動作に対して示されるように、定期(TCAn.P ER)レジスタは常に"更新"(UPDATE)条件で更 新されます。これは丸めと奇数波形の生成を 防ぎます。

注: 他に指定されない場合、TCA動作を示す図では緩衝が使われます。



#### 20.3.3.4. 比較チャネル

各比較nチャネルは計数器(TCAn.CNT)値を比較n(TCAn.CMPn)レシ、スタと継続的に比較します。TCAn.CNTとTCAn.CMPnが等しい場合、比較器は一致を合図します。この一致は次の計時器クロック周期で比較チャネルの割り込み要求フラケ(INTFLAGS.CMPn)を設定(1)し、任意選択の割り込みが生成されます。

比較n緩衝(TCAn.CMPnBUF)レシ、スタは定期緩衝(TCAn.PERBUF)レシ、スタのものと等価な能力を持つ2重緩衝を提供します。2重緩衝はUPDATE条件に従って、計数の流れのTOPまたはBOTTOMのどちらかに対して緩衝値でのTCAn.CMPnレシ、スタの更新を同期化します。同期化は不具合なしの出力のために奇数長の発生、非対称ハ。ルスを防ぎます。

CMPnBUFの値はUPATE条件でCMPnに移動され、次の計数から計数器(TCAn.CNT)値と比較されます。

#### 20.3.3.4.1. 波形生成

比較チャネルは対応するポート ピンでの波形生成に使うことができます。接続されたポート ピンで波形を見ることができるようにするには、以下の必要条件が完全に満たされなければなりません。

- 1. 制御B(TCAn.CTRLB)レジスタの波形生成動作(WGMODE)ビット領域を書くことによって波形設定動作形態が選ばれなければなりません。
- 2. 使われる比較チャネルが許可(TCAn.CTRLBレジスタの比較n許可(CMPnEN)=1に)されなければならず、これは対応するピンに対する 出力値を指定変更します。代替ピンはポート多重器(PORTMUX)を構成設定することによって選ぶことができます。詳細については「PORTMUX - ポート多重器」章を参照してください。
- 3. 連携するポート ピンに対する方向は出力としてポート周辺機能で構成設定されなければなりません。
- 4. 任意選択: 連携するポート ピンに反転波形出力を許可してください。詳細については「PORT I/Oピン構成設定」章を参照してください。

注: 標準動作では利用可能な波形出力はWO0~2だけです。WO3~5を使うには分割動作が許可されなければなりません。

#### 20.3.3.4.2. 周波数(FRQ)波形生成

周波数生成に関して、周期(T)は定期(TCAn.PER)レシ、スタに代わって比較(TCAn.CMP0)レシ、スタによって制御されます。対応する波形生成(WG)出力はTCAn.CNTとTCAn.CMPnのレシ、スタ間の各比較一致で交互切り替えされます。

波形周波数(fFRQ)は次式によって定義されます。

$$f_{\text{FRQ}} = \frac{f_{\text{CLK\_PER}}}{2N(\text{CMPn+1})}$$



ここでNは使われる前置分周数(制御A(TCAn.CTRLA)レジスタのクロック選択(CLKSEL)ビット領域参照)を表し、fclk\_perは周辺機能クロック 周波数です。

生成される波形の最大周波数はTCAn.CMP0レシスタが0(\$0000)を書かれて前置分周が全く使われない(TCAn.CTRLAのCLKSEL= 0、N=1の)時に周辺機能クロック周波数(fCLK\_PER)の半分です。

#### 20.3.3.4.3. 单一傾斜PWM生成

単一傾斜PWM生成に関して、TCAn.PERレシブスタが周期(T)を制御する一方で、TCAn.CMPnレシブスタ値は生成する波形のデューティサイクルを制御します。下図は計数器がどうBOTTOMからTOPへ計数し、その後にBOTTOMから再開するかを示します。波形生成器出力はBOTTOMで設定(1)され、TCAn.CNTとTCAn.CMPnのレシブスタ間の比較一致で解除(0)されます。

CMPn=BOTTOMはWOnで静的なLow信号を生じ、一方でCMPn>TOPはWOnで静的なHigh信号を生じます。

定期(TCAn.PER)レシスタはPWM分解能を定義します。最小分解能は2ビット(TCAn.PER=\$0002)で、最大分解能は16ビット(TCAn.PER=MAX-1)です。

次式は単一傾斜PWMに対するビットでの正確な分解能 (RPWM SS)を計算します。

$$R_{\text{PWM\_SS}} = \frac{\log(\text{PER+2})}{\log(2)}$$



単一傾斜PWM周波数(fpwm\_ss)は周期設定(TCAn.PER)、周辺機能クロック周波数(fCLK\_PER)、TCA前置分周器(TCAn.CTRLAレジスタのCLKSELビット領域)に依存します。それは使う前置分周数をNが表す次式によって計算されます。

$$f_{\text{PWM\_SS}} = \frac{f_{\text{CLK\_PER}}}{N(\text{PER+1})}$$

#### 20.3.3.4.4. 2傾斜PWM生成

2傾斜PWM生成に関して、定期(TCAn.PER)レジスタが周期(T)を制御する一方で、比較n(TCAn.CMPn)レジスタ値は波形生成(WG)出力のデューティ サイクルを制御します。

下図は2傾斜PWMに対して計数器がBOTTOMからTOPへそしてその後にTOPからBOTTOMへどう繰り返し計数するかを示します。 波形生成器出力はBOTTOMで設定(1)され、上昇計数時の比較一致で解除(0)され、下降計数時の比較一致で設定(1)されます。

CMPn=BOTTOMはWOnで静的なLow信号を生じ、一方でCMPn=TOPはWOnで静的なHigh信号を生じます。

2傾斜PWMの使用は単一傾斜PWM動作と比較して周期毎に倍の計時器増加数のため、半分の最大動作周波数になります。

定期(TCAn.PER)レジスタはPWM分解能を定義します。最小分解能は2ビット(TCAn.PER=\$0003)で、最大分解能は16ビット(TCAn.PER=MAX)です。

次式は2傾斜PWMに対する正確な分解能( $R_{PWM_DS}$ )を計算します。



$$R_{\text{PWM\_DS}} = \frac{\log(\text{PER+1})}{\log(2)}$$

PWM周波数( $f_{PWM_DS}$ )はTCAn.PERレシ、スタでの周期設定、周辺機能クロック周波数( $f_{CLK_PER}$ )、TCAn.CTRLAレシ、スタのCLKSELヒ、ット領域で選ばれる前置分周器に依存します。それは次式によって計算することができます。

$$f_{\text{PWM\_DS}} = \frac{f_{\text{CLK\_PER}}}{2N \times \text{PER}}$$

ここでNは使う前置分周数を表します。

#### 20.3.3.4.5. 波形生成に関するポート無効化

ポート ピンで利用可能な波形生成を行うには、対応するポート ピンの方向が出力として設定(方向(PORTx.DIR)レン゙スタの方向(DIRn)=1に)されなければなりません。TCAは比較チャネルが許可(制御B(TCAn.CTRLB)レン゙スタの比較n許可(CMPnEN)=1に)され、波形生成動作が選ばれる時にポート ピン値を覆します。

下図はTCAに関するポート無効化を示します。タイマ/カウンタ比較チャネルは対応するポート ピン(Pxn)でのポート ピン出力値(PORTx.OUTレジスタのOUTn)を無効にします。ポート ピンでの反転I/O許可(PORTx.PINnCTRLレジスタのINVEN=1)は対応するWG出力を反転します。



#### 20.3.3.5. タイマ/カウンタ指令

周辺機能の状態を直ちに変更するために、ソフトウェアによって1組の指令を発行することができます。これらの指令は更新、再始動、リセットの信号の直接制御を与えます。指令は制御E設定(TCAn.CTRLESET)レジスタの指令(CMD)ビット領域に各々の値を書くことによって発行されます。

更新(UPDATE)指令はUPDATE指令が制御E(TCAn.CTRLESET/CLR)レジスタの更新施錠(LUPD)ビットの状態によって影響を及ぼされないことを除き、更新条件が起こる時と同じ効果を持ちます。

ソフトウェアは再始動(RESTART)指令を発行することによって現在の波形周期の再始動を強制することができます。この場合は計数器、方向それと全ての比較出力が'0'に設定されます。

リセット(RESET)指令は全てのタイマ/カウンタレジ、スタをそれらの初期値に設定します。RESET指令はタイマ/カウンタが走行していない(TCAn. CTRLAレジ、スタの許可(ENABLE)=0の)時にだけ発行することができます。

#### 20.3.3.6. 分割動作 - 2つの8ビット タイマ/カウンタ

# 分割動作概要

分割動作はTCAで計時器とPWMチャネルの数を倍にするために提供されます。この分割動作では、各々がPWM生成用に3つの比較 チャネルを持つ2つの独立した8ビット計時器として働きます。分割動作は単一傾斜下降計数でだけ動きます。事象で制御される操作は 分割動作で支援されません。

分割動作の有効化はいくつかのレシ、スタとレシ、スタ ビットの機能を変更します。この変更は独立したレシ、スタ割り当てで記述されます (「20.6. レシ、スタ要約 - 分割動作」をご覧ください)。

#### 標準動作と比べた分割動作の違い

- 計数
  - 下降計数専用
  - 下位バイト タイマ/カウンタ(TCAn.LCNT)レシ、スタと上位バイト タイマ/カウンタ(TCAn.HCNT)レシ、スタは独立です。
- 波形生成
  - 単一傾斜PWM専用(TCAn.CTRLBレジスタのWGMODE=SINGLESLOPE)
- 割り込み
  - 下位バイト タイマ/カウンタ(TCAn.LCNT)レジスタに対する変更なし
  - 上位バイト タイマ/カウンタ(TCAn.HCNT)レジスタに対する下溢れ割り込み
  - 比較n上位バイト(TCAn.HCMPn)レジスタに対する比較割り込みと割り込み要求フラグなし
- · 事象活動: 不適合
- ・緩衝レシ、スタと緩衝有効フラグ: 不使用
- ・レシブスタ アクセス:全てのレシブスタに対してバイト アクセス

#### 構成図



#### 分割動作初期化

標準動作と分割動作の間を移る時に、いくつのレジスタとビットの機能が変わりますが、それらの値は変わりません。この理由のため、予期せぬ動きを避けるため、動作を変更する時に周辺機能を禁止(TCAn.CTRLAレジスタのENABLE=0)して、ハードリセット(制御E設定(TCAn.CTRLESET)レジスタの指令(CMD)=RESET)を行うことが推奨されます。

ハート゛リセット後に基本的な分割動作でタイマ/カウンタの使用を開始するには、以下のこれらの手順に従ってください。

- 1. 制御D(TCAn.CTRLD)レジスタの分割動作許可(SPLITM)ビットに'1'を書くことによって分割動作を許可してください。
- 2. 定期(TCAn.H/LPER)レジスタにTOP値を書いてください。
- 3. 制御A(TCAn.CTRLA)レシ、スタの許可(ENABLE)ビットに'1'を書くことによって周辺機能を許可してください。計数器はTCAn.CTRL Aレシ、スタのクロック選択(CLKSEL)ビット領域に従ってクロック刻みを計数します。
- 4. 計数器値は計数(TCAn.H/LCNT)レジスタの計数(H/LCNT)ビット領域から読むことができます。

分割動作の有効化はいくつかのレジスタとレジスタビットの機能の変更に帰着します。この変更は分離したレジスタ配置で記述されます。

### 20.3.4. 事象

TCAは下表で記述される事象を生成することができます。TCAn\_HUNFを除く全ての生成部は標準動作と分割動作の操作間で共有されます。

表20-2. TCAでの事象生成部

| 生」   | 成部名      | 説明                                         | 事象型 | 生成クロック領域 | 事象長         |
|------|----------|--------------------------------------------|-----|----------|-------------|
| 周辺機能 | 事象       | 武功                                         | 争多至 | 土成がが関域   | 尹豕艾         |
|      | OVF_LUNF | 標準動作: 溢れ<br>分割動作: 下位バイト計時器下溢れ              |     |          |             |
|      | HUNF     | 標準動作: 利用不可<br>分割動作: 上位バイト計時器下溢れ            |     |          |             |
| TCAn | CMP0     | 標準動作: 比較チャネル0一致<br>分割動作: 下位バイト計時器比較チャネル0一致 | パルス | CLK_PER  | 1 CLK_PER周期 |
|      | CMP1     | 標準動作: 比較チャネル1一致<br>分割動作: 下位バイト計時器比較チャネル1一致 |     |          |             |
|      | CMP2     | 標準動作: 比較チャネル2一致<br>分割動作: 下位バイト計時器比較チャネル2一致 |     |          |             |

注: 事象生成の条件は標準動作と分割動作の両方に対して割り込み要求フラグ(TCAn.INTFLAGS)レジスタで対応する割り込み要求フラグを掲げるそれらと同じです。

TCAは入力事象での検出と活動のために1つの事象使用部を持ちます。下表は事象使用部と関連機能を記述します。

| 表20-3. TCA | 表20-3. TCAでの事象使用部                   |      |        |  |  |  |  |
|------------|-------------------------------------|------|--------|--|--|--|--|
| 使用部名       | 説明                                  | 入力検出 | 同期/非同期 |  |  |  |  |
|            | 事象正端で計数                             | 端    | 同期     |  |  |  |  |
| TCA.       | 事象両端で計数                             | 端    | 同期     |  |  |  |  |
| TCAn       | 事象信号がHighの間に計数                      | レベル  | 同期     |  |  |  |  |
|            | 事象レベルは、Low時に上昇、High時に下降で計数方向を制御します。 | レベル  | 同期     |  |  |  |  |

上表で記述される特定の活動は事象制御(TCAn.EVCTRL)レジスタの事象活動(EVACT)ビットに書くことによって選ばれます。入力事象はTCAn.EVCTRLの事象入力で計数許可(CNTEI)ビットに'1'を書くことによって許可されます。

事象入力は分割動作で使われません。

事象形式と事象システム構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照してください。

#### 20.3.5. 割り込み

| 表20-4     | 煙準動作で利                                   | 田可能が割り込  | みべりなと供給元       |
|-----------|------------------------------------------|----------|----------------|
| 1X Z U 4. | 1元十二十二十二十二十二十二十二十二十二十二十二十二十二十二十二十二十二十二十二 | 用り 服体制ソム | ひとい ノブロ にんかロフレ |

| 名称   | ベクタ説明       | 条件                  |
|------|-------------|---------------------|
| OVF  | 溢れ割り込み      | 計数器がTOPまたはBOTTOMに到達 |
| CMP0 | 比較チャネル0割り込み | 計数器値と比較0レジスタ間の一致    |
| CMP1 | 比較チャネル1割り込み | 計数器値と比較1レジスタ間の一致    |
| CMP2 | 比較チャネル2割り込み | 計数器値と比較2レジスタ間の一致    |

#### 表20-5. 分割動作で利用可能な割り込みベクタと供給元

| 名称    | ベクタ説明       | 条件                    |
|-------|-------------|-----------------------|
| LUNF  | 下位バイ下溢れ割り込み | 下位バイト計時器がBOTTOMに到達    |
| HUNF  | 上位バイ下溢れ割り込み | 上位バイト計時器がBOTTOMに到達    |
| LCMP0 | 比較チャネル0割り込み | 計数器値と下位バイト比較0レジスタ間の一致 |
| LCMP1 | 比較チャネル1割り込み | 計数器値と下位バイト比較1レジスタ間の一致 |
| LCMP2 | 比較チャネル2割り込み | 計数器値と下位バイト比較2レジスタ間の一致 |

割り込み条件が起こると、周辺機能の割り込み要求フラケ(TCAn.INTFLAGS)レシ、スタで対応する割り込み要求フラケが設定(1)されます。割り込み元は周辺機能の割り込み制御(TCAn.INTCTRL)レシ、スタで対応する許可じットを書くことによって許可または禁止にされます。割り込み要求は対応する割り込み元が許可され、割り込み要求フラケが設定(1)される時に生成されます。割り込み要求は割り込み要求フラケが解除(0)されるまで活性に留まります。割り込み要求フラケを解除する方法の詳細については周辺機能のINTFLAGSレシ、スタをご覧ください。

# 20.3.6. 休止形態動作

タイマ/カウンタはアイドル休止動作で動作を続けます。

# 20.4. レジスタ要約 - 標準動作

| 変位         | 略称       | ビット位置        | ヒ゛ットフ | ピット6                                             | ピット5         | じット4   | ピット3      | ピット2         | ヒ゛ット1                                            | ピット0         |
|------------|----------|--------------|-------|--------------------------------------------------|--------------|--------|-----------|--------------|--------------------------------------------------|--------------|
| +\$00      | CTRLA    | 7~0          |       |                                                  |              |        |           | CLKSEL2~0    | )                                                | ENABLE       |
| +\$01      | CTRLB    | 7~0          |       | CMP2EN                                           | CMP1EN       | CMP0EN | ALUPD     | V            | VGMODE2~                                         | 0            |
| +\$02      | CTRLC    | 7~0          |       |                                                  |              |        |           | CMP2OV       | CMP1OV                                           | CMP0OV       |
| +\$03      | CTRLD    | 7~0          |       |                                                  |              |        |           |              |                                                  | SPLITM       |
| +\$04      | CTRLECLR | 7~0          |       |                                                  |              |        | CM        | D1,0         | LUPD                                             | DIR          |
| +\$05      | CTRLESET | 7~0          |       |                                                  |              |        | CM        | D1,0         | LUPD                                             | DIR          |
| +\$06      | CTRLFCLR | 7~0          |       |                                                  |              |        | CMP2BV    | CMP1BV       | CMP0BV                                           | PERBV        |
| +\$07      | CTRLFSET | 7~0          |       |                                                  |              |        | CMP2BV    | CMP1BV       | CMP0BV                                           | PERBV        |
| +\$08      | 予約       |              |       |                                                  |              |        |           |              |                                                  |              |
| +\$09      | EVCTRL   | 7 <b>~</b> 0 |       |                                                  |              |        |           | EVACT2~0     | 1                                                | CNTEI        |
| +\$0A      | INTCTRL  | 7~0          |       | CMP2                                             | CMP1         | CMP0   |           |              |                                                  | OVF          |
| +\$0B      | INTFLAGS | 7 <b>~</b> 0 |       | CMP2                                             | CMP1         | CMP0   |           |              |                                                  | OVF          |
| +\$0C      | <b>₹</b> |              |       |                                                  |              |        |           |              |                                                  |              |
| +\$0D      | 予約       |              |       |                                                  |              |        |           |              |                                                  |              |
| +\$0E      | DBGCTRL  | 7~0          |       |                                                  |              |        |           |              |                                                  | DBGRUN       |
| +\$0F      | TEMP     | 7~0          |       |                                                  |              | TEM    | P7∼0      |              |                                                  |              |
| +\$10      |          |              |       |                                                  |              |        |           |              |                                                  |              |
| -<br>+\$1F | 予約       |              |       |                                                  |              |        |           |              |                                                  |              |
| +\$20      |          | 7~0          |       |                                                  |              | CNT    | 7~0       |              |                                                  |              |
| +\$21      | CNT      | 15~8         |       |                                                  |              |        | 15~8      | +            | +                                                |              |
| +\$22      |          | 10 0         |       |                                                  |              | 0111   | 10 0      |              |                                                  |              |
| +\$25      | 予約       |              |       |                                                  |              |        |           |              |                                                  |              |
| +\$26      |          | 7~0          |       |                                                  |              | PER    | 27~.0     |              |                                                  |              |
| +\$27      | PER      | 15~8         |       | -                                                | -            | PER    |           | +            | +                                                |              |
| +\$28      |          | 7~0          |       | -                                                | -            |        | 27~0      | +            | +                                                |              |
| +\$29      | CMP0     | 15~8         |       | <del>                                     </del> | <del></del>  | -      | 215~8     | <del> </del> | <del> </del>                                     |              |
| +\$2A      |          | 7~0          |       | l                                                |              | -      |           | <del> </del> | <del> </del>                                     | -            |
| +\$2B      | CMP1     | 15~8         |       | <del>                                     </del> |              |        | 215~8     | <del> </del> | <del>                                     </del> |              |
| +\$2C      |          | 7~0          |       | l                                                |              |        | 27~0      | l            | l                                                |              |
| +\$2D      | CMP2     | 15~8         |       | <del> </del>                                     | <del>-</del> |        | 215~8     | <del> </del> | <del> </del>                                     |              |
| +\$2E      |          | 10 0         |       |                                                  |              | CIVII  |           |              |                                                  |              |
| $\sim$     | 予約       |              |       |                                                  |              |        |           |              |                                                  |              |
| +\$35      |          | 7~0          |       |                                                  |              | DEDDI  | <br>UF7∼0 |              |                                                  |              |
| +\$36      | PERBUF   | 15~8         |       | l                                                | -            |        |           | <del> </del> | <del> </del>                                     | <del> </del> |
| +\$37      |          |              |       | <del>                                     </del> | <del></del>  |        | JF15~8    | +            | +                                                |              |
| +\$38      | CMP0BUF  | 7~0          |       | -                                                |              | -      | UF7~0     |              |                                                  |              |
| +\$39      |          | 15~8         |       |                                                  |              | l      | JF15~8    |              |                                                  |              |
| +\$3A      | CMP1BUF  | 7~0          |       |                                                  |              |        | UF7~0     |              | -                                                |              |
| +\$3B      |          | 15~8         |       |                                                  |              |        | JF15~8    | -            | -                                                |              |
| +\$3C      | CMP2BUF  | 7~0          |       | -                                                |              |        | UF7~0     |              | -                                                |              |
| +\$3D      |          | 15~8         |       |                                                  |              | CMPBU  | JF15∼8    |              |                                                  |              |

# 20.5. レジスタ説明 - 標準動作

**20.5.1. CTRLA - 制御A** (Control A) - 標準/分割動作共通

名称: CTRLA 変位:+\$00 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3   | 2         | 1   | 0      |
|--------|---|---|---|---|-----|-----------|-----|--------|
|        |   |   |   |   |     | CLKSEL2~0 |     | ENABLE |
| アクセス種別 | R | R | R | R | R/W | R/W       | R/W | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0   | 0         | 0   | 0      |

# ● ビット3~1 - CLKSEL2~0: クロック選択 (Clock Select)

このビット領域はタイマ/カウンタに対するクロック周波数を選びます。

| 値                       | 0 0 0       | 0 0 1      | 0 1 0      | 0 1 1      | 100         | 101         | 1 1 0        | 111           |
|-------------------------|-------------|------------|------------|------------|-------------|-------------|--------------|---------------|
| 名称                      | DIV1        | DIV2       | DIV4       | DIV8       | DIV16       | DIV64       | DIV256       | DIV1024       |
| 説明 (f <sub>TCA</sub> =) | $f$ CLK_PER | fclk_per/2 | fclk_per/4 | fclk_per/8 | fclk_per/16 | fclk_per/64 | fclk_per/256 | fclk_per/1024 |

#### ● ビット0 - ENABLE:許可(Enable)

| 値  | 0            | 1            |
|----|--------------|--------------|
| 説明 | 周辺機能は禁止されます。 | 周辺機能は許可されます。 |

# **20.5.2. CTRLB - 制御B** (Control B) - 標準動作

名称: CTRLB 変位:+\$01 リセット: \$00 特質:-

| ピット    | 7 | 6      | 5      | 4      | 3     | 2   | 1         | 0   |
|--------|---|--------|--------|--------|-------|-----|-----------|-----|
|        |   | CMP2EN | CMP1EN | CMP0EN | ALUPD |     | WGMODE2∼0 |     |
| アクセス種別 | R | R/W    | R/W    | R/W    | R/W   | R/W | R/W       | R/W |
| リセット値  | 0 | 0      | 0      | 0      | 0     | 0   | 0         | 0   |

# ● ビット6~4 - CMPnEN: 比較n許可(Compare n Enable)

FRQ(周波数)とPWMの波形生成動作で比較n許可(CMPnEN)ビットはWOnに対応するピンでの波形出力を利用可能にします。

| 値  | 0                       | 1                              |
|----|-------------------------|--------------------------------|
| 説明 | 波形出力WOnは対応するピンで利用できません。 | 波形出力WOnは対応するピンの出力値を<br>無効にします。 |

#### ● ビット3 - ALUPD: 更新自動施錠 (Auto Lock Update)

更新自動施錠ビットは制御E(TCAn.CTRLE)レン゙スタの更新施錠(LUPD)ビットを制御します。ALUPDが'1'を書かれると、全ての許可された比較チャネルの緩衝部有効(CMPnBV)ビットが'1'になるまでLUPDビットが'1'に設定されます。(前行の)この条件がLUPDを解除(0)します。

これは緩衝値が比較n(CMPn)レジスタに転送され、LUPDビットが再び'1'に設定される後続するUPDATE条件まで解除(0)に留まります。これは許可された全ての比較緩衝部が書かれるまで、比較n緩衝(CMPnBUF)レジスタ値がCMPnレジスタに転送されないことを保証します。

| 値  | 0                                       | 1                                               |
|----|-----------------------------------------|-------------------------------------------------|
| 説明 | TCAn.CTRLEレジスタのLUPDビットは<br>自動的に変えられません。 | TCAn.CTRLEレジスタのLUPDビットは<br>自動的に設定(1)/解除(0)されます。 |

#### ● ビット2~0 - WGMODE2~0:波形生成動作 (Waveform Generation Mode)

このビット領域は波形生成動作を選び、計数器の計数進行、TOP値、UPDATE条件、割り込み条件、生成される波形の形式を制御します。

標準形態の動作では波形生成が全く実行されません。他の全ての動作形態に対して対応する比較n許可(CMPnEN)ビットを設定(1)する場合、波形生成部出力がポート ピンに直結されるだけです。ポート ピンの方向は出力として設定されなければなりません。

| 値    |     | 0 0 0           | 0 0 1           | 0 1 0 | 0 1 1       | 100  | 101    | 1 1 0      | 111      |
|------|-----|-----------------|-----------------|-------|-------------|------|--------|------------|----------|
| 名和   | 4   | NORMAL          | FRQ             | _     | SINGLESLOPE | _    | DSTOP  | DSBOTH     | DSBOTTOM |
|      | 動作  | 標準              | 周波数             | (予約)  | 1傾斜PWM      | (予約) | 2傾斜PWM | 2傾斜PWM     | 2傾斜PWM   |
| 説明   | TOP | PER             | CMP0            | -     | PER         | -    | PER    | PER        | PER      |
| 1 記り | 更新  | TOP( <u>注</u> ) | TOP( <u>注</u> ) | -     | BOTTOM      | -    | BOTTOM | BOTTOM     | ВОТТОМ   |
|      | OVF | TOP( <u>注</u> ) | TOP( <b>注</b> ) | -     | BOTTOM      | 1    | TOP    | TOPとBOTTOM | BOTTOM   |

注: 上昇計数時

### **20.5.3. CTRLC - 制御C** (Control C) - 標準動作

名称: CTRLC 変位:+\$02 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2      | 1      | 0      |
|--------|---|---|---|---|---|--------|--------|--------|
|        |   |   |   |   |   | CMP2OV | CMP1OV | CMP0OV |
| アクセス種別 | R | R | R | R | R | R/W    | R/W    | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0      | 0      | 0      |

# ● ビット2 - CMP2OV: 比較2出力値 (Compare Output Value 2)

CMP0OVをご覧ください。

● ビット1 - CMP1OV: 比較1出力値 (Compare Output Value 1)

CMP0OVをご覧ください。

# ● ビット0 - CMP0OV : 比較0出力値 (Compare Output Value 0)

CMPnOVビットはタイマ/カウンタが許可されない時に波形生成(WG)部の出力値への直接アクセスを許します。これはタイマ/カウンタが走行していない時にWG出力値を設定(1)または解除(0)するのに使われます。

注: この出力をパッドへ接続時、制御B(TCAn.CTRLB)レジスタの比較n許可(CMPnEN)ビットが設定(1)されない限り、これらのビットの指定変更は動きません。この出力をCCLへ接続時、TCAn.CTRLBレジスタのCMPnENビットは迂回されます。

#### **20.5.4. CTRLD - 制御D** (Control D) - 標準/分割動作共通

名称: CTRLD 変位:+\$03 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|--------|---|---|---|---|---|---|---|--------|
|        |   |   |   |   |   |   |   | SPLITM |
| アクセス種別 | R | R | R | R | R | R | R | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0      |

#### ● ビット0 - SPLITM: 分割動作許可 (Enalbe Split Mode)

このビットはタイマ/カウンタを分割動作形態に設定し、2つの8ビットタイマ/カウンタとして動きます。標準16ビット動作と比べてレジスタ割り当てが変わります。

# **20.5.5.** CTRLECLR - 制御E解除 (Control Register E Clear) - 標準動作

名称: CTRLECLR

変位:+\$04 リセット:\$00 特質:-

そのビット位置に'1'を書くことによって個別ビットを解除(0)するため、このレジスタを読み-変更-書き(RMW)の代わりに使ってください。

| ピット    | 7 | 6 | 5 | 4 | 3   | 2    | 1    | 0   |
|--------|---|---|---|---|-----|------|------|-----|
|        |   |   |   |   | CMI | 01,0 | LUPD | DIR |
| アクセス種別 | R | R | R | R | R/W | R/W  | R/W  | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0   | 0    | 0    | 0   |

# ビット3,2 - CMD1,0:指令(Command)

このビット領域はタイマ/カウンタの更新、再始動、リセットのソフトウェア制御に使われます。指令ビット領域は常に'0'として読みます。

| 値  | 0 0            | 0 1 | 1 0     | 1 1                     |  |  |
|----|----------------|-----|---------|-------------------------|--|--|
| 名称 | 名称 NONE UPDATE |     | RESTART | RESET                   |  |  |
| 説明 | 説明 指令なし 強制更新   |     | 強制再始動   | 強制ハードリセット(TCAが許可の場合は無効) |  |  |

#### ● ビット1 - LUPD: 更新施錠(Lock Update)

更新施錠は更新を実行するのに先立って全ての緩衝部が有効であることを保証するのに使うことができます。

| 値 | 1                                                                   |
|---|---------------------------------------------------------------------|
|   | 例えUPDATE条件が起きても、緩衝されるレジスタの更新は実行されません。この設定は指令ビット領域によって発行される更新を妨げません。 |

#### ● ビット0 - DIR: 計数方向 (Counter Direction)

通常、このビットは波形生成動作または事象活動によってハードウェアで制御されますが、ソフトウェアからも変更することができます。

| 値  | 0             | 1            |
|----|---------------|--------------|
| 説明 | 計数器は上昇計数 (増加) | 計数器は下降計数(減少) |

# **20.5.6. CTRLESET - 制御E設定** (Control Register E Set) - 標準動作

名称 : CTRLESET 変位 : +\$05

リセット : \$00 特質 :-

そのビット位置に'1'を書くことによって個別ビットを設定(1)するため、このレジスタを読み-変更-書き(RMW)の代わりに使ってください。

| CMD1,0LUPDDIRアクセス種別RRRR/WR/WR/WR/W | ピット    | 7 | 6 | 5 | 4 | 3   | 2    | 1    | 0   |
|------------------------------------|--------|---|---|---|---|-----|------|------|-----|
|                                    |        |   |   |   |   | СМ  | 01,0 | LUPD | DIR |
|                                    | アクセス種別 | ĸ |   | R | R | R/W | R/W  | R/W  | R/W |
| リセット値 0 0 0 0 0 0 0 0 0            | リセット値  | 0 | 0 | 0 | 0 | 0   | 0    | 0    | 0   |

#### ビット3,2 - CMD1,0:指令(Command)

このビット領域はタイマ/カウンタの更新、再始動、リセットのソフトウェア制御に使われます。指令ビット領域は常に'0'として読みます。

| 値  | 0 0            | 0 1 | 1 0     | 11                      |  |  |
|----|----------------|-----|---------|-------------------------|--|--|
| 名称 | 名称 NONE UPDATE |     | RESTART | RESET                   |  |  |
| 説明 |                |     | 強制再始動   | 強制ハードリセット(TCAが許可の場合は無効) |  |  |

# ● ビット1 - LUPD: 更新施錠(Lock Update)

更新を施錠することは更新を実行するのに先立って全ての緩衝部が有効であることを保証します。

| 値 | 1                                                                   |
|---|---------------------------------------------------------------------|
|   | 例えUPDATE条件が起きても、緩衝されるレジスタの更新は実行されません。この設定は指令ビット領域によって発行される更新を妨げません。 |

#### ● ビット0 - DIR: 計数方向 (Counter Direction)

通常、このビットは波形生成動作または事象活動によってハードウェアで制御されますが、ソフトウェアからも変更することができます。

| 値  | 0             | 1             |
|----|---------------|---------------|
| 説明 | 計数器は上昇計数 (増加) | 計数器は下降計数 (減少) |

#### **20.5.7. CTRLFCLR - 制御F解除** (Control Register F Clear) - 標準動作専用

名称: CTRLFCLR 変位:+\$06 リセット: \$00 特質:-

そのビット位置に'1'を書くことによって個別ビットを解除(0)するため、このレジスタを読み-変更-書き(RMW)の代わりに使ってください。

| ピット    | 7 | 6 | 5 | 4 | 3      | 2      | 1      | 0     |
|--------|---|---|---|---|--------|--------|--------|-------|
|        |   |   |   |   | CMP2BV | CMP1BV | CMP0BV | PERBV |
| アクセス種別 | R | R | R | R | R/W    | R/W    | R/W    | R/W   |
| リセット値  | 0 | 0 | 0 | 0 | 0      | 0      | 0      | 0     |

● ビット3 - CMP2BV: 比較2緩衝有効 (Compare 2 Buffer Valid)

CMP0BVをご覧ください。

● ビット2 - CMP1BV : 比較1緩衝有効 (Compare 1 Buffer Valid)

CMP0BVをご覧ください。

● ビット1 - CMP0BV: 比較1緩衝有効 (Compare 0 Buffer Valid)

CMPnBVビットは新しい値が対応する比較n緩衝(TCAn.CMPnBUF)レジスタに書かれた時に設定(1)されます。これらのビットはUPDATE 条件で自動的に解除(0)します。

● ビット0 - PERBV : 定期緩衝有効 (Period Buffer Valid)

このビットは新しい値が定期緩衝(TCAn.PERBUF)レシブスタに書かれた時に設定(1)されます。このビットはUPDATE条件で自動的に解除(0)します。

#### **20.5.8. CTRLFSET - 制御F設定** (Control Register F Set) - 標準動作専用

名称 : CTRLFSET 変位 : +\$07 リセット : \$00 特質 : -

そのビット位置に'1'を書くことによって個別ビットを設定(1)するため、このレジスタを読み-変更-書き(RMW)の代わりに使ってください。

| ピット    | 7 | 6 | 5 | 4 | 3      | 2      | 1      | 0     |
|--------|---|---|---|---|--------|--------|--------|-------|
|        |   |   |   |   | CMP2BV | CMP1BV | CMP0BV | PERBV |
| アクセス種別 | R | R | R | R | R/W    | R/W    | R/W    | R/W   |
| リセット値  | 0 | 0 | 0 | 0 | 0      | 0      | 0      | 0     |

● ビット3 - CMP2BV: 比較2緩衝有効 (Compare 2 Buffer Valid)

CMP0BVをご覧ください。

● ビット2 - CMP1BV : 比較1緩衝有効 (Compare 1 Buffer Valid)

CMP0BVをご覧ください。

● ビット1 - CMP0BV: 比較1緩衝有効 (Compare 0 Buffer Valid)

CMPnBVE ットは新しい値が対応する比較n緩衝(TCAn.CMPnBUF)レシ スタに書かれた時に設定(1)されます。これらの E ットは UPDATE 条件で自動的に解除(O)します。

● ビット0 - PERBV: 定期緩衝有効 (Period Buffer Valid)

このビットは新しい値が定期緩衝(TCAn.PERBUF)レジスタに書かれた時に設定(1)されます。このビットはUPDATE条件で自動的に解除(0)します。

# **20.5.9. EVCTRL - 事象制御** (Event Control) - 標準動作専用

名称: EVCTRL 変位: +\$09 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3   | 2        | 1   | 0     |
|--------|---|---|---|---|-----|----------|-----|-------|
|        |   |   |   |   |     | EVACT2~0 |     | CNTEI |
| アクセス種別 | R | R | R | R | R/W | R/W      | R/W | R/W   |
| リセット値  | 0 | 0 | 0 | 0 | 0   | 0        | 0   | 0     |

#### ● ビット3~1 - EVACT2~0: 事象活動 (Event Action)

このビット領域はどの事象活動の形式で計数器が増加または減少するかを定義します。

| 値  | 0 0 0         | 0 0 1         | 0 1 0                                  | 0 1 1              | その他  |
|----|---------------|---------------|----------------------------------------|--------------------|------|
| 名称 | EVACT_POSEDGE | EVACT_ANYEDGE | EVACT_HIGHLVL                          | EVACT_UPDOWN       | _    |
| 説明 | 正端事象で計数       | 両端事象で計数       | 事象信号がHigh(1)<br>の間に前置分周し<br>たクロック周期を計数 | 事象線がLow(0)の時に上昇計数、 | (予約) |

# ● ビット0 - CNTEI: 事象入力で計数許可 (Enable Count on Event Input)

| 値  | 0          | 1                        |
|----|------------|--------------------------|
| 説明 | 事象入力での計数禁止 | EVACTビット領域に従って事象入力での計数許可 |

# 20.5.10. INTCTRL - 割り込み制御 (Interrupt Control) - 標準動作

名称:INTCTRL 変位:+\$0A リセット:\$00 特質:-

| ヒ゛ット   | 7 | 6    | 5    | 4    | 3 | 2 | 1 | 0   |
|--------|---|------|------|------|---|---|---|-----|
|        |   | CMP2 | CMP1 | CMP0 |   |   |   | OVF |
| アクセス種別 | R | R/W  | R/W  | R/W  | R | R | R | R/W |
| リセット値  | 0 | 0    | 0    | 0    | 0 | 0 | 0 | 0   |

- ビット6 CMP2: 比較チャネル2割り込み許可 (Compare Channel 2 Interrupt Enable)
- CMP0をご覧ください。
- ビット5 CMP1:比較チャネル1割り込み許可 (Compare Channel 1 Interrupt Enable)

CMP0をご覧ください。

● ビット4 - CMP0: 比較チャネル0割り込み許可 (Compare Channel 0 Interrupt Enable)

CMPnビットへの'1'書き込みはチャネルnからの比較割り込みを許可します。

● ビット0 - OVF:上下溢れ割り込み許可 (Timer Overflow/Underflow Interrupt Enable)

OVFt ットへの'1'書き込みは上下溢れ割り込みを許可します。

# 20.5.11. INTFLAGS - 割り込み要求フラグ (Interrupt Flag Register) - 標準動作

名称: INTFLAGS 変位:+\$0B リセット: \$00 特質:-

| ピット    | 7 | 6    | 5    | 4    | 3 | 2 | 1 | 0   |
|--------|---|------|------|------|---|---|---|-----|
|        |   | CMP2 | CMP1 | CMP0 |   |   |   | OVF |
| アクセス種別 | R | R/W  | R/W  | R/W  | R | R | R | R/W |
| リセット値  | 0 | 0    | 0    | 0    | 0 | 0 | 0 | 0   |

● ビット6 - CMP2: 比較チャネル2割り込み要求フラグ(Compare Channel 2 Interrupt Flag)

CMP0をご覧ください。

● ビット5 - CMP1 : 比較チャネル1割り込み要求フラグ(Compare Channel 1 Interrupt Flag)

CMP0をご覧ください。

● ビット4 - CMP0: 比較チャネル0割り込み要求フラグ (Compare Channel 0 Interrupt Flag)

比較割り込み要求(CMPn)フラグは対応する比較チャネルでの比較一致で設定(1)されます。全ての動作形態に対して、CMPnフラグは計数(CNT)レジスタと対応する比較(CMPn)レジスタ間で比較一致が起こる時に設定(1)されます。CMPnフラグは自動的に解除(0)されません。そのビット位置に'1'を書くことによってだけ解除(0)されます。

● ビット0 - OVF: 上下溢れ割り込み要求フラグ (Timer Overflow/Underflow Interrupt Flag)

このフラグ は波形生成動作(WGMODE)設定に依存して、TOP(上溢れ)またはBOTTOM(下溢れ)のどちらかで設定(1)されます。OVFフラグ は自動的に解除(0)さません。このビット位置に'1'を書くことによってだけ解除(0)されます。

### **20.5.12. DBGCTRL - デバック 制御** (Debug Control) - 標準/分割動作共通

名称: DBGCTRL 変位: +\$0E リセット: \$00 特質: -

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|--------|---|---|---|---|---|---|---|--------|
|        |   |   |   |   |   |   |   | DBGRUN |
| アクセス種別 | R | R | R | R | R | R | R | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0      |

● ビット0 - DBGRUN: デバッグ時走行(Run in Debug)

| 値  | 0                      | 1                        |
|----|------------------------|--------------------------|
| 説明 | TCAはデバッグ動作中断で停止し、事象を無視 | TCAはCPU停止中のデバッグ動作中断で走行継続 |

#### **20.5.13**. **TEMP - 一時レジスタ** (Temporary bits for 16-bit Access) - 標準動作専用

名称: TEMP 変位: +\$0F リセット: \$00 特質: -

一時レシ、スタはこの周辺機能の16ビット レシ、スタへの16ビット単一周期アクセスのためにCPUによって使われます。このレシ、スタはこの周辺機能の全ての16ビット レシ、スタに対して共通でソフトウェアによって読み書きすることができます。16ビット レシ、スタの読み書きのより多くの詳細については「AVR® CPU」章の「16ビット レシ、スタのアクセス」を参照してください。

| ピット    | 7   | 6       | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|-----|---------|-----|-----|-----|-----|-----|-----|--|--|
|        |     | TEMP7~0 |     |     |     |     |     |     |  |  |
| アクセス種別 | 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 - TEMP7~0: 一時値 (Temporary Bits for 16-bit Access)

# **20.5.14. CNT - 計数** (Counter Register) - 標準動作

名称: CNT (CNTH, CNTL)

変位:+\$20 リセット:\$0000 特質:-

TCAn.CNTHとTCAn.CNTLのレジスタ対は16ビット値のTCAn.CNTを表します。下位ハイト[7~0](接尾辞L)は変位原点でアクセスできます。上位ハイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

CPUとUPDIの書き込みアクセスはレジスタの内部更新を超える優先権を持ちます。

| 15      | 14            | 13              | 12                                                                                          | 11                                                                                                                                                                | 10                                                                                                                                                                                                            | 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|---------|---------------|-----------------|---------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| CNT15~8 |               |                 |                                                                                             |                                                                                                                                                                   |                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| 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       | C             | F               | 4                                                                                           | 9                                                                                                                                                                 | 0                                                                                                                                                                                                             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| (       | . 6           | 5               | 4<br>CNT                                                                                    |                                                                                                                                                                   | . 2                                                                                                                                                                                                           | . 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | . 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|         |               |                 | . CNI                                                                                       | , 1~0                                                                                                                                                             |                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| R/W     | R/W           | R/W             | R/W                                                                                         | R/W                                                                                                                                                               | R/W                                                                                                                                                                                                           | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| 0       | 0             | 0               | 0                                                                                           | 0                                                                                                                                                                 | 0                                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|         | R/W<br>0<br>7 | R/W R/W 0 0 7 6 | R/W         R/W         R/W           0         0         0           7         6         5 | R/W         R/W         R/W         R/W         R/W           0         0         0         0           7         6         5         4           CNT         CNT | CNT15~8           R/W         R/W         R/W         R/W         R/W           0         0         0         0         0           7         6         5         4         3           CNT7~0         CNT7~0 | R/W         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O         O <td>CNT15~8           R/W         O         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0</td> | CNT15~8           R/W         O         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 |  |  |  |

● ビット15~8 - CNT15~8: 計数値上位バイト (Counter high byte)

これらのビットは16ビット計数レジスタの上位バイトを保持します。

● ビット7~0 - CNT7~0: 計数値下位バイト (Counter low byte) これらのビットは16ビット計数レジスタの下位バイトを保持します。

# **20.5.15. PER - 定期** (Period Register) - 標準動作

名称: PER (PERH, PERL)

変位:+\$26 リセット:\$FFFF 特質:-

TCAn.PERは周波数波形生成(FRQ)を除く全ての動作形態でタイマ/カウンタの16ビットTOP値を含みます。

TCAn.PERHとTCAn.PERLのレシ、スタ対は16ビット値のTCAn.PERを表します。下位ハ・イト[7~0](接尾辞L)は変位原点でアクセスできます。 上位ハ・イト[15~8](接尾辞H)は変位+1でアクセスすることができます。

| ピット    | 15                        | 14  | 13  | 12  | 11  | 10  | 9   | 8   |  |  |  |
|--------|---------------------------|-----|-----|-----|-----|-----|-----|-----|--|--|--|
|        | PER15~8                   |     |     |     |     |     |     |     |  |  |  |
| アクセス種別 | R/W                       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |  |  |  |
| リセット値  | 1                         | 1   | 1   | 1   | 1   | 1   | 1   | 1   |  |  |  |
| ピット    | 7                         | 6   | E   | 4   | 9   | 9   | 1   | 0   |  |  |  |
| L 91   | 7 6 5 4 3 2 1 0<br>PER7~0 |     |     |     |     |     |     |     |  |  |  |
| L      |                           | •   |     | •   |     |     |     |     |  |  |  |
| アクセス種別 | R/W                       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |  |  |  |
| リセット値  | 1                         | 1   | 1   | 1   | 1   | 1   | 1   | 1   |  |  |  |

● ビット15~8 - PER15~8: 定期値上位バイト (Periodic high byte)

これらのビットは16ビット定期レジスタの上位バイトを保持します。

● ビット7~0 - PER7~0: 定期値下位バイト (Periodic low byte) これらのビットは16ビット定期レジスタの下位バイトを保持します。

#### **20.5.16**. **CMPn - 比較n** (Compare n Register) - 標準動作

名称: CMP0 (CMP0H,CMP0L): CMP1 (CMP1H,CMP1L): CMP2 (CMP2H,CMP2L)

**変位**:+\$28 :+\$2A :+\$2C

リセット: \$0000

特質:-

このレジスタは継続的に計数器値と比較します。通常、比較器からの出力は波形を生成するのに使われます。

TCAn.CMPnレシ、スタはUPDATE条件発生時に対応する比較緩衝(TCAn.CMPnBUF)レシ、スタからの緩衝値で更新されます。

TCAn.CMPnHとTCAn.CMPnLのレジスタ対は16ビット値のTCAn.CMPnを表します。下位ハイト[7~0](接尾辞L)は変位原点でアクセスできます。上位ハイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

| 15     | 14 13         | 12                            | 11                                                | 10                                                                                                                                                                                                                                                           | 9                                                                                                                                                                                                                                                                                                        | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|--------|---------------|-------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|        | CMP15~8       |                               |                                                   |                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| CMP7~0 |               |                               |                                                   |                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| R/W R  | /W R/W        | R/W                           | R/W                                               | R/W                                                                                                                                                                                                                                                          | R/W                                                                                                                                                                                                                                                                                                      | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| 0      | 0             | 0                             | 0                                                 | 0                                                                                                                                                                                                                                                            | 0                                                                                                                                                                                                                                                                                                        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|        | R/W R,<br>0 7 | R/W R/W R/W<br>0 0 0<br>7 6 5 | R/W R/W R/W R/W 0 0 0 0 0 7 6 5 4 R/W R/W R/W R/W | CMP15~8           R/W         R/W         R/W         R/W         R/W           0         0         0         0         0           7         6         5         4         3           CMP7~0           R/W         R/W         R/W         R/W         R/W | CMP15~8           R/W         R/W         R/W         R/W         R/W         R/W           0         0         0         0         0         0           7         6         5         4         3         2           CMP7~0           R/W         R/W         R/W         R/W         R/W         R/W | CMP15~8           R/W         R/W |  |  |  |  |

● ビット15~8 - CMP15~8: 比較値上位バイト (Compare high byte)

これらのビットは16ビット比較レジスタの上位バイトを保持します。

● ビット7~0 - CMP7~0: 比較値下位バイト (Compare low byte)

これらのビットは16ビット比較レジスタの下位バイトを保持します。

#### **20.5.17**. **PERBUF - 定期緩衝** (Period Buffer Register) - 標準動作

名称: PERBUF (PERHBUF, PERBUFL)

変位:+\$36 リセット:\$FFFF 特質:-

このレシ、スタは定期(TCAn.PER)レシ、スタの緩衝部として扱います。CPUまたはUPDIからのこのレシ、スタ書き込みは制御F(TCAn.CTRLF)レシ、スタの定期緩衝有効(PERBV)フラケ、を設定(1)します。

TCAn.PERBUFHとTCAn.PERBUFLのレジスタ対は16ビット値のTCAn.PERBUFを表します。下位バイト[7~0](接尾辞L)は変位原点でアクセスできます。上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

| ピット    | 15  | 14  | 13  | 12    | 11     | 10  | 9   | 8   |
|--------|-----|-----|-----|-------|--------|-----|-----|-----|
|        |     |     |     | PERBU | JF15∼8 |     |     |     |
| アクセス種別 | R/W | R/W | R/W | R/W   | R/W    | R/W | R/W | R/W |
| リセット値  | 1   | 1   | 1   | 1     | 1      | 1   | 1   | 1   |
| ピット    | 7   | 6   | 5   | 4     | 3      | 2   | 1   | 0   |
|        |     |     |     | PERB  | JF7∼0  |     |     |     |
| アクセス種別 | R/W | R/W | R/W | R/W   | R/W    | R/W | R/W | R/W |
| リセット値  | 1   | 1   | 1   | 1     | 1      | 1   | 1   | 1   |

● ビット15~8 - PERBUF15~8: 定期緩衝値上位バイト (Period Buffer high byte)

これらのビットは16ビット定期緩衝レジスタの上位バイトを保持します。

● ビット7~0 - PERBUF7~0: 定期緩衝値下位バ仆 (Period Buffer low byte)

これらのビットは16ビット定期緩衝レジスタの下位バイトを保持します。

#### **20.5.18. CMPnBUF - 比較n緩衝** (Compare n Buffer Register) - 標準動作

名称:CMP0BUF (CMP0BUFH,CMP0BUFL):CMP1BUF (CMP1BUFH,CMP1BUFL):CMP2BUF (CMP2BUFH,CMP2BUFL)

**変位**:+\$38 :+\$3A :+\$3C

リセット: \$0000 特質:-

このレシ、スタは連携する比較(TCAn.CMPn)レシ、スタに対する緩衝部として扱います。CPUまたはUPDIからのこれらのどれかのレシ、スタ書き込みは制御F(TCAn.CTRLF)レシ、スタの対応する比較緩衝有効(CMPnBV)フラグを設定(1)します。

TCAn.CMPnBUFHとTCAn.CMPnBUFLのレジスタ対は16ビット値のTCAn.CMPnBUFを表します。下位バイト[7~0](接尾辞L)は変位原点でアクセスできます。上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

| ピット _  | 15  | 14       | 13       | 12          | 11                | 10       | 9        | 8   |
|--------|-----|----------|----------|-------------|-------------------|----------|----------|-----|
|        |     |          |          | CMPBU       | JF15∼8            |          |          |     |
| アクセス種別 | 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   | C        | _        | 4           | 0                 | 0        | 1        | 0   |
| [ "Yr  | - ( | . 6      | 5        | - 4<br>CMDP | 3<br>LID7- 0      | . 2      | <u> </u> | . 0 |
|        |     |          |          | . CIVIPD    | <u>UF1~0</u>      |          |          |     |
| アクセス種別 | R/W | R/W      | R/W      | R/W         | R/W               | R/W      | R/W      | R/W |
| リセット値  | 0   | 0        | 0        | 0           | 0                 | 0        | 0        | 0   |
|        | •   | R/W<br>0 | R/W<br>0 | •           | UF7~0<br>R/W<br>0 | R/W<br>0 | R/W<br>0 | ,   |

● ビット15~8 - CMPBUF15~8: 比較緩衝値上位バイト (Compare Buffer high byte)

これらのビットは16ビット比較緩衝レジスタの上位バイトを保持します。

● ビット7~0 - CMPBUF7~0: 比較緩衝値下位バイト (Compare Buffer low byte)

これらのビットは16ビット比較緩衝レジスタの下位バイトを保持します。

# 20.6. レジスタ要約 - 分割動作

| 赤片         | 略称          | ビット位置               | ヒ゛ットフ | じット6                                             | ヒ゛ット5                                            | じット4        | ヒ゛ット3    | <b>Ľット2</b>  | ヒ゛ット1        | <b>Ľット</b> 0 |
|------------|-------------|---------------------|-------|--------------------------------------------------|--------------------------------------------------|-------------|----------|--------------|--------------|--------------|
| 変位         |             | <b>こがれ</b> 返<br>7~0 | こ ツト/ | פאנים                                            | כיוני ב                                          | E 7/4       |          | CLKSEL2~0    |              |              |
| +\$00      | CTRLA       |                     |       | LICADOENI                                        | LICA (D1ENI                                      | TICM (DOEN) |          |              |              | ENABLE       |
| +\$01      | CTRLB       | 7~0                 |       |                                                  | HCMP1EN                                          |             |          | LCMP2EN      | LCMP1EN      | LCMP0EN      |
| +\$02      | CTRLC       | 7~0                 |       | HCMP2OV                                          | HCMP1OV                                          | HCMP0OV     |          | LCMP2OV      | LCMP1OV      |              |
| +\$03      | CTRLD       | 7~0                 |       |                                                  |                                                  |             | G) (     |              | G) (D        | SPLITM       |
| +\$04      | CTRLECLR    | 7~0                 |       |                                                  |                                                  |             |          | D1,0         |              | EN1,0        |
| +\$05      | CTRLESET    | 7 <b>~</b> 0        |       |                                                  |                                                  |             | CM.      | D1,0         | CMD          | EN1,0        |
| +\$06<br>∼ | 予約          |                     |       |                                                  |                                                  |             |          |              |              |              |
| +\$09      | 3 703       |                     |       |                                                  |                                                  |             |          |              |              |              |
| +\$0A      | INTCTRL     | 7 <b>~</b> 0        |       | LCMP2                                            | LCMP1                                            | LCMP0       |          |              | HUNF         | LUNF         |
| +\$0B      | INTFLAGS    | 7 <b>~</b> 0        |       | LCMP2                                            | LCMP1                                            | LCMP0       |          |              | HUNF         | LUNF         |
| +\$0C      | <b>₹</b> %A |                     |       |                                                  |                                                  |             |          |              |              |              |
| -<br>+\$0D | 予約          |                     |       |                                                  |                                                  |             |          |              |              |              |
| +\$0E      | DBGCTRL     | 7~0                 |       |                                                  |                                                  |             |          |              |              | DBGRUN       |
| +\$0F      |             |                     |       |                                                  |                                                  |             |          |              |              |              |
| ~<br>+\$1F | 予約          |                     |       |                                                  |                                                  |             |          |              |              |              |
| +\$20      | LCNT        | 7~0                 |       |                                                  |                                                  | LCN'        | <br>Τ7∼0 |              |              |              |
| +\$21      | HCNT        | 7~0                 |       | <del> </del>                                     | <del> </del>                                     | HCN'        |          |              |              |              |
| +\$22      | 110111      | , ,                 |       |                                                  |                                                  | 11011       |          |              |              |              |
| $\sim$     | 予約          |                     |       |                                                  |                                                  |             |          |              |              |              |
| +\$25      | LPER        | 7~0                 |       |                                                  |                                                  | LPEI        | 77 - 0   |              |              |              |
| +\$26      |             |                     |       | <del>                                     </del> | <del>                                     </del> |             |          | -            |              |              |
| +\$27      | HPER        | 7~0                 |       | <del>                                     </del> | <del>                                     </del> | HPE         |          |              |              |              |
| +\$28      | LCMP0       | 7~0                 |       | <del> </del>                                     | <del> </del>                                     | LCM         | l        | <del> </del> | <del> </del> |              |
| +\$29      | HCMP0       | 7~0                 |       | -                                                | -                                                | HCM         |          |              | -            |              |
| +\$2A      | LCMP1       | 7~0                 |       | -                                                | -                                                | LCM         |          |              | -            |              |
| +\$2B      | HCMP1       | 7~0                 |       |                                                  |                                                  | HCM         |          |              |              |              |
| +\$2C      | LCMP2       | 7~0                 |       | <del>-</del>                                     | -                                                | LCM         |          |              |              |              |
| +\$2D      | HCMP2       | 7 <b>~</b> 0        |       |                                                  | 1                                                | HCM         | P7~0     | ı            | 1            |              |

# 20.7. レジスタ説明 - 分割動作

**20.7.1. CTRLA - 制御A** (Control A) - 標準/分割動作共通

名称: CTRLA 変位:+\$00 リセット: \$00 特質:-

| ピット      | 7 | 6 | 5 | 4 | 3      | 2         | 1   | 0      |
|----------|---|---|---|---|--------|-----------|-----|--------|
|          |   |   |   |   |        | CLKSEL2~0 |     | ENABLE |
| アクセス種別   | R | D | D | D | D /11/ | D/W       | D/W | D/III  |
| ノフビハ作里刀リ | Л | R | K | K | R/W    | R/W       | R/W | R/W    |

● ビット3~1 - CLKSEL2~0: クロック選択 (Clock Select)

これらのビットはタイマ/カウンタに対するクロック周波数を選びます。

| 値                       | 000      | 0 0 1      | 0 1 0      | 0 1 1      | 100         | 101         | 1 1 0        | 111           |
|-------------------------|----------|------------|------------|------------|-------------|-------------|--------------|---------------|
| 名称                      | DIV1     | DIV2       | DIV4       | DIV8       | DIV16       | DIV64       | DIV256       | DIV1024       |
| 説明 (f <sub>TCA</sub> =) | fclk_per | fclk_per/2 | fclk_per/4 | fclk_per/8 | fclk_per/16 | fclk_per/64 | fclk_per/256 | fclk_per/1024 |

● ビット0 - ENABLE:許可(Enable)

| 値  | 0                 | 1                 |
|----|-------------------|-------------------|
| 説明 | 周辺機能(TCA)は禁止されます。 | 周辺機能(TCA)は許可されます。 |

# **20.7.2**. **CTRLB - 制御B** (Control B) - 分割動作

名称: CTRLB 変位:+\$01 リセット: \$00 特質:-

| ピット _  | 7 | 6       | 5       | 4       | 3 | 2       | 1       | 0       |
|--------|---|---------|---------|---------|---|---------|---------|---------|
|        |   | HCMP2EN | HCMP1EN | HCMP0EN |   | LCMP2EN | LCMP1EN | LCMP0EN |
| アクセス種別 | R | R/W     | R/W     | R/W     | R | R/W     | R/W     | R/W     |
| リセット値  | 0 | 0       | 0       | 0       | 0 | 0       | 0       | 0       |

● ビット6 - HCMP2EN : 上位バイト比較2許可 (High-byte Compare 2 Enable)

HCMP0ENをご覧ください。

● ビット5 - HCMP1EN : 上位バイト比較1許可 (High-byte Compare 1 Enable)

HCMP0ENをご覧ください。

● ビット4 - HCMP0EN : 上位バイ比較0許可 (High-byte Compare 0 Enable)

FRQまたはPWM波形生成動作形態でのHCMPnENt゙ット設定(1)は対応するWOn+3t゚ンに対するポート出力(PORTx.OUT)レジスタを無効にします。

● ビット2 - LCMP2EN: 下位バイト比較2許可(Low-byte Compare 2 Enable)

LCMP0ENをご覧ください。

● ビット1 - LCMP1EN:下位バイト比較1許可 (Low-byte Compare 1 Enable)

LCMP0ENをご覧ください。

● ビット0 - LCMP0EN:下位バイト比較0許可(Low-byte Compare 0 Enable)

FRQまたはPWM波形生成動作形態でのLCMPnENt゙ット設定(1)は対応するWOnt゚ンに対するポート出力(PORTx.OUT)レン゙スタを無効にします。

# **20.7.3. CTRLC - 制御C** (Control C) - 分割動作

名称: CTRLC 変位:+\$02 リセット: \$00 特質:-

| ピット    | 7 | 6       | 5       | 4       | 3 | 2       | 1       | 0       |
|--------|---|---------|---------|---------|---|---------|---------|---------|
|        |   | HCMP2OV | HCMP1OV | HCMP0OV |   | LCMP2OV | LCMP1OV | LCMP0OV |
| アクセス種別 | R | R/W     | R/W     | R/W     | R | R/W     | R/W     | R/W     |
| リセット値  | 0 | 0       | 0       | 0       | 0 | 0       | 0       | 0       |

● ビット6 - HCMP2OV:上位バイト比較2出力値 (High-byte Compare 2 Output Value)

HCMP0OVをご覧ください。

● ビット5 - HCMP1OV:上位バイト比較1出力値 (High-byte Compare 1 Output Value)

HCMP0OVをご覧ください。

● ビット4 - HCMP00V : 上位バイト比較0出力値 (High-byte Compare 0 Output Value)

HCMPnOVビットはタイマ/カウンタが許可されない時に波形生成部の出力値への直接アクセスを許します。これはタイマ/カウンタが走行していない時にWOn+3出力値を設定(1)または解除(0)するのに使われます。

● ビット2 - LCMP2OV:下位バイ比較2出力値 (Low-byte Compare 2 Output Value)

LCMP0OVをご覧ください。

● ビット1 - LCMP1OV: 下位バイ比較1出力値 (Low-byte Compare 1 Output Value)

LCMP0OVをご覧ください。

● ビット0 - LCMP0OV: 下位バイト比較0出力値 (Low-byte Compare 0 Output Value)

LCMPnOVビットはタイマ/カウンタが許可されない時に波形生成部の出力値への直接アクセスを許します。これはタイマ/カウンタが走行していない時にWOn出力値を設定(1)または解除(0)するのに使われます。

# **20.7.4. CTRLD - 制御D** (Control D) - 標準/分割動作共通

名称 : CTRLD 変位 : +\$03 リセット : \$00 特質 : -

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|--------|---|---|---|---|---|---|---|--------|
|        |   |   |   |   |   |   |   | SPLITM |
| アクセス種別 | R | R | R | R | R | R | R | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0      |

● ビット0 - SPLITM:分割動作許可(Enalbe Split Mode)

このビットはタイマ/カウンタを分割動作形態に設定します。その後は2つの8ビット タイマ/カウンタとして動きます。標準16ビット動作と比べてレジスタ割り当てが変わります。

# **20.7.5.** CTRLECLR - 制御E解除 (Control Register E Clear) - 分割動作

名称:CTRLECLR 変位:+\$04

リセット: \$00 特質:-

このレシ、スタはそのビット位置に'1'を書くことによって個別ビットを解除(0)するため、読み-変更-書き(RMW)の代わりに使うことができます。

| <b>ビット</b> | 7 | 6 | 5 | 4 | 3   | 2    | 1   | 0     |
|------------|---|---|---|---|-----|------|-----|-------|
|            |   |   |   |   | CMI | D1,0 | CMD | EN1,0 |
| アクセス種別     | R | R | R | R | R/W | R/W  | R/W | R/W   |
| リセット値      | 0 | 0 | 0 | 0 | 0   | 0    | 0   | 0     |

### ビット3,2 - CMD1,0:指令(Command)

これらのビットはタイマ/カウンタの再始動とリセットのソフトウェア制御に使われます。指令ビットは常に'0'として読みます。

| 値  | 0 0  | 0 1  | 1 0     | 11                       |
|----|------|------|---------|--------------------------|
| 名称 | NONE | _    | RESTART | RESET                    |
| 説明 | 指令なし | (予約) | 強制再始動   | 強制ハート゛リセット(TCAが許可の場合は無効) |

#### ● ビット1,0 - CMDEN1,0: 指令許可 (Command enable)

これらのビットはCMDビットによって与えられた指令がどのタイマ/カウンタに適用するかを構成設定します。

| 値  | 0 0  | 0 1  | 1 0  | 11                        |
|----|------|------|------|---------------------------|
| 名称 | NONE | _    | -    | ВОТН                      |
| 説明 | なし   | (予約) | (予約) | 指令は上下バイトの両 タイマ/カウンタに対して適用 |

# **20.7.6.** CTRLESET - 制御E設定 (Control Register E Set) - 分割動作

名称: CTRLESET

つか . CTRLESE 変位 : +\$05 リセット : \$00

特質:-

このレシ、スタはそのビット位置に'1'を書くことによって個別ビットを設定(1)するため、読み-変更-書き(RMW)の代わりに使うことができます。

| ピット    | 7 | 6 | 5 | 4 | 3   | 2    | 1   | 0     |
|--------|---|---|---|---|-----|------|-----|-------|
|        |   |   |   |   | CM  | 01,0 | CMD | EN1,0 |
| アクセス種別 | R | R | R | R | R/W | R/W  | R/W | R/W   |
| リセット値  | 0 | 0 | 0 | 0 | 0   | 0    | 0   | 0     |

### ビット3,2 - CMD1,0:指令(Command)

これらのビットはタイマ/カウンタの再始動とリセットのソフトウェア制御に使われます。指令ビットは常に'0'として読みます。CMDビット領域は指令許可(CMDEN)ビットと共に使われなければなりません。リセット指令を使うには下位バイトと上位バイトの両タイマ/カウンタ(BOTH)で選ばれたCMDENを必要とします。

| 値  | 0 0  | 0 1  | 1 0     | 1 1                      |
|----|------|------|---------|--------------------------|
| 名称 | NONE | -    | RESTART | RESET                    |
| 説明 | 指令なし | (予約) | 強制再始動   | 強制ハート゛リセット(TCAが許可の場合は無効) |

#### ● ビット1.0 - CMDEN1.0: 指令許可 (Command enable)

これらのビットはCMDビットによって与えられた指令がどのタイマ/カウンタに適用するかを構成設定します。

| 値  | 0 0  | 0 1  | 1 0  | 11                       |
|----|------|------|------|--------------------------|
| 名称 | NONE | -    | _    | ВОТН                     |
| 説明 | なし   | (予約) | (予約) | 指令は上下バイの両 タイマ/カウンタに対して適用 |

**20.7.7. INTCTRL - 割り込み制御** (Interrupt Control) - 分割動作

名称:INTCTRL 変位:+\$0A リセット:\$00 特質:-

| ピット    | 7 | 6     | 5     | 4     | 3 | 2 | 1    | 0    |
|--------|---|-------|-------|-------|---|---|------|------|
|        |   | LCMP2 | LCMP1 | LCMP0 |   |   | HUNF | HUNF |
| アクセス種別 | R | R/W   | R/W   | R/W   | R | R | R/W  | R/W  |
| リセット値  | 0 | 0     | 0     | 0     | 0 | 0 | 0    | 0    |

- ビット6 LCMP2: 下位バイト比較2割り込み許可 (Low-byte Compare Channel 2 Interrupt Enable) LCMP0をご覧ください。
- ビット5 LCMP1: 下位バイル・比較1割り込み許可 (Low-byte Compare Channel 1 Interrupt Enable) LCMP0をご覧ください。
- **ビット4 LCMP0**: 下位バイト比較0割り込み許可 (Low-byte Compare Channel 0 Interrupt Enable) LCMPnビットへの 1 書き込みは下位バイト比較チャネルn割り込みを許可します。
- **ビット1 HUNF**: 上位バイ下溢れ割り込み許可 (High-byte Underflow Interrupt Enable) HUNFビットへの'1'書き込みは上位バイト下溢れ割り込みを許可します。
- **ビット0 LUNF**: **下位バイト下溢れ割り込み許可** (Low-byte Underflow Interrupt Enable) LUNFビットへの'1'書き込みは下位バイト下溢れ割り込みを許可します。

20.7.8. INTFLAGS - 割り込み要求フラグ (Interrupt Flag Register) - 分割動作

名称: INTFLAGS 変位: +\$0B リセット: \$00 特質:-

| <b>ビット</b> | 7 | 6     | 5     | 4     | 3 | 2 | 1    | 0    |
|------------|---|-------|-------|-------|---|---|------|------|
|            |   | LCMP2 | LCMP1 | LCMP0 |   |   | HUNF | HUNF |
| アクセス種別     | R | R/W   | R/W   | R/W   | R | R | R/W  | R/W  |
| リセット値      | 0 | 0     | 0     | 0     | 0 | 0 | 0    | 0    |

- ビット6 LCMP2: 下位バイト比較2割り込み要求フラグ (Low-byte Compare Channel 2 Interrupt Flag) LCMP0フラグ記述をご覧ください。
- ビット5 LCMP1: 下位バイト比較1割り込み要求フラグ (Low-byte Compare Channel 1 Interrupt Flag) LCMP0フラグ記述をご覧ください。
- **ビット4 LCMP0**: 下位バイト比較0割り込み要求フラグ (Low-byte Compare Channel 0 Interrupt Flag) 下位バイト比較割り込み要求(LCMPn)フラグは対応する下位バイト計時器の比較チャネルでの比較一致で設定(1)されます。

全ての動作形態に対して、LCMPnフラグは下位バイ計数(TCAn.LCNT)レジスタと対応する下位バイル較n(TCAn.LCMPn)レジスタ間で比較一致が起こる時に設定(1)されます。LCMPnフラグは自動的に解除(0)されないのでソフトウェアが解除(0)しなければなりません。このビット位置への'1'書き込みがこれを行います。

● ビット1 - HUNF : 上位バイト下溢れ割り込み要求フラグ(High-byte Underflow Interrupt Flag)

このフラグは上位バイト計時器のBOTTOM(下溢れ)条件で設定(1)されます。HUNFは自動的に解除(0)されず、ソフトウェアによって解除(0)されることが必要です。このビット位置への'1'書き込みがこれを行います。

● ビット0 - LUNF: 下位バイト下溢れ割り込み要求フラグ(Low-byte Underflow Interrupt Flag)

このフラグは下位バイト計時器のBOTTOM(下溢れ)条件で設定(1)されます。LUNFは自動的に解除(0)されず、ソフトウェアによって解除(0)されることが必要です。このビット位置への'1'書き込みがこれを行います。

# **20.7.9. DBGCTRL - デバッグ制御** (Debug Control) - 標準/分割動作共通

名称: DBGCTRL 変位: +\$0E リセット: \$00 特質:-

| <u> </u> | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|----------|---|---|---|---|---|---|---|--------|
|          |   |   |   |   |   |   |   | DBGRUN |
| アクセス種別   | R | R | R | R | R | R | R | R/W    |
| リセット値    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0      |

● ビット0 - DBGRUN: デバッグ時走行(Run in Debug)

| 値  | 0                      | 1                        |
|----|------------------------|--------------------------|
| 説明 | TCAはデバッグ動作中断で停止し、事象を無視 | TCAはCPU停止中のデバッグ動作中断で走行継続 |

# **20.7.10. LCNT - 下位バ付計数** (Low-byte Timer Counter Register) - 分割動作

名称:LCNT 変位:+\$20 リセット:\$00 特質:-

TCAn.LCNTは下位バイト計時器用計数値を含みます。CPUとUPDIの書き込みアクセスはこの計数器の計数、解消、再設定を超える優先権を持ちます。

| ピット    | 7   | 6   | 5       | 4   | 3   | 2   | 1   | 0   |  |  |  |
|--------|-----|-----|---------|-----|-----|-----|-----|-----|--|--|--|
|        |     |     | LCNT7~0 |     |     |     |     |     |  |  |  |
| アクセス種別 | 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 - LCNT7~0: 下位バイト計時器用計数値 (Counter Value for low-byte timer)

これらのビットは下位バイト計時器の計数器値を定義します。

# **20.7.11. HCNT - 上位バ仆計数** (High-byte Timer Counter Register) - 分割動作

名称: HCNT 変位:+\$21 リセット: \$00 特質:-

TCAn.HCNTは上位バイト計時器用計数値を含みます。CPUとUPDIの書き込みアクセスはこの計数器の計数、解消、再設定を超える優先権を持ちます。

| ピット    | 7       | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|---------|-----|-----|-----|-----|-----|-----|-----|--|--|
|        | HCNT7~0 |     |     |     |     |     |     |     |  |  |
| アクセス種別 | 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 - HCNT7~0: 上位バイト計時器用計数値 (Counter Value for high-byte timer)

これらのビットは上位バイト計時器の計数器値を定義します。

# **20.7.12. LPER - 下位バイ定期** (Low-byte Timer Period Register) - 分割動作

名称: LPER 変位:+\$26 リセット: \$FF 特質:-

TCAn.LPERレシ、スタは下位バイト計時器用TOP値を含みます。

| ピット    | 7       | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |
|--------|---------|-----|-----|-----|-----|-----|-----|-----|--|--|--|
|        | LPER7∼0 |     |     |     |     |     |     |     |  |  |  |
| アクセス種別 | R/W     | R/W | R/W | R/W | R/W | R/W | R/W | R/W |  |  |  |
| リセット値  | 1       | 1   | 1   | 1   | 1   | 1   | 1   | 1   |  |  |  |

#### ● ビット7~0 - LPER7~0: 下位バイト計時器用定期値 (Period value low-byte timer)

これらのビットは下位バイト計時器用TOP値を保持します。

#### **20.7.13. HPER - 上位バ仆定期** (High-byte Timer Period Register) - 分割動作

名称: HPER 変位:+\$27 リセット: \$FF 特質:-

TCAn.HPERレジスタは上位バイト計時器用TOP値を含みます。

| ピット    | 7   | 6   | 5       | 4   | 3   | 2   | 1   | 0   |  |  |  |
|--------|-----|-----|---------|-----|-----|-----|-----|-----|--|--|--|
|        |     |     | HPER7~0 |     |     |     |     |     |  |  |  |
| アクセス種別 | R/W | R/W | R/W     | R/W | R/W | R/W | R/W | R/W |  |  |  |
| リセット値  | 1   | 1   | 1       | 1   | 1   | 1   | 1   | 1   |  |  |  |

#### ● ビット7~0 - HPER7~0: 上位バイト計時器用定期値 (Period value high-byte timer)

これらのビットは上位バイト計時器用TOP値を保持します。

# **20.7.14. LCMPn - 下位バイ比較n** (Low-byte Compare Register n) - 分割動作

名称:LCMP0:LCMP1:LCMP2 変位:+\$28:+\$2A:+\$2C

リセット: \$00 特質:-

TCAn.LCMPnレシ、スタは下位バイト用比較チャネルnの比較値を表します。このレシ、スタは下位バイト計時器(TCAn.LCNT)の計数器値と継続的に比較されます。通常、比較器からの出力はその後に波形を生成するのに使われます。

| ピット    | 7   | 6   | 5       | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|-----|-----|---------|-----|-----|-----|-----|-----|--|--|
|        |     |     | LCMP7~0 |     |     |     |     |     |  |  |
| アクセス種別 | 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 - LCMP7~0: 下位バイト比較n値 (Compare value of channel n)

これらのビットはTCAn.LCNTと比較されるチャネルnの下位バイル比較値を保持します。

# **20.7.15. HCMPn - 上位バイ比較n** (High-byte Compare Register n) - 分割動作

名称: HCMP0: HCMP1: HCMP2 変位: +\$29: +\$2B: : +\$2D

リセット : \$00 特質 :-

TCAn.HCMPnレシ、スタは上位バイト用比較チャネルnの比較値を表します。このレジスタは上位バイト計時器(TCAn.HCNT)の計数器値と継続的に比較されます。通常、比較器からの出力はその後に波形を生成するのに使われます。

| ピット    | 7       | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|---------|-----|-----|-----|-----|-----|-----|-----|
|        | HCMP7∼0 |     |     |     |     |     |     |     |
| アクセス種別 | 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 - HCMP7~0: 上位バイト比較n値 (Compare value of channel n)

これらのビットはTCAn.HCNTと比較されるチャネルnの上位バイト比較値を保持します。

# 21. TCB - 16ビット タイマ/カウンタB型

# 21.1. 特徴

- ・16ビット計数器動作形態
  - 周期的割り込み
  - 制限時間検査
  - 計数捕獲
    - 事象での捕獲
    - 周波数測定
    - パルス幅測定
    - ・ 周波数とパルス幅の測定
  - 単発
  - 8ビット パルス幅変調(PWM)
- 事象入力での雑音消去器
- ・TCA0との同期動作

### 21.2. 概要

16ビット タイマ/カウンタB型(TCB)の能力は周波数と波形の生成、デジタル信号の時間と周波数の測定を持つ事象での計数捕獲を含みます。TCBは基本計数器と各動作形態が独特な機能を提供する8つの異なる動作形態の1つに設定することができる制御論理回路から成ります。基本計数器は任意選択の前置分周を持つ周辺機能クロックによってクロック駆動されます。

#### 21.2.1. 構成図



このタイマ/カウンタは周辺機能クロック(CLK\_PER)または16ビット タイマ/カウンタA型(CLK\_TCAn)からクロック駆動することができます。

制御A(TCBn.CTRLA)レジスタのクロック選択(CLKSEL)ビット領域はクロック入力(CLK\_TCB)として前置分周器出力の1つを直接選びます。

TCAnからのクロックを使うタイマ/カウンタ設定はそのTCAnと同期して動くことをタイマ/カウンタに許します。

EVSYSを使うことにより、何れかの入出力ピンでの外部クロック信号のようなどの外部事象供給元も制御論理回路入力として使うことができます。事象活動で制御される動作使用時、クロック選択は計数器入力として事象チャネルを使うように設定されなければなりません。



### 21.2.2. 信号説明

| 信 <del>号</del> | 形式        | 説明   |
|----------------|-----------|------|
| WO             | デジタル非同期出力 | 波形出力 |

# 21.3. 機能的な説明

#### 21.3.1. 定義

右の定義は文書全体を通して使われます。

注: 一般的に用語の'計時器'はタイマ/カウンタが周期的クロック刻みを計数する時に使われます。 用語の'計数器'は入力信号が散発的または 不規則なクロック刻みを持つ時に使われます。

| 表21-1. タイマ | 表21-1. タイマ/カウンタ定義              |  |  |  |  |  |  |  |  |  |
|------------|--------------------------------|--|--|--|--|--|--|--|--|--|
| 名称         | 説明                             |  |  |  |  |  |  |  |  |  |
| BOTTOM     | 計数器は\$0000になる時にBOTTOMに到達します。   |  |  |  |  |  |  |  |  |  |
| MAX        | 計数器は\$FFFFになる時に最大に到達します。       |  |  |  |  |  |  |  |  |  |
| TOP        | 計数器が計数の流れで最高値と等しくなる時にTOPに達します。 |  |  |  |  |  |  |  |  |  |
| CNT        | 計数器(TCBn.CNT)レジスタ値             |  |  |  |  |  |  |  |  |  |
| CCMP       | 捕獲/比較(TCBn.CCMP)レジスタ値          |  |  |  |  |  |  |  |  |  |

#### 21.3.2. 初期化

既定でTCBは周期的割り込み動作です。これの使用を開始するには以下のようにこれらの手順に従ってください。

- 1. 比較/捕獲(TCBn.CCMP)レシブスタにTOP値を書いてください。
- 2. 任意選択: 制御B(TCBn.CTRLB)レジスタの比較/捕獲出力許可(CCMPEN)ビットに'1'を書いてください。これは対応するPORT出力レジスタの値を無効にして対応するピンでの波形出力を利用可能にします。
- 3. 制御A(TCBn.CTRLA)レジスタの許可(ENABLE)ビットに'1'を書くことによって計数器を許可してください。計数器はTCBn.CTRLAレジスタのクロック選択(CLKSEL)ビット領域で設定した前置分周器に従ったクロック刻みの計数を開始します。
- 4. 計数値は計数(TCBn.CNT)レジスタから読むことができます。周辺機能はCNT値がTOPに達する時に捕獲(CAPT)割り込みと事象を生成します。
  - a. 比較/捕獲レジスタが現在のCNTよりも低い値に変更される場合、周辺機能はMAXまで計数して丸めを行います。
  - b. MAXで溢れ(OVF)割り込みと事象が生成されます。

#### 21.3.3. 動作

#### 21.3.3.1. 動作形態

計時器は以降の部分で記述される8つの異なる動作形態の1つで動くように構成設定することができます。端検出を保証するために事象パルスは1システム クロック周期より長いことが必要です。

#### 21.3.3.1.1. 周期的割り込み動作

周期的割り込み動作では計数器が捕獲(TOP)値まで計数してBOTTOMから再開します。CAPT割り込みと事象はCNTがTOPと等しい時に生成されます。TOPがCNTよりも低い値に更新された場合、MAX到達でOVFの割り込みと事象が生成され、計数器はBOTTOMから再開します。



### 21.3.3.1.2. 制限時間検査動作

制限時間検査動作では事象入力チャネルで検出した最初の信号端で計数器が計数を開始し、次の信号端で停止します。CNTは停止端後静止(凍結状態)に留まり、計数器は新しい開始端で再開します。

この動作は事象使用部として構成設定されたTCB を必要とし、事象部分で説明されます。

開始と停止の端は事象制御(TCBn.EVCTRL)レシ、スタの事象端(EDGE)ピットによって決められます。第2端前にCNTがTOPに到達する場合、CAPT割り込みと事象が生成されます。TOPがCNTよりも低い値に更新された場合、MAX到達でOVF割り込みと同時に事象が生成され、計数器はBOTTOMから再開します。凍結状態での計数(TCBn.CNT)レジ、スタまたは比較/捕獲(TCBn.CCMP)レジ、スタの読み込み、または状態(TCBn.STATUS)レジ、スタの走行(RUN)ピット書き込みは無効です。



#### 21.3.3.1.3. 事象での捕獲動作

事象での捕獲動作では計数器がBOTTOMからMAXへ継続的に計数します。事象検出時、計数(TCBn.CNT)レジスタ値は比較/捕獲 (TCBn.CCMP)レジスタに転送され、CAPT割り込みと事 象が生成されます。事象端検出部は上昇端または下降 図21-5. 事象での計数捕獲

象が生成されます。事象端検出部は上昇端または下降端のどちらかで捕獲を起動するように構成設定することができます。

右図は事象入力信号の下降端で計数捕獲するように構成設定した捕獲部を示します。CAPT割り込み要求フラグは比較/捕獲(TCBn.CCMP)レジスタの下位バイが読まれた後で自動的に解除(0)されます。

他のどれかの動作からこの動作へ移行する時にTCBn. CNTレジスタに0を書くことが推奨されます。



#### 21.3.3.1.4. 計数捕獲周波数測定動作

計数捕獲周波数動作ではTCBが事象入力信号の正端 または負端のどちらかで計数器値を捕獲して再始動し ます。

CAPT割り込み要求フラケーは比較/捕獲(TCBn.CCMP)レジスタの下位ハーイトが読まれた後で自動的に解除(0)されます。

右図は上昇端で働くように構成設定された時のこの動作を図解します。



#### 21.3.3.1.5. 計数捕獲パルス幅測定動作

計数捕獲パルス幅測定動作では計数捕獲パルス幅測定が正端で計数器を再始動し、割り込み要求が生成されるのに先立って次の下降端で捕獲します。CAPT割り込み要求フラグは比較/捕獲(TCBn.CCMP)レジスタの下位バイが読まれた後、自動的に解除(0)されます。計時器は自動的に上昇端と下降端の方向を切り替えますが、正しい動きのために2クロック周期の最小端間分離が必要とされます。



#### 21.3.3.1.6. 計数捕獲周波数/パルス幅測定動作

計数捕獲周波数/パルス幅測定動作では事象入力信号で正端が検出された時に計時器が計数を開始します。後続する下降端で計数値が捕獲されます。計数器は事象入力信号の2つ目の上昇端が検出された時に停止します。これは割り込み要求フラグを設定(1)します。

比較/捕獲(TCBn.CCMP)レシ、スタの下位ハ、小読み込み後、CAPT割り込み要求フラケが自動的に解除(0)され、新しい捕獲手順の準備が整います。従って、計数(TCBn.CNT)レシ、スタは事象入力信号の次の正端でBOTTOMにリセットされるため、比較/捕獲レシ、スタの前に読んでください。CNTがMAXの時にOVF割り込みと事象が生成されます。



#### 21.3.3.1.7. 単発動作

単発動作は接続された事象チャネルで上昇端または下降端が観測される毎に比較/捕獲(TCBn.CCMP)レジスタによって定義される持続時間を持つパルスを生成するのに使うことができます。

計数器が止まると、出力ピンがLowに設定されます。接続した事象チャネルで事象が検出された場合、計時器はリセットしてBOTTOMからTOPまでの計数を開始し、同時にその出力をHighに駆動します。計数器が計数しているかを見るのに状態(TCBn.STATUS)レジスタの走行(Run)ビットを読んでください。一旦CNTの値がCCMPレジスタに達すると、計数器は計数を止めます。同時に出力ピンが最小1計数器クロック(CLK\_TCB)周期間Low状態に移ります。この期間中に起きる新しいどの事象も無視されます。これに続き、新しい事象を受けてから出力がHighに設定されるまでに2周辺機能クロック(CLK\_PER)周期の遅延があります。事象制御(TCBn.EVCTRL)レジスタの事象端(EDGE)ビットが、1、を書かれると、どの端も計数器の開始を起動できます。EDGEビットが、0、正端だけが開始を起動します。

計数器は例え事象を起動することなしでも、許可されると直ぐに計数を開始します。これは計数(TCBn.CNT)レジスタにTOP値を書くこ

とによって防がれます。同様の動きは事象制御(TCBn. EVCTRL)レジスタ内の事象端(EDGE)ビットが '1'と同時にこの単位部が許可される場合にも見られます。計数レジスタへのTOP値書き込みはこれも防ぎます。

制御B(TCBn.CTRLB)レシ、スタの非同期許可(ASYNC)ヒットが、1、を書かれた場合、計時器は到着事象に対して非同期に反応します。事象端は出力信号を直ちに設定(1)させます。計数器は未だ事象が受け取られた後の2クロック周期で計数を開始します。

この動作は事象使用部として構成設定されたTCBを必要とし、事象部分で説明されます。



#### 21.3.3.1.8. 8L ットPWM動作

TCBは各16ビット比較/捕獲(TCBn.CCMPHとTCBn.CCMPL)レジスタ対が個別の比較レジスタとして使われる8ビットPWM動作で動くように構成設定することができます。CCMPLは周期(T)を制御し、同時にCCMPHは波形のデューティサイクルを制御します。計数器はBOTTOMからCCMPLまで継続的に計数し、出力はBOTTOMで設定(1)され、計数器がCCMPHに達する時に解除(0)されます。

CCMPHは出力がHighに駆動される間のクロック数です。 CCMPL+1が出力パルスの周期です。



# 21.3.3.2. 出力

計時器同期と出力論理レヘ・ルは選んだ制御B(TCBn.CTRLB)レシ、スタの計時器動作(CNTMODE)ビット領域に依存します。単発動作では信号生成が到着事象に対して非同期に起こるようにタイマ/カウンタを構成設定(TCBn.CTRLBの非同期許可(ASYNC)ビット=1に)することができます。その後、出力信号はTCBクロックに同期化される代わりに到着事象で直ちに設定(1)されます。出力が直ちに設定(1)されるとは言え、計数器が計数を開始するのに先立って2~3 CLK TCB周期かかります。

TCBn.CTRLBの比較/捕獲出力許可(CCMPEN)ビットの'1'書き込みが波形出力を許可し、これは対応するポート出力レジスタでの値を無効にして対応するピンで波形出力を利用可能にします。

各種構成設定と出力でのそれらの影響が下表で一覧にされます。

| 表21-2. 出 | 表21-2. 出力構成設定 |       |                                                    |  |  |  |  |  |  |  |
|----------|---------------|-------|----------------------------------------------------|--|--|--|--|--|--|--|
| CCMPEN   | CNTMODE       | ASYNC | 出力                                                 |  |  |  |  |  |  |  |
| ₩ 水利/h   |               | 0     | 出力は計数器開始時にHigh、計数器停止時にLowです。                       |  |  |  |  |  |  |  |
| 1        | 単発動作          |       | 出力は事象到着時にHigh、計数器停止時にLowです。                        |  |  |  |  |  |  |  |
| 1        | 8ビットPWM動作 非適  |       | 8ピットPWM動作                                          |  |  |  |  |  |  |  |
|          | その他の動作        | 非適用   | 出力初期レベルはTCBn.CTRLBレジスタの比較/捕獲ピン初期値(CCMPINIT)ビット値で設定 |  |  |  |  |  |  |  |
| 0        | 非適用           | 非適用   | 出力なし                                               |  |  |  |  |  |  |  |

周辺機能が許可されている間の動作変更は予期せぬ出力を生成し得るため推奨されません。計時器構成設定中に割り込み要求フラグが設定(1)される可能性があります。周辺機能構成設定後にタイマ/カウンタ割り込み要求フラグ(TCBn.INTFLAGS)レジスタを解除(=0)することが推奨されます。

#### 21.3.3.3. 雑音消去器

雑音消去器は簡単なデジタル濾波器の仕組みを用いることによって雑音耐性を改善します。事象制御(TCBn.EVCTRL)レジスタの雑音 濾波器(FILTER)ビットが許可されると、周辺機能は事象チャネルを監視して最後の4つの観測試料の記録を維持します。4つの連続する 試料が等しければ、その入力は安定と見做され、その信号は端(エッジ)検出器に供給されます。

許可されると、雑音消去器は入力に印加された変化と入力比較レジスタの更新の間に4システム クロック周期の付加遅延をもたらします。 雑音消去器はシステム クロックを使い、従って、前置分周器によって影響を及ぼされません。

#### 21.3.3.4. タイマ/カウンタA型との同期

TCBは制御A(TCBn.CTRLA)レシ、スタのクロック選択(CLKSEL)ヒ、ット領域に'10'を書くことによってタイマ/カウンタA型(TCAn)のクロック(CLK\_T CA)を使うように構成設定することができます。この設定でTCBはTCAnで選ばれるのと正確に同じクロック元で計数します。

制御A(TCBn.CTRLA)レジスタの同期更新(SYNCUPD)ビットが'1'を書かれると、TCB計数器はTCAn計数器が再始動する時に再始動します。

#### 21.3.4. 事象

TCBは以下の表で記述される事象を生成することができます。

#### 表21-3. TCBでの事象生成部

| 生    | 成部名  | 説明            | 事象型 | 生成クロック領域 | 事象長         |  |
|------|------|---------------|-----|----------|-------------|--|
| 周辺機能 | 事象   | a元 9月         | 尹豕至 | 上ルカツ頂塚   | 尹豕坛         |  |
| TCBn | CAPT | CAPTフラク・設定(1) | パルス | CLK_PER  | 1 CLK_PER周期 |  |

CAPT事象を生成するための条件はタイマ/カウンタ割り込み要求フラグ(TCBn.INTFLAGS)レジスタで対応する割り込み要求フラグを掲げる それらと同じです。事象使用部と事象システム構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照してください。

TCBは下表で記述される事象を受け取ることができます。

#### 表21-4 TCBでの事象使用部と利用可能な事象活動

| 使    | 用部名  | 説明                                                 | 入力検出 | 同期/非同期  |
|------|------|----------------------------------------------------|------|---------|
| 周辺機能 | 入力   | 武ツ                                                 | 人力快山 | 四州/ 非四州 |
| TCBn | САРТ | 制限時間検査、事象で計数捕獲、計数捕獲周波数測定、計数捕獲パルス幅測定、計数捕獲周波数/パルス幅測定 | 端    | 同期      |
|      |      | 単発                                                 |      | 両方      |

事象制御(TCBn.EVCTRL)レジスタの捕獲事象入力許可(CAPTEI)ビットが'1'を書かれた場合、やって来る事象は制御B(TCBn.CTRL B)レジスタの計時器動作(CNTMODE)ビット領域とTCBn.EVCTRLレジスタの事象端選択(EDGE)ビットによって定義されたような事象活動になります。事象は認知されるために最低1 CLK\_PER周期間留まることが必要です。

単発動作に対して非同期動作が許可された場合、事象は端起動され、1システム クロック周期よりも短い事象入力で変更を捕獲します。

#### 21.3.5. 割り込み

# 表21-5. 利用可能な割り込みベクタと供給元

| 名称   | ベクタ説明   | 条件                                        |
|------|---------|-------------------------------------------|
| CAPT | TCB割り込み | 動作形態に依存。TCBn.INTFLAGSレジスタのCAPTの記述をご覧ください。 |

割り込み条件が起こると、周辺機能の割り込み要求フラケ、(TCBn.INTFLAGS)レジスタで対応する割り込み要求フラケが設定(1)されます。割り込み元は周辺機能の割り込み制御(TCBn.INTCTRL)レジスタで対応する許可ビットを書くことによって許可または禁止にされます。割り込み要求は対応する割り込み元が許可され、割り込み要求フラケが設定(1)される時に生成されます。割り込み要求は割り込み要求フラケが解除(0)されるまで活性に留まります。割り込み要求フラケを解除する方法の詳細については周辺機能のINTFLAGSレジスタをご覧ください。

# 21.3.6. 休止形態動作

TCBは既定によってスタンバイ休止動作で禁止されます。休止動作へ移行すると直ぐに停止されます。

制御A(TCBn.CTRLA)レシ、スタのスタンハ・イ時走行(RUNSTDBY)ヒ、ットが、1、を書かれた場合、この単位部は完全な動作をすることができます。

全ての動作はパワーダウン休止動作で停止されます。

# 21.4. レジスタ要約

| 変位                  | 略称       | ビット位置        | ビット7 | ピット6     | ピット5     | ヒ゛ット4   | ピット3  | ピット2 | ヒ゛ット1    | ピット0   |
|---------------------|----------|--------------|------|----------|----------|---------|-------|------|----------|--------|
| +\$00               | CTRLA    | 7 <b>~</b> 0 |      | RUNSTDBY |          | SYNCUPD |       | CLKS | EL1,0    | ENABLE |
| +\$01               | CTRLB    | 7~0          |      | ASYNC    | CCMPINIT | CCMPEN  |       | C    | NTMODE2~ | 0      |
| +\$02<br>~<br>+\$03 | 予約       |              |      |          |          |         |       |      |          |        |
| +\$04               | EVCTRL   | 7 <b>~</b> 0 |      | FILTER   |          | EDGE    |       |      |          | CAPTEI |
| +\$05               | INTCTRL  | 7 <b>~</b> 0 |      |          |          |         |       |      |          | CAPT   |
| +\$06               | INTFLAGS | 7~0          |      |          |          |         |       |      |          | CAPT   |
| +\$07               | STATUS   | 7 <b>~</b> 0 |      |          |          |         |       |      |          | RUN    |
| +\$08               | DBGCTRL  | 7 <b>~</b> 0 |      |          |          |         |       |      |          | DBGRUN |
| +\$09               | TEMP     | 7 <b>~</b> 0 |      | 1        |          | TEM     | P7~0  |      | 1        |        |
| +\$0A               | CNT      | 7 <b>~</b> 0 |      | 1        |          | CNT     | 7~0   |      | 1        |        |
| +\$0B               | CNI      | 15~8         |      | 1        |          | CNT     | 15~8  |      | 1        |        |
| +\$0C               | CCMD     | 7~0          |      | 1        |          | CCM     | P7~0  |      | 1        |        |
| +\$0D               | ССМР     | 15~8         |      |          |          | CCMI    | P15~8 |      |          |        |

# 21.5. レジスタ説明

**21.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位:+\$00 リセット: \$00 特質:-

| ピット    | 7 | 6        | 5 | 4       | 3 | 2    | 1     | 0      |
|--------|---|----------|---|---------|---|------|-------|--------|
|        |   | RUNSTDBY |   | SYNCUPD |   | CLKS | EL1,0 | ENABLE |
| アクセス種別 | R | R/W      | R | R/W     | R | R/W  | R/W   | R/W    |
| リセット値  | 0 | 0        | 0 | 0       | 0 | 0    | 0     | 0      |

● ビット6 - RUNSTDBY: スタンバイ時走行 (Run Standby)

このビットへの'1'書き込みはスタンバイ休止動作での走行をこの周辺機能に許します。クロック選択(CLKSEL)が'10'に設定される時は適用できません。

● ビット4 - SYNCUPD: 同期更新 (Synchronize Update)

このビットへの'1'書き込みはTCA計数器が再始動または溢れる時に必ずTCBが再始動します。これはPWM周期での同期捕獲に使うことができます。CLKSELが'01'(CLK\_PER/2)に設定される時には適用できません。

ビット2.1 - CLKSEL1.0:クロック選択(Clock Select)

これらビットの書き込みはこの周辺機能用のクロック元を選びます。

| 値  | 0 0     | 0 1       | 1 0            | 11   |
|----|---------|-----------|----------------|------|
| 名称 | CLKDIV1 | CLKDIV2   | CLKTCA         | _    |
| 説明 | CLK_PER | CLK_PER/2 | TCA0からのCLK_TCA | (予約) |

● ビット0 - ENABLE:許可(Enable)

このビットに'1'を書くことはタイマ/カウンタB型周辺機能を許可します。

**21.5.2. CTRLB - 制御B** (Control B)

名称: CTRLB 変位:+\$01 リセット: \$00 特質:-

| ピット    | 7 | 6     | 5        | 4      | 3 | 2   | 1         | 0   |
|--------|---|-------|----------|--------|---|-----|-----------|-----|
|        |   | ASYNC | CCMPINIT | CCMPEN |   | (   | CNTMODE2~ | 0   |
| アクセス種別 | R | R/W   | R/W      | R/W    | R | R/W | R/W       | R/W |
| リセット値  | 0 | 0     | 0        | 0      | 0 | 0   | 0         | 0   |

● ビット6 - ASYNC: 非同期許可(Asynchronous Enable)

このビットに'1'を書くことは単発動作でTCB出力信号の非同期更新を許します。

| 値  | 0                        | 1                   |
|----|--------------------------|---------------------|
| 説明 | 出力は計数器の同期後開始時にHighになります。 | 出力は事象到着時にHighになります。 |

● ビット5 - CCMPINIT: 比較/捕獲ピン初期値 (Compare/Capture Pin Initial Value)

このビットはピン出力が使われる時にピンの初期出力値を設定するのに使われます。このビットは8ビットPWM動作と単発動作で無効です。

| 値  | 0              | 1               |
|----|----------------|-----------------|
| 説明 | 初期のピン状態はLowです。 | 初期のピン状態はHighです。 |

● ビット4 - CCMPEN: 比較/捕獲出力許可 (Compare/Capture Output Enable)

このビットに'1'を書くと、波形出力を許可します。これは対応するPORT出力レジスタの値を無効にして対応するピンで波形出力を利用可能にします。対応するピン方向はPORT周辺機能で出力として構成設定されなければなりません。

| 値  | 0                  | 1                     |
|----|--------------------|-----------------------|
| 説明 | 対応ピンで波形出力は許可されません。 | 波形出力は対応ピンの出力値を上書きします。 |

● ビット2~0 - CNTMODE2~0:計時器動作(Timer Mode)

これらのビット書き込みは計時器動作を選びます。

| 値  | 0 0 0      | 0 0 0    |                  | 0 1 0      |        |      | 0 1 1           |
|----|------------|----------|------------------|------------|--------|------|-----------------|
| 名称 | INT        | TIMEOUT  |                  | CAPT       |        |      | FRQ             |
| 説明 | 周期的割り込み動作  | 制限時間検査動作 |                  | 事象での計数捕獲動作 |        | 計数捕獲 | <b>语周波数測定動作</b> |
| 値  | 100        |          | 1 0 1            |            | 1      | 1 0  | 111             |
| 名称 | PW         |          | FRQPW            |            | SINGLE |      | PWM8            |
| 説明 | 計数捕獲パルス幅測定 | 動作       | 計数捕獲周波数/パルス幅測定動作 |            | 単発動作   |      | 8ビットPWM動作       |

# 21.5.3. EVCTRL - 事象制御 (Event Control)

名称: EVCTRL 変位: +\$04 リセット: \$00 特質:-

| ピット    | 7 | 6      | 5 | 4    | 3 | 2 | 1 | 0      |
|--------|---|--------|---|------|---|---|---|--------|
|        |   | FILTER |   | EDGE |   |   |   | CAPTEI |
| アクセス種別 | R | R/W    | R | R/W  | R | R | R | R/W    |
| リセット値  | 0 | 0      | 0 | 0    | 0 | 0 | 0 | 0      |

● ビット6 - FILTER: 捕獲入力雑音消去濾波器許可 (Input Capture Noise Cancellation Filter)

このビットに'1'を書くことが捕獲入力雑音消去部を許可します。

● ビット4 - EDGE: 事象端選択(Event Edge)

このビットは事象端を選ぶのに使われます。このビットの影響は制御B(TCBn.CTRLB)レジスタで選んだ計数動作(CNTMODE)に依存します。"-"は事象や端がこの動作で無効なことを意味します。

| 計数動作             | EDGE | 正(上昇)端              | 負(下降)端              |
|------------------|------|---------------------|---------------------|
| 周期的割り込み動作        | 0    | -                   | -                   |
| 问知时前以还今期日        | 1    | -                   | -                   |
| 制限時間検査動作         | 0    | 計数開始                | 計数停止                |
| <b>前欧时间恢复</b>    | 1    | 計数停止                | 計数開始                |
| 車色での乳粉は凝動が       | 0    | 計数値を捕獲、割り込み         | -                   |
| 事象での計数捕獲動作       | 1    | -                   | 計数値を捕獲、割り込み         |
| 1.粉卡灌用水粉测空和佐     | 0    | 計数値を捕獲/解消/再開、割り込み   | -                   |
| 計数捕獲周波数測定動作      | 1    | -                   | 計数値を捕獲/解消/再開、割り込み   |
| 計数捕獲パルス幅測定動作     | 0    | 計数値を解消/再開           | 計数値を捕獲、割り込み         |
| 司数補後ハルへ幅例足動作     | 1    | 計数値を捕獲、割り込み         | 計数値を解消/再開           |
| 計数捕獲周波数/パルス幅測定動作 | 0    | 第1正端で計数値を解消/再開、後続する | る負端で捕獲、第2正端で停止と割り込み |
| 可数拥缓问仅数/ハル州側是動作  | 1    | 第1負端で計数値を解消/再開、後続する | る正端で捕獲、第2負端で停止と割り込み |
| 単発動作             | 0    | 計数開始                | _                   |
| 中光期作             | 1    |                     | 計数開始                |
| 8ビットPWM動作        | 0    |                     |                     |
| OC NUL MINIBUTE  | 1    | -                   |                     |

● ビット0 - CAPTEI: 捕獲事象入力許可 (Capture Event Input Enable) このビットに'1'を書くことがTCBに対する事象入力捕獲を許可します。

# **21.5.4. INTCTRL - 割り込み制御** (Interrupt Control)

名称:INTCTRL 変位:+\$05 リセット:\$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|--------|---|---|---|---|---|---|---|------|
|        |   |   |   |   |   |   |   | CAPT |
| アクセス種別 | R | R | R | R | R | R | R | R/W  |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    |

# ● ビット0 - CAPT:捕獲割り込み許可(Capture Interrupt Enable)

このビットに'1'を書くことが捕獲での割り込みを許可します。

# 21.5.5. INTFLAGS - 割り込み要求フラグ (Interrupt Flags)

名称: INTFLAGS 変位: +\$06 リセット: \$00 特質: -

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|--------|---|---|---|---|---|---|---|------|
|        |   |   |   |   |   |   |   | CAPT |
| アクセス種別 | R | R | R | R | R | R | R | R/W  |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    |

### ● ビット0 - CAPT:捕獲割り込み要求フラグ(Capture Interrupt Flag)

このビットは捕獲割り込み発生時に設定(1)されます。割り込み条件は制御B(TCBn.CTRLB)レジスタの計数動作(CNTMODE)ビット領域に依存します。

このビットはこれに'1'を書くことによって、または捕獲動作で比較/捕獲(CCMP)レジスタが読まれた時に解除(0)されます。

| 計数器動作     | 割り込み設定条件                        | TOP値  | CAPT             |
|-----------|---------------------------------|-------|------------------|
| 周期的割り込み動作 |                                 |       |                  |
| 制限時間検査動作  | 計数器がTOPに達した時に設定(1)              | CCMP  | CNT=TOP          |
| 単発動作      |                                 |       |                  |
|           | 捕獲レジスタを設定して計数器再始動時端で設定(1)、フラグは捕 |       | 事象でCNTをCCMPに複写、  |
| 測定動作      | 獲読み込み時に解除( <mark>0</mark> )     |       | 計数再開(CNT=BOTTOM) |
| 事象での      | 事象が起きて捕獲レジスタが設定される時に設定(1)、フラグは捕 |       |                  |
| 計数捕獲動作    | 獲読み込み時に解除( <mark>0</mark> )     | _     |                  |
| 計数捕獲パルス幅  | 捕獲レジスタを設定して計数器再始動時端で設定(1)、直前端で  |       | 事象でCNTをCCMPに複写、  |
| 測定動作      | 計数器初期化、フラグは捕獲読み込み時に解除(0)        |       | 計数継続             |
| 計数捕獲周波数/  | 計数器停止時の第2(正/負)端で設定(1)、フラグは捕獲読み込 |       |                  |
| パルス幅測定動作  | み時に解除(0)                        |       |                  |
| 8ビットPWM動作 | 計数器がCCMPLに達した時に設定(1)            | CCMPL | CNT=CCMPL        |

# 21.5.6. STATUS - 状態 (Status)

名称: STATUS 変位: +\$07 リセット: \$00 特質: -

| ヒ゛ット _ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|--------|---|---|---|---|---|---|---|-----|
|        |   |   |   |   |   |   |   | RUN |
| アクセス種別 | R | R | R | R | R | R | R | R   |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0   |

# ビット0 - RUN: 走行(Run)

計数器が走行している時にこのビットが'1'に設定されます。計数器が停止されると、このビットが'0'に解除されます。このビットは読み込み専用でUPDIによって設定することはできません。

# **21.5.7. DBGCTRL - デバッグ制御** (Debug Control)

名称: DBGCTRL 変位: +\$08 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|--------|---|---|---|---|---|---|---|--------|
|        |   |   |   |   |   |   |   | DBGRUN |
| アクセス種別 | R | R | R | R | R | R | R | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0      |

#### ● ビット0 - DBGRUN: デバッグ時走行 (Debug Run)

| 値  | 0                  | 1                    |
|----|--------------------|----------------------|
| 説明 | 中断デバッグ動作で停止され事象を無視 | 中断デバッグ動作でCPU停止時に走行継続 |

#### 21.5.8. TEMP - 一時レジスタ (Temporary Value)

名称: TEMP 変位:+\$09 リセット: \$00 特質:-

一時レジスタはこの周辺機能の16ビット レジスタへの16ビット単一周期アクセスのためにCPUによって使われます。このレジスタはこの周辺機能の全ての16ビット レジスタに対して共通で、ソフトウェアによって読み書きすることができます。16ビット レジスタ読み書きのより多くの詳細については「AVR® CPU」章の「16ビット レジスタのアクセス」を参照してください。

| ピット    | 7       | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|---------|-----|-----|-----|-----|-----|-----|-----|
|        | TEMP7~0 |     |     |     |     |     |     |     |
| アクセス種別 | 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 - TEMP7~0: 一時値 (Temporary Value)

#### 21.5.9. CNT - 計数 (Count)

名称: CNT (CNTH, CNTL)

変位 : +\$0A リセット : \$0000 特質 : -

TCBn.CNTHとTCBn.CNTLのレシ、スタ対は16ビット値のTCBn.CNTを表します。下位ハイト[7~0](接尾辞L)は変位原点でアクセスできます。上位ハイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

CPUとUPDIの書き込みアクセスはレジスタの内部更新を超える優先権を持ちます。

| 15  | 14            | 13                    | 12                                                              | 11                                            | 10                                                                                                                                                               | 9                                                                                                                                                                                      | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|---------------|-----------------------|-----------------------------------------------------------------|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |               |                       | CNT                                                             | 15~8                                          |                                                                                                                                                                  |                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ·   |               |                       | CNT                                                             | 7~0                                           |                                                                                                                                                                  |                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| R/W | R/W           | R/W                   | R/W                                                             | R/W                                           | R/W                                                                                                                                                              | R/W                                                                                                                                                                                    | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0   | 0             | 0                     | 0                                                               | Λ                                             | Λ                                                                                                                                                                | 0                                                                                                                                                                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|     | R/W<br>0<br>7 | R/W R/W<br>0 0<br>7 6 | R/W R/W R/W 0 0 0 0 7 6 5 8 8 7 8 7 8 7 8 7 8 7 8 7 8 7 8 7 8 7 | CNT  R/W R/W R/W R/W  0 0 0 0 0  7 6 5 4  CNT | CNT15~8       R/W     R/W     R/W     R/W     R/W       0     0     0     0     0       7     6     5     4     3       CNT7~0       R/W     R/W     R/W     R/W | CNT15~8       R/W     R/W     R/W     R/W     R/W       0     0     0     0     0       7     6     5     4     3     2       CNT7~0       R/W     R/W     R/W     R/W     R/W     R/W | CNT15~8           R/W         R/W |

#### ● ビット15~8 - CNT15~8: 計数値上位バイト (Count Value high)

これらのビットは16ビット計数レジスタの上位バイトを保持します。

#### ● ビット7~0 - CNT7~0: 計数値下位バイト (Count Value low)

これらのビットは16ビット計数レジスタの下位バイトを保持します。

# 21.5.10. CCMP - 比較/捕獲 (Compare/Capture)

名称: CCMP (CCMPH, CCMPL)

変位:+\$28 リセット:\$0000 特質:-

TCBn.CCMPHとTCBn.CCMPLのレシ、スタ対は16ビット値のTCBn.CCMPを表します。下位バイト[7~0](接尾辞L)は変位原点でアクセスできます。上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

このレジスタは動作形態に依存して異なる機能を持ちます。

- ・捕獲動作に対して、これらのレシ、スタは捕獲発生時に捕獲された計数器の値を含みます。
- ・周期的割り込み、制限時間検査、単発の動作でこのレジスタはTOP値として働きます。
- ・8ビットPWM動作ではTCBn.CCMPHとTCBn.CCMPLは2つの独立した比較レジブスタとして働きます。波形の周期がCCMPLによって制御される一方で、CCMPHがデューティサイクルを制御します。

| 15  | 14            | 13              | 12                        | 11                                                                                                                                                                | 10                                                                                                                                                                                               | 9                                                                                                                                                                                                          | 8                                                                                                                                                                  |
|-----|---------------|-----------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |               |                 | CCMI                      | P15~8                                                                                                                                                             |                                                                                                                                                                                                  |                                                                                                                                                                                                            |                                                                                                                                                                    |
| 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                                                                                                                                                                  |
|     |               |                 | CCM                       | P7∼0                                                                                                                                                              |                                                                                                                                                                                                  |                                                                                                                                                                                                            |                                                                                                                                                                    |
| R/W | R/W           | R/W             | R/W                       | R/W                                                                                                                                                               | R/W                                                                                                                                                                                              | R/W                                                                                                                                                                                                        | R/W                                                                                                                                                                |
| 0   | 0             | 0               | 0                         | 0                                                                                                                                                                 | 0                                                                                                                                                                                                | 0                                                                                                                                                                                                          | 0                                                                                                                                                                  |
|     | R/W<br>0<br>7 | R/W R/W 0 0 7 6 | R/W R/W R/W 0 0 0 0 7 6 5 | R/W         R/W         R/W         R/W         R/W           0         0         0         0           7         6         5         4           CCM         CCM | CCMP15~8           R/W         R/W         R/W         R/W         R/W           0         0         0         0         0           7         6         5         4         3           CCMP7~0 | CCMP15~8           R/W         R/W         R/W         R/W         R/W           0         0         0         0         0           7         6         5         4         3         2           CCMP7~0 | CCMP15~8       R/W     R/W     R/W     R/W     R/W     R/W     R/W       0     0     0     0     0     0       7     6     5     4     3     2     1       CCMP7~0 |

● ビット15~8 - CCMP15~8: 比較/捕獲値上位バイト (Compare/Capture Value high byte)

これらのビットは16ビットの比較/捕獲/TOP値の上位バイトを保持します。

● ビット7~0 - CCMP7~0: 比較/捕獲値下位バイト (Compare/Capture Value low byte)

これらのビットは16ビットの比較/捕獲/TOP値の下位バイトを保持します。

# 22. TCD - 12ビット タイマ/カウンタD型

# 22.1. 特徴

- ・ 12ビット タイマ/カウンタ
- ・ 設定可能な前置分周器
- ・2重緩衝された比較レジスタ
- 波形生成
  - 1傾斜動作
  - 2傾斜動作
  - 4傾斜動作
  - 2重勾配動作
- ・2つの独立した入力チャネル
- ・ソフトウェアと捕獲に基づく入力
- ・入力事象に対する設定可能な濾波器
- 外部事象での条件付き波形生成
  - 障害処理
  - 入力抑止
  - 過負荷保護機能
  - ハートウェアによる緊急停止
- ・半ブリッジと全ブリッジの出力を支援

### 22.2. 概要

タイマ/カウンタD型(TCD)は非同期計数器、前置分周器と、比較、捕獲、制御の論理回路から成る高性能な波形制御器です。

TCDは周辺機能クロックに対して非同期のクロックで動くことができる計数器を含みます。これは任意選択の沈黙時間を持つ独立した2つの出力を生成することができる比較論理回路を含みます。それは捕獲と決定論的障害制御のため、事象システムに接続されます。タ イマ/カウンタは比較一致と溢れで割り込みと事象を生成することができます。

このデバイスはTCD周辺機能の1つの実体であるTCD0を提供します。

#### 22.2.1. 構成図



TCDコアは周辺機能クロックに対して非同期です。タイマ/カウンタは各々独立した波形出力を持つ2つの比較/捕獲単位部から成ります。この単位部の1つからの出力に等しくすることができる2つの追加波形出力もあります。各比較/捕獲単位部に対して、各々の周辺機能レジスタ(TCDn.CMPASET、TCDn.CMPACLR、TCDn.CMPBSET、TCDn.CMPBCLR)で格納される比較レジスタの対があります。

標準動作中、計数器値は継続して比較レシブスタと比較されます。これは割り込みと事象の両方を生成するのに使われます。

TCDは2つの入力事象に対して独立して選ばれる10種の入力動作で入力事象を使うことができます。入力動作は入力事象が出力に どう影響を及ぼすかと、事象発生時に計数器がTCD周回のどこへ行かなければならないかを定義します。

TCDは前置分周することができる3つの異なるクロック元から選ぶことができます。下で示されるように、独立した制御を持つ3つの異なる前置分周器があります。



TCD同期部クロックは他の単位部クロックから独立し、TCD領域とI/O領域間のより早い同期を許します。 計数器に対する総前置分周は次のとおりです。

#### 同期前置分周器(SYNCPRES)分周係数×計数器前置分周器(CNTPRES)分周係数

遅延前置分周器は入力抑止/遅延事象出力機能に使われるクロックの前置分周に使われます。この前置分周器は独立して構成設定することができ、計数器機能から独立した範囲と精度の設定を許します。同期前置分周器と計数器前置分周器は制御A(TCDn.CTR LA)レジスタで構成設定することができる一方で、遅延前置分周器は遅延制御(TCDn.DLYCTRL)レジスタで構成設定することができます。

# 22.2.2. 信号説明

| 信号  | 形式     | 説明       |
|-----|--------|----------|
| WOA | デジタル出力 | TCD波形出力A |
| WOB | デジタル出力 | TCD波形出力B |
| WOC | デジタル出力 | TCD波形出力C |
| WOD | デジタル出力 | TCD波形出力D |

# 22.3. 機能的な説明

#### 22.3.1. 定義

以下の定義はこの文書を通して使われます。

#### 表22-1. タイマ/カウンタ定義

| 表22 <sup>-1</sup> . 为1 ₹/ 加7/29 足我 |                                                 |  |  |  |
|------------------------------------|-------------------------------------------------|--|--|--|
| 名称                                 | 説明                                              |  |  |  |
| TCD周回                              | 計数器が同じ場所に戻される前に通って行くことが必要が4つの状態の連続した流れ          |  |  |  |
| 入力抑止                               | TCD周回の選択可能な部分で設定可能な時間の間、事象入力を無視ための機能            |  |  |  |
| 非同期出力制御                            | 事象発生時に瞬時に出力を上書きすることを許します。これは回復不能障害を処理するのに使われます。 |  |  |  |
| 1傾斜                                | 計数器はTCD周回中に1度、0にリセットされます。                       |  |  |  |
| 2傾斜                                | 計数器はTCD周回中に2度、0にリセットされます。                       |  |  |  |
| 4傾斜                                | 計数器はTCD周回中に4度、0にリセットされます。                       |  |  |  |
| 2重勾配                               | 計数器はTCD周回中に0と選んだ頂上値間を上昇と下降の両方で計数します。            |  |  |  |
| 入力動作                               | 与えられた入力事象に基づいて出力特性を変更する予め定義された設定                |  |  |  |

#### 22.3.2. 初期化

TCDを初期化するには次のとおりです。

- 1. 制御A(TCDn.CTRLA)レシ、スタでクロック元と前置分周器を選んでください。
- 2. 制御B(TCDn.CTRLB)レジスタで波形生成動作を選んでください。
- 3. 任意選択: 他の静的レジスタを望む機能に構成設定してください。
- 4. 比較(TCDn.CMPxSET/CLR)レシブスタに初期値を書いてください。
- 5. 任意選択: 他の2重緩衝されたレジスタに望む値を書いてください。
- 6. 状態(TCDn.STATUS)レジスタの許可準備可(ENRDY)ビットが'1'に設定されているのを確実にしてください。
- 7. 制御A(TCDn.CTRLA)レジスタの許可(ENABLE)ビットに'1'を書くことによってTCDを許可してください。

#### 22.3.3. 動作

#### 22.3.3.1. レジスタ同期区分

殆どのI/OレジスタはTCDコア クロック領域に対して同期されることが必要です。これは各種レジスタ区分に対して違うように行われます。

#### 表22-2. レジスタの区分

| 許可と指令のレジスタ                | 2重緩衝されるレジスタ  | 静的レジスタ                                            | 読み込み専用レジスタ    | 標準I/Oレジスタ     |
|---------------------------|--------------|---------------------------------------------------|---------------|---------------|
| TCDn.CTRLA<br>(ENABLEビット) | TCDn.DLYCTRL | TCDn.CTRLA ( <mark>注1</mark> )<br>(ENABLEを除く全ビット) | TCDn.STATUS   | TCDn.INTCTRL  |
| TCDn.CTRLE                | TCDn.DLYVAL  | TCDn.CTRLB                                        | TCDn.CAPTUREA | TCDn.INTFLAGS |
|                           | TCDn.DITCTRL | TCDn.CTRLC                                        | TCDn.CAPTUREB |               |
|                           | TCDn.DITVAL  | TCDn.CTRLD                                        |               |               |
|                           | TCDn.DBGCTRL | TCDn.EVCTRLA                                      |               |               |
|                           | TCDn.CMPASET | TCDn.EVCTRLB                                      |               |               |
|                           | TCDn.CMPACLR | TCDn.INPUTCTRLA                                   |               |               |
|                           | TCDn.CMPBSET | TCDn.INPUTCTRLB                                   |               |               |
|                           | TCDn.CMPBCLR | TCDn.FAULTCTRL ( <mark>注2</mark> )                |               |               |

注1: TCDn.CTRLAレジスタのビットはENABLEビットの例外を除き、許可保護されます。これらは先にENABLEビットが'0'を書かれた 時にだけ書くことができます。

注2: このレジスタはそれの値設定の変更に対して時限書き込み手順を必要とする構成設定変更保護機構によって保護されます。

#### 指令と許可のレジスタ

クロック領域間の同期のため、状態(TCDn.STATUS)レジスタの許可準備可(ENRDY)ビットが゚1゚の間にだけ制御A(TCDn.CTRLA)レジスタの許可(ENABLE)ビットを変更することが可能です。

制御E(TCDn.CTRLE)レジスタは、TCDが許可された時で、既に同期化が進行中でない限り、TCDコア領域に対して自動的に同期化されます。新しい指令を書くことが可能なことを確かめるには、TCDn.STATUSレジスタの指令準備可(CMDRDY)ビットが'1'か調べてください。TCDn.CTRLEは指令が送られる時にそれ自身を解除(0)する瞬発(ストローブ)レジスタです。

# 2重緩衝されるレジスタ

2重緩衝されるレジスタはTCDが許可されて2つのクロック領域間の同期が進行中でない間に標準I/O書き込みで更新することができます。2重緩衝されるレジスタを更新することが可能なことを確かめるためにTCDn.STATUSレジスタのCMDRDYビットが'1'であることを調べてください。この値は同期指令が送られた時またはTCDが許可された時にTCDコア領域に同期化されます。

#### 表22-3. 同期指令発行

| 同期発行ビット           | 2重緩衝レジスタ更新                          |
|-------------------|-------------------------------------|
| CTRLC.AUPDATE     | CMPBCLRHレジスタが書かれる度毎に同期化がTCD周回の最後で発生 |
| CTRLE.SYNC (注)    | SYNCビットがTCD領域に同期されると直ぐに1度発生         |
| CTRLE.SYNCEOC (注) | 次のTCD周回の最後で1度発生                     |

注: 同期が既に進行中の場合、その活動は無効です。

#### 静的レジスタ

静的レジスタはTCDが許可されている間に更新することができません。従って、これらのレジスタはTCDを許可する前に構成設定されなければなりません。TCDが許可されているかを知るには、制御A(TCDn.CTRLA)レジスタの許可(ENABLE)ビットが'1'として読めるか調べてください。

#### 標準I/Oと読み込み専用のレジスタ

標準I/Oと読み込み専用のレジスタは領域間のどの同期化によっても制約されません。読み込み専用レジスタは同期状態についてとコア 領域からの同期された値を通知します。

#### 22.3.3.2. 波形生成動作

TCDは制御B(TCDn.CTRLB)レシブスタの波形生成動作(WGMODE)ビット領域によって制御される4つの異なる波形生成動作を提供します。波形生成動作は次のとおりです。

- · 1傾斜動作
- 2傾斜動作
- 4傾斜動作
- 2重勾配動作

波形生成動作はTCD周回中に計数器がどう計数するかと比較値が波形にどう影響するかを決めます。TCD周回は以下のこれらの状態に分けられます。

・WOA 沈黙時間 (DTA) ・WOA ON時間 (OTA) ・WOB 沈黙時間 (DTB) ・WOB ON時間 (OTB)

比較A設定(TCDn.CMPASET)、比較A解除(TCDn.CMPACLR)、比較B設定(TCDn.CMPBSET)、比較B解除(TCDn.CMPBCLR)の比較値が各状態の最後と次の開始の時を定義します。

#### 22.3.3.2.1. 1傾斜動作

1傾斜動作ではTCD計数器が比較B解除(TCDn.CMPBCLR)レジスタ値に達するまで上昇計数します。その後にTCD周回が完了されて計数器は新しいTCD周回を始める\$000から再始動します。TCD周回の周期は次のとおりです。

$$T_{TCD\_cycle} = \frac{(CMPBCLR+1)}{f_{CLK} TCD CNT}$$

下の左図ではCMPASET<CMPACLR<CMPBSET<CMPBCLRです。1傾斜動作で、これはON時間中の重複出力を避けるために必要とされます。下の右図はCMPBSET<CMPASET<CMPACLR<CMPBCLRの例で、ON時間中の重複出力を持ちます。





CMPBCLRとの一致は常に全出力解除に帰着します。他の比較値のどれかがCMPBCLRよりも大きければ、それらの関連する効果は決して起きません。CMPACLRがCMPASET値よりも小さい場合、その解除値は無効です。

#### 22.3.3.2.2. 2傾斜動作

2傾斜動作ではTCD計数器が比較A解除(TCDn.CMPACLR)レジスタ値に達するまで上昇計数し、そしてリセットして比較B解除(TCDn.CMPBCLR)レジスタ値に達するまで上昇計数します。その後にTCD周回が完了され、計数器は新しいTCD周回を始める\$000から再始動します。TCD周回の周期は以下によって与えられます。

$$T_{\text{TCD\_cycle}} = \frac{\text{(CMPACLR+1+CMPBCLR+1)}}{f_{\text{CLK}} \text{ TCD CNT}}$$

右図ではCMPASET<CMPACLRとCMPBSET<CMPBCLRです。これは出力をHighにさせます。CMPBSETとCMPBCLR値と比べてCMPASETとCMPACLRに制限はありません。

2傾斜動作で上書き機能を使わずに重複出力を得ることは不可能です。例えCMPASET/CMPBSET>CMPACLR/CMPBCLRでも、計数器はCMPACLR/CMPBCLRでリセットし、決してCMPASET/CMPBSETに達しません。



#### 22.3.3.2.3. 4傾斜動作

4傾斜動作でのTCD周回は以下のこの様式です。

- 1. TCD周回はTCD計数器が0から比較A設定(TCDn.CMPASET)レジスタ値に達するまで上昇計数し、そして0にリセットすることで始まります。
- 2. TCD計数器は比較A解除(TCDn.CMPACLR)レジスタ値に達するまで上昇計数し、そして0にリセットします。
- 3. TCD計数器は比較B設定(TCDn.CMPBSET)レジスタ値に達するまで上昇計数し、そして0にリセットします。
- 4. TCD計数器は比較B解除(TCDn.CMPBCLR)レジスタ値に達するまで上昇計数し、そして0にリセットすることによってTCD周回を終わります。

TCD周回の周期は以下によって与えられます。



 $T_{TCD\_cycle} = \frac{(CMPASET+1+CMPACLR+1+CMPBSET+1+CMPBCLR+1)}{f_{CLK\_TCD\_CNT}}$ 

それらに依存性がないため、比較値に関して制限はありません。

4傾斜動作で上書き機能を使わずに重複出力を得ることは不可能です。

#### 22.3.3.2.4. 2重勾配動作

2重勾配動作でのTCD周回は比較B解除(TCDn.CMPBCLR)レジスタ値から0への下降計数、そして再びCMPBCLRレジスタ値への上昇計数から成ります。これは右のようなTCD周回周期を与えます。

 $T_{TCD\_cycle} = \frac{2 \times (CMPBCLR+1)}{f_{CLK\_TCD\_CNT}}$ 

WOA出力はTCD計数器が下降計数して比較A設定(CMPASET)レジスタ値と一致する時に設定(1)されます。WOAはTCD計数器が上昇計数してCMPASETレジスタ値と一致する時に解除(0)されます。

WOB出力はTCD計数器が上昇計数して比較B設定(CMPBSET)レジスタ値と一致する時に設定(1)されます。WOBはTCD計数器が下降計数してCMPBSETレジスタ値と一致する時に解除(0)されます。

出力はCMPASET>CMPBSETの場合に重なります。

比較A解除(CMPACLR)レジスタは2重勾配動作で使われません。CMPACLRレジスタへの値書き込みは無効です。

2重勾配動作でTCDを開始すると、TCD計数器はCMPBCLRレジスタ値で始まって下降計数します。最初の周回で、WOBは上昇計数時にTCD計数器がCMPBSETレジスタ値と一致するまで設定(1)されません。

制御E(TCDn.CTRLE)レシ、スタのTCD周回の最後で禁止発動(DISEOC)ビットが設定(1)されると、TCDはそのTCD周回の最後で自動的に禁止されます。





## 22.3.3.3. TCD禁止

TCDの禁止は以下のような2つの異なる方法で行うことができます。

- 1. 制御A(TCDn.CTRLA)レシブスタの許可(ENABLE)ビットに'0'を書くことによります。これはTCDコア領域に同期される時に直ぐに禁止されます。
- 2. 制御E(TCDn.CTRLE)レジスタのTCD周回の最後で禁止発動(DISEOC)ビットに'1'を書くことによります。これはTCD周回の最後でTCDを禁止します。

#### 22.3.3.4. TCD入力

TCDは事象システムに接続された2つの入力、入力Aと入力Bを持ちます。各々の入力は対応する出力(WOAとWOB)に接続される機能を持ちます。この機能は事象制御(TCDn.EVCTRLAとTCDn.EVCTRLB)レシ、スタと入力制御(TCDn.INPUTCTRLAとTCDn.INPUTCTRLB)レシ、スタによって制御されます。

入力事象を許可するには、対応する事象制御(TCDn.EVCTRLAまたはTCDn.EVCTRLB)レジスタの事象入力起動許可(TRIGEI)ビットに'1'を書いてください。この入力は既定で障害検出として使われますが、それらは捕獲起動としても使うことができます。捕獲起動を許可するには、対応する事象制御(TCDn.EVCTRLAまたはTCDn.EVCTRLB)レジスタの事象活動(ACTION)ビットに'1'を書いてください。障害検出を禁止するには、対応する入力制御(TCDn.INPUTCTRLAとTCDn.INPUTCTRLB)レジスタの入力動作(INPUTMODE) ビット領域が'0000'を書かれなければなりません。

障害検出には10種の異なる入力動作があります。この2つの入力は入力Aによってのみ支援される入力抑制を除き、同じ機能を持ちます。入力抑制は遅延制御(TCDn.DLYCTRL)レシブスタと遅延値(TCDn.DLYVAL)レシブスタによって構成設定されます。

この入力は事象システムに接続されます。事象供給元とTCD入力間の接続は事象システムで構成設定されなければなりません。



入力事象受け取りとそれを処理して出力を上書きする間にTCD同期部クロックで2~3クロック周期の遅延があります。非同期事象検出を使う場合、出力は入力処理の外側で瞬時に上書きされます。

#### 22.3.3.4.1. 入力抑制

入力抑制機能はTCD周回の選択可能な部分で設定可能な時間の間、入力事象を遮蔽します。入力抑制は出力での変化発生直後に起動される"偽"入力事象を遮蔽するのに使うことができます。

入力抑制は遅延制御(TCDn.DLYCTRL)レシ、スタの遅延選択(DLYSEL)ヒ、ット領域を構成設定することによって許可することができます。 起動元はTCDn.DLYCTRLレシ、スタの遅延起動元(DLYTRIG)ヒ、ット領域によって選ばれます。

入力抑制は遅延クロックに使われます。起動後、計数器は遅延値(TCDn.DLYVAL)レジスタの遅延値(DLYVAL)まで上昇計数します。その後、入力抑制がOFFにされます。TCD遅延クロックは同期クロック(CLK\_TCD\_SYNC)の前置分周された版です。分周係数は遅延制御(TCDn.DLYCTRL)レジスタの遅延前置分周器(DLYPRESC)ビット領域によって設定されます。入力抑制の持続時間は以下によって与えられます。

$$t_{blank} = \frac{DLYPRESC分周係数 \times DLYVAL}{fCLK\_TCD\_SYNC}$$

入力抑制は設定可能な出力事象と同じ論理回路を使います。この理由のため同時に両方を使うことはできません。

## 22.3.3.4.2. デジタル濾波器

事象入力x用のデジタル濾波器は対応する事象制御(TCDn.EVCTRLAとTCDn.EVCTRLB)レジスタの事象構成設定(CFG)ビットに'01' (FILTERON)を書くことによって許可されます。デジタル濾波器が許可されると、4 TCD計数器クロック周期未満継続するどのパルスも濾波されます。従って、やって来る事象上のどの変化も、それが入力処理論理回路に影響を及ぼすのに先立って4計数器クロック周期かかります。

#### 22.3.3.4.3. 非同期事象検出

入力事象で非同期事象検出を許可するには、事象制御(TCDn.EVCTRLAとTCDn.EVCTRLB)レシブスタの事象構成設定(CFG)ビット領域がそれに応じて構成設定されなければなりません。

非同期事象検出は入力事象発生時に出力を非同期に上書きすることを可能にします。入力事象が何を行うかは入力動作に依存します。事象が同期クロック(CLK\_TCD\_SYNC)に同期化される時に出力が直接上書きされ、同時に計数器の流れが変更されます。 非同期事象検出とデジタル濾波器を同時に使うことは不可能です。

#### 22.3.3.4.4. ソフトウェア指令

次表はTCD単位部に対する指令を示します。

## 表22-4. ソフトウェア指令

| <b>数22 年 77 円 7 年 7 日 日</b> |                              |  |  |  |
|-----------------------------|------------------------------|--|--|--|
| 起動                          | ソフトウェア指令                     |  |  |  |
| TCDmCTRLEレジスタのSYNCEOCビット    | TCD周回の最後で2重緩衝されたレジスタを更新      |  |  |  |
| TCDmCTRLEレジスタのSYNCビット       | 2重緩衝されたレシ、スタを更新              |  |  |  |
| TCDmCTRLEレジスタのRESTARTビット    | TCD計数器を再始動                   |  |  |  |
| TCDmCTRLEレジスタのSCAPTUREAビット  | 捕獲A(TCDn.CAPTUREAH/L)レジスタに捕獲 |  |  |  |
| TCDmCTRLEレジスタのSCAPTUREBビット  | 捕獲B(TCDn.CAPTUREBH/L)レジスタに捕獲 |  |  |  |

## 22.3.3.4.5. 入力動作

使用者は10種の入力動作を選ぶことができます。選択は入力制御(TCDn.INPUTCTRLAとTCDn.INPUTCTRLB)レジスタの入力動作 (INPUTMODE)ビット領域を書くことによって行われます。

# 22.3.3.4.5.1. 入力動作の有効性

全ての入力動作が全ての波形生成動作で動く訳ではありません。下表は各種入力動作でどの波形生成動作が有効かを示します。

| 表22-5.  | _         | 1 = 1         | 11-  |               | Lat |
|---------|-----------|---------------|------|---------------|-----|
| エッツート   |           | <b>——</b> ——  |      | \ <b>—</b> —  | ルケー |
| 7V//-:) | $\Lambda$ | <b>ノ</b> I 半川 | TEU. | <b>71</b> X/I | 1+  |
|         |           |               |      |               |     |

| 表22-5. 人刀動作の有象 |       |       |       |        |
|----------------|-------|-------|-------|--------|
| INPUTMODE      | 1傾斜動作 | 2傾斜動作 | 4傾斜動作 | 2重勾配動作 |
| 0 0 0 0        | 有効    | 有効    | 有効    | 有効     |
| 0 0 0 1        | 有効    | 有効    | 有効    | 使用禁止   |
| 0 0 1 0        | 使用禁止  | 有効    | 有効    | 使用禁止   |
| 0 0 1 1        | 使用禁止  | 有効    | 有効    | 使用禁止   |
| 0 1 0 0        | 有効    | 有効    | 有効    | 有効     |
| 0 1 0 1        | 使用禁止  | 有効    | 有効    | 使用禁止   |
| 0 1 1 0        | 使用禁止  | 有効    | 有効    | 使用禁止   |
| 0 1 1 1        | 有効    | 有効    | 有効    | 有効     |
| 1 0 0 0        | 有効    | 有効    | 有効    | 使用禁止   |
| 1 0 0 1        | 有効    | 有効    | 有効    | 使用禁止   |
| 1 0 1 0        | 有効    | 有効    | 有効    | 使用禁止   |

# 22.3.3.4.5.2. 入力動作0: 入力活動なし

入力動作0での入力は出力に影響を及ぼしませんが、許可されていれば、それらは未だ捕獲と割り込みを起動することができます。



## 22.3.3.4.5.3. 入力動作1: 出力停止、逆の比較周回へ飛んで待機

入力動作1での入力事象は出力信号を停止し、逆側沈黙時間へ飛び、TCD計数器が続けるのに先立って入力事象がLowになるまで待ちます。

入力動作1が入力Aで使われた場合、事象はTCDが沈黙時間A(DTA)またはON時間A(OTA)の場合にだけ有効で、WOA出力に影響するだけです。事象が終わると、TCD計数器は沈黙時間B(DTB)で始まります。



入力動作1が入力Bで使われた場合、事象はTCDが沈黙時間B(DTB)またはON時間B(OTB)の場合にだけ有効で、WOB出力に影響するだけです。事象が終わると、TCD計数器は沈黙時間A(DTA)で始まります。



#### 22.3.3.4.5.4. 入力動作2: 出力停止、逆の比較周回を実行して待機

入力動作2での入力事象は出力信号を停止し、逆側の沈黙時間とON時間を実行し、そしてその後にTCD計数器が続けるのに先立って入力事象がLowになるまで待ちます。逆側の沈黙時間とON時間が終わる前にその入力が終わった場合、待機はありませんが、逆側の沈黙時間とON時間が続きます。

入力動作2が入力Aで使われた場合、事象はTCDが沈黙時間A(DTA)またはON時間A(OTA)の場合にだけ有効で、WOA出力に影響するだけです。



入力動作2が入力Bで使われた場合、事象はTCDが沈黙時間B(DTB)またはON時間B(OTB)の場合にだけ有効で、WOB出力に影響するだけです。



#### 22.3.3.4.5.5. 入力動作3: 出力停止、障害活性の間、逆の比較周期を実行

入力動作3での入力事象は出力信号を停止し、障害/入力が活性である限り、各々逆側の沈黙時間とON時間を実行します。入力が開放されると、進行中の沈黙時間やON時間が終わってその後に通常の流れが始まります。

入力動作3が入力Aで使われた場合、事象はTCDが沈黙時間A(DTA)またはON時間A(OTA)の場合にだけ有効です。



入力動作3が入力Bで使われた場合、事象はTCDが沈黙時間B(DTB)またはON時間B(OTB)の場合にだけ有効です。



#### 22.3.3.4.5.6. 入力動作4:全出力停止、周波数維持

入力動作4が使われると、入力Aと入力Bの両方が同じ機能を与えられます。入力事象は事象が活性である限り出力を非活性にします。この動作での事象によってTCD計数器は影響を及ぼされません。



## 22.3.3.4.5.7. 入力動作5:全出力停止、障害活性の間、沈黙時間を実行

入力動作5が使われると、入力Aと入力Bの両方が同じ機能を与えられます。入力事象は出力を停止してそれがON時間の間に起きた場合に逆側の沈黙時間を開始します。事象が沈黙時間の間に起きた場合、沈黙時間は次のON時間が開始を予定されるまで続きます。けれども、入力が未だ活性の場合、周回は他の沈黙時間で続きます。事象が活性である限り、沈黙時間の(交互)切り替えが起きます。入力事象が停止すると、進行中の沈黙時間は終了し、通常の流れで次のON時間が続きます。



#### 22.3.3.4.5.8. 入力動作6: 出力停止、次の比較周回へ飛んで待機

入力動作6が使われると、入力Aと入力Bの両方が同じ機能を与えられます。入力事象は出力を停止してこれがON時間の間に起きた場合に逆側の沈黙時間へ飛びます。事象が沈黙時間の間に起きた場合、開始すべき次のON時間まで続けます。事象が活性である限り、TCD計数器は待機します。入力事象が停止すると、次の沈黙時間が開始し、通常の流れが続きます。



## 22.3.3.4.5.9. 入力動作7:全出力停止、ソフトウェア活動待ち

入力動作7が使われると、入力Aと入力Bの両方が同じ機能を与えられます。入力事象は出力とTCD計数器を停止します。これは再始動指令が与えられるまで停止されます。(制御E(TCDn.CTRLE)レジスタの再始動発動(RESTART)ビットで)再始動指令が与えられた時に入力事象が未だHighなら、再び直ぐに停止します。TCD計数器が再始動する時は常に沈黙時間Aから開始します。



#### 22.3.3.4.5.10. 入力動作8: エッジ(端)で出力停止、次の比較周回へ飛ぶ

入力動作8では、対応する出力がONの間の入力事象での正端が出力を停止してTCD計数器を逆側の沈黙時間に飛ばします。 入力Aで入力動作8が使われ、ON時間Aの間に入力事象で正端が起きた場合、TCD計数器は沈黙時間Bへ飛びます。



入力Bで入力動作8が使われ、ON時間Bの間に入力事象で正端が起きた場合、TCD計数器は沈黙時間Aへ飛びます。



#### 22.3.3.4.5.11. 入力動作9: エッシ (端)で出力停止、周波数維持

入力動作9では対応する出力がONの間の入力事象での正端がON時間の残りの間、出力を停止させます。TCD計数器は事象によって影響を及ぼされず、出力だけが影響を及ぼされます。

入力Aで入力動作9が使われ、ON時間Aの間に入力事象で正端が起きた場合、ON時間の残りの間も出力がOFFになります。



入力Bで入力動作9が使われ、ON時間Bの間に入力事象で正端が起きた場合、ON時間の残りの間も出力がOFFになります。



#### 22.3.3.4.5.12. 入力動作10: レベルで出力停止、周波数維持

入力動作10での入力事象はこの入力が活性である限り対応する出力を停止にさせます。対応する出力でON時間でなければならない間にこの入力がLowになった場合、出力はON時間の残りの間、非活性(OFF)になります。TCD計数器は事象によって影響を及ぼされず、出力だけが影響を及ぼされます。

入力Aで入力動作10が使われて入力事象が起きた場合、WOAはその事象が続く限りOFFになります。ON時間の間に開放された場合、ON時間の残りの間もOFFになります。



入力Bで入力動作10が使われて入力事象が起きた場合、WOBはその事象が続く限りOFFになります。ON時間の間に開放された場合、ON時間の残りの間はOFFになります。



#### 22.3.3.4.5.13. 入力動作要約

表22-6.は先行する項のタイシケ図で図解されるような条件を要約します。

#### 表22-6. 入力動作要約

| INPUTMODE | 起動元⇒影響を<br>及ぼされる出力                       | 障害ON/活性                  | 障害開放/不活性      |
|-----------|------------------------------------------|--------------------------|---------------|
| 0 0 0 0   | -                                        | 活動なし                     | 活動なし          |
| 0 0 0 1   | 7 +4 14104                               | 現ON時間終了、待機               | 他の比較の沈黙時間で開始  |
| 0 0 1 0   | 入力A⇒WOA<br>入力B⇒WOB                       | 現ON時間終了、他の比較周回を実行、待機     | 現在の比較の沈黙時間で開始 |
| 0 0 1 1   | /\/JD\\\OD                               | 現ON時間実行、その後他の比較周回を繰り返し実行 | 現在の比較周回を再許可   |
| 0 1 0 0   |                                          | 出力を非活性                   | _             |
| 0 1 0 1   | 入力A⇒{WOA,WOB}                            | 沈黙時間のみ実行                 | _             |
| 0 1 1 0   | 入力B⇒{WOA,WOB}                            | ON時間終了、待機                | 他の比較の沈黙時間で開始  |
| 0 1 1 1   |                                          | ON時間終了、ソフトウェア活動待機        | 現在の比較の沈黙時間で開始 |
| 1 0 0 0   | 7 LA \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | 現ON時間終了、他の沈黙時間で継続        | _             |
| 1 0 0 1   | 入力A⇒WOA<br>入力B⇒WOB                       | 現ON時間を妨げて手順継続            | _             |
| 1 0 1 0   | / <b>C</b> /JD <del>-/</del> WOD         | 起動元活性の間、手順の最後までON時間不活性   | -             |
| その他       | -                                        | -                        | -             |

注: 各事象入力で異なる動作を使う時に起こり得る矛盾を考慮し、予期せぬ結果を避けるため、TCDが単一の計数器であることを 忘れないでください。

#### 22.3.3.5. ディサリング

前置分周器/周期選択の制限のために望む周波数を達成するのが不可能な場合、望む周波数に近づけて波形変動を減らすのに ディザを使うことができます。

ディザ は各周回に対して計数器の小数誤差を累積します。この分数誤差が溢れる(<mark>訳補</mark>:1を超える)と、周回の選んだ部分に付加周期が追加されます。

## 例22-1. 10MHzクロックから75kHzを生成

計時器クロック周波数が10MHzの場合、それは計時器に100nsの分解能を与えます。そして、出力周波数は13333nsの周期を意味する75kHzです。この周期は133.33周回を必要とするため、100ns分解能で達成することができません。出力期間は133周回(75.188kHz)または134周回(74.626kHz)のどちらかに設定することができます。

75kHzの平均出力周波数を得るためにファームウェアに於いて手動で2つの周波数間の周期を変更(毎回の第3期間を134周回に変更)することが可能です。ディザは誤差(0.33周回)を累積することによってこれを自動的に行うことができます。累積器は累積された誤差が1クロック周期よりも大きい時を計算します。それが起きた時に計時器周回に付加周期が追加されます。

使用者はディサー制御(TCDn.DITCTRL)レシ、スタのディサ、選択(DITHERSEL)ヒットに書くことによってディサーが追加されるTCD周回内の以下の場所を選ぶことができます。

- ・ON時間B
- ON時間AとB
- ·沈黙時間B
- ・沈黙時間AとB

ティサ・がTCD周回時間にどれ位影響を及ぼすかは使う波形生成動作に依存します(**表22-7**.をご覧ください)。ディサ゛は2<u>重勾配動作で</u> 支援されません。



# 表22-7. 動作に依存するTCD周回へのディザ追加

| 波形生成動作 | TCDn.DITCTRLの<br>DITHERSEL | TCD周回への<br>追加TCDクロック周期 | 波形生成動作 | TCDn.DITCTRLの<br>DITHERSEL | TCD周回への<br>追加TCDクロック周期 |
|--------|----------------------------|------------------------|--------|----------------------------|------------------------|
|        | ON時間B                      | 1                      |        | ON時間B                      | 1                      |
| 1傾斜動作  | ON時間AとB                    | 1                      | 4傾斜動作  | ON時間AとB                    | 2                      |
|        | 沈黙時間B                      | 0                      |        | 沈黙時間B                      | 1                      |
|        | 沈黙時間AとB                    | 0                      |        | 沈黙時間AとB                    | 2                      |
|        | ON時間B                      | 1                      |        | ON時間B                      | 不支援                    |
| 2傾斜動作  | ON時間AとB                    | 2                      | 2重勾配動作 | ON時間AとB                    | 不支援                    |
|        | 沈黙時間B                      | 0                      | 4里初配期作 | 沈黙時間B                      | 不支援                    |
|        | 沈黙時間AとB                    | 0                      |        | 沈黙時間AとB                    | 不支援                    |

TCD周回へ追加されるTCDクロック周期数の違いはTCD周回で使われる比較値の異なる数によって起こります。例えば1傾斜動作は比較B解除(CMPBCLR)だけがTCD周回時間に影響を及ぼします。

TCD周回に付加周期が全く追加されないディザ制御(TCDn.DITCTRL)レジスタのディザ選択(DITHERSEL)構成設定に対して、補償は後続する出力状態を短くすることによって達せられます。

#### 例22-2.1傾斜動作でのDITHERSEL

DITHERSELが沈黙時間Bを選ぶ1傾斜動作では、ディザ溢れ発生時に沈黙時間Bが増やされ、ON時間Bを1周期減らします。

#### 22.3.3.6. TCD計数器捕獲

TCD計数器は周辺機能クロックと非同期で、故に計数器の値を直接読み出すことができません。これは2つの方法でI/Oクロック領域に同期してTCD計数器値を捕獲することが可能です。

- 入力事象での捕獲値
- ・ソフトウェア捕獲

捕獲論理回路はTCD計数器値を捕獲してI/Oクロック領域に同期することができる捕獲A(CAPTUREA)と捕獲B(CAPTUREB)の2つの独立した捕獲部を含みます。CAPTUREA/Bは入力事象A/Bまたはソフトウェアによって起動することができます。

捕獲値は先に捕獲下位(TCDn.CAPTUREAL/TCDn.CAPTUREBL)、その後に捕獲上位(TCDn.CAPTUREAH/TCDn.CAPTUREB H)のレジスタを読むことによって得ることができます。

#### 入力事象によって起動される捕獲

入力事象での捕獲を許可するには、事象入力を構成設定する時に各々の事象制御(TCDn.EVCTRLAまたはTCDn.EVCTRLB)レジスタで事象活動(ACTION)ビットに'1'を書いてください。

捕獲が起こると、割り込み要求フラウ、(TCDn.INTFLAGS)レジスタで起動割り込み要求(TRIGA/B)フラウが掲げられます(=1)。対応する TRIGA/B割り込みは割り込み制御(TCDn.INTCTRL)レジスタで各々の起動割り込み許可(TRIGAまたはTRIGB)ビットに'1'を書くことに よって許可することができます。TCDn.INTFLAGSレジスタでTRIGAまたはTRIGBのポーリングにより、捕獲(CAPTUREAまたはCAPTURE B)値が利用可能なことを知り、先に捕獲下位(TCDn.CAPTUREALまたはTCDn.CAPTUREBL)、その後に捕獲上位(TCDn.CAPTUR EAHまたはTCDn.CAPTUREBH)のレジスタを読むことによってその値を読み出すことができます。

#### 例22-3. PWM捕獲

PWM捕獲を実行には、事象AとBの両方をPWM信号を含む同じ非同期事象チャネルに接続してください。PWM信号での情報を得るには、1つの事象入力をその信号の上昇端を捕獲するように構成設定してください。他の事象入力をその信号の下降端を捕獲するように構成設定してください。



注: ▲: 事象起動、▲: 割り込み起動

#### ソフトウェアによって起動される捕獲

ソフトウェアは制御E(TCDn.CTRLE)レシ、スタで各々のソフトウェア捕獲A/B発動(SCATPUREx)ヒ、ットに'1'を書くことによってTCD値を捕獲することができます。この指令が実行されて状態(TCDn.STATUS)レシ、スタの指令準備可(CMDRDY)ヒ、ットが再び'1'を読む時に、CAPTURE A/B値が利用可能です。今やこれは先に捕獲下位(TCDn.CAPTUREALまたはTCDn.CAPTUREBL)、その後に捕獲上位(TCDn.CA PTUREAHまたはTCDn.CAPTUREBH)のレシ、スタを読むことによって読むことができます。

#### 入力動作と共の捕獲の使い方

捕獲機能は入力動作と共に使うことができます。そして同じ事象が選んだ入力動作に依存して計数器の捕獲と計数の流れでの変更の起動の両方を行います。

## 例22-4. 入力事象捕獲による1傾斜動作リセット

1傾斜動作では入力事象によって計数器をリセットすることができます。これを達成するには事象Bを使い、入力制御B(TCDn.INPUTCT RLB)レジ゙スタの入力動作(INPUTMODE)ビット領域に\$08を書いてください。



## 22.3.3.7. 出力制御

出力は<mark>障害制御(TCDn.FAULTCTRL)レシ</mark>ブスタに書くことによって構成設定されます。TCDn.FAULTCTRLレシブスタは電源ONリセット後にだけ、0、にリセットされます。どのリセット後でもリセット手順中にTCDn.FAULTCTRLレシブスタはTCD(FUSE.TCD0CFG)ヒュース、から自動的にそれの値を得ます。

TCDn.FAULTCTRLレシ、スタの比較x許可(CMPxEN)じットは各種出力を許可します。TCDn.FAULTCTRLレシ、スタの比較x値(CMPx)じットは障害が起動された時に出力値を設定します。

TCDそれ自身は2つの異なる出力、WOAとWOBを生成します。2つの追加出力、WOCとWODは制御C(TCDn.CTRLC)レジスタの比較C/D出力選択(CMPCSELとCMPDSEL)ビットを書くことによってWOAまたはWOBのどちらに接続されるかをソフトウェアによって構成設定することができます。

制御C(TCDn.CTRLC)レシ<sup>\*</sup>スタの比較出力値上書き(CMPOVR)ビットに'1'を書くことによってTCD計数器の状態に基づいて出力を上書きすることができます。そして制御D(TCDn.CTRLD)レシ<sup>\*</sup>スタの比較x値(CMPAVALとCMPBVAL)ビット領域に書くことによって各種の沈黙時間とON時間での出力値を選ぶことができます。

1傾斜動作使用時、WOAは出力を設定するのに沈黙時間A(DTA)とON時間A(OTA)に対する構成設定だけを使います。WOBは出力を設定するのに沈黙時間B(DTB)とON時間B(OTB)の値だけを使います。

(入力動作での)障害検出と共に上書き機能を使う時に、TCDn.FAULTCTRLレジスタのCMPA(WOC/DがWOAと等しければそれとCM PC/D)ビットはTCDn.CTRLDレジスタのCMPAVALのビット2と0と等しくなければなりません。そうでなければ、障害が検出された後の最初の周回は出力で不正な極性を持ち得ます。同じことがTCDn.FAULTCTRLレジスタのCMPB(WOC/DがWOBと等しければCMPC/D)ビットにも適用され、TCDn.CTRLDレジスタのCMPBVALのビット2と0に等しくなければなりません。

入力事象が直ちに出力信号に影響を及ぼすことができるTCDの非同期の特質のため、ピンでどの負荷も持たない出力でnsのスパイクを発生する危険があります。この事例は'0'以外のどれかの入力動作で入力事象が起動する時に起きます。このスパイク値は常にTC Dn.FAULTCTRLレシ、スタによって与えられるCMPx値の方向です。

# 22.3.4. 事象

TCDは次表で記述される事象を生成することができます。

| 表22-8. TCD | じりま | 水化 | か、台に |
|------------|-----|----|------|

| 生    | 成部名     | 5X DD                      | = 当          |          | 事象長              |  |
|------|---------|----------------------------|--------------|----------|------------------|--|
| 周辺機能 | 事象      | 説明                         | 事象型          | 生成クロック領域 | 尹豕氏              |  |
|      | CMPBCLR | 計数器CMPBCLR一致               |              |          |                  |  |
| TCD. | CMPASET | 計数器CMPASET一致               | パルス          | CLV TCD  | 1 CLK_TCD周期      |  |
| TCDn | CMPBSET | 計数器CMPBSET一致               | <i>/\/\/</i> | CLK_TCD  |                  |  |
|      | PROGEV  | 設定可能な事象出力 ( <del>注</del> ) |              |          | 1 CLK_TCD_SYNC周期 |  |

注: 起動元と(CMPACLRを含む)全ての比較一致を選ぶことができます。また、0~255 TCD遅延周期で出力事象を遅らせることが可能です。

計数器一致に基づく3つの事象はTCD計数器クロックで1クロック周期間続く事象瞬発信号(ストローブ)を直接生成します。設定可能な出力事象はTCD同期部クロックで1クロック周期間続く事象瞬発信号を生成します。

TCDは次表で記述される事象を受け取ることができます。

| 表22-9 TC  | :Dでの事象体 | 田部人利田司  | 「能な事象活動  |
|-----------|---------|---------|----------|
| 1222 3. 1 | ルしい世外に  | ᆩᇚᆫᄯᆘᅏᆸ | 肥は世外/ロシニ |

| 1     | 使用部名          | 説明                     | 入力検出      | 同期/非同期        |
|-------|---------------|------------------------|-----------|---------------|
| 周辺機能  | 入力            | 武ツ                     | 人力快出      | 四朔/ 非回朔  <br> |
|       |               | 出力停止、逆の比較周回へ飛んで待機      |           |               |
|       |               | 出力停止、逆の比較周回を実行して待機     |           |               |
|       |               | 出力停止、障害が活性の間、逆の比較周期を実行 |           |               |
|       |               | 全出力停止、周波数維持            | レベル       |               |
| TCDn  | INPUTA/INPUTB | 全出力停止、障害が活性の間、沈黙時間を実行  |           | 両方            |
| TCDII | INPUTA/INPUTD | 全出力停止、次の比較周回へ飛んで待機     |           |               |
|       |               | 全出力停止、ソフトウェア活動待ち       |           |               |
|       |               | エッシ (端)で出力停止、次の比較周回へ飛ぶ | 端         |               |
|       |               | エッシ・(端)で出力停止、周波数維持     | <b>少而</b> |               |
|       |               | レヘールで出力停止、周波数維持        | レベル       |               |

入力Aと入力Bは入力事象を検出して反応するTCD事象使用部です。入力事象それらの構成設定方法についての追加情報は「22.3.3.4. TCD入力」項で見つけることができます。事象型と事象システム構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照してください。

#### 22.3.4.1. 設定可能な出力事象

設定可能な出力事象(PROGEV)は起動元選択と遅延用の入力抑制と同じ論理回路を使います。従って機能的に独立して構成設定することは不可能です。入力抑制機能が使われた場合、出力事象を遅らせることはできず、入力抑制に使われる起動元は出力事象にも使われます。

PROGEVは<mark>遅延制御(TCDn.DLYCTRL)と遅延値(TCDn.DLYVAL)</mark>のレシ<sup>\*</sup>スタで構成設定されます。出力事象を0~256 TCD遅延クロックを関果らせることが可能です。遅延出力事象機能はTCD遅延クロックを使い、起動元が事象として送り出すのに先立ってDLYVAL値に達するまで計数します。TCD遅延クロックはTCD同期クロック(CLK\_TCD\_SYNC)の前置分周版で分周係数はTCDn.DLYCTRLレシ<sup>\*</sup>スタの遅延前置分周器(DLYPRESC)と<sup>\*</sup>ットによって設定されます。出力事象はn=DLYPRESC×DLYVALのCLK\_TCD\_SYNCクロック周期よって遅らされます。

 $t_{DELAY} = \frac{DLYPRESC \times DLYVAL}{f_{CLK\_TCD\_SYNC}}$ 



# 22.3.5. 割り込み

## 表22-10. 利用可能な割り込みべりなと供給元

| 1222 10. | 表22 10. 利用引配を引う色が、万色医帽光 |                                  |  |  |  |  |
|----------|-------------------------|----------------------------------|--|--|--|--|
| 名称       | ベクタ説明                   | 条件                               |  |  |  |  |
| OVF      | 溢れ割り込み                  | TCDが1 TCD周回を終了                   |  |  |  |  |
| TRIG     | 起動元割り込み                 | ・TRIGA: 事象入力Aで<br>・TRIGB: 事象入力Bで |  |  |  |  |

割り込み条件が起こると、周辺機能の割り込み要求フラケ(TCDn.INTFLAGS)レジスタで対応する割り込み要求フラケが設定(1)されます。割り込み元は周辺機能の割り込み制御(TCDn.INTCTRL)レジスタで対応する許可ビットを書くことによって許可または禁止にされます。割り込み要求は対応する割り込み元が許可され、割り込み要求フラケが設定(1)される時に生成されます。割り込み要求は割り込み要求フラケが解除(0)されるまで活性に留まります。割り込み要求フラケを解除する方法の詳細については周辺機能のINTFLAGSレジスタをご覧ください。

様々な割り込み要求条件が割り込みペクタによって支援される時に、割り込み要求は割り込み制御器に対して1つの結合された割り込み要求へ共に論理和(OR)されます。使用者はどの割り込み条件が存在するかを決めるために周辺機能のINTGLAGSレジスタを読まなければなりません。

## 22.3.6. 休止形態動作

TCDはアイドル動作で動き、スタンバイとパワーダウンの休止動作に入る時に停止されます。

#### 22.3.7. デバッグ操作

デバック・動作でのCPUの扱いは周辺機能の標準動作を停止します。この周辺機能はデバック・制御(TCDn.DBGCTRL)レシ、スタのデバック・時走行(DBGRUN)ビットに'1'を書くことによって停止されたCPUでの動作を強制することができます。

TCDn.DBGCTRLの障害検出(FAULTDET)ビットが'1'を書かれ、CPUがデ`バック'動作で停止されると、両入力事象チャネルで事象/障害が作成されます。これらの事象/障害は中断する限り持続し、例えば、外部部品欠落を強制することにより、デ`バック'動作での保護として扱うことができます。

周辺機能が割り込みまたは同様なものを通してCPUによって定期的な処理を必要とするように構成設定される場合、停止したデバッグ中に不正な動作やデータ損失になるかもしれません。

## 22.3.8. 構成設定変更保護

この周辺機能は構成設定変更保護(CCP)下にあるレジスタを持ちます。これらのレジスタへ書くには最初に構成設定変更保護(CPU.CC P)レジスタへ或る鍵が書かれ、4 CPU命令以内に保護されたビットへの書き込みアクセスが後続しなければなりません。

適切なCCP解錠手順に従わずに保護されたレジスタへの書き込みを試みることは保護されたレジスタを無変化のままにします。

右のレジスタがCCP下です。

| 表22-11. | TCDでの | )構成設定変 | で更保護で | 「のレジスタ |
|---------|-------|--------|-------|--------|
|         |       |        |       |        |

| レシ゛スタ         | 鍵種別   |
|---------------|-------|
| TCD.FAULTCTRL | IOREG |

# 22.4. レジスタ要約

| 変位         | 略称               | ビット位置        | ヒ゛ット7    | ピット6      | ヒ゛ット5    | ピット4       | ピット3      | ピット2     | ヒ゛ット1    | ピット0    |
|------------|------------------|--------------|----------|-----------|----------|------------|-----------|----------|----------|---------|
| +\$00      | CTRLA            | 7~0          |          | CLKS      | EL1,0    | CNTP       | RES1,0    | SYNCF    | RES1,0   | ENABLE  |
| +\$01      | CTRLB            | 7~0          |          |           |          |            |           |          | WGMO     | DE1,0   |
| +\$02      | CTRLC            | 7~0          | CMPDSEL  | CMPCSEL   |          |            | FIFTY     |          | AUPDATE  | CMPOVR  |
| +\$03      | CTRLD            | 7~0          |          | CMPBV     | /AL3~0   |            |           | CMPAV    | /AL3~0   |         |
| +\$04      | CTRLE            | 7~0          | DISEOC   |           |          | SCAPTUREB  | SCAPTUREA | RESTART  | SYNC     | SYNCEOC |
| +\$05      | · · ·            |              |          |           |          |            |           |          |          |         |
| +\$07      | 予約               |              |          |           |          |            |           |          |          |         |
| +\$08      | EVCTRLA          | 7~0          | CFO      | G1,0      |          | EDGE       |           | ACTION   |          | TRIGEI  |
| +\$09      | EVCTRLB          | 7~0          |          | G1,0      |          | EDGE       |           | ACTION   |          | TRIGEI  |
| +\$0A      | Evernes          | . 0          | 01       | 31,0      |          | EDGE       |           | 71011011 |          | THUOLI  |
| $\sim$     | 予約               |              |          |           |          |            |           |          |          |         |
| +\$0B      | INITOTOL         | 7 <b>~</b> 0 |          |           |          |            | TDICD     | TDICA    |          | OVE     |
| +\$0C      | INTERLACE        |              |          |           |          |            | TRIGB     | TRIGA    |          | OVF     |
| +\$0D      | INTFLAGS         | 7~0          | DUALACTO | DUNAACTA  |          |            | TRIGB     | TRIGA    | CMDDDM   | OVF     |
| +\$0E      | STATUS           | 7~0          | PWMACTB  | PWMAC I A |          |            |           |          | CMDRDY   | ENRDY   |
| +\$0F      | 予約<br>INPUTCTRLA | 7~0          |          |           |          |            |           | INPUTM   | ODEs. s  |         |
|            |                  |              |          |           |          |            |           | INPUTM   |          | +       |
|            | INPUTCTRLB       | 7~0          | C) (DDEN | C) (DCD)  | C) (DDEN | C) (D) (D) | CI (IDD   |          |          | C) (D)  |
|            | FAULTCTRL        | 7 <b>~</b> 0 | CMPDEN   | CMPCEN    | CMPBEN   | CMPAEN     | CMPD      | CMPC     | CMPB     | CMPA    |
| +\$13      | 予約               | 7 0          |          |           | DLVDE    | DECC1 A    | D.L.I.M.  | 21.01.0  | DIM      |         |
| +\$14      | DLYCTRL          | 7~0          |          |           | DLYPF    | ESC1,0     | DLYT      | RIG1,0   | DLYS     | EL1,0   |
| +\$15      | DLYVAL           | 7~0          |          |           |          | DLYV.      | AL7~0     |          |          |         |
| +\$16<br>∼ | 予約               |              |          |           |          |            |           |          |          |         |
| +\$17      |                  |              |          |           |          |            |           |          |          |         |
| +\$18      | DITCTRL          | 7 <b>~</b> 0 |          |           |          |            |           |          |          | RSEL1,0 |
| +\$19      | DITVAL           | 7 <b>~</b> 0 |          |           |          |            |           | DITHI    | ER3∼0    |         |
| +\$1A      | 予約               |              |          |           |          |            |           |          |          |         |
| +\$1D      | <b>J</b> ′       |              |          |           |          |            |           |          |          |         |
| +\$1E      | DBGCTRL          | 7~0          |          |           |          |            |           | FAULTDET |          | DBGRUN  |
| +\$1F      | - · ·            |              |          |           |          |            |           |          |          |         |
| -<br>+\$21 | 予約               |              |          |           |          |            |           |          |          |         |
| +\$22      |                  | 7~0          |          |           |          | CAPTU      | REA7~0    |          |          |         |
| +\$23      | CAPTUREA         | 15~8         |          |           |          |            |           | CAPTUF   | REA11~8  | -       |
| +\$24      |                  | 7~0          |          |           |          | CAPTU      | REB7~0    |          |          | -       |
| +\$25      | CAPTUREB         | 15~8         |          |           |          | 0.11.10    |           | CAPTUE   | REB11~8  |         |
| +\$26      |                  | 10 0         |          |           |          |            |           | 0.1.101  |          |         |
| $\sim$     | 予約               |              |          |           |          |            |           |          |          |         |
| +\$27      |                  | 7~0          |          |           |          | CMPAS      | SET70     |          |          |         |
| +\$28      | CMPASET          |              |          |           |          | CIVIFAL    | SET 7°0   | CMDAC    | ET11. 0  |         |
| +\$29      |                  | 15~8         |          |           |          | CMDAG      | CLR7~0    | CMPAS    | E111~8   |         |
| +\$2A      | CMPACLR          | 7~0          |          |           |          | CMPAC      | JLK1~U    | CMDAC    | I D11. 0 |         |
| +\$2B      |                  | 15~8<br>7~0  |          |           |          | CMDD       | PET7- 0   | CMPAC    | LR11~8   |         |
| +\$2C      | CMPBSET          |              |          |           |          | CMPBS      | SET7~0    | CMDCI    | ET11 - 0 |         |
| +\$2D      |                  | 15~8         |          |           |          | CMDD       | ZI DZ O   | CMPSE    | 8 - 111  |         |
| +\$2E      | CMPBCLR          | 7~0          |          |           |          | CMPBC      | CLR7~0    | CMDDG    | I D11 0  |         |
| +\$2F      |                  | 15~8         |          |           |          |            |           | CMPBC    | LKII~8   |         |

# 22.5. レジスタ説明

# **22.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位: +\$00 リセット: \$00

特質: ENABLEt ットを除き、許可保護

| ピット    | 7 | 6    | 5     | 4    | 3      | 2     | 1      | 0      |
|--------|---|------|-------|------|--------|-------|--------|--------|
|        |   | CLKS | EL1,0 | CNTP | RES1,0 | SYNCF | RES1,0 | ENABLE |
| アクセス種別 | R | R/W  | R/W   | R/W  | R/W    | R/W   | R/W    | R/W    |
| リセット値  | 0 | 0    | 0     | 0    | 0      | 0     | 0      | 0      |

# ビット6,5 - CLKSEL1,0: クロック選択 (Clock Select)

クロック選択ビットはTCDクロックのクロック元を選びます。

| 値  |                       |      | 1 0    | 11        |
|----|-----------------------|------|--------|-----------|
| 名称 | 20MHZ                 | _    | EXTCLK | SYSCLK    |
| 説明 | 内部16/20MHz発振器(OSC20M) | (予約) | 外部クロック | システム クロック |

# ● ビット4,3 - CNTPRES1,0:計数器前置分周器 (Counter Prescaler)

計数器前置分周器ビットはTCD計数器クロックの分周係数を選びます。

| 値  | 0 0       | 0 1  | 1 0   | 11   |
|----|-----------|------|-------|------|
| 名称 | DIV1      | DIV4 | DIV32 | -    |
| 説明 | 1分周(分周なし) | 4分周  | 32分周  | (予約) |

# ● ビット2,1 - SYNCPRES1,0: 同期前置分周器 (Syncronization Prescaler)

同期前置分周器ビットはTCDクロックの分周係数を選びます。

| 値  | 0 0       | 0 1  | 1 0  | 11   |
|----|-----------|------|------|------|
| 名称 | DIV1      | DIV2 | DIV4 | DIV8 |
| 説明 | 1分周(分周なし) | 2分周  | 4分周  | 8分周  |

# ● ビット0 - ENABLE : 許可 (Enable)

このビットに書くと、それは自動的にTCDクロック領域に同期されます。

このビットはこのビットの同期化が進行中でない限り変更することができます。状態(TCDn.STATUS)レジスタの許可準備可(ENRDY)ビットをご覧ください。

このビットは許可保護されません。

| 値  | 0           | 1              |
|----|-------------|----------------|
| 名称 | NO          | YES            |
| 説明 | TCDは禁止されます。 | TCDは許可されて動きます。 |

# **22.5.2. CTRLB - 制御B** (Control B)

名称: CTRLB 変位:+\$01 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0      |
|--------|---|---|---|---|---|---|------|--------|
|        |   |   |   |   |   |   | WGMO | DDE1,0 |
| アクセス種別 | R | R | R | R | R | R | R/W  | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0      |

# ● ビット1,0 - WGMODE1,0:波形生成動作 (Waveform Generation Mode)

これらのビットは波形生成を選びます。

| 値  | 0 0     | 0 1     | 1 0      | 11     |
|----|---------|---------|----------|--------|
| 名称 | ONERAMP | TWORAMP | FOURRAMP | DS     |
| 説明 | 1傾斜動作   | 2傾斜動作   | 4傾斜動作    | 2重勾配動作 |

## **22.5.3. CTRLC - 制御C** (Control C)

名称: CTRLC 変位: +\$02 リセット: \$00 特質: -

| ピット    | 7       | 6       | 5 | 4 | 3     | 2 | 1       | 0      |
|--------|---------|---------|---|---|-------|---|---------|--------|
|        | CMPDSEL | CMPCSEL |   |   | FIFTY |   | AUPDATE | CMPOVR |
| アクセス種別 | R/W     | R/W     | R | R | R/W   | R | R/W     | R/W    |
| リセット値  | 0       | 0       | 0 | 0 | 0     | 0 | 0       | 0      |

# ● ビット7 - CMPDSEL: 比較D出力選択 (Compare D Output Select)

このビットはどの波形が出力Dに接続されるかを選びます。

| 値  | 0    | 1    |
|----|------|------|
| 名称 | PWMA | PWMB |
| 説明 | 波形A  | 波形B  |

## ● ビット6 - CMPCSEL: 比較C出力選択 (Compare C Output Select)

このビットはどの波形が出力Cに接続されるかを選びます。

| 値  | 0    | 1    |
|----|------|------|
| 名称 | PWMA | PWMB |
| 説明 | 波形A  | 波形B  |

## ● ビット3 - FIFTY: 50%波形 (Fifty Percent Waveform)

FIFTY='1'の場合、比較A設定(TCDn.CMPASET)または比較B設定(TCDn.CMPBSET)のどちらかへの書き込みは両レジスタに書かれます。比較A解除(TCDn.CMPACLR)と比較B解除(TCDn.CMPBCLR)に対する場合も同じです。

## ● ビット1 - AUPDATE:自動更新 (Automatically Update)

このビットが'1'を書かれた場合、比較B解除上位(TCDn.CMPBCLRH)レジスタが書かれた後でTCD周回の最後での同期が自動的に要求されます。

50%波形が許可(FIFTY='1')される場合、比較A解除上位(TCDn.CMPACLRH)または比較B解除上位(TCDn.CMPBCLRH)のどちらかのレジスタへの書き込みはTCD周回の最後での同期を要求します。

#### ● ビット0 - CMPOVR : 比較出力値上書き (Compare Output Value Override)

このビットが'1'を書かれると、波形出力AとBの既定値は制御D(TCDn.CTRLD)レジスタの活性状態の比較x値(CMPxVAL)ビット領域に書かれた値によって上書きされます。より多くの詳細については「22.5.4. 制御D(CTRLD)レジスタ」記述をご覧ください。

# **22.5.4. CTRLD - 制御D** (Control D)

名称: CTRLD 変位:+\$03 リセット: \$00 特質:-

| ピット    | 7          | 6   | 5   | 4   | 3          | 2   | 1   | 0   |  |
|--------|------------|-----|-----|-----|------------|-----|-----|-----|--|
|        | CMPBVAL3∼0 |     |     |     | CMPAVAL3~0 |     |     |     |  |
| アクセス種別 | R/W        | R/W | R/W | R/W | R/W        | R/W | R/W | R/W |  |
| リセット値  | 0          | 0   | 0   | 0   | 0          | 0   | 0   | 0   |  |

# ● ビット3~0,7~4 - CMPAVAL3~0,CMPBVAL3~0: (活性状態の)比較x値 (Compare x Value (in active state))

これらのビットはTCD周回で対応する状態に対するPWMx信号の論理値を設定します。これらの設定は制御C(TCDn.CTRLC)レジスタの比較出力値上書き(CMPOVR)ビットが゙1゚を書かれる場合にだけ有効です。

#### 表22-12.2傾斜動作と4傾斜動作

| CMPxVAL | DTA      | ОТА      | DTB      | ОТВ      |
|---------|----------|----------|----------|----------|
| PWMA    | CMPAVAL0 | CMPAVAL1 | CMPAVAL2 | CMPAVAL3 |
| PWMB    | CMPBVAL0 | CMPBVAL1 | CMPBVAL2 | CMPBVAL3 |

1傾斜動作で使われる時に、WOAは出力を設定するのに沈黙時間A(DTA)とON時間A(OTA)だけを使います。WOBは出力を設定するのに沈黙時間B(DTB)とON時間B(OTB)だけを使います。

#### 表22-13.1傾斜動作

| CMPxVAL | DTA      | OTA      | DTB      | ОТВ      |
|---------|----------|----------|----------|----------|
| PWMA    | CMPAVAL1 | CMPAVAL0 | -        | -        |
| PWMB    | -        | -        | CMPBVAL3 | CMPBVAL2 |

#### **22.5.5. CTRLE** - 制御E (Control E)

名称: CTRLE 変位: +\$04 リセット: \$00 特質: -

| ピット    | 7      | 6 | 5 | 4         | 3         | 2       | 1    | 0       |
|--------|--------|---|---|-----------|-----------|---------|------|---------|
|        | DISEOC |   |   | SCAPTUREB | SCAPTUREA | RESTART | SYNC | SYNCEOC |
| アクセス種別 | R/W    | R | R | R/W       | R/W       | R/W     | R/W  | R/W     |
| リセット値  | 0      | 0 | 0 | 0         | 0         | 0       | 0    | 0       |

#### ● ビット7 - DISEOC: TCD周回の最後で禁止発動 (Disable at End of TCD Cycle Strobe)

このビットが'1'を書かれると、TCDはTCD周回の最後で自動的に禁止されます。

状態(TCDn.STATUS)レシブスタの許可準備可(ENRDY)ビットはTCDが禁止されるまで'0'に留まることに注意してください。

このビットへの書き込みはTCD領域と制御A(TCDn.CTRLA)レジスタの許可(ENABLE)ビットでの進行中の同期化がない場合にだけ有効です。TCDn.STATUSレジスタのENRDYビットをご覧ください。

#### ● ビット4 - SCAPTUREB: ソフトウェア捕獲B発動 (Software Capture B strobe)

このビットが'1'を書かれると、TCDクロック領域への同期化が起こると直ぐに捕獲B(TCDn.CAPTUREBH/L)レジスタに対するソフトウェア捕獲が起動されます。

このビットへの書き込みは進行中の指令の同期がない場合にだけ有効です。状態(TCDn.STATUS)レジスタの指令準備可(CMDRDY) ビットをご覧ください。

#### ● ビット3 - SCAPTUREA: ソフトウェア捕獲A発動 (Software Capture A strobe)

このビットが'1'を書かれると、TCDクロック領域への同期化が起こると直ぐに捕獲A(TCDn.CAPTUREAH/L)レジスタに対するソフトウェア捕獲が起動されます。

このビットへの書き込みは進行中の指令の同期がない場合にだけ有効です。状態(TCDn.STATUS)レジスタの指令準備可(CMDRDY) ビットをご覧ください。

## ● ビット2 - RESTART: 再始動発動 (Restart Strobe)

このビットが'1'を書かれると、このビットがTCD領域に同期されると直ぐにTCD計数器の再始動が実行されます。

このビットへの書き込みは進行中の指令の同期がない場合にだけ有効です。状態(TCDn.STATUS)レジスタの指令準備可(CMDRDY) ビットをご覧ください。

# ● ビット1 - SYNC: 同期発動 (Synchronize Strobe)

このビットが、1、を書かれると、このビットがTCD領域に同期されると直ぐに2重緩衝されるレジスタがTCD領域に設定されます。

このビットへの書き込みは進行中の指令の同期がない場合にだけ有効です。状態(TCDn.STATUS)レジスタの指令準備可(CMDRDY) ビットをご覧ください。

#### ● ビット0 - SYNCEOC: TCD周回の最後で同期発動 (Synchronize End of TCD Cycle Strobe)

このビットが´1`を書かれると、次のTCD周回の最後で2重緩衝されるレジスタがTCD領域に設定されます。

このビットへの書き込みは進行中の指令の同期がない場合にだけ有効です。状態(TCDn.STATUS)レジスタの指令準備可(CMDRDY) ビットをご覧ください。

## **22.5.6. EVCTRLx - 事象制御x** (Event Control x) (訳注:xはAまたはB)

名称: EVCTRLA: EVCTRLB 変位: +\$08: +\$09

リセット: \$00 特質:-

| ピット    | 7   | 6    | 5 | 4    | 3 | 2      | 1 | 0      |
|--------|-----|------|---|------|---|--------|---|--------|
|        | CF  | G1,0 |   | EDGE |   | ACTION |   | TRIGEI |
| アクセス種別 | R/W | R/W  | R | R/W  | R | R/W    | R | R/W    |
| リセット値  | 0   | 0    | 0 | 0    | 0 | 0      | 0 | 0      |

#### ● ビット7,6 - CFG1,0: 事象構成設定 (Event Configuration)

捕獲入力雑音消去器が活性化(FILTERON)されると、事象入力が濾波されます。この濾波機能はその出力の変更のために起動ピンの連続する4つの等しい値の採取が必要です。従って雑音消去器が許可(FILTERON)される時に捕獲は4クロック周期遅らされます。 非同期事象が許可(ASYNCON)されると、事象入力は出力に直接影響を及ぼします。

| 値  | 0 0             | 0 1           | 1 0         | 1 1  |
|----|-----------------|---------------|-------------|------|
| 名称 | NEITHER         | FILTERON      | ASYNCON     | -    |
| 説明 | 濾波器と非同期事象どちらもなし | 捕獲入力雑音消去濾波器許可 | 非同期事象出力修飾許可 | (予約) |

#### ● ビット4 - EDGE: エッジ(端)選択(Edge Selection)

このビットは事象入力の有効端またはレベルを選ぶのに使われます。

| 値  | 0                                       | 1                                        |
|----|-----------------------------------------|------------------------------------------|
| 名称 | FALL_LOW                                | RISE_HIGH                                |
| 説明 | 事象入力の下降端またはLowレヘブルが<br>捕獲または障害活動を起動します。 | 事象入力の上昇端またはHighレヘブルが<br>捕獲または障害活動を起動します。 |

## ● ビット2 - ACTION: 事象活動 (Event Action)

このビットは事象入力での捕獲を許可します。既定により、この入力は入力制御x(TCDn.INPUTCTRLx)レジスタの入力動作(INPUTMO DE)に依存して障害を起動します。事象入力で捕獲を起動することも可能です。

| 値  | 0          | 1             |
|----|------------|---------------|
| 名称 | FAULT      | CAPTURE       |
| 説明 | 事象入力が障害を起動 | 事象入力が障害と捕獲を起動 |

#### ● ビット0 - TRIGEI: 事象入力起動許可 (Trigger Event Input Enable)

このビットに'1'を書くことは入力x(x=A/B)に対する起動元としての事象を許可します。

## **22.5.7. INTCTRL - 割り込み制御** (Interrupt Control)

名称:INTCTRL 変位:+\$0C リセット:\$00 特質:-

| ビット    | 7 | 6 | 5 | 4 | 3     | 2     | 1 | 0   |
|--------|---|---|---|---|-------|-------|---|-----|
|        |   |   |   |   | TRIGB | TRIGA |   | OVF |
| アクセス種別 | R | R | R | R | R/W   | R/W   | R | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0     | 0     | 0 | 0   |

#### ● ビット3 - TRIGB: 起動B割り込み許可 (Trigger B Interrupt Enable)

このビットに'1'を書くことが起動入力Bを受け取った時の割り込みを許可します。

#### ● ビット2 - TRIGA: 起動A割り込み許可 (Trigger A Interrupt Enable)

このビットに'1'を書くことが起動入力Aを受け取った時の割り込みを許可します。

# ● ビット0 - OVF:計数器溢れ割り込み許可(Counter Overflow)

このビットに'1'を書くことが流れ手順の再始動割り込みまたは溢れ割り込みを許可します。

# (訳注) 原書でのEVCTRLAとEVCTRLBのレジスタはEVCTRLxとして纏めました。

## **22.5.8. INTFLAGS - 割り込み要求フラグ** (Interrupt Flags)

名称: INTFLAGS 変位:+\$0D リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3     | 2     | 1 | 0   |
|--------|---|---|---|---|-------|-------|---|-----|
|        |   |   |   |   | TRIGB | TRIGA |   | OVF |
| アクセス種別 | R | R | R | R | R/W   | R/W   | R | R/W |
| リセット値  |   |   |   |   |       |       |   |     |

## ● ビット3 - TRIGB: 起動B割り込み要求フラグ(Trigger B Interrupt Flag)

起動B割り込み要求(TRIGB)フラグは起動Bまたは捕獲B条件で設定(1)されます。このフラグはこのビット位置に'1'に書くことによって解除(0)されます。

# ● ビット2 - TRIGA: 起動A割り込み要求フラグ(Trigger A Interrupt Flag)

起動A割り込み要求(TRIGA)フラク・は起動Aまたは捕獲A条件で設定(1)されます。このフラク・はこのビット位置に'1'に書くことによって解除(0)されます。

## ● ビット0 - OVF:計数器溢れ割り込み要求フラグ(Counter Overflow Interrupt Flag)

溢れフラグ(OVF)はTCD周回の最後で設定(1)されます。このフラグはこのビット位置に'1'に書くことによって解除(0)されます。

## **22.5.9. STATUS - 状態** (Status)

名称: STATUS 変位: +\$0E リセット: \$00 特質:-

| ピット    | 7       | 6       | 5 | 4 | 3 | 2 | 1      | 0     |
|--------|---------|---------|---|---|---|---|--------|-------|
|        | PWMACTB | PWMACTA |   |   |   |   | CMDRDY | ENRDY |
| アクセス種別 | J R/W   | R/W     | R | R | R | R | R      | R     |
| リセット値  | 0       | 0       | 0 | 0 | 0 | 0 | 0      | 0     |

#### ● ビット7 - PWMACTB: BでのPWM活動 (PWM Activity on B)

このビットはWOB出力が'0'から'1'または'1'から'0'に切り替わる度毎にハードウェアによって設定(1)されます。 この状態ビットは新しいPWM活動が検出され得る前に'1'を書くことでソフトウェアによって解除(0)されなければなりません。

# ● ビット6 - PWMACTA: AでのPWM活動 (PWM Activity on A)

このビットはWOA出力が'0'から'1'または'1'から'0'に切り替わる度毎にハードウェアによって設定(1)されます。 この状態ビットは新しいPWM活動が検出され得る前に'1'を書くことでソフトウェアによって解除(0)されなければなりません。

## ● ビット1 - CMDRDY: 指令準備可 (Command Ready)

この状態ビットは指令がTCDクロック領域に同期され、システムが新しい指令を受け取るための準備が整った時を知らせます。 以下の活動がCMDRDYビットを解除(0)します。

- 1. 制御E(TCDn.CTRLE)レシブスタのTCD周回の最後で同期発動(SYNCEOC)の瞬発(ストローフ)
- 2. TCDn.CTRLEレシ、スタの同期発動(SYNC)の瞬発(ストローフ)
- 3. TCDn.CTRLEレシ、スタの再始動発動(RESTART)の瞬発(ストローフ))
- 4. TCDn.CTRLEレシ、スタのソフトウェア捕獲A発動(SCAPTUREA)の捕獲A瞬発(ストローフ)
- 5. TCDn.CTRLEレシ、スタのソフトウェア捕獲B発動(SCAPTUREB)の捕獲B瞬発(ストローフ)
- 6. 制御C(TCDn.CTRLC)レジスタの自動更新(AUPDATE)が'1'を書かれ、捕獲B解除上位(TCDn.CMPBCLRH)レジスタへの書き込み

#### ● ビット0 - ENRDY: 許可準備可(Enable Ready)

この状態ビットは制御A(TCDn.CTRLA)レジスタの許可(ENABLE)値がTCDクロック領域に同期され、再び書かれる準備が整った時を知らせます。

以下の活動がENRDYビットを解除(0)します。

- 1. TCDn.CTRLAレシ、スタの許可(ENABLE)ビットへの書き込み
- 2. 制御E(TCDn.CTRLE)レジネタのTCD周回の最後で禁止発動(DISEOC)の瞬発(ストローフ)
- 3. デバッグ制御(TCDn.DBGCTRL)レジスタのデバッグ時走行(DBGRUN)ビットが'1'でなく、チップ上デバッグ(OCD)作業で中断に行く

# **22.5.10. INPUTCTRLx - 入力制御x** (Input Control x) (訳注:xはAまたはB)

名称:INPUTCTRLA:INPUTCTRLB

変位:+\$10::+\$11

リセット: \$00 特質:-

| ビット    | 7 | 6 | 5 | 4 | 3   | 2      | 1      | 0   |
|--------|---|---|---|---|-----|--------|--------|-----|
|        |   |   |   |   |     | INPUTM | ODE3~0 |     |
| アクセス種別 | R | R | R | R | R/W | R/W    | R/W    | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0   | 0      | 0      | 0   |

#### ● ビット3~0 - INPUTMODE3~0:入力動作 (Input Mode)

| 値       | 名称           | 説明                     |
|---------|--------------|------------------------|
| 0000    | NONE         | 入力は活動なし                |
| 0001    | JMPWAIT      | 出力停止、逆の比較周回へ飛んで待機      |
| 0 0 1 0 | EXECWAIT     | 出力停止、逆の比較周回を実行して待機     |
| 0 0 1 1 | EXECFAULT    | 出力停止、障害が活性の間、逆の比較周期を実行 |
| 0 1 0 0 | FREQ         | 全出力停止、周波数維持            |
| 0 1 0 1 | EXECDT       | 全出力停止、障害が活性の間、沈黙時間を実行  |
| 0 1 1 0 | WAIT         | 全出力停止、次の比較周回へ飛んで待機     |
| 0 1 1 1 | WAITSW       | 全出力停止、ソフトウェア活動待ち       |
| 1000    | EDGETRIG     | エッシ(端)で出力停止、次の比較周回へ飛ぶ  |
| 1001    | EDGETRIGFREQ | エッシ (端)で出力停止、周波数維持     |
| 1010    | LVLTRIGFREQ  | レベルで出力停止、周波数維持         |

# **22.5.11. FAULTCTRL - 障害制御** (Fault Control)

名称: FAULTCTRL

変位:+\$12

リセット: ヒューズから設定 特質:構成設定変更保護

| ピット    | 7      | 6      | 5      | 4      | 3    | 2    | 1    | 0    |
|--------|--------|--------|--------|--------|------|------|------|------|
|        | CMPDEN | CMPCEN | CMPBEN | CMPAEN | CMPD | CMPC | CMPB | CMPA |
| アクセス種別 | R/W    | R/W    | R/W    | R/W    | R/W  | R/W  | R/W  | R/W  |
| リセット値  | X      | X      | X      | X      | X    | X    | X    | X    |

## ● ビット4,5,6,7 - CMPAEN,CMPBEN,CMPCEN,CMPDEN: 比較x許可(Compare x Enable)

このビット領域はピンでの出力として比較からの波形を許可します。このビット領域は電源ONリセット後に'0'にリセットされます。他のリセットでこの内容は維持されますが、リセット手順中にTCD構成設定(FUSE.TCD0CFG)ヒューズから複写/設定されます。

## ● ビット0,1,2,3 - CMPA,CMPB,CMPC,CMPD: 比較x値(Compare Value x)

このビット領域はリセットから、または入力事象が出力に対する変更を引き起こす障害を起動する時の既定状態を設定します。このビット領域は電源ONリセット後に'0'にリセットされます。他のリセットでこの内容は維持されますが、リセット手順中にTCD構成設定(FUSE.TCD0CFG)ヒューズから複写/設定されます。

(訳注) 原書でのINPUTCTRLAとINPUTCTRLBのレシブスタはINPUTCTRLxとして纏めました。

# **22.5.12**. **DLYCTRL** - 遅延制御 (Delay Control)

名称: DLYCTRL 変位:+\$14 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5     | 4           | 3   | 2          | 1   | 0     |
|--------|---|---|-------|-------------|-----|------------|-----|-------|
|        |   |   | DLYPR | DLYPRESC1,0 |     | DLYTRIG1,0 |     | EL1,0 |
| アクセス種別 | R | R | R/W   | R/W         | R/W | R/W        | R/W | R/W   |
| リセット値  | 0 | 0 | 0     | 0           | 0   | 0          | 0   | 0     |

# ● ビット5,4 - DLYPRESC1,0:遅延前置分周器 (Delay Prescaler)

このビット領域は入力抑制または出力事象遅延に対する前置分周器設定を制御します。

| 値  | 0 0       | 0 1      | 1 0      | 11       |
|----|-----------|----------|----------|----------|
| 名称 | DIV1      | DIV2     | DIV4     | DIV8     |
| 説明 | 1分周(分周なし) | 前置分周器2分周 | 前置分周器4分周 | 前置分周器8分周 |

# ● ビット3,2 - DLYTRIG1,0:遅延起動元 (Delay Trigger)

このビット領域は入力抑制または出力事象遅延の起動を制御します。

| 値  | 0 0           | 0 1           | 1 0           | 11                       |  |
|----|---------------|---------------|---------------|--------------------------|--|
| 名称 | CMPASET       | CMPACLR       | CMPBSET       | CMPBCLR                  |  |
| 説明 | CMPASETが遅延を起動 | CMPACLRが遅延を起動 | CMPBSETが遅延を起動 | CMPBCLR(周回の最後)<br>が遅延を起動 |  |

## ● ビット1,0 - DLYSEL1,0:遅延選択 (Delay Select)

このビット領域は遅延の引き金、遅延前置分周器、遅延値によって制御される機能を選びます。

| 値  | 0 0     | 0 1     | 1 0       | 11   |  |
|----|---------|---------|-----------|------|--|
| 名称 | OFF     | INBLANK | EVENT     | _    |  |
| 説明 | 遅延機能不使用 | 入力抑制    | 設定可能な出力事象 | (予約) |  |

# **22.5.13. DLYVAL - 遅延値** (Delay Value)

名称: DLYVAL 変位:+\$15 リセット: \$00 特質:-



## ● ビット7~0 - DLYVAL7~0 : 遅延値 (Delay Value)

このビット領域はは前置分周されたTCDクロック周期数で入力抑制/出力事象遅延時間または事象出力同期遅延を構成設定します。

# **22.5.14. DITCTRL - ディサ 制御** (Dither Control)

名称: DITCTRL 変位: +\$18 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0       |
|--------|---|---|---|---|---|---|-------|---------|
|        |   |   |   |   |   |   | DITHE | RSEL1,0 |
| アクセス種別 | R | R | R | R | R | R | R/W   | R/W     |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0     | 0       |

## • ビット1,0 - DITHERSEL1,0:ディザ選択 (Dither Select)

このビット領域はTCD周回のどの状態がディザ機能の恩恵を受けるかを選びます。 「22.3.3.5. ディザリング」項をご覧ください。

| 値  | 0 0      | 0 1        | 1 0       | 11         |
|----|----------|------------|-----------|------------|
| 名称 | ONTIMEB  | ONTIMEAB   | DEADTIMEB | DEADTIMEAB |
| 説明 | ON時間Bの傾斜 | ON時間AとBの傾斜 | 沈黙時間Bの傾斜  | 沈黙時間AとBの傾斜 |

# **22.5.15**. **DITVAL** - ディサ 値 (Dither Value)

名称: DITVAL 変位: +\$19 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3   | 2    | 1     | 0   |
|--------|---|---|---|---|-----|------|-------|-----|
|        |   |   |   |   |     | DITH | ER3~0 |     |
| アクセス種別 | R | R | R | R | R/W | R/W  | R/W   | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0   | 0    | 0     | 0   |

# • ビット3~0 - DITHER3~0 : ディザ値 (Dither Value)

これらのビットはディザ制御(TCDn.DITCTRL)レジスタのディザ選択(DITHERSEL)ビットに従ってON時間またはOFF(沈黙)時間の分数調整を構成設定します。DITHER値は各TCD周回の最後で4ビットの累積器に加算されます。累積器が溢れると、周波数調整が起こります。

DITHERL'ットは2重緩衝され、故に新しい値は更新条件発生時に複写されます。

# **22.5.16**. **DBGCTRL** – デバック 制御 (Debug Control)

名称: DBGCTRL 変位: +\$1E リセット: \$00 特質:-

| ピット _  | 7 | 6 | 5 | 4 | 3 | 2        | 1 | 0      |
|--------|---|---|---|---|---|----------|---|--------|
|        |   |   |   |   |   | FAULTDET |   | DBGRUN |
| アクセス種別 | R | R | R | R | R | R/W      | R | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0        | 0 | 0      |

#### ● ビット2 - FAULTDET: 障害検出(Fault Detection)

このビットはデバッグ動作で停止時に周辺機能がどう動くかを定義します。

| 値  | 0                                   | 1                                                |
|----|-------------------------------------|--------------------------------------------------|
| 名称 | NONE                                | FAULT                                            |
| 説明 | デバッグ動作でTCDが停止された場合、<br>全く障害を生成しません。 | デバッグ動作でTCDが停止された場合、<br>障害が生成され、両起動フラグが設定(1)されます。 |

# ● ビット0 - DBGRUN:デバッグ時走行(Debug Run)

'1'を書かれると、周辺機能はCPUが停止された時にデバッグ動作で動作を続けます。

| 値  | 0                                      | 1                     |
|----|----------------------------------------|-----------------------|
| 説明 | デ゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙ | CPU停止時のデバッグ動作中断で走行を継続 |

#### **22.5.17. CAPTUREx - 捕獲x** (Capture x) (訳注:xはAまたはB)

名称: CAPTUREA (CAPTUREAH, CAPTUREAL): CAPTUREB (CAPTUREBH, CAPTUREBL)

**変位**:+\$22 :+\$24

リセット: \$0000 特質:-

TCDn.CAPTURExHとTCDn.CAPTURExLのレジスタ対は12ビット値のTCDn.CAPTURExを表します。下位バイト[7~0](接尾辞L)は変位 原点でアクセスできます。上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

捕獲動作に関して、これらのレジスタはCPUに対する第2緩衝レベルとアクセス点を構成します。TCDn.CAPTURExレジスタは更新条件発生時に緩衝部の値で更新されます。CAPTUREAレジスタは起動元Aまたはソフトウェア捕獲Aが起きた時のTCD計数器値を含みます。CAPTUREBレジスタは起動元Bまたはソフトウェア捕獲Bが起きた時のTCD計数器値を含みます。

TCD計数器値はソフトウェアまたは事象のどちらかによってCAPURExに同期化されます。

捕獲レジスタはこのレジスタの上位バイが読まれるまで新しい捕獲データの更新を妨げられます。

| ピット    | 15 | 14 | 13 | 12    | 11     | 10     | 9       | 8 |
|--------|----|----|----|-------|--------|--------|---------|---|
|        |    |    |    |       |        | CAPTUI | REx11~8 | • |
| アクセス種別 | R  | R  | R  | R     | R      | R      | R       | R |
| リセット値  | 0  | 0  | 0  | 0     | 0      | 0      | 0       | 0 |
| ピット    | 7  | 6  | 5  | 4     | 3      | 2      | 1       | 0 |
|        |    |    |    | CAPTU | REx7∼0 |        |         |   |
| アクセス種別 | R  | R  | R  | R     | R      | R      | R       | R |
| リセット値  | 0  | 0  | 0  | 0     | 0      | 0      | 0       | 0 |
|        |    |    |    |       |        |        |         |   |

● ビット11~0 - CAPTUREx11~0:捕獲x値 (Capture x Byte)

# 22.5.18. CMPxSET - 比較x設定 (Compare Set x) (訳注:xはAまたはB)

名称: CMPASET (CMPASETH, CMPASETL): CMPBSET (CMPBSETH, CMPBSETL)

**変位**:+\$28 :+\$2C

リセット: \$0000 特質:-

TCDn.CMPxSETHとTCDn.CMPxSETLのレンブスタ対は12ピット値のTCDn.CMPxSETを表します。下位バイト[7~0](接尾辞L)は変位原点でアクセスできます。上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

このレジスタは計数器値と継続的に比較されます。その後、比較器からの出力は波形を生成するのに使われます。

| ピット    | 15       | 14       | 13       | 12                | 11                 | 10       | 9        | 8        |
|--------|----------|----------|----------|-------------------|--------------------|----------|----------|----------|
|        |          |          |          |                   |                    | CMPxS    | ET11~8   |          |
| アクセス種別 | R        | R        | R        | R                 | R/W                | R/W      | R/W      | R/W      |
| リセット値  | 0        | 0        | 0        | 0                 | 0                  | 0        | 0        | 0        |
| ピット    | 7        | 6        | 5        | 4                 | 2                  | 9        | 1        | 0        |
| Γ / I  | 1        | . 0      |          | CMP <sub>v</sub>  | SFT7~0             |          | 1        | . 0      |
| L      |          |          |          |                   |                    |          |          |          |
| アクセス種別 | R/W      | R/W      | R/W      | R/W               | R/W                | R/W      | R/W      | R/W      |
| リセット値  | 0        | 0        | 0        | 0                 | 0                  | 0        | 0        | 0        |
| アクセス種別 | R/W<br>0 | R/W<br>0 | R/W<br>0 | CMPxS<br>R/W<br>0 | SET7~0<br>R/W<br>0 | R/W<br>0 | R/W<br>0 | R/W<br>0 |

● ビット11~0 - CMPxSET11~0:比較x設定(Compare x Set)

これらのビットは比較レジスタの値を保持します。

(訳注) 原書でのCAPTUREAとCAPTUREBのレシブスタはCAPTUREx、CMPASETとCMPBSETのレシブスタはCMPxSETとして纏めました。

# **22.5.19. CMPxCLR - 比較x解除** (Compare Clear x) (<mark>訳注</mark>:xはAまたはB)

名称: CMPACLR (CMPACLRH, CMPACLRL): CMPBCLR (CMPBCLRH, CMPBCLRL)

**変位**:+\$2A : +\$2E

リセット: \$0000 特質:-

TCDn.CMPxCLRHとTCDn.CMPxCLRLのレシ、スタ対は12ピット値のTCDn.CMPxCLRを表します。下位ハイト[7~0](接尾辞L)は変位原点でアクセスできます。上位ハイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

このレジスタは計数器値と継続的に比較されます。その後、比較器からの出力は波形を生成するのに使われます。

| ピット    | 15  | 14  | 13  | 12    | 11     | 10    | 9      | 8   |
|--------|-----|-----|-----|-------|--------|-------|--------|-----|
|        |     |     |     |       |        | CMPxC | LR11~8 |     |
| アクセス種別 | R   | R   | R   | R     | R/W    | R/W   | R/W    | R/W |
| リセット値  | 0   | 0   | 0   | 0     | 0      | 0     | 0      | 0   |
| ヒ゛ット   | 7   | 6   | 5   | 4     | 3      | 2     | 1      | 0   |
|        |     |     |     | CMPx( | CLR7~0 |       |        |     |
| アクセス種別 | 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~0 - CMPxCLR11~0:比較x解除(Compare x Clear)

これらのビットは比較レジスタの値を保持します。

(訳注) 原書でのCMPACLRとCMPBCLRのレジスタはCMPxCLRとして纏めました。

# 23. RTC - 実時間計数器

## 23.1. 特徴

- 16ビット分解能
- ・選択可能なクロック元
- ・設定可能な15ビットクロック前置分周
- ・1つの比較レジブスタ
- ・1つの定期レジスタ
- ・定期上昇溢れでの計数器解消
- ・任意選択の上昇溢れと比較一致での割り込み/事象
- ・周期的な割り込みと事象

## 23.2. 概要

RTC周辺機能は実時間計数器(RTC:Real-Time Couter)と周期的割り込み計時器(PIT:Priodic Interrupt Timer)の2つのタイング機能を提供します。

PIT機能はRTC機能から独立して許可することができます。

## RTC - 実時間計数器

RTCは計数レジスタで(前置分周された)クロック周期を計数し、計数レジスタの内容を定期レジスタ及び比較レジスタと比較します。

RTCは比較一致または溢れで割り込みと事象の両方を生成することができます。計数器が比較レジスタ値と等しい後の最初の計数で比較割り込みや事象を、計数器値が定期レジスタ値と等しい後の最初の計数で溢れ割り込みや事象を生成します。溢れは計数器値を0にリセットします。

RTC周辺機能は時間の経緯を保つよう、一般的に低電力休止動作形態を含み継続して動きます。これは規則的な間隔で休止動作形態からデバイスを起き上がらせたり、デバイスに割り込むことができます。

基準クロックは代表的に外部クリスタルからの32.768kHz出力です。RTCは外部クロック信号、32.768kHz内部発振器(OSCULP32K)、または32分周されたOSCULP32Kからもクロック駆動することができます。

RTC周辺機能は計数器へ至る前に基準クロックを下げることができる設定可能な15ビットの前置分周器を含みます。RTCに対して広範囲の分解能と時間限度を構成設定することができます。32.768kHzのクロック元とで、最大分解能は30.5μsで、時間限度期間は2sまでにすることができます。1sの分解能とで、最大時間限度期間は18時間よりも多くなります(65536s)。

## PIT - 周期的割り込み計時器

PITはRTC機能と同じクロック元を使い、毎回の第nクロック周期で割り込み要求やレベル事象を生成することができます。nは割り込みに対して4,8,16,~32768、事象に対して64,128,256,~8192から選ぶことができます。

## 23.2.1. 構成図



# 23.3. クロック

周辺機能クロック(CLK\_PER)は前置分周器設定と無関係に計数器値を読むためにRTCクロック(CLK\_RTC)よりも最低4倍速いことが必要とされます。

32.768kHzクリスタルは必要とされる何れかの負荷容量と共にTOSC1とTOSC2のピンに接続することができます。代わりに、外部デジタルクロックをTOSC1ピンに接続することができます。

# 23.4. RTCの機能的な説明

RTC周辺機能は実時間計数器(RTC)と周期的割り込み計時器(PIT)の2つのタイシケ機能を提供します。

#### 23.4.1. 初期化

RTC周辺機能と望む活動(割り込み要求、出力事象)を許可する前に、RTCを動かすためにRTC計数器用の供給元クロックが構成設定されなければなりません。

# 23.4.1.1. CLK\_RTCクロック構成設定

CLK RTCを構成設定するには以下のこれらの手順に従ってください。

- 1. クロック制御器(CLKCTRL)周辺機能で望む発振器を必要とされる動作に構成設定してください。
- 2. それに応じてクロック選択(RTC.CLKSEL)レジスタのクロック選択(CLKSEL)ビット領域を書いてください。
- CLK RTCクロック構成設定はRTCとPITの両機能によって使われます。

## 23.4.1.2. RTC構成設定

RTCを動かすには以下のこれらの手順に従ってください。

- 1. 比較(RTC.CMP)レシ、スタに比較値、定期(RTC.PER)レジ、スタに溢れ値を設定してください。
- 2. 割り込み制御(RTC.INTCTRL)レジスタで各々の割り込み許可(CMP,OVF)ビットに'1'を書くことによって望む割り込みを許可してください。
- 3. 制御A(RTC.CTRLA)レジスタで前置分周器(PRESCALER)ビット領域に望む値を書くことによってRTC内部前置分周器を構成設定してください。
- 4. RTC.CTRLAレジスタでRTC周辺機能許可(RTCEN)ビットに'1'を書くことによってRTCを許可してください。
- 注: RTC周辺機能はデバイス始動の間で内部的に使われます。常に及び初期構成設定で、状態(RTC.STATUS)と周期割り込み計時器状態(RTC.PITSTATUS)のレシ、スタで同期中多忙ビットを調べてください。

## 23.4.2. 操作 - RTC

#### 23.4.2.1. 許可と禁止

RTCは制御Aレジスタ(RTC.CTRLA)レジスタのRTC周辺機能許可(RTCEN)ビットに'1'を書くことによって許可されます。RTCはRTC.CT RLAのRTCENビットに'0'を書くことによって禁止されます。

## 23.5. PITの機能的な説明

RTC周辺機能は実時間計数器(RTC)と周期割り込み計時器(PIT)の2つのタイジング機能を提供します。

#### 23.5.1. 初期化

PITを動かすには以下のこれらの手順に従ってください。

- 1. 「23.4.1.1. CLK RTCクロック構成設定」項で記述されるようにRTCクロック(CLK RTC)を構成設定してください。
- 2. 周期割り込み計時器割り込み制御(RTC.PITINTCTRL)レジスタの周期割り込み許可(PI)ビットに'1'を書くことによって割り込みを許可してください。
- 3. 周期割り込み計時器制御A(RTC.PITCTRLA)レジスタで周期(PERIOD)ビット領域に望む値と周期割り込み計時器許可(PITEN)ビットに'1'を書くことによって割り込み周期を選んでPITを許可してください。
- 注: RTC周辺機能はデバイス始動の間で内部的に使われます。常に及び初期構成設定で、状態(RTC.STATUS)と周期割り込み計時器状態(RTC.PITSTATUS)のレシ、スタで同期中多忙ビットを調べてください。

#### 23.5.2. 操作 - PIT

#### 23.5.2.1. 許可と禁止

PITは周期割り込み計時器制御A(RTC.PITCTRLA)レシブスタの周期割り込み計時器許可(PITEN)ビットに'1'を書くことによって許可されます。PITはRTC.PITCTRLAのPITENビットに'0'を書くことによって禁止されます。

## 23.5.2.2. PIT割り込みタイミング

# 初回割り込みのタイミング

PIT機能とRTC機能は前置分周器内側の同じ計数器で動き、下で記述されるように構成設定することができます。

- ・RTC割り込み周期は定期(RTC.PER)レジスタを書くことによって構成設定されます。
- ・PIT割り込み周期は周期割り込み計時器制御A(RTC.PITCTRLA)レジスタの周期(PERIOD)ビット領域を書くことによって構成設定されます。

前置分周器は両機能がOFF(RTC.CTRLAのRTC周辺機能許可(RTCEN)ビットとRTC.PITCTRLAの周期割り込み計時器許可(PITE N)ビットが0)の時にOFFですが、どちらかの機能が許可されると動きます(即ち、内部計数器が計数します)。この理由のため、最初のPIT割り込みとRTC計数刻みのタイシンがは未知(許可と完全な周期間の何時か)です。

## 継続動作

初回割り込み後、PITは完全なPIT周期信号に帰着する1/2 PIT周期毎の交互切り替えを続けます。

## 例23-1. PERIOD=CYC16に対するPITタイミング図

RTC.PITCTRLAでのPERIOD=CYC16に対して、PITは事実上前置分周器計数器ビット3の状態に従い、故に結果の割り込み出力は16 CLK\_RTC周回の周期を持ちます。

初回PIT割り込みとPITENへの'1'書き込み間の時間は実質的に0と(n CLK\_RTC周期の)PIT周期間で変わり得ます。PIT許可とそれの初回出力間の正確な遅延は前置分周器の計数段階に依存し、下で示される初回割り込みは先行する時間窓内側の何処かでPITENへ'1'を書くことによってもたらされます。

# 図23-2. PIT許可と初回割り込み間のタイミング



# 23.6. 事象

RTCは次表で記述される事象を生成することができます。

表23-1. RTC事象生成部

| 1223 1.111 |             |                   |                                         |          |                         |
|------------|-------------|-------------------|-----------------------------------------|----------|-------------------------|
| 生          | <b></b>     | 説明                | 事象型                                     | 生成クロック領域 | 事象長                     |
| 周辺機能       | 事象          | נפיתם             | 尹豕王                                     | 上水ルが原域   | <b>学</b> 承 文            |
|            | OVF         | 溢れ                | ハ <sup>°</sup> ルス                       |          | 1 CLK_RTC周期             |
|            | CMP         | 比較一致              | <i>/\/\/</i>                            |          | I CLK_KIC向别             |
|            | PIT_DIV8192 | 8196前置分周したRTCクロック |                                         |          | 8196前置分周したRTCクロックで与えられる |
|            | PIT_DIV4096 | 4096前置分周したRTCクロック |                                         |          | 4096前置分周したRTCクロックで与えられる |
| RTC        | PIT_DIV2048 | 2048前置分周したRTCクロック |                                         | CLK_RTC  | 2048前置分周したRTCクロックで与えられる |
| RIC        | PIT_DIV1024 | 1024前置分周したRTCクロック | レヘブル                                    | CLK_KIC  | 1024前置分周したRTCクロックで与えられる |
|            | PIT_DIV512  | 512前置分周したRTCクロック  | V / / / / / / / / / / / / / / / / / / / |          | 512前置分周したRTCクロックで与えられる  |
|            | PIT_DIV256  | 256前置分周したRTCクロック  |                                         |          | 256前置分周したRTCクロックで与えられる  |
|            | PIT_DIV128  | 128前置分周したRTCクロック  |                                         |          | 128前置分周したRTCクロックで与えられる  |
|            | PIT_DIV64   | 64前置分周したRTCクロック   |                                         |          | 64前置分周したRTCクロックで与えられる   |

OVFとCMPの事象を生成するための条件は割り込み要求フラグ(RTC.INTFLAGS)レジスタで対応する割り込み要求フラグを掲げるそれらと同じです。

事象使用部と事象システム構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照してください。

## 23.7. 割り込み

#### 表23-2. 利用可能な割り込みべりなど供給元

|     | THE PARTY OF THE P |                                                                                                               |  |  |  |  |  |  |  |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 名称  | ベクタ説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 条件                                                                                                            |  |  |  |  |  |  |  |
| RTC | 実時間計数器溢れと<br>比較一致割り込み                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ・溢れ(OVF) : 計数器が定期(RTC.PER)レジスタからの値に達して0に丸められる<br>・比較一致(CMP): 計数器(RTC.CNT)レジスタからの値と比較(RTC.CMP)レジスタからの<br>値間で一致 |  |  |  |  |  |  |  |
| PIT | 周期割り込み計時器割り込み                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RTC.PITCTRLAのPERIODビット領域で構成設定したように時間周期通過                                                                      |  |  |  |  |  |  |  |

割り込み条件が起こると、周辺機能の割り込み要求フラケ、(RTC.INTFLAGS, RTC.PITINTFLAGS)レシ、スタで対応する割り込み要求フラケが設定(1)されます。

割り込み元は周辺機能の割り込み制御(RTC.INTCTRL, RTC.PITINTCTRL)レジスタで対応する許可ビットを書くことによって許可または禁止にされます。

割り込み要求は対応する割り込み元が許可され、割り込み要求フラグが設定(1)される時に生成されます。割り込み要求は割り込み要求フラグが解除(0)されるまで活性に留まります。割り込み要求フラグを解除する方法の詳細については周辺機能の(PIT)INTFLAGSレジスタをご覧ください。

- 注: ・RTCはRTC用のRTC.INTFLAGSとPIT用のRTC.PITINTFLAGSの2つのINTFLAGSレジスタを持ちます。
  - ・RTCはRTC用のRTC.INTCTRLとPIT用のRTC.PITINTCTRLの2つのINTCTRLレジスタを持ちます。

# 23.8. 休止形態動作

RTCはアイト・ル休止動作で動作を続けます。制御Aレシ、スタレハ・イトはアイト・ル休止動作で動作を続けます。制御Aレシ、スタレハ・イトは動作で走行します。

PITはどの休止動作形態でも動作を続けます。

## 23.9. 同期

RTCとPITは共に非同期で、周辺機能クロック(CLK\_PER)から独立した違うクロック元(CLK\_RTC)で動きます。制御と計数レジスタ更新に関して、更新されたレジスタ値がレジスタで利用可能になる前、または構成設定変更が各々RTCやPITに影響を及ぼすまで、RTCクロックや周辺機能クロックで多少の周期数がかかります。この同期時間はレジスタ説明項で各レジスタに対して記述されます。

いくつかのRTCレジスタに関して、状態(RTC.STATUS)レジスタで同期多忙(CMPBUSY, PERBUSY, CNTBUSY, CTRLABUSY)フラグが利用可能です。

周期割り込み計時器制御A(RTC.PITCTRLA)レジスタについては、周期割り込み計時器状態(RTC.PITSTATUS)レジスタでPIT制御A同期多忙(CTRLBUSY)フラケが利用可能です。

言及したレシブスタへ書く前にこれらのフラグを調べてください。

## 23.10. デバッグ操作

デバッグ制御(DBGCTRL)レジスタのディッグ時走行(DBGRUN)ビットが'1'の場合、RTCは標準動作を続けます。DBGRUNが'0'でCPU が停止された場合、RTCは動作を停止してどの到着事象も無視します。

周期割り込み計時器デバッグ制御(PITDBGCTRL)レジスタのデバッグ時走行(DBGRUN)ビットが'1'の場合、PITは標準動作を続けます。 デバッグ動作に於いてDBGRUNが'0'でCPUが停止された場合、PIT出力はLowです。 その時にPIT出力がHighだったなら、中断から 再始動する時に割り込み要求フラグを設定(1)するために新しい正端が起きます。 結果は標準動作中に起こらない追加のPIT割り込みです。 中断でPIT出力がLowだったなら、 PITは追加の割り込みなしでLowを再開します。

# 23.11. レジスタ要約

| 変位         | 略称           | ビット位置        | ヒ゛ット7    | ヒ゛ット6 | ヒ゛ット5  | じット4   | ピット3             | じット2    | ヒ゛ット1   | ピット0      |
|------------|--------------|--------------|----------|-------|--------|--------|------------------|---------|---------|-----------|
| +\$00      | CTRLA        | 7~0          | RUNSTDBY |       | PRESCA | LER3~0 |                  |         |         | RTCEN     |
| +\$01      | STATUS       | 7~0          |          |       |        |        | CMPBUSY          | PERBUSY | CNTBUSY | CTRLABUSY |
| +\$02      | INTCTRL      | 7~0          |          |       |        |        |                  |         | CMP     | OVF       |
| +\$03      | INTFLAGS     | 7~0          |          |       |        |        |                  |         | CMP     | OVF       |
| +\$04      | TEMP         | 7~0          |          |       |        | TEM    | P7∼0             | 1       | 1       |           |
| +\$05      | DBGCTRL      | 7~0          |          |       |        |        |                  |         |         | DBGRUN    |
| +\$06      | 予約           | 7~0          |          |       |        |        |                  |         |         |           |
| +\$07      | CLKSEL       | 7 <b>~</b> 0 |          |       |        |        |                  |         | CLKS    | EL1,0     |
| +\$08      | CNT          | 7 <b>~</b> 0 |          |       |        | CNT    | 7~0              |         | 1       | '         |
| +\$09      | CIVI         | 15~8         |          |       |        | CNT    | 15~8             |         |         |           |
| +\$0A      | PER          | 7~0          |          |       |        | PER    | <sup>2</sup> 7∼0 | 1       | 1       |           |
| +\$0B      | FER          | 15~8         |          |       |        | PER    | 15~8             |         | 1       |           |
| +\$0C      | СМР          | 7 <b>~</b> 0 |          |       |        | CMF    | P7~0             |         |         | '         |
| +\$0D      | CIVIF        | 15~8         | '        |       |        | CMP    | 15~8             |         |         | '         |
| +\$0E      | <b>₹.</b> ∜A |              |          |       |        |        |                  |         |         |           |
| -<br>+\$0F | 予約           |              |          |       |        |        |                  |         |         |           |
| +\$10      | PITCTRLA     | 7~0          |          |       | PERIC  | )D3~0  |                  |         |         | PITEN     |
| +\$11      | PITSTATUS    | 7~0          |          |       |        |        |                  |         |         | CTRLBUSY  |
| +\$12      | PITINTCTRL   | 7~0          |          |       |        |        |                  |         |         | PI        |
| +\$13      | PITINTFLAGS  | 7~0          |          |       |        |        |                  |         |         | PI        |
| +\$14      | 予約           |              |          |       |        |        |                  |         |         |           |
| +\$15      | PITDBGCTRL   | 7~0          |          |       |        |        |                  |         |         | DBGRUN    |

# 23.13. レジスタ説明

# **23.13.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位:+\$00 リセット: \$00 特質:-

| ピット    | 7        | 6   | 5      | 4      | 3   | 2 | 1 | 0     |
|--------|----------|-----|--------|--------|-----|---|---|-------|
| I      | RUNSTDBY |     | PRESCA | LER3~0 |     |   |   | RTCEN |
| アクセス種別 | R/W      | R/W | R/W    | R/W    | R/W | R | R | R/W   |
| リセット値  | 0        | 0   | 0      | 0      | 0   | 0 | 0 | 0     |

## ● ビット7 - RUNSTDBY: スタンバイ時走行(Run Standby)

| 値  | 0               | 1               |
|----|-----------------|-----------------|
| 説明 | スタンバイ休止動作でRTC禁止 | スタンバイ休止動作でRTC許可 |

## ● ビット6~3 - PRESCALER3~0:前置分周器 (Prescaler)

これらのビットはCLK\_RTCクロック信号の前置分周を定義します。

| 値  | 0000        | 0001        | 0 0 1 0      | 0 0 1 1      | 0 1 0 0      | 0 1 0 1      | 0 1 1 0       | 0 1 1 1       |
|----|-------------|-------------|--------------|--------------|--------------|--------------|---------------|---------------|
| 名称 | DIV1        | DIV2        | DIV4         | DIV8         | DIV16        | DIV32        | DIV64         | DIV128        |
| 説明 | CLK_RTC/1   | CLK_RTC/2   | CLK_RTC/4    | CLK_RTC/8    | CLK_RTC/16   | CLK_RTC/32   | CLK_RTC/64    | CLK_RTC/128   |
| 値  | 1000        | 1001        | 1010         | 1011         | 1 1 0 0      | 1 1 0 1      | 1110          | 1111          |
| 名称 | DIV256      | DIV512      | DIV1024      | DIV2048      | DIV4096      | DIV8192      | DIV16384      | DIV32768      |
| 説明 | CLK_RTC/256 | CLK_RTC/512 | CLK_RTC/1024 | CLK_RTC/2048 | CLK_RTC/4096 | CLK_RTC/8192 | CLK_RTC/16384 | CLK_RTC/32768 |

# ● ビット0 - RTCEN: RTC周辺機能許可(RTC Peripheral Enable)

| 値  | 0         | 1         |  |  |  |
|----|-----------|-----------|--|--|--|
| 説明 | RTC周辺機能禁止 | RTC周辺機能許可 |  |  |  |

**>** 

重要: RTCクロックと主クロック領域間同期のため、レシ、スタ更新からそれが効果を持つまでに2 RTCクロック周期の遅れがあります。 応用ソフトウェアはこのレシ、スタを書く前に状態(RTC.STATUS)レシ、スタの制御A同期多忙(CTRLABUSY)フラケが解除(0)されているのを確認しなければなりません。

# 23.13.2. STATUS - 状態 (Status)

名称: STATUS 変位: +\$01 リセット: \$00 特質: -

| ビット    | 7 | 6 | 5 | 4 | 3       | 2       | 1       | 0         |
|--------|---|---|---|---|---------|---------|---------|-----------|
|        |   |   |   |   | CMPBUSY | PERBUSY | CNTBUSY | CTRLABUSY |
| アクセス種別 | R | R | R | R | R/W     | R/W     | R/W     | R/W       |
| リセット値  | 0 | 0 | 0 | 0 | 0       | 0       | 0       | 0         |

## ● ビット3 - CMPBUSY: 比較同期多忙 (Compare Synchronization Busy)

このビットはRTCがRTCクロック領域で比較(RTC.CMP)レジスタを同期中多忙の時に'1'です。

#### ● ビット2 - PERBUSY: 定期同期多忙 (Period Synchronization Busy)

このビットはRTCがRTCクロック領域で定期(RTC.PER)レン゙スタを同期中多忙の時に'1'です。

## ● ビット1 - CNTBUSY : 計数器同期多忙 (Counter Synchronization Busy)

このビットはRTCがRTCクロック領域で計数(RTC.CNT)レジスタを同期中多忙の時に'1'です。

## ● ビット0 - CTRLABUSY : 制御A同期多忙 (Control A Synchronization Busy)

このビットはRTCがRTCクロック領域で制御A(RTC.CTRLA)レジスタを同期中多忙の時に'1'です。

## **23.12.3. INTCTRL - 割り込み制御** (Interrupt Control)

名称:INTCTRL 変位:+\$02 リセット:\$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0   |
|--------|---|---|---|---|---|---|-----|-----|
|        |   |   |   |   |   |   | CMP | OVF |
| アクセス種別 | R | R | R | R | R | R | R/W | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0   | 0   |

## ● ビット1 - CMP: 比較一致割り込み許可 (Compare Match Interrupt Enable)

比較一致での(即ち、計数(RTC.CNT)レシ、スタ値が比較(RTC.CMP)レシ、スタ値と一致した時の)割り込みを許可します。

| 値  | 0                | 1                |
|----|------------------|------------------|
| 説明 | 比較一致割り込みは禁止されます。 | 比較一致割り込みは許可されます。 |

## ● ビット0 - OVF: 溢れ割り込み許可(Overflow Interrupt Enable)

計数器溢れでの(即ち、計数(RTC.CNT)レシ、スタ値が定期(RTC.PER)レシ、スタ値と一致して0に丸められる時の)割り込みを許可します。

| 値  | 0              | 1              |
|----|----------------|----------------|
| 説明 | 溢れ割り込みは禁止されます。 | 溢れ割り込みは許可されます。 |

## 23.12.4. INTFLAGS - 割り込み要求フラグ (Interrupt Flag)

名称: INTFLAGS 変位:+\$03 リセット: \$00 特質:-

| <b>ビット</b> | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0   |
|------------|---|---|---|---|---|---|-----|-----|
|            |   |   |   |   |   |   | CMP | OVF |
| アクセス種別     | R | R | R | R | R | R | R/W | R/W |
| リセット値      | 0 | 0 | 0 | 0 | 0 | 0 | 0   | 0   |

# ● ビット1 - CMP: 比較一致割り込み要求フラグ(Compare Match Interrupt Flag)

このフラグは計数(RTC.CNT)レジスタ値が比較(RTC.CMP)レジスタ値と一致した時に設定(1)されます。

このビットへの'1'書き込みがこのフラグを解除(0)します。

#### ● ビット0 - OVF: 溢れ割り込み要求フラグ (Overflow Interrupt Flag)

このフラグは計数(RTC.CNT)レジスタ値が定期(RTC.PER)レジスタ値と一致して0に丸められる時に設定(1)されます。

このビットへの'1'書き込みがこのフラグを解除(0)します。

## **23.12.5. TEMP - 一時レジスタ** (Temporary)

名称: TEMP 変位:+\$04 リセット: \$00 特質:-

一時レジスタはこの周辺機能の16ビット レジスタへの16ビット単一周期アクセスのためにCPUによって使われます。このレジスタはこの周辺機能の全ての16ビット レジ、スタに対して共通でソフトウェアによって読み書きすることができます。「AVR® CPU」章の「16ビット レジスタのアクセス」を参照してください。

| ピット    | 7       | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|---------|-----|-----|-----|-----|-----|-----|-----|--|--|
|        | TEMP7~0 |     |     |     |     |     |     |     |  |  |
| アクセス種別 | 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 - TEMP7~0: 一時値 (Temporary)

16ビットレジスタでの読み書き操作用一時レジスタ

# 23.12.6. DBGCTRL - デバッグ制御 (Debug Control)

名称: DBGCTRL 変位:+\$05 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|--------|---|---|---|---|---|---|---|--------|
|        |   |   |   |   |   |   |   | DBGRUN |
| アクセス種別 | R | R | R | R | R | R | R | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0      |

## ● ビット0 - DBGRUN: デバッグ時走行 (Debug Run)

| 値  | 0                      | 1                        |
|----|------------------------|--------------------------|
| 説明 | RTCはデバッグ動作中断で停止し、事象を無視 | RTCはCPU停止中のデバッグ動作中断で走行継続 |

# 23.12.7. CLKSEL - クロック選択 (Clock Selection)

名称: CLKSEL 変位:+\$07 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0     |
|--------|---|---|---|---|---|---|------|-------|
|        |   |   |   |   |   |   | CLKS | EL1,0 |
| アクセス種別 | R | R | R | R | R | R | R/W  | R/W   |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0     |

# • ビット1,0 - CLKSEL1,0: クロック選択 (Clock Select)

これらのビット書き込みはRTCクロック(CLK\_RTC)用の供給元を選びます。

RTCをXOSC32KまたはXTAL32K1での外部クロックのどちらかで使うように構成設定すると、XOSC32Kは許可されることが必要で、クロック制御器のXOSC32K制御A(CLKCTRL.XOSC32KCTRLA)レジスタの供給元選択(SEL)ビットとスタンバイ時走行(RUNSTDBY)ビットはそれに応じて構成設定されなければなりません。

| 値  | 0 0          | 0 1          | 1 0                 | 11          |
|----|--------------|--------------|---------------------|-------------|
| 名称 | INT32K       | INT1K        | TOSC32K             | EXTCLK      |
| 説明 | OSCULP32Kからの | OSCULP32Kからの | XOSC32Kからの32.768kHz | EXTCLKピンからの |
|    | 32.768kHz    | 1.024kHz     | またはTOSC1からの外部クロック   | 外部クロック      |

## 23.12.8. CNT - 計数 (Count)

名称: CNT (CNTH, CNTL)

変位:+\$08 リセット:\$0000 特質:-

RTC.CNTHとRTC.CNTLのレジスタ対は16ビット値のRTC.CNTを表します。下位バイト[7~0](接尾辞L)は変位原点でアクセスできます。上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

| ピット    | 15      | 14  | 13  | 12  | 11  | 10  | 9   | 8   |  |  |  |  |
|--------|---------|-----|-----|-----|-----|-----|-----|-----|--|--|--|--|
|        | CNT15~8 |     |     |     |     |     |     |     |  |  |  |  |
| アクセス種別 | 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   |  |  |  |  |
|        |         |     |     | CNT | 7~0 |     |     |     |  |  |  |  |
| アクセス種別 | R/W     | R/W | R/W | R/W | R/W | R/W | R/W | R/W |  |  |  |  |
| リセット値  | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 0   |  |  |  |  |
|        |         |     |     |     |     |     |     |     |  |  |  |  |

## ● ビット15~8 - CNT15~8: 計数値上位バイト (Counter high byte)

これらのビットは16ビット計数レジスタの上位バイトを保持します。

● ビット7~0 - CNT7~0: 計数値下位バイト (Counter low byte)

これらのビットは16ビット計数レジスタの下位バイトを保持します。



重要: RTCクロックと主クロック領域間同期のため、レジスタ更新からそれが効果を持つまでに2 RTCクロック周期の遅れがあります。 応用ソフトウュアはこのレジスタを書く前に状態(RTC.STATUS)レジスタの計数器同期多忙(CNTBUSY)フラグが解除(0)されているのを確認しなければなりません。

## 23.12.9. PER - 定期 (Period)

名称: PER (PERH, PERL)

変位:+\$0A リセット:\$FFFF 特質:-

RTC.PERHとRTC.PERLのレジスタ対は16ビット値のRTC.PERを表します。下位バイト[7~0](接尾辞L)は変位原点でアクセスできます。上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

| ピット _   | 15  | 14  | 13  | 12  | 11        | 10  | 9   | 8   |
|---------|-----|-----|-----|-----|-----------|-----|-----|-----|
|         |     |     |     | PER | 15~8      |     |     |     |
| アクセス種別  | R/W | R/W | R/W | R/W | R/W       | R/W | R/W | R/W |
| リセット値   | 1   | 1   | 1   | 1   | 1         | 1   | 1   | 1   |
| ピット     | 7   | 6   | 5   | 4   | 2         | 9   | 1   | 0   |
| C 9F    | - 1 | . 0 |     | PFR | 3<br>27~0 |     |     | . 0 |
| マカムっ毛口川 | D/W | D/W | D/W | •   |           | D/W | D/W | D/W |
| アクセス種別  | R/W | R/W | R/W | R/W | R/W       | R/W | R/W | R/W |
| リセット値   | 1   | 1   | 1   | 1   | l         | 1   | 1   | 1   |

● ビット15~8 - PER15~8: 定期値上位バイト (Periodic high byte)

これらのビットは16ビット定期レジスタの上位バイトを保持します。

● ビット7~0 - PER7~0: 定期値下位バイト (Periodic low byte)

これらのビットは16ビット定期レジスタの下位バイトを保持します。



重要: RTCクロックと主クロック領域間同期のため、レジスタ更新からそれが効果を持つまでに2 RTCクロック周期の遅れがあります。 応用ソフトウュアはこのレジスタを書く前に状態(RTC.STATUS)レジスタの定期同期多忙(PERBUSY)フラグが解除(0)されているのを確認しなければなりません。

# **23.12.10**. **CMP** - 比較 (Compare)

名称: CMP (CMPH, CMPL)

変位:+\$0C リセット:\$0000 特質:-

RTC.CMPHとRTC.CMPLのレジスタ対は16ビット値のRTC.CMPを表します。下位バイト[7~0](接尾辞L)は変位原点でアクセスできます。 上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

| ヒ゛ット   | 15      | 14  | 13  | 12  | 11   | 10  | 9   | 8   |  |  |  |  |
|--------|---------|-----|-----|-----|------|-----|-----|-----|--|--|--|--|
|        | CMP15~8 |     |     |     |      |     |     |     |  |  |  |  |
| アクセス種別 | 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   |  |  |  |  |
|        |         |     |     | CMF | P7∼0 |     |     |     |  |  |  |  |
| アクセス種別 | R/W     | R/W | R/W | R/W | R/W  | R/W | R/W | R/W |  |  |  |  |
| リセット値  | 0       | 0   | 0   | 0   | 0    | 0   | 0   | 0   |  |  |  |  |
|        |         |     |     |     |      |     |     |     |  |  |  |  |

● ビット15~8 - CMP15~8: 比較値上位バイト (Compare high byte)

これらのビットは16ビット比較レジスタの上位バイトを保持します。

● ビット7~0 - CMP7~0: 比較値下位バイト (Compare low byte)

これらのビットは16ビット比較レジスタの下位バイトを保持します。



重要: RTCクロックと主クロック領域間同期のため、レジスタ更新からそれが効果を持つまでに2 RTCクロック周期の遅れがあります。 応用ソフトウェアはこのレジスタを書く前に状態(RTC.STATUS)レジスタの比較同期多忙(CMPBUSY)フラグが解除(0)されているのを確認しなければなりません。

# 23.12.11. PITCTRLA - 周期割り込み計時器制御A (Peiodic Interrupt Timer Control A)

名称:;PITCTRLA 変位:+\$10 リセット: \$00 特質:-

| ピット    | 7 | 6   | 5    | 4     | 3   | 2 | 1 | 0     |
|--------|---|-----|------|-------|-----|---|---|-------|
|        |   |     | PERI | OD3~0 |     |   |   | PITEN |
| アクセス種別 | R | R/W | R/W  | R/W   | R/W | R | R | R/W   |
| リセット値  | 0 | 0   | 0    | 0     | 0   | 0 | 0 | 0     |

## ビット6~3 - PERIOD3~0: 周期 (Period)

このビット領域は各割り込み間のRTCクロック周期数を選びます。

| 値  | 0 0 0 0 | 0 0 0 1 | 0 0 1 0 | 0 0 1 1 | 0 1 0 0 | 0 1 0 1  | 0 1 1 0  | 0 1 1 1 |
|----|---------|---------|---------|---------|---------|----------|----------|---------|
| 名称 | OFF     | CYC4    | CYC8    | CYC16   | CYC32   | CYC64    | CYC128   | CYC256  |
| 説明 | 割り込みなし  | 4周期     | 8周期     | 16周期    | 32周期    | 64周期     | 128周期    | 256周期   |
| 値  | 1000    | 1001    | 1010    | 1011    | 1100    | 1 1 0 1  | 1110     | 1111    |
| 名称 | CYC512  | CYC1024 | CYC2048 | DIV4096 | CYC8192 | CYC16384 | CYC32768 | _       |
| 説明 | 512周期   | 1024周期  | 2048周期  | 4096周期  | 8192周期  | 16384周期  | 32768周期  | (予約)    |

# ● ビット0 - PITEN: 周期割り込み計時器許可 (Periodic Interrupt Timer Enable)

| 値  | 0           | 1           |
|----|-------------|-------------|
| 説明 | 周期割り込み計時器禁止 | 周期割り込み計時器許可 |

# **3**

重要: RTCクロックと主クロック領域間同期のため、レジスタ更新からそれが効果を持つまでに2 RTCクロック周期の遅れがあります。 応用ソフトウュアはこのレジスタを書く前にPIT状態(RTC.PITSTATUS)レジスタのPIT制御A同期多忙(CTRLBUSY)フラグが解除 (0)されているのを確認しなければなりません。

# 23.12.12. PITSTATUS - 周期割り込み計時器状態 (Periodic Interrupt Timer Status)

名称: PITSTATUS

変位 : +\$11 リセット : \$00 特質 : -

| <u> </u> | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |
|----------|---|---|---|---|---|---|---|----------|
|          |   |   |   |   |   |   |   | CTRLBUSY |
| アクセス種別   | R | R | R | R | R | R | R | R/W      |
| リセット値    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0        |

## ● ビット0 - CTRLBUSY: PIT制御A同期多忙 (PITCTRLA Synchronization Busy)

このビットはRTCがRTCクロック領域で周期割り込み計時器制御A(RTC.PITCTRLA)レジスタを同期中多忙の時に'1'です。

## 23.12.13. PITINTCTRL - PIT割り込み制御 (PIT Interrupt Control)

名称: PITINTCTRL

変位:+\$12 リセット:\$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|--------|---|---|---|---|---|---|---|-----|
|        |   |   |   |   |   |   |   | PI  |
| アクセス種別 | R | R | R | R | R | R | R | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0   |

## ● ビット0 - PI: 周期割り込み許可 (Periodic Interrupt)

| 値  | 0        | 1        |
|----|----------|----------|
| 説明 | 周期割り込み禁止 | 周期割り込み許可 |

# 23.12.14. PITINTFLAGS - PIT割り込み要求フラク (PIT Interrupt Flag)

名称: PITINTFLAGS

変位:+\$13 リセット:\$00 特質:-

| ヒ"ット   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|--------|---|---|---|---|---|---|---|-----|
|        |   |   |   |   |   |   |   | PI  |
| アクセス種別 | R | R | R | R | R | R | R | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0   |

# ● ビット0 - PI: 周期割り込み要求フラグ(Periodic Interrupt Flag)

このフラグは周期割り込みが発行される時に設定(1)されます。

'1'書き込みがこのフラグを解除(0)します。

# 23.12.15. PITDBGCTRL - 周期割り込み計時器デブック 制御 (Periodic Interrupt Timer Debug Control)

名称:PITDBGCTRL

変位:+\$15 リセット:\$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|--------|---|---|---|---|---|---|---|--------|
|        |   |   |   |   |   |   |   | DBGRUN |
| アクセス種別 | R | R | R | R | R | R | R | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0      |

# ● ビット0 - DBGRUN:デバッグ時走行(Debug Run)

| Γ | 値  | 0                                      | 1                     |
|---|----|----------------------------------------|-----------------------|
| Γ | 説明 | デ゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙゙ | CPU停止時のデバッグ動作中断で走行を継続 |

# 24. USART - 万能同期/非同期送受信器

## 24.1. 特徴

- 全二重操作
- 半二重操作
  - 単線動作
  - RS-485動作
- ・ 非同期と同期の操作
- ・5,6,7,8,9のデータ ビットと1または2の停止ビットを持つ直列フレーム支援
- 分数ボーレート発生器
  - どの周辺機能クロック周波数からも望むボーレートを生成可
  - 外部発振器不要
- ・組み込みの誤り検出と修正の仕組み
  - 奇数/偶数パリティ生成器とパリティ検査
  - 緩衝部オーバランとフレーム異常検出
  - 不正開始ビット検出とデジタル低域通過濾波器を含む雑音濾波
- ・以下の独立した割り込み
  - 送信完了
  - 送信データレジスタ空
  - 受信完了
- · 主装置SPI動作
- ・複数プロセッサ通信動作
- ・フレーム開始検出
- ・IrDA®適合パルス変調/復調用赤外線通信(IRCOM)単位部
- ·LIN従装置支援

## 24.2. 概要

万能同期/非同期直列送受信器(USART:Universal Synchronous and Asynchronuos serial Receiver and Transmitter)は高速で柔軟な直列通信周辺機能です。USARTは複数の形式の応用と通信装置に対応することができるいくつかの異なる動作形態を支援します。例えば、単線半二重動作は少ピン数応用が望まれる時に有用です。通信はフレームに基づき、フレーム形式は広範囲の規格を支援するように直すことができます。

USARTは両方向で緩衝され、フレーム間でのどんな遅延もなしに継続するデータ転送を許します。受信と送信の完了に対する独立した割り込みは完全な割り込み駆動通信を許します。

送信部は2段の書き込み緩衝部、移動レジスタ、それと各種フレーム形式用の制御論理回路から成ります。受信部は2段の受信緩衝部と移動レジスタから成ります。受信したデータの状態情報は異常検査に対して利用可能です。データとクロックの再生部は非同期データ受信中の頑強な同期と雑音濾波を保証します。

# 24.2.1. 構成図



# 24.2.2. 信号説明

| 信号   | 形式  | 説明              |
|------|-----|-----------------|
| XCK  | 入出力 | 同期動作用クロック       |
| XDIR | 出力  | RS485用送信許可      |
| TxD  | 入出力 | 送信線(と単線動作での受信線) |
| RxD  | 入力  | 受信線             |

# 24.3. 機能的な説明

## 24.3.1. 初期化

#### 全二重動作:

- 1. ボーレート(USARTn.BAUD)を設定してください。
- 2. フレーム構成と動作形態(USARTn.CTRLC)を設定してください。
- 3. TxDt°ンを出力として構成設定してください。
- 4. 送信部と受信部を許可してください(USARTn.CTRLB)。
- 注:・割り込み駆動USART操作について、初期化の間は全体割り込みが禁止されなければなりません。
  - ・ ボーレートまたはフレーム構成の変更を伴う再初期化を行う前に、そのレジスタが変更される間に進行中の送信がないことを確実にしてください。

#### 単線半二重動作:

- 1. 内部的にTxDをUSART受信部に接続してください(制御A(USARTn.CTRLA)レジスタの折り返し動作許可(LBME)ビット)。
- 2. RxD/TxDピン用の内部プルアップを許可してください(ピンn制御(PORTx.PINnCTRL)レジスタのプルアップ許可(PULLUPEN)ビット)。
- 3. オープン トレイン動作を許可してください(制御B(USARTn.CTRLB)レジンスタのオープン トレイン動作許可(ODME)ビット)。
- 4. ボーレート(USARTn.BAUD)を設定してください。
- 5. フレーム構成と動作形態(USARTn.CTRLC)を設定してください。
- 6. 送信部と受信部を許可してください(USARTn.CTRLB)。
- 注:・オープントレイン動作が許可されると、TxDピンはハードウェアによって自動的に出力に設定されます。
  - ・割り込み駆動USART操作について、初期化の間は全体割り込みが禁止されなければなりません。
  - ・ ボーレートまたはフレーム構成の変更を伴う再初期化を行う前に、そのレジスタが変更される間に進行中の送信がないことを確実にしてください。

#### 24.3.2. 動作

#### 24.3.2.1. フレーム形式

USARTデータ転送はフレームに基づきます。フレームは開始ビットで始まり、データビットの1文字が後続します。許可されたなら、データビット後で最初の停止ビットの前にパリティビットが挿入されます。フレームの停止ビット後、直ちに次のフレームを後続するか、または通信線をアイバル(High)状態に戻すかのどちらかにすることができます。USARTは有効なフレーム形式として以下の組み合わせ全てを受け入れます。

- ・1つの開始ビット
- 5, 6, 7, 8, 9 ビット データ
- ・奇数または偶数パリティビット、またはなし
- ・1つまたは2つの停止ビット

下図は可能なフレーム形式の組み合わせを図解します。[]付きビットは任意選択です。



#### 24.3.2.2. クロック生成

データ ビットの移動と採取に使われるクロックは内部的に分数ボーレート発生器、または外部的に転送クロック(XCK)ピンから生成されます。



#### 24.3.2.2.1. 分数ボーレート発生器

USARTがクロック元としてXCK入力を使わない動作ではクロックを生成するのに分数ボーレート生成器が使われます。ボーレートは秒毎のビット数(bps)の言葉で与えられ、ボーレート(USARTn.BAUD)レジスタを書くことによって構成設定されます。ボーレート(fBAUD)は周辺機能クロック (fCLK PER)をBAUDレジスタによって決められる分割係数で分割することによって生成されます。

分数ボーレート発生器はf<sub>BAUD</sub>で割り切れない場合に対応するハートウェアが特徴です。通常、この状況は丸め誤差をもたらします。分数ボーレート発生器は表24-1.の式で実行されるように、6ビット左移動した望む分割係数を含むBAUDレシ、スタを期待します。そして下位6 ビットは望む除数の小数部を保持します。BAUDレシ、スタの小数部は望むボーレートにより近い近似を達成するため動的にf<sub>BAUD</sub>を調節するのに使われます。

ボーレートをfclk\_perよりも高くすることができないため、BAUDレシブスタの整数部は最低1であることが必要です。結果は6ビット左移動されるため、対応するBAUDレジブスタの最小値は64です。有効な範囲は64~65535です。

同期動作では、BAUDレジスタの10ビット整数部(BAUD15~6)だけがボーレートを決め、従って、小数部(BAUD5~0)は0を書かれなければなりません。

下表はボーレートをBAUDレジスタ用の入力値に変換するための式を一覧にします。式は分数解釈を考慮に入れているので、これらの式で計算されたBAUD値はどんな追加の尺度調整もなしに直接USARTn.BAUDに書くことができます。

## 表24-1. ボーレート レジスタ設定計算用の式

| 動作形態  | 条件                                                                        | <b>ボーレート</b> (ビット/秒:bps)                                                 | USARTn.BAUDレジスタ値計算                                                      |  |
|-------|---------------------------------------------------------------------------|--------------------------------------------------------------------------|-------------------------------------------------------------------------|--|
| 非同期   | $f_{\text{BAUD}} \leq \frac{f_{\text{CLK\_PER}}}{S}$ \ USARTn.BAUD\geq 64 | $f_{\text{BAUD}} = \frac{64 \times f_{\text{CLK\_PER}}}{S \times BAUD}$  | $BAUD = \frac{64 \times f_{\text{CLK\_PER}}}{S \times f_{\text{BAUD}}}$ |  |
| 同期主装置 | $f_{\rm BAUD} < \frac{f_{\rm CLK\_PER}}{S}$ , USARTn.BAUD $\geq$ 64       | $f_{\text{BAUD}} = \frac{f_{\text{CLK\_PER}}}{S \times BAUD[15 \sim 6]}$ | $BAUD[15\sim 6] = \frac{f_{\text{CLK\_PER}}}{S \times f_{\text{BAUD}}}$ |  |

Sはビット当たりの採取数です。

・非同期標準動作: S=16・非同期倍速動作: S=8・同期動作: S=2

## 24.3.2.3. データ送信

USART送信部は周期的に送信線をLowに駆動することによってデータを送ります。データ送信は送るデータを送信データ(USARTn.TXD ATALとUSARTn.TXDATAH)レジスタに設定することによって始められます。送信データレジスタのデータは送信緩衝部が一旦空になるとそれに移され、移動レジスタが一旦空になるとそれに進み、新しいフレームを送る準備が整います。移動レジスタがデータを設定された後、データフレームが送信されます。

移動レジスタのフレーム全体が移動出力されてしまい、送信緩衝部に存在する新しいデータがないと、状態(USARTn.STATUS)レジスタの送信完了割り込み要求フラグ(TXCIF)ビットが設定(1)され、それが許可されていれば割り込みが生成されます。

TXDATAはこのレシ、スタが空で新しいデータの準備が整っていることを示すUSARTn.STATUSレシ、スタのデータレシ、スタ空割り込み要求フラケ(DREIF)ビットが設定(1)される時にだけ書くことができます。

8ビットよりも少ないフレームの使用時、TXDATAに書かれる上位側ビットは無視されます。9ビット文字(データ)が使われる場合、USASRTn.T XDATAHレジスタのDATA8ビットはUSARTn.TXDATALレジスタのDATA7~0ビットに先立って書かれなければなりません。

#### 24.3.2.3.1. 送信部禁止

送信部を禁止すると、その操作は進行中と保留中の送信が完了される(即ち、送信移動レシ、スタと送信緩衝レシ、スタが送信されるべき データを含まない時)まで有効になりません。送信部が禁止されると、もはやTxDピンを指定変更せず、PORT単位部がピン制御を取り戻します。ピンはそれの直前の設定に関わらず、ハードウェアによって自動的に入力として構成設定されます。ピンは今やUSARTからのポート指定変更なしに標準入出力ピンとして使うことができます。

## 24.3.2.4. データ受信

USART受信部は検出して受信したデータを解釈するために受信線を採取します。従って、ピンの方向は方向(PORTx.DIR)レジスタの対応するビットに'0'を書くことによって入力として構成設定されなければなりません。

受信部は有効な開始ビットが検出されと、データを受け入れます。開始ビットに後続する各ビットはボーレートまたはXCKクロックで採取され、フレームの最初の停止ビットが受信されるまで受信移動レジスタに移されます。第2停止ビットは受信部によって無視されます。最初の停止ビットが受信され、完全な直列フレームが受信移動レジスタに存在すると、移動レジスタの内容が受信緩衝部に移されます。状態(USARTn. STATUS)レジスタの受信完了割り込み要求フラグ(RXCIF)が設定(1)され、許可されていれば割り込みが生成されます。

RXDATAレシ、スタはRXCIFが設定(1)される時に応用ソフトウェアによって読むことができる受信緩衝部の一部です。8ビットよりも少ないフレームの使用時、未使用上位側ビットは'0'として読みます。9ビット文字(データ)が使われる場合、USASRTn.RXDATAHレシ、スタのDATA8ビットはUSARTn.RXDATALレシ、スタのDATA7~0に先立って読まれなければなりません。

#### 24.3.2.4.1. 受信異常フラグ

USART受信部は送信化けを暴く異常検出機構が特徴です。これらの機構は以下を含みます。

- ・フレーム異常検出 受信したフレームが有効かどうかを管理します。
- ・緩衝部溢れ検出 受信緩衝部が満杯で新しいデータによって上書きされたためのデータ損失を示します。
- ・ パリティ誤り検出 到着フレームのパリティを計算してパリティ ビットと比べることによって到着フレームの有効性を調べます。

各異常検出機構は受信データ上位バイト(USARTn.RXDATAH)レジスタで読むことができる各々1つの異常フラグを制御します。

- フレーム異常(FERR)
- ・緩衝部溢れ(BUFOVF)
- パリティ誤り(PERR)

異常フラグはそれらが対応するフレームと共に受信緩衝部に置かれます。RXDATALレジスタ読み込みがRX緩衝部のRXDATAハイト移動を起動するため、異常フラグを含むRXDATAHレジスタはRXDATALレジスタに先立って読まれなければなりません。

注:制御C(USARTn.CTRLC)レシ`スタの文字ビット数(CHSIZE)ビット領域が9ビット下位バイト先行(9BITL)に設定される場合、RXDATALレジ、スタに代わってRXDATAHレシ、スタがRXDATAバイト移動を起動します。その場合、RXDATALレジ、スタがRXDATAHレジ、スタに先立って読まれなければなりません。

#### 24.3.2.4.2. 受信部禁止

受信部を禁止すると、その操作は即時です。受信緩衝部が破棄され、進行中の受信からのデータは失われます。

#### 24.3.2.4.3. 受信緩衝部破棄

通常動作の間に受信緩衝部が破棄されなければならない場合、USARTn.RXDATAHレジスタの受信完了割り込み要求フラケ(RXCIF)が解除(0)されるまでDATA位置(USARTn.RXDATAHとUSARTn.RXDATALのレジスタ)を繰り返し読んでください。

## 24.3.3. 通信動作形態

USARTは複数の異なる通信規約を支援する柔軟な周辺機能です。利用可能な動作形態は、同期と非同期の通信の2つの群に分けることができます。

同期通信はXCKピンを通してクロック信号を残りの装置に供給する主権があるバス上の1つの主装置に依存します。全ての装置は追加の同期機構を必要とせず、送受信両方にこの共通クロック信号を使います。

装置は同期バスで主装置または従装置のどちらかで動くように構成設定することができます。

非同期通信は共通クロック信号を使いません。代わりに、通信する装置に於いて同じボーレートで構成設定されることに頼ります。やって来る伝送の受信時、受信する装置の周辺機能クロックでやって来る伝送を整列するのにハードウェア同期機構が使われます。

非同期に通信する時に4つの異なる動作形態が利用可能です。それらの動作の1つは標準速度の倍で伝送を受信することができ、通常の16の代わりにビット毎に8回だけ採取します。他の3つの動作形態は同期論理回路の変種を使い、全て標準速度で受信します。

## 24.3.3.1. 同期動作

## 24.3.3.1.1. クロック動作

XCKピン方向は転送クロックが入力(従装置動作)か、または出力(主装置動作)かを制御します。対応するポート ピン(PORTx.DIRレジスタの DIRn)方向は主装置動作用に出力または従装置動作用に入力に設定されなければなりません。下図で示されるように(RxDでの)デー タ入力はデータが(TxDで)送信される場所の逆端のXCKクロック端で採取されます。

I/Oピンはポート周辺機能のピンn制御(PORTx.PINnCTRL)レジスタの反転I/O許可(INVEN)ビットに'1'を書くことによって反転することができます。対応するXCKポートピンに反転I/O設定を使い、RxD採取とTxD送信に使われるXCKクロック端を選ぶことができます。反転I/Oが禁止(INVEN=0)される場合、XCKクロック上昇端が新しいデータビットの開始を表し、受信データはXCKクロック下降端で採取されます。反転I/Oが許可(INVEN=1)された場合、XCKクロック下降端が新しいデータビットの開始を表し、受信データはXCKクロック上昇端で採取されます。



#### 24.3.3.1.2. 外部クロック制限

USARTが同期従装置動作に構成設定されると、XCK信号は主装置によって外部的に提供されなければなりません。このクロックが外部的に提供されるため、BAUDレジ、スタ構成設定は転送速度に何の影響も持ちません。クロック再生成功には各上昇端と下降端に対して最低2回採取するクロック信号を必要とします。従って、同期動作形態での最大XCK速度(fslave SCK)は以下によって制限されます。

XCKクロックに細動(ジッタ)がある場合、またはHigh/Low区間のデューティ サイクルが50%/50%でない場合、XCKが各端に対して最低2回採取することを保証するために、それに応じて最大XCKクロック速度が低減されなければなりません。

 $f_{\text{Slave\_SCK}} < \frac{f_{\text{CLK\_PER}}}{4}$ 

#### 24.3.3.1.3. 主装置SPI動作でのUSART

USARTは複数の異なる通信インターフェースを持つ機能に構成設定されるかもしれず、それらの1つが主装置として機能することができる直列周辺インターフェース(SPI)です。SPIは主装置に1つ以上の従装置との通信を許す4線インターフェースです。

#### フレーム形式

主装置SPI動作でのUSARTに対する直列フレームは常に8つのデータ ビットを含みます。データ ビットは制御C(USARTn.CTRLC)レジスタの データ順(UDORD)ビットに書くことによってLSB先行またはMSB先行のどちらかで送信されるように構成設定することができます。 SPIは開始、停止、パリティのビットを使わず、故に伝送フレームはデータ ビットだけで成り得ます。

#### クロック生成

同期インターフェースでの主装置になる主装置SPI動作は従装置と共有されるインターフェース クロックを生成しなければなりません。このインタフェース クロックは「24.3.2.2.1. 分数ボーレート発生器」で記述される分数ボーレート発生器を使って生成されます。

各データ ビットは1つの完全なクロック周期に対してデータ線をHighまたはLowに引くことによって送信されます。受信部は下図で示されるように送信部保持期間の中央でビットを採取します。これはピンn制御(PORTx.PINnCTRL)レジスタの反転I/O許可(INVEN)ビットと制御C (USARTn.CTRLC)レジスタのUSARTクロック位相(UCPHA)ビットを使ってタイミングの仕組みをどう構成設定することができるかも示します。



右表は上図を更に説明します。

| - 3                             | 表24-2. INVENビットとUCPHAビットの機能 |   |   |        |        |  |  |  |  |  |  |  |
|---------------------------------|-----------------------------|---|---|--------|--------|--|--|--|--|--|--|--|
| SPI動作形態 INVEN UCPHA 先行端 (注) 後行端 |                             |   |   |        |        |  |  |  |  |  |  |  |
|                                 | 0                           | 0 | 0 | 上昇端、採取 | 下降端、送信 |  |  |  |  |  |  |  |
|                                 | 1                           | 0 | 1 | 上昇端、送信 | 下降端、採取 |  |  |  |  |  |  |  |
|                                 | 2                           | 1 | 0 | 下降端、採取 | 上昇端、送信 |  |  |  |  |  |  |  |
|                                 | 3                           | 1 | 1 | 下降端、送信 | 上昇端、採取 |  |  |  |  |  |  |  |

注: 先行端はクロック周期の最初のクロック端です。後行端はクロック周期の最後のクロック端です。

# データ送信

主装置SPI動作でのデータ送信は「動作」項で記述されるような全般的なUSART動作と機能的に同じです。送信部割り込み要求フラグと対応するUSART割り込みも同じです。更なる記述については「24.3.2.3. データ送信」をご覧ください。

## データ受信

主装置SPI動作でのデータ受信は「動作」項で記述されるような全般的なUSART動作と機能的に同じです。使われずに常に'0'として読む受信異常フラグを別にして、受信部割り込み要求フラグと対応するUSART割り込みも同じです。更なる記述については「24.3.2.4. データ受信」をご覧ください。

## 主装置SPI動作でのUSART対SPI

主装置SPI動作でのUSARTは独立型SPI周辺機能と完全な互換性があります。それらのデータフレームとタイミング構成設定は同じです。 けれども、以下のようないくつかのSPI特有特殊機能は主装置SPI動作でのUSARTで支援されません。

- ・書き込み衝突(WRCOL)フラグ保護
- 倍速動作
- 複数主装置支援

主装置SPI動作でのUSARTとSPIで使われるピンの比較が右表で示されます。

表24-3. 主装置SPI動作でのUSARTとSPIのピン比較

| l | JSART | SPI  | 注釈                      |
|---|-------|------|-------------------------|
|   | TxD   | MOSI | 主装置出力                   |
|   | RxD   | MISO | 主装置入力                   |
|   | XCK   | SCK  | 機能的に同一                  |
| 討 | 核当なし  | SS   | 主装置SPI動作でのUSARTで不支援 (注) |

注: 独立型SPI周辺機能について、このピンは複数主装置機能で、または専用従装置選択として使われます。複数主装置機能は主装置SPI動作でのUSARTで利用不可で、専用従装置選択ピンは利用不可です。

#### 24.3.3.2. 非同期動作

#### 24.3.3.2.1. クロック再生

非同期動作使用時に共通クロック信号がないため、通信する各装置は独立したクロック信号を生成します。これらのクロック信号は行われる通信に対して同じボーレートで動くように構成設定されなければなりません。従って、装置は同じ速度で動きますが、それらのタイミングはお互いの関係に於いて歪められています。これに対応するため、USARTはやって来る非同期直列フレームを内部的に生成したボー レート クロックと同期するハードウェア クロック再生部が特徴です。

下図は到着フレームの開始ビット用採取処理を図解します。これは標準と倍速の両動作(各々、'00'と'01'に構成設定された制御B(US ARTn.CTRLB)レシ、スタの受信部動作(RXMODE)ビット)に対するタイミングの仕組みを示します。標準動作用採取速度はボーレートの16倍、一方で倍速動作用採取速度はボーレートの8倍です(「24.3.3.2.4. 倍速動作」をご覧ください)。赤帯(訳注:原文は水平矢印)は最大同期誤差を示します。最大同期誤差が倍速動作でより大きいことに注意してください。



クロック再生論理回路がアイドル(High)状態から開始ビット(Low)への下降端を検出すると、開始ビット検出手順が始められます。上図に於いて、採取1は最初の'0'読み採取を記します。その後クロック再生論理回路は有効な開始ビットが受信されたかを判断するのに3つの連続採取(標準動作で採取8,9,10、倍速動作で採取4,5,6)を使います。2つまたは3つの採取が'0'を読む場合、開始ビットが受け入れられます。クロック再生部が同期化され、データ再生を始めることができます。2つ未満の採取が'0'を読む場合、この開始ビットは捨てられます。この処理は各開始ビット毎に繰り返されます。

## 24.3.3.2.2. データ再生

クロック再生と同様に、データ再生部は倍速動作または標準動作で動いているかに依存して、各々、ボーレートよりも8または16倍速い速度で採取します。下図は受信したフレームでのビット読み取り用採取処理を示します。



受信したビットの論理レベルを判断するのにクロック再生でのように中央3採取での多数決技法が使われます。この処理は完全なフレームが受信されるまで各ビットに対して繰り返されます。

データ再生部は最初の停止ビットだけを受け取る一方で、もっとある場合に残りを無視します。採取した停止ビットが'0'を読む場合、受信データ上位(USARTn.RXDADAH)レシ、スタのフレーム異常(FERR)フラケが設定(1)されます。下図は停止ビットの採取を示します。これは最も早く可能な次のフレームの始めも示します。



新しいフレームの開始ビットを示すHighからLowへの遷移は多数決に使ったビットの最後の直後に来得ます。標準速動作については最初のLowレベル採取、上図でAと記された点で有り得ます。倍速動作については最初のLowレベルが多数決採取後の最初の採取であるB点に遅らされなければなりません。C点は公称ボーレートでの停止ビットの全長(の終点)を記します。

#### 24.3.3.2.3. 許容誤差

内部的に生成したボーレートの速度と外部的に受信したデータ速度は理想的に同じであるべきですが、本来のクロック元誤差のため、これ は通常、その状況ではありません。USARTはこのような誤差を許容し、この許容の限度が時に動作範囲として知られるものを構成しま

以下の表は許容することができる最大受信部ボーレート誤差であるUSARTの動作範囲を一覧にします。標準速動作が倍速動作よりも より高いボーレート変化の許容誤差を持つことに注意してください。

表24-4. 標準速と倍速での受信部ホーレート推奨最大許容誤差

|    |   | 7                     | 標準速動作    | ₹ (RXMODE= <mark>00</mark> (NC | ORMAL))   | 倍速動作 (RXMODE= <mark>01</mark> (CLK2X)) |          |             |           |  |  |  |  |
|----|---|-----------------------|----------|--------------------------------|-----------|----------------------------------------|----------|-------------|-----------|--|--|--|--|
|    |   | R <sub>slow</sub> (%) | Rfast(%) | 総合許容誤差(%)                      | 推奨許容誤差(%) | R <sub>slow</sub> (%)                  | Rfast(%) | 総合許容誤差(%)   | 推奨許容誤差(%) |  |  |  |  |
| 5  | 5 | 93.20                 | 106.67   | -6.80∼+6.67                    | ±3.0      | 94.12                                  | 105.66   | -5.88~+5.66 | $\pm 2.5$ |  |  |  |  |
| 6  | 3 | 94.12                 | 105.79   | -5.88~+5.79                    | ±2.5      | 94.92                                  | 104.92   | -5.08~+4.92 | $\pm 2.0$ |  |  |  |  |
| 7  | 7 | 94.81                 | 105.11   | -5.19~+5.11                    | ±2.0      | 95.52                                  | 104.35   | -4.48~+4.35 | $\pm 1.5$ |  |  |  |  |
| 8  | 3 | 95.36                 | 104.58   | -4.54~+4.58                    | ±2.0      | 96.00                                  | 103.90   | -4.00~+3.90 | $\pm 1.5$ |  |  |  |  |
| 9  | ) | 95.81                 | 104.14   | -4.19~+4.14                    | ±1.5      | 96.39                                  | 103.53   | -3.61~+3.53 | ±1.5      |  |  |  |  |
| 10 | 0 | 96.17                 | 103.78   | −3.83∼+3.78                    | ±1.5      | 96.70                                  | 103.23   | -3.30~+3.23 | ±1.0      |  |  |  |  |

· Rslow: 受信部ボーレートに関連して受け入れすることができる最低到着データ速度の比率

· Rfast: 受信部ホーレートに関連して受け入れすることができる最高到着データ速度の比率

(訳注) 原書の表24-4.と表24-5.は表24-4.として纏めました。

最大受信部ボーレート誤差の推奨は受信側と送信側が最大総許容誤差を等しく分けるとの仮定の元で作られました。 以下の式は到着データ速度と内部受信部ボーレートの最大比率計算に使われます。

: 文字(データ)ビット数とパリティビットの合計(D=5~10) D S(D+1) $R_{\text{slow}} = \frac{S(D+1) + SF - 1}{S(D+1) + SF - 1}$ 

: ビット当たりの採取数。標準速動作はS=16、倍速動作はS=8

: 多数決に使う最初の採取番号。標準速動作はSF=8、倍速動作はSF=4 SM: 多数決に使う中心の採取番号。標準速動作はSM=9、倍速動作はSM5

S(D+2) $R_{\text{fast}} = \frac{1}{S(D+1) + S_{\text{M}}}$ Rslow: 受信側ボーレートに対して許容できる最低到着データ速度の比率 Rfast: 受信側ボーレートに対して許容できる最高到着データ速度の比率

24.3.3.2.4. 倍速動作

倍速動作はより低い周辺機能クロック周波数での非同期動作下でより高いボーレートを許します。この動作は制御B(USARTn.CTRLB)レ ジスタの受信部動作(RXMODE)ビットに'01'を書くことによって許可されます。

許可されると、与えられた非同期ボーレート設定に対するボーレートが倍にされます。これは「24.3.2.2.1. 分数ボーレート発生器」での式で示 されます。この動作では、受信部がデータ採取とクロック再生に対して(16から8に減らされた)半分の採取数を使います。これはもっと正 確なボーレート設定と周辺機能クロックを必要とします。より多くの詳細については「24.3.3.2.3. 許容誤差」をご覧ください。

#### 24.3.3.2.5. 自動ボーレート

自動ボーレート機能は通信装置からの入力に基づいてボーレート(USARTn.BAUD)レジスタの構成設定をUSARTにさせます。これは異なる ボーレートで通信する複数装置と自律的に通信することを装置に許します。USART周辺機能は標準自動ボーレート動作とLIN制限自動 ボーレート動作の2つの自動ボーレート動作が特徴です。

どちらの自動ホーレート動作も下図で見られるように自動ホーレートフレームを受け取らなければなりません。

中断領域は12以上の連続Low周期が採取される時に検出 され、これから同期領域を受信しようとすることをUSARTに 通知します。中断領域後、同期領域の開始ビットが検出され ると、周辺機能クロック速度で動く計数器が開始されます。計 数器はその後に同期領域の次の8Tbit間増やされます。全 8ビットが採取されると、計数器が停止されます。 結果の計数 器値が事実上の新しいBAUDレジスタ値です。



USART受信動作が(制御B(USARTn.CTRLB)レジスタの受信動作(RXMODE)ビット)でGENAUTOに設定されると、標準自動ボーレート動 作が許可されます。この動作では、どの長さ(即ち、12周期よりも短くても)中断領域の検出を許すために状態(USARTn.STATUS)レジ スタの中断待機(WFB)ビットを設定(1)することができます。これは現在のボーレートを知ることなく、任意の新しいボーレート設定を可能にし ます。測定された同期領域が有効なBAUD値(\$0064~\$FFFF)になるなら、BAUDレジスタが更新されます。

USART受信動作が(USARTn.CTRLBレシ`スタのRXMODEビットで)LINAUTO動作に設定されると、LIN形式に従います。 標準自動ボー レート動作でのWFB機能はLIN制限自動ボーレートと非互換です。これは有効な中断領域のために受信した信号が12周辺機能クロック周 期以上の間Lowでなければならないことを意味します。中断領域が検出されると、USARTは\$55である後続する同期領域文字を期待 します。受信した同期領域文字が\$55でない場合、矛盾同期領域異常フラグ(USARTn.STATUSレジスタのISFIFビット)が設定(1)され、 ボーレートは無変化です。

#### 24.3.3.2.6. 半二重動作

半二重は2つ以上の装置が互いに通信できますが、同時に1つだけである通信の形式です。USARTは以下の半二重動作で動くように構成設定することができます。

- 単線動作
- · RS-485動作

#### 単線動作

単線動作は制御A(USARTn.CTRLA)レジスタの折り返し動作許可(LBME)を設定(1)することによって許可されます。これはTxDピンを結合TxD/RxD線にするTxDピンとUSART受信部間の内部接続を許します。RxDピンはUSART受信部から切り離され、違う周辺機能によって制御されるかもしれません。

単線動作では複数装置が同時にTxD/RxD線を操作することができます。1つの装置がピンを論理Highレベル(VDD)に駆動し、別の装置がこの線をLow(GND)に引く場合、短絡が起きます。これに対応するため、USARTは送信部にピンを論理Highレベルに駆動させないようにするオープンドレイン動作(制御B(USARTn.CTRLB)レジスタのオープンドレイン動作許可(ODME)ビット)が特徴で、それにより、ピンをLowに引くことだけできるように制限します。内部プルアップ機能(ピンn制御(PORTx.PINnCTRL)レジスタのプルアップ許可(PULLUPEN)ビット)とこの機能の組み合わせは線にプルアップ抵抗を通してHighを保持させ、どの装置にもLowへ引くことを許します。線がLowに引かれると、VDDからGNDへの電流はプルアップ抵抗によって制限されます。TxDピンはオープンドレイン動作が許可される時にハードウェアによって自動的に出力に設定されます。

USARTがTxD/RxDt°ンへ送信している時は自身の送信も受け取ります。これは受信したデータが送信したデータと同じであるかを調べることによって重なった送信に対する検査に使うことができます。

#### RS-485動作

RS-485はUSART周辺機能によって支援される通信規格です。これは通信回路の構成を定義する物理的インターフェースです。データは通信を雑音に対して頑強にする差動信号を使って伝送されます。RS-485は制御A(USARTn.CTRLA)レジスタのRS-485動作(RS485) ビット領域に書くことによって許可されます。

RS-485動作は単一USART送信を対応する差動対信号に変換する外部線駆動部デバイスを支援します。RS4850ビットの'1'書き込みは線駆動部デバイスに対して送信または受信を許可するのに使うことができるXDIRピンの自動制御を許可します。USARTは送信している間、自動的にXDIRピンをHighに駆動し、送信完了時にLowへ引きます。このような回路の例が下図で示されます。

XDIRピンは外部線駆動部を許可するための若干の保護時間を許すため、データが移動出力される1ボーレート クロック周期前にHighになります。XDIRピンは停止ビットを含む完全なフレーム間Highに留まります。





RS4851ビットの'1'書き込みは送信開始1クロック周期前に出力に設定して送信完了時にそれを入力に設定し戻すことを自動的にTxDピンに設定するRS-485動作を許可します。

RS-485動作は単線動作と互換性があります。単線動作はTxDピンを結合したTx D/RxD線にするTxDピンとUSART受信部間の内部接続を許します。RxDピンはU SART受信部から切り離され、違う周辺機能によって制御されるかもしれません。このような回路の例が右図で示されます。



#### 24.3.3.2.7. IRCOM動作形態

USART周辺機能は115.2kbpsまでのボーレートに適合するIr DA® 1.4である赤外線通信動作(IRCOM:Infrared Commu nication mode)に構成設定することができます。許可されると、IRCOM動作はUSARTに対して赤外線パルスの符号化/復号を許します。

USARTは制御C(USARTn.CTRLC)レジスタの通信動作(CMODE)ビットに'10'を書くことによってIRCOM動作に設定されます。TxD/RxDピン上のデータは送受信される赤外パルスの反転値です。これはIRCOM受信部に対する入力とし



て事象システムからの事象チャネルを選ぶことも可能です。これは入出力ピンまたは対応するRxDピン以外の供給元からの入力の受信を IRCOMに許します。これはUSARTピンからのRxD入力を禁止します。

送信については以下のような3つのパルス変調方式が利用可能です。

- ・ 3/16ボーレート周期
- ・周辺機能クロック周波数に基いた設定可能な固定パルス時間
- ・パルス変調禁止

受信については論理'0'として復号されるべきパルスに対して定められた選択可能な最小Highレベル パルス幅が使われます。より短い パルスは破棄され、そのビットはパルスが全く受信されなかった場合に論理'1'に復号されます。

IRCOM動作が許可されると、USARTに対して倍速動作を使うことはできません。

## 24.3.4. 付加機能

#### 24.3.4.1. ハ<sup>°</sup>リティ

パリティ ビットはデータ フレームの有効性検査のため、USARTによって使うことができます。パリティ ビットは送信に於いて'1'の値を持つビット数に基づいて送信部によって設定され、受信に於いて受信部によって管理されます。パリティ ビットが送信フレームと矛盾する場合、受信部はデータ フレームが不正にされたと推測することができます。

偶数または奇数のパリティは制御C(USARTn.CTRLC)レシ、スタのパリティ動作(PMODE)ビットを書くことによって誤り検査用に選ぶことができます。偶数パリティが選ばれた場合、パリティ ビットは、1'値を持つデータ ビット数が奇数の場合に、1'に設定されます(、1'値を持つ総ビット数を偶数にします)。奇数パリティが選ばれた場合、パリティ ビットは、1'値を持つデータ ビット数が偶数の場合に、1'を設定します(、1'を持つ総ビット数を奇数にします)。

許可されると、パリティ検査部は到着フレーム内のデータ ビットのパリティを計算し、その結果を対応するフレームのパリティ ビットと比べます。パリティ誤りが検出された場合、受信データ上位バイト(USARTn.RXDATAH)レジスタのパリティ誤り(PERR)フラグが設定(1)されます。

LIN制限自動ボーレート動作が許可(制御B(USARTn.CTRLB)レシブスタの受信動作(RXMODE)ビット='11')された場合、パリティ検査は保護された識別子領域でだけ実行されます。下の式の1つが真でなければパリティ誤りが検出され、それがパリティ誤り(PERR)フラケを設定(1)します。

P0 = ID0 XOR ID1 XOR ID2 XOR ID4 P1 = NOT ( ID1 XOR ID3 XOR ID4 XOR ID5 )



#### 24.3.4.2. フレーム開始検出

フレーム開始検出機能はデータ受信でスタンハイ休止動作から起き上がることをUSARTに許します。

RxDピンでHighからLowへの遷移が検出されると、発振器が給電されてUART周辺機能クロックが許可されます。始動後、ボーレートが発振器始動時間に対して充分遅ければ、データ フレームの残りを受信することができます。発振器の始動時間は供給電圧と温度で変わります。発振器始動時間特性の詳細については「電気的特性」章を参照してください。

誤った開始ビットが検出された場合で別の供給元が起動してしまっていなければ、スタンバイ休止動作に戻ります。

フレーム開始検出は非同期動作でだけ動きます。これは制御B(USARTn.CTRLB)レジスタのフレーム開始検出許可(SFDEN)ビットを(1に)書くことによって許可されます。デ`バイスがスタンバイ休止動作の間に開始ビットが検出された場合、UART開始割り込み要求フラグ(RXSIF) ビットが設定(1)されます。

UART受信完了フラク (RXCIF) ビットとUART開始割り込み要求フラク (RXSIF) ビットは同じ割り込み線を共用しますが、各々は専用の割り込み設定を持ちます。下表は割り込み設定に依存するUSARTフレーム開始検出動作を示します。

| 表24-6. し | 表24-6. USARTフレーム開始検出動作 |           |                                                              |  |  |  |  |  |  |
|----------|------------------------|-----------|--------------------------------------------------------------|--|--|--|--|--|--|
| SFDEN    | RXSIF割り込み              | RXCIF割り込み | 注釈                                                           |  |  |  |  |  |  |
| 0        | X                      | X         | 標準動作                                                         |  |  |  |  |  |  |
| 1        | 禁止                     | 禁止        | 発振器はフレーム受信中にだけ給電されます。割り込みが禁止されて緩衝部溢れが無視された場合、全ての到着データが失われます。 |  |  |  |  |  |  |
| 1        | 禁止                     | 許可        | システム/全てのクロックが受信完了割り込みで起き上がり(起動し)ます。                          |  |  |  |  |  |  |
| 1        | 許可                     | X         | システム/全てのクロックが開始ビット検出時に起き上がり(起動し)ます。                          |  |  |  |  |  |  |

注: SLEEP命令は進行中の通信がある場合に発振器を停止しません。

#### 24.3.4.3. 複数プロセッサ通信

複数プロセッサ通信動作(MPCM)は同じ直列バス経由で複数のマイクロ コントローラ通信を持つシステムで、受信部によって処理されなければならない到着フレーム数を効果的に減らします。この動作は制御B(USARTn.CTRLB)レジスタの複数プロセッサ通信動作(MPCM)ビットに'1'を書くことによって許可されます。この動作ではフレームがアドレスかデータのどちらのフレーム形式かを示すのにフレーム内の専用ビットが使われます。

受信部が5~8データ ビットを含むフレームを受信するように構成設定されたなら、最初の停止ビットはフレーム形式を示すのに使われます。 受信部が9データ ビットのフレームに構成設定されたなら、フレーム形式を示すのに第9ビットが使われます。フレーム形式(最初の停止または第9)ビットが1゚の時にそのフレームはアドレスを含みます。フレーム形式ビットが1゚の時にそのフレームはデータ フレームです。5~8ビット文字(データ)フレームが使われる場合、最初の停止ビットがフレーム形式を示すのに使われるため、送信部は2停止ビット使用に設定されなければなりません。

特定の従装置MCUがアトレス指定されたなら、そのMCUは後続するデータフレームを通常のように受信し、一方他の従装置MCUは別のアトレスフレームが受信されるまでフレームを無視します。

#### 24.3.4.3.1. 複数プロセッサ通信動作の使い方

複数プロセッサ通信動作(MPCM)でデータを交換するのに次の手順が使われるべきです。

- 1. 全ての従装置MCUは複数プロセッサ通信動作です。
- 2. 主装置MCUはアドレス フレームを送り、全ての従装置がこのフレームを受け取って読みます。
- 3. 各従装置MCUは選択されたかを判定します。
- 4. アトンス指定されたMCUはMPCMを禁止して全てのデータフレームを受信します。他の従装置MCUはデータフレームを無視します。
- 5. アトンス指定されたMCUが最後のデータフレームを受信してしまうと、再びMPCMを許可して主装置からの新しいアトンスフレームを待たなければなりません。

その後、手順は2.からを繰り返します。

#### 24.3.5. 事象

USARTは下表で記述される事象を生成することができます。

#### 表24-7. USARTでの事象生成部

| 生      | 成部名 | 説明                            | 事象型 | 生成クロック領域 | 事象長     |  |
|--------|-----|-------------------------------|-----|----------|---------|--|
| 周辺機能   | 事象  | 高元·97                         | 尹豕至 | 土成が切りり限場 | 争多女     |  |
| USARTn | XCK | SPI主装置動作と同期USART主装置動作でのクロック信号 | パルス | CLK_PER  | 1 XCK周期 |  |

下表は事象使用部とその関連機能を記述します。

#### 表24-8. USARTでの事象使用部

| •      | 使用部名 | 説明              | <br>入力検出 | 同期/非同期 |  |
|--------|------|-----------------|----------|--------|--|
| 周辺機能   | 入力   | 高元 <i>9</i> 月   | 八刀换山     |        |  |
| USARTr | IREI | USARTn IrDA事象入力 | ハ゜ルス     | 同期     |  |

#### 24.3.6. 割り込み

# 表24-9. 利用可能な割り込みベクタと供給元

| 1224 3 | ・ 利用 印 配は 司り込の ハブス | - 庆帅儿                                                                                                                               |
|--------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 名称     | ベクタ説明              | 条件                                                                                                                                  |
| RXC    | 受信完了割り込み           | <ul> <li>・受信緩衝部に未読データ有 (RXCIE)</li> <li>・検出されたフレーム開始の受信 (RXSIE)</li> <li>・自動ホーレート異常/矛盾同期領域割り込み要求フラケ (ISFIF)設定(1) (ABEIE)</li> </ul> |
| DRE    | データレジスタ空割り込み       | 送信緩衝部が空/新しいデータを受け取る準備可 (DREIE)                                                                                                      |
| TXC    | 送信完了割り込み           | 送信移動レジスタのフレーム全体が出力され、送信緩衝部に新データ無し(TXCIE)                                                                                            |

割り込み条件が起こると、状態(USARTn.STATUS)レシブスタで対応する割り込み要求フラクブが設定(1)されます。

割り込み元は制御A(USARTn.CTRLA)レシブスタで対応する許可ビットを書くことによって許可または禁止にされます。

割り込み要求は対応する割り込み元が許可され、割り込み要求フラケが設定(1)される時に生成されます。割り込み要求は割り込み要求フラケが解除(0)されるまで活性に留まります。割り込み要求フラケを解除する方法の詳細についてはUSARTn.STATUSレジスタをご覧ください。

# 24.4. レジスタ要約

| 変位    | 略称       | ビット位置        | Ľット7  | じット6     | ヒ゛ット5 | ヒ゛ット4          | <b>ビット3</b> | ヒ゛ット2 | ヒ゛ット1     | ピット0   |  |
|-------|----------|--------------|-------|----------|-------|----------------|-------------|-------|-----------|--------|--|
| +\$00 | RXDATAL  | 7~0          |       |          |       | DATA7~0        |             |       |           |        |  |
| +\$01 | RXDATAH  | 7~0          | RXCIF | BUFOVF   |       |                |             | FERR  | PERR      | DATA8  |  |
| +\$02 | TXDATAL  | 7~0          |       |          |       | DAT.           | A7~0        |       |           |        |  |
| +\$03 | TXDATAH  | 7~0          |       |          |       |                |             |       |           | DATA8  |  |
| +\$04 | STATUS   | 7 <b>~</b> 0 | RXCIF | TXCIF    | DREIF | RXSIF          | ISFIF       |       | BDF       | WFB    |  |
| +\$05 | CTRLA    | 7 <b>~</b> 0 | RXCIE | TXCIE    | DREIE | RXSIE          | LBME        | ABEIE | RS48      | 351,0  |  |
| +\$06 | CTRLB    | 7~0          | RXEN  | TXEN     |       | SFDEN          | ODME        | RXMC  | DE1,0     | MPCM   |  |
| +\$07 | CTRLC    | 7 <b>∼</b> 0 | CMO   | CMODE1,0 |       | MODE1,0 SBMODE |             |       | CHSIZE2~0 |        |  |
| +\$07 | CIRLO    | 7:00         | CIVIO | DE1,0    |       |                |             | UDORD | UCPHA     |        |  |
| +\$08 | BAUD     | 7 <b>~</b> 0 |       |          |       | BAUD7~0        |             |       |           |        |  |
| +\$09 | BAUD     | 15~8         |       |          |       | BAUI           | )<br>15~8   |       |           |        |  |
| +\$0A | CTRLD    | 7 <b>~</b> 0 | ABV   | V1,0     |       |                |             |       |           |        |  |
| +\$0B | DBGCTRL  | 7 <b>~</b> 0 |       |          |       |                |             |       |           | DBGRUN |  |
| +\$0C | EVCTRL   | 7 <b>~</b> 0 |       |          |       |                |             |       |           | IREI   |  |
| +\$0D | TXPLCTRL | 7~0          |       |          |       | TXP            | L7∼0        |       |           |        |  |
| +\$0E | RXPLCTRL | 7~0          |       |          |       | 1              | RXPL7~0     |       |           |        |  |

# 24.5. レジスタ説明

**24.5.1. RXDATAL - 受信データ下位バイ** (Rceiver Data Register Low Byte)

名称: RXDATAL 変位:+\$00 リセット: \$00 特質:-

USARTn.RXDATALレシ、スタ位置読み込みはRXDATAL、ットの下位側8じ、小の内容を返します。

受信緩衝部は2段の緩衝部から成ります。緩衝部とRXDATAの上位バイ内の対応するフラグは受信緩衝部がアクセスされる(読まれる)時に必ず状態を変更します。制御C(USARTn.CTRLC)レジスタの文字ビット数(CHSIZE)が9ビット下位バイト先行に設定された場合、正しいフラグを得るために、USARTn.RX DATAHレジスタの前にUSARTn.RXDATALレジスタを、そうでない場合は常にUSARTn.RXDATALレジスタの前にUSAR Tn.RXDATAHレジスタを読んでください。

| ピット _  | 7 | 6 | 5 | 4   | 3    | 2 | 1 | 0 |
|--------|---|---|---|-----|------|---|---|---|
|        |   |   |   | DAT | A7~0 |   | ' |   |
| アクセス種別 | R | R | R | R   | R    | R | R | R |
| リセット値  | 0 | 0 | 0 | 0   | 0    | 0 | 0 | 0 |

● ビット7~0 - DATA7~0: 受信データ (Receiver Data Register)

**24.5.2. RXDATAH - 受信データ上位バ** (Rceiver Data Register High Byte)

名称: RXDATAH 変位: +\$01 リセット: \$00 特質: -

USARTn.RXDATAHレジスタ位置読み込みは第9 RXDATAビットと状態ビットの内容を返します。

受信緩衝部は2段の緩衝部から成ります。緩衝部とRXDATAの上位バイ内の対応するフラグは受信緩衝部がアクセスされる(読まれる)時に必ず状態を変更します。制御C(USARTn.CTRLC)レジスタの文字ビット数(CHSIZE)が9ビット下位バイト先行に設定された場合、正しいフラグを得るために、USARTn.RX DATAHレジスタの前にUSARTn.RXDATALレジスタを、そうでない場合は常にUSARTn.RXDATALレジスタの前にUSARTn.RXDATAHレジスタを読んでください。

| ピット _  | 7     | 6      | 5 | 4 | 3 | 2    | 1    | 0     |
|--------|-------|--------|---|---|---|------|------|-------|
|        | RXCIF | BUFOVF |   |   |   | FERR | PERR | DATA8 |
| アクセス種別 | R/W   | R/W    | R | R | R | R/W  | R/W  | R/W   |
| リセット値  | 0     | 0      | 0 | 0 | 0 | 0    | 0    | 0     |

# ● ビット7 - RXCIF: 受信完了割り込み要求フラグ(Receive Complete Interrupt Flag)

このフラグは受信緩衝部内に未読データがある時に設定(1)され、受信緩衝部が空の(即ち、何の未読データも含まない)時に解除(0)されます。受信部が禁止されると、受信緩衝部は破棄され、その結果としてRXCIFが'0'になります。

## ● ビット6 - BUFOVF:緩衝部溢れフラグ(Buffer Overflow)

BUFOVFフラグは"受信緩衝部満杯"状態のためのデータ損失を示します。このフラグは緩衝部溢れ状態が検出される場合に設定(1)されます。緩衝部溢れは受信緩衝部が満杯(2文字)で、新しい文字が受信移動レジスタで待機中で、新しい開始ビットが検出される時に起きます。このフラグは受信緩衝部(USARTn.RXDATAL)が読まれるまで有効です。

このフラグは主装置SPI動作形態で使われません。

# ● ビット2 - FERR: フレーム異常フラク (Frame Error)

FERRフラウ は受信緩衝部に格納された次に読み込み可能なフレームの最初の停止ビットの状態を示します。このビットは受信した文字がフレーム異常を持つ場合、即ち、最初の停止ビットが'0'だった時に設定(1)され、受信したデータの停止ビットが'1'の時に解除(0)されます。このビットは受信緩衝部(USARTn.RXDATAL)が読まれるまで有効です。受信部は最初の停止ビットを除く全てを無視するので、FERRビットは制御C(USARTn.CTRLC)レジスタの停止ビット動作(SBMODE)ビットによって影響を及ぼされません。

このフラグは主装置SPI動作形態で使われません。

## ● ビット1 - PERR: パリティ誤りフラグ(Parity Error)

パリティ検査が許可され、受信緩衝部内の次の文字がパリティ誤りを持つ場合に、このフラグが設定(1)されます。パリティ検査が許可されていなければ、PERRビットは常に'0'として読みます。このビットは受信緩衝部(USARTn.RXDATAL)が読まれるまで有効です。パリティ計算の詳細については「24.3.4.1. パリティ」を参照してください。USARTがLINAUTO動作に設定される場合、このビットは保護された識別子領域のパリティ検査になり、USARTn.RXDATAHレジスタの第9ビット(DATA8)が'0'を読む時に有効です。

このフラグは主装置SPI動作形態で使われません。

#### ● ビット0 - DATA8: 受信データ ビット8 (Receiver Data Register)

USART受信部がLINAUTO動作に構成設定されると、このビットは受信データがLINフレームの応答空間内かを示します。受信データが保護された識別子領域なら、このビットは'0'として読みます。さもなければ、このビットは'1'として読みます。LINAUTO動作以外の受信部動作に対して、DATA8は第9データ ビットを持つ直列フレームで動く時に受信した文字の第9データ ビットを保持します。

#### **24.5.3. TXDATAL - 送信データ下位バイト** (Transmit Data Register Low Byte)

名称: TXDATAL 変位:+\$02 リセット: \$00 特質:-

送信データ緩衝(TXB)レシ、スタはUSARTn.DATALレシ、スタ位置に書かれたデータの行き先です。

5,6,7ビット文字に対する上側の未使用ビットは送信部によって無視され、受信部によって'0'に設定されます。

送信緩衝部は状態(USARTn.STATUS)レシ、スタのデータレシ、スタ空割り込み要求フラケ(DREIF)が設定(1)される時にだけ書くことができます。DREIFフラケが設定(1)されない時にDATAビットへ書かれたデータはUSART送信部によって無視されます。送信緩衝部にデータが書かれ、送信部が許可されると、送信部は移動レシ、スタが空の時にデータを送信移動レシ、スタ内に設定します。その後にデータはTxDピンで送信されます。

| ピット    | 7       | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |
|--------|---------|-----|-----|-----|-----|-----|-----|-----|--|
|        | DATA7~0 |     |     |     |     |     |     |     |  |
| アクセス種別 | 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 - DATA7~0: 送信データ (Transmit Data Register)

## **24.5.4. TXDATAH** - 送信データ上位バイト (Transmit Data Register High Byte)

名称: TXDATAH 変位: +\$03 リセット: \$00 特質:-

USARTn.TXDATAHレジスタは第9データ ビットを持つ直列フレームで動く時に送信されるべき文字の第9データ ビットを保持します。使われる時は、制御C(USARTn.CTRLC)レジスタの文字ビット数(CHSIZE)ビットが、USARTn.TXDATALレシ、スタが先に書かれるべきである9ビット下位バイト先行に設定される場合を除き、USARTn.DATALレシ、スタを書くのに先立ってこの(レシ、スタ)ビットが書かれなければなりません。このビットは主装置SPI動作形態で未使用です。

| アクセス種別 R R R R R R R R R/W       リセット値 0 0 0 0 0 0 0 0 | ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
|--------------------------------------------------------|--------|---|---|---|---|---|---|---|-------|
|                                                        |        |   |   |   |   |   |   |   | DATA8 |
| リセット値 0 0 0 0 0 0 0 0                                  | アクセス種別 | R | R | R | R | R | R | R | R/W   |
| 7 -7 · IE                                              | リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0     |

#### ● ビット7 - DATA8: 送信データ ビット8 (Transmit Data Register)

このビットは制御C(USARTn.CTRLC)レジスタの文字ビット数(CHSIZE)=9BITLまたは9BITHの時に使われます。

## **24.5.5**. **STATUS** - 状態 (USART Status Register)

名称: STATUS 変位:+\$04 リセット: \$20 特質:-

| ピット    | 7     | 6     | 5     | 4     | 3     | 2 | 1   | 0   |
|--------|-------|-------|-------|-------|-------|---|-----|-----|
|        | RXCIF | TXCIF | DREIF | RXSIF | ISFIF |   | BDF | WFB |
| アクセス種別 | R/W   | R/W   | R     | R/W   | R/W   | R | R/W | R/W |
| リセット値  | 0     | 0     | 1     | 0     | 0     | 0 | 0   | 0   |

## ● ビット7 - RXCIF: 受信完了割り込み要求フラグ (Receive Complete Interrupt Flag)

このフラグは受信緩衝部内に未読データがある時に設定(1)され、受信緩衝部が空の(即ち、何の未読データも含まない)時に解除(0)されます。受信部が禁止されると、受信緩衝部は破棄され、その結果としてRXCIFビットが'0'になります。

割り込み駆動データ受信が使われると、受信完了割り込み処理ルーチンはRXCIFを解除(0)するために受信データ(RXDATA)レシブスタから受信データを読まなければなりません。そうしなければ、現在の割り込みから戻った直後に新しい割り込みが起きます。

#### ● ビット6 - TXCIF: 送信完了割り込み要求フラグ (USART Transmit Complete Interrupt Flag)

このフラグは送信移動レジスタのフレーム全体が移動出力されてしまい、送信緩衝部(TXDATA)内に新しいデータがない時に設定(1)されます。

このビットへの'1'書き込みがこのフラグを解除(0)します。

#### ● ビット5 - DREIF:データレジスタ空割り込み要求フラグ(USART Data Register Empty Flag)

このフラグは送信緩衝部(TXDATA)が新しいデータを受け取る準備が整っているかを示します。このフラグは送信緩衝部が空の時に'1'に設定され、送信緩衝部が移動レジスタ内へ未だ移動されていないけれども送信されるべきデータを含む時に'0'です。DREIFビットは送信部準備可を示すためにリセット後に設定(1)されます。

DREIFは送信データ(USARTn.TXDATAL)レジスタ書き込みによって'0'に解除されます。割り込み駆動データ送信が使われると、データレジスタ空割り込み処理ルーチンはDREIFを解除(0)するためにTXDATAに新しいデータを書くか、またはデータレジスタ空割り込みを禁止するかのどちらかを行わなければなりません。そうしなければ、現在の割り込みからの復帰直後に新しい割り込みが起きます。

## ● ビット4 - RXSIF: 受信開始割り込み要求フラグ(USART Receive Start Interrupt Flag)

このフラグはRxD線上での有効な開始条件を示します。このフラグはシステムがスタンバイ休止動作で、RxD線上でHigh(アイゲル)からLow(開始)への有効な遷移が検出された時に設定(1)されます。開始検出が許可されないなら、RXSIFビットは常に'0'として読みます。このフラグはこのビット位置への'1'を書くことによってのみ解除(0)することができます。このフラグは主装置SPI動作形態で使えません。

## ● ビット3 - ISFIF: 矛盾同期領域割り込み要求フラグ (Inconsistent Sync Field Interrupt Flag)

このフラグは自動ボーレートが許可されて、同期領域ビット時間が有効なボーレート設定に対して速すぎる、または遅すぎる時に設定(1)されます。USARTがLINAUTO動作に設定され、同期(SYNC)文字が\$55のデータ値と違う時にも設定(1)されます。

このビットへの'1'書き込みはこのフラグを解除(0)してUSARTをアイドル状態に戻します。

## ● ビット1 - BDF: 中断検出フラグ(Break Detected Flag)

このフラグはLINAUTO受信動作に構成設定されたUSART用に意図されます。中断検出は検出されるべき中断(BREAK)に対して11 ビットのLowの固定閾値を持ちます。BDFビットは有効な中断(BREAK)と同期(SYNC)の文字を検出した後に設定( $\frac{1}{2}$ )されます。このビットは次のデータを受信した時に自動的に解除( $\frac{0}{2}$ )されます。このビットはUSARTがGENAUTO動作に設定される時も同様に動きます。NORMALまたはCLK2Xの受信動作でのBDFビットは未使用にされます。

このビットはこれに'1'を書くことによって解除(0)されます。

#### ● ビット0 - WFB:中断待機(Wait For Break)

このビットに'1'を書くことはRxD線上での次のLowとHighの遷移を中断文字として記録します。これは任意の幅の中断(BREAK)文字を待つのに使うことができます。GENAUTO動作に設定したUSARTとの組み合わせで、これはそれがボーレート(USARTn.BAUD)レジスタの有効範囲内である限り、中断(BREAK)と同期(SYNC)を通してどのBAUD速度に設定することをも使用者に許します。このビットは常に'0'を読みます。

## **24.5.6. CTRLA - 制御A** (Control A)

名称: CTRLA 変位:+\$05 リセット: \$00 特質:-

| ピット _  | 7     | 6     | 5     | 4     | 3    | 2     | 1    | 0     |
|--------|-------|-------|-------|-------|------|-------|------|-------|
|        | RXCIE | TXCIE | DREIE | RXSIE | LBME | ABEIE | RS48 | 351,0 |
| アクセス種別 | 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 - RXCIE: 受信完了割り込み許可 (Receive Complete Interrupt Enable)

このビットは受信完了割り込み(RXC割り込みベクタ)を許可します。許可された割り込みは状態(USARTn.STATUS)レジスタの受信完了割り込み要求フラグ(RXCIF)ビットが設定(1)される時に起動されます。

#### ● ビット6 - TXCIE: 送信完了割り込み許可 (Transmit Complete Interrupt Enable)

このビットは送信完了割り込み(TXC割り込みベクタ)を許可します。許可された割り込みは状態(USARTn.STATUS)レジスタの送信完了割り込み要求フラグ(TXCIF)ビットが設定(1)される時に起動されます。

#### • ビット5 - DREIE: データ レジスタ空割り込み許可 (Data Register Empty Interrupt Enable)

このビットはデータ レジスタ空割り込み(DRE割り込みベクタ)を許可します。許可された割り込みは状態(USARTn.STATUS)レジスタのデータ レ ジスタ空割り込み要求フラグ(DREIF)ビットが設定(1)される時に起動されます。

# ● ビット4 - RXSIE : 受信開始割り込み許可 (Receiver Start Frame Interrupt Enable)

このビットへの'1'書き込みはフレーム条件の開始が検出された時にRXC割り込みベクタでの割り込みを生成することをフレーム開始検出器に許します。

● ビット3 - LBME: 折り返し動作許可 (Loop-back Mode Enable)

このビットへの'1'書き込みはTxDピンと受信部間の内部接続を許可し、RxDピンからUSART受信部への入力を禁止します。

● ビット2 - ABEIE:自動ボーレート異常割り込み許可(Auto-baud Error Interrupt Enable)

このビットへの'1'書き込みはRXC割り込みベクタでの自動ボーレート異常割り込みを許可します。許可された割り込みは状態(USARTn.S TATUS)レジスタの矛盾同期領域割り込み要求フラグ(ISFIF)が設定(1)される条件に対して起動します。

● ビット1.0 - RS4851.0 : RS-485動作 (RS-485 Mode)

これらのビットはRS-485を許可して動作形態を選びます。RS4850の'1'書き込みは自動的に送信開始1クロック周期前にXDIRピンをHighに駆動して送信完了時に再びそれをLowに引くRS-485動作を許可します。RS4851の'1'書き込みは自動的に送信開始1クロック周期前にTxDピンを出力に設定し、送信完了時にそれを入力に設定し戻すRS-485動作を許可します。

## **24.5.7. CTRLB - 制御B** (Control B)

名称: CTRLB 変位: +\$06 リセット: \$00 特質: -

| ピット    | 7    | 6    | 5 | 4     | 3    | 2    | 1     | 0    |
|--------|------|------|---|-------|------|------|-------|------|
|        | RXEN | TXEN |   | SFDEN | ODME | RXMC | DE1,0 | MPCM |
| アクセス種別 | R/W  | R/W  | R | R/W   | R/W  | R/W  | R/W   | R/W  |
| リセット値  | 0    | 0    | 0 | 0     | 0    | 0    | 0     | 0    |

#### ● ビット7 - RXEN: 受信許可 (Receiver Enable)

このビットを'1'に書くことがUSART受信部を許可します。受信部の禁止(RXEN='0')はフレーム異常(FERR)、緩衝部溢れ(BUFOVF)、パッリティ誤り(PERR)のフラグを無効にする受信緩衝部の破棄を行います。GENAUTOとLINAUTOの動作では受信部の禁止は自動ボーレート検出論理回路をリセットします。

● ビット6 - TXEN: 送信許可 (Transmitter Enable)

このビットを'1'に書くことがUSART送信部を許可します。送信部は許可された時にTxDピンに対する標準ポート動作を無効にします。送信部の禁止(TXENビットの'0'書き込み)は進行中と保留中の送信が完了される(即ち、送信移動レジスタと送信緩衝レジスタが送信すべきデータを含まない時)まで有効になりません。送信部が禁止されると、それはもはやTxDピンを無効にせず、例え使用者によってピンの方向が出力として構成設定されていたとしても、ハードウェアによって自動的に入力として設定されます。

● ビット4 - SFDEN: フレーム開始検出許可 (Start of Frame Detection Enable)

このビットを'1'に書くことがUSARTフレーム開始検出動作を許可します。フレーム開始検出器はRxD線上でHigh(アイドル)からLow(開始)への遷移が検出される時にアイドルまたはスタンバイの休止動作形態からシステムを起き上がらせることができます。

● ビット3 - ODME: オープントレイン動作許可(Open Drain Mode Enable)

このビットを'1'に書くことはTxDピン オープン ドレイン機能を与えます。TxDピンに論理'1'が出力される時に線を浮き状態から防ぐために内部プルアップ(ピンn制御(PORTx.PINnCTRL)レジスタのプルアップ許可(PULLUPEN)ビット)が許可されるべきです。

● ビット2,1 - RXMODE1,0: 受信動作 (Receiver Mode)

これらのビット書き込みはUSARTの受信部動作を選びます。CLK2X動作ではボーレート分周器の分周数が16から非同期通信動作に対する転送速度を効率的に倍にする8に減らされます。同期動作に対するCLK2X動作は無効で、RXMODEビットは常に'00'を書かれるべきです。RXMODEはUSART通信動作がIRCOMに構成設定される時に'00'でなければなりません。RXMODEのGENAUTO設定は'0'と'1'の間を変える8つのビットが記録される時の同期(SYNC)文字が有効な標準自動ボーレートを許可します。この動作では有効なボーレート(BAUD)を与える同期(SYNC)文字が受け入れられます。LINAUTO動作では同期(SYNC)文字が制限され、毎回の2ビットが内部ボーレートの32±6ビット ボーレート採取内に入り、\$55のデータ値と一致する場合に有効と判定します。GENAUTOとLINAUTOの動作は非同期従装置動作で動作するUSART操作に対してだけ支援されます。

| 値  | 0 0          | 0 1          | 1 0         | 11             |
|----|--------------|--------------|-------------|----------------|
| 名称 | NORMAL       | CLK2X        | GENAUTO     | LINAUTO        |
| 説明 | 標準速標準USART動作 | 倍速標標準USART動作 | 標準自動ボーレート動作 | LIN制限自動ボーレート動作 |

## ● ビット0 - MPCM:複数プロセッサ通信動作 (Multi-processor Communication Mode)

このビットへの'1'書き込みは複数プロセッサ通信動作を許可します。USART受信部はアドレス情報を含まない全ての着信フレームを無視します。送信部はMPCM設定によって影響を及ぼされません。より多くの詳細情報については「24.3.4.3. 複数プロセッサ通信動作」をご覧ください。

# **24.5.8.** CTRLC - 制御C - 非同期動作 (Control C - Async Mode)

名称: CTRLC 変位:+\$07 リセット: \$03 特質:-

このレシ、スタ記述は主装置SPI動作を除く全動作に対して有効です。このレシ、スタのUSART通信動作(CMODE)ビットが'MSPI'を書かれた時の正確な記述については「制御C(CTRLC) - 主装置SPI動作」レシ、スタをご覧ください。

| <b>ビット</b> | 7   | 6     | 5    | 4     | 3      | 2   | 1         | 0   |
|------------|-----|-------|------|-------|--------|-----|-----------|-----|
|            | CMO | DE1,0 | PMO: | DE1,0 | SBMODE |     | CHSIZE2~0 |     |
| アクセス種別     | R/W | R/W   | R/W  | R/W   | R/W    | R/W | R/W       | R/W |
| リセット値      | 0   | 0     | 0    | 0     | 0      | 0   | 1         | 1   |

## ● ビット7,6 - CMODE1,0: 通信動作 (USART Communication Mode)

これらのビットへの書き込みはUSARTの通信動作を選びます。

これらのビットへの'11'書き込みはこのレジスタでの利用可能なビット領域が変わります。「制御C(CTRLC) - 主装置SPI動作」レジスタをご覧ください。

| 値  | 0 0          | 0 1         | 1 0   | 11     |
|----|--------------|-------------|-------|--------|
| 名称 | ASYNCHRONOUS | SYNCHRONOUS | IRCOM | MSPI   |
| 説明 | 非同期USART     | 同期USART     | 赤外線通信 | 主装置SPI |

## ビット5,4 - PMODE1,0: パリティ動作 (Parity Mode)

これらのビットへの書き込みはパリティ生成の形式を選びます。

許可されると、送信部は各フレーム内の送信したデータ ビットのパリティを自動的に生成して送ります。受信部は着信データに対してパリティ値を生成し、それをPMODE設定と比較して、不一致が検出された場合に受信データ上位バイト(USARTn.RXDATAH)レン゙スタのパリティ誤り (PERR)フラグを設定(1)します。

主装置SPI動作(通信動作(CMODE)='11')に於いて、これらのビットは無効です。

| 値  | 0 0      | 0 1  | 1 0       | 11        |
|----|----------|------|-----------|-----------|
| 名称 | DISABLED | -    | EVEN      | ODD       |
| 説明 | 禁止       | (予約) | 許可、偶数パリティ | 許可、奇数パリティ |

## ● ビット3 - SBMODE: 停止ビット動作(Stop Bit Mode)

このビットの書き込みは送信部によって挿入される停止ビット数を選びます。 受信部はこの設定を無視します。

主装置SPI動作(通信動作(CMODE)='11')に於いて、これらのビットは無効です。

| 値  | 0      | 1      |
|----|--------|--------|
| 説明 | 1停止ビット | 2停止ビット |

#### ● ビット2~0 - CHSIZE2~0:文字ビット数(Character Size)

これらのビットへの書き込みはフレーム内のデータ ビット数を選びます。受信部と送信部は同じ設定を使います。9ビット文字に対しては、受信データ(RXDATA)または送信データ(TXDATA)の下位または上位で先に読み書きするバイト順が選択可能です。

| 値  | 0 0 0 | 0 0 1 | 0 1 0 | 0 1 1 | 100  | 101  | 1 1 0         | 111           |
|----|-------|-------|-------|-------|------|------|---------------|---------------|
| 名称 | 5BIT  | 6BIT  | 7BIT  | 8BIT  | _    | -    | 9BITL         | 9BITH         |
| 説明 | 5ピット  | 6Ľ'yŀ | 7ピット  | 8Ľ"yŀ | (予約) | (予約) | 9ビット(下位バイト先行) | 9ビット(上位バイト先行) |

# **24.5.9. CTRLC - 制御C -** 主装置SPI動作 (Control C - Master SPI Mode)

名称: CTRLC 変位:+\$07 リセット: \$02 特質:-

このレシブスタ記述はUSARTが(通信動作(CMODE)がMSPIを書かれる)主装置SPI動作の時にだけ有効です。他のCMODE値ついての正確な記述に関しては「制御C(CTRLC) - 非同期動作」レシブスタをご覧ください。

主装置SPI動作の完全な記述については「24.3.3.1.3. 主装置SPI動作でのUSART」をご覧ください。

| ピット    | 7   | 6     | 5 | 4 | 3 | 2     | 1     | 0 |
|--------|-----|-------|---|---|---|-------|-------|---|
|        | CMO | DE1,0 |   |   |   | UDORD | UCPHA |   |
| アクセス種別 | R/W | R/W   | R | R | R | R/W   | R/W   | R |
| リセット値  | 0   | 0     | 0 | 0 | 0 | 0     | 1     | 0 |

## ● ビット7,6 - CMODE1,0: 通信動作 (USART Communication Mode)

これらのビットへの書き込みはUSARTの通信動作を選びます。

これらのビットへの'11'以外の書き込みはこのレジスタでの利用可能なビット領域が変わります。「制御C(CTRLC) - 非同期動作」レジスタをご覧ください。

| 値  | 0 0          | 0 1         | 1 0   | 11     |
|----|--------------|-------------|-------|--------|
| 名称 | ASYNCHRONOUS | SYNCHRONOUS | IRCOM | MSPI   |
| 説明 | 非同期USART     | 同期USART     | 赤外線通信 | 主装置SPI |

#### ● ビット2 - UDORD: USARTデータ順 (USART Data Order)

このビットの書き込みはフレーム形式を選びます。

受信部と送信部は同じ設定を使います。UDORDビットの設定変更は送受信部両方に対して進行中の全ての通信を不正にします。

| 値  | 0                  | 1                  |
|----|--------------------|--------------------|
| 説明 | データ語のMSBが先に送信されます。 | データ語のLSBが先に送信されます。 |

## ● ビット1 - UCPHA: USARTクロック位相 (USART Clock Phase)

UCPHAビット設定はデータがXCKの先行(先頭)端または後行(最終)端のどちらで採取されるかを決めます。詳細については「クロック生成」を参照してください。

## **24.5.10**. **BAUD** - ホーレート (Baud Register)

名称: BAUD (BAUDH, BAUDL)

変位:+\$08 リセット:\$0000 特質:-

USARTn.BAUDHとUSARTn.BAUDLのレジスタ対は16ビット値のUSARTn.BAUDを表します。下位バイト[7~0](接尾辞L)は変位原点でアクセス可能です。上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

送信部と受信部の進行中の転送はボーレートが変更される場合に不正にされます。このレジスタへの書き込みはボーレート前置分周器の即時更新を起動します。ボーレートの設定方法のより多くの情報については表24-1. ボーレート レジスタ設定計算用の式をご覧ください。

| ピット    | 15  | 14  | 13  | 12       | 11    | 10  | 9   | 8   |
|--------|-----|-----|-----|----------|-------|-----|-----|-----|
|        |     |     |     | BAUI     | )15~8 |     |     |     |
| アクセス種別 | 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        | 2     | 0   | 1   | 0   |
| L "Y r |     | , 0 | , 2 | <u>4</u> | J     |     | . 1 | . 0 |
| L      |     |     |     | . BAU.   | D7~0  |     |     |     |
| アクセス種別 | R/W | R/W | R/W | R/W      | R/W   | R/W | R/W | R/W |
| リセット値  | 0   | 0   | 0   | 0        | 0     | 0   | 0   | 0   |

## ● ビット15~8 - BAUD15~8: ボーレート上位ハイト (USART Baud Rate high byte)

これらのビットは16ビット ボーレート レジスタの上位バイトを保持します。

#### ● ビット7~0 - BAUD7~0: ボーレート下位バイト (USART Baud Rate low byte)

これらのビットは16ビット ボーレート レジスタの下位バイトを保持します。

## **24.5.11. CTRLD - 制御D** (Control D)

名称: CTRLD 変位: +\$0A リセット: \$00 特質: -

| ピット    | 7   | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|-----|------|---|---|---|---|---|---|
|        | ABV | V1,0 |   |   |   |   |   |   |
| アクセス種別 | R/W | R/W  | R | R | R | R | R | R |
| リセット値  | 0   | 0    | 0 | 0 | 0 | 0 | 0 | 0 |

## ● ビット7,6 - ABW1,0: 自動ボーレート窓幅 (Auto-baud Window Size)

これらのビットは同期(SYNC)文字が有効にされる窓の大きさを設定します。

| 値  | 0 0   | 0 1   | 1 0   | 11    |
|----|-------|-------|-------|-------|
| 名称 | WDW0  | WDW1  | WDW2  | WDW3  |
| 説明 | 18%許容 | 15%許容 | 21%許容 | 25%許容 |

# 24.5.12. DBGCTRL - デバッグ制御 (Debug Control)

名称: DBGCTRL 変位: +\$0B リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|--------|---|---|---|---|---|---|---|--------|
|        |   |   |   |   |   |   |   | DBGRUN |
| アクセス種別 | R | R | R | R | R | R | R | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0      |

## ● ビット0 - DBGRUN: デバッグ時走行 (Debug Run)

| 値  | 0                  | 1                    |
|----|--------------------|----------------------|
| 説明 | 中断デバッグ動作で停止され事象を無視 | 中断デバッグ動作でCPU停止時に走行継続 |

# **24.5.13**. **EVCTRL** - 事象制御 (IrDA Control Register)

名称: EVCTRL 変位: +\$0C リセット: \$00 特質:-

| ピット _  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|--------|---|---|---|---|---|---|---|------|
|        |   |   |   |   |   |   |   | IREI |
| アクセス種別 | R | R | R | R | R | R | R | R/W  |
| リセット値  | 0 | 0 | Λ | 0 | 0 | 0 | Λ | 0    |

## ● ビット0 - IREI : IrDA事象入力許可 (IrDA Event Input Enable)

このビットは赤外線通信(IRCOM)受信部に対する事象供給元を許可します。IRCOM受信部に対して事象入力が選ばれる場合、USA RTのRxDピンからの入力は自動的に禁止されます。

# **24.5.14**. **TXPLCTRL - IRCOM送信パルス長制御** (IRCOM Transmitter Pulse Length Control Register)

名称: TXPLCTRL 変位:+\$0D リセット: \$00 特質:-

| <u> </u> | 7       | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------|---------|-----|-----|-----|-----|-----|-----|-----|
|          | TXPL7~0 |     |     |     |     |     |     |     |
| アクセス種別   | 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 - TXPL7~0: 送信パルス長 (Transmitter Pulse Length)

この8ビット値は送信部に対するパルス変調方式を設定します。このレジスタの設定はUSARTによってIRCOM動作が選択される場合にだけ有効で、USART送信部が許可(TXEN)される前に構成設定されなければなりせん。

| 値         | 説明                                                                                                 |
|-----------|----------------------------------------------------------------------------------------------------|
| \$00      | 3/16ボーレート周期パルス変調が使われます。                                                                            |
| \$01~\$FE | 固定パルス長符号化が使われます。この8ビット値はパルスに対する周辺機能クロック周期数を設定します。パルスの始めはボーレート クロックの上昇端で同期されます。                     |
| \$FF      | パルス符号化禁止。送受信の信号はIRCOM単位部を無変化で通過します。これは半二重USART、折り返し検査、事象チャネルからのUSART受信入力のような、IRCOM単位部を通す他の機能を許します。 |

# 24.5.15. RXPLCTRL - IRCOM受信パルス長制御 (IRCOM Receiver Pulse Length Control Register)

名称: RXPLCTRL 変位: +\$0E リセット: \$00 特質: -



## ● ビット6~0 - RXPL7~0: 受信パルス長 (Receiver Pulse Length)

この7ビット値はIRCOM送受信部に対する濾波係数を設定します。このレジスタの設定はUSARTによってIRCOM動作が選択される場合にだけ有効で、USART受信部が許可(RXEN)される前に構成設定されなければなりせん。

| 値         | 説明                                                |
|-----------|---------------------------------------------------|
| \$00      | 濾波が禁止されます。                                        |
| \$01~\$7F | 濾波が許可されます。RXPL+1の値は受け入れるべき受信したパルスに必要とされる採取数を表します。 |

# 25. SPI - 直列周辺インターフェース

## 25.1. 特徴

- ・全二重、3線同期データ転送
- ・主装置または従装置の動作
- ・LSB先行またはMSB先行のデータ転送
- ・設定可能な7つのビット速度
- ・転送の最後での割り込み要求フラグ
- ・書き込み衝突フラグ保護
- ・アイドル休止動作からの起き上がり
- · 倍速(CK/2)主装置SPI動作

## 25.2. 概要

直列周辺インターフェース(SPI)は3または4つのピンを用いる高速同期データ転送インターフェースです。それはAVR®デバイスと周辺装置間、または様々なマイクロ コントローラ間での全二重通信を許します。SPI周辺機能は主装置または従装置のどちらかとして構成設定することができます。主装置が全てのデータ転送処理を始めて制御します。

SPIを持つ主装置と従装置のデバイス間の相互接続は構成図で示されます。このシステムは2つの移動レジスタと主装置クロック発生器から成ります。SPI主装置は望む従装置の従装置選択(SS)信号をLowに引くことによって通信周回を始めます。主装置と従装置は送るべきデータをそれらの各々の移動レジスタに用意して、主装置はデータを交換するためにSCK線上に必要とするクロック パルスを生成します。データは常に主装置出力従装置入力(MOSI)線で主装置から従装置へ、主装置入力従装置出力(MISO)線で従装置から主装置へ移動されます。

## 25.2.1. 構成図



SPIは同時にデータの移動出力と入力を行う8ビット移動レジスタ周辺を構築します。データ(DATA)レジスタは物理的なレジスタではありませんが、読み書きされる時に他のレジスタに割り当てられます。送信時のデータ(SPIn.DATA)レジスタは標準動作で移動レジスタに、緩衝動作で送信緩衝レジスタに書きます。受信時のデータ(SPIn.DATA)レジスタ読み込みは標準動作で受信データ レジスタを、緩衝動作で受信データ緩衝レジスタを読みます。

主装置動作ではSPIがSCKクロックを生成するクロック生成器を持ちます。従装置では受け取ったSCKクロックが同期化されて移動レジスタでデータの移動を起動するように採取されます。

#### 25.2.2. 信号説明

## 表25-1. 主装置動作と従装置動作での信号

| 信号   | 形          | 式                           | 説明         |
|------|------------|-----------------------------|------------|
| 活万   | 主装置動作      | 従装置動作                       | 高元 リナ      |
| MOSI | 使用者定義 (注1) | 入力                          | 主装置出力従装置入力 |
| MISO | 入力         | 使用者定義 ( <mark>注1,2</mark> ) | 主装置入力従装置出力 |
| SCK  | 使用者定義 (注1) | 入力                          | 従装置クロック    |
| SS   | 使用者定義 (注1) | 入力                          | 従装置選択      |

注1: ピンのデータ方向が出力として構成設定される場合、ピンのレベルはSPIによって制御されます。

注2: SPIが従装置動作でMISOピンのデータ方向が出力として構成設定される場合、以下のようにSSピンがMISOピンを制御します。

- SSピンがLowに駆動されるなら、MISOピンはSPIによって制御されます。
- SSピンがHighに駆動されるなら、MISOピンはHi-Zにされます。

SPI単位部が許可されると、MOSI、MISO、SCK、SSピンのデータ方向は表25-1.に従って上書きされます。

## 25.3. 機能的な説明

#### 25.3.1. 初期化

以下のこれらの手順によってSPIを基本機能状態に初期化してください。

- 1. ポート周辺機能でSSピンを構成設定してください。
- 2. 制御A(SPIn.CTRLA)レジスタの主/従装置選択(MASTER)ビットを書くことによってSPI主装置/従装置動作を選んでください。
- 3. 主装置動作では、SPIn.CTRLAレジスタで前置分周器(PRESC)ビットとクロック倍速(CLK2X)ビットを書くことによってクロック速度を選んでください。
- 4. 任意選択: 制御B(SPIn.CTRLB)レシブスタの動作形態(MODE)ビットに書くことによって転送動作形態を選んでください。
- 5. 任意選択: SPIn.CTRLAレシブスタのデータ順(DORD)ビットを書いてください。
- 6. 任意選択: 制御B(SPIn.CTRLB)レジスタで緩衝動作許可(BUFEN)と緩衝動作受信待機(BUFWR)のビットを書くことによって緩衝動作を構成設定してください。
- 7. 任意選択: 主装置動作での複数主装置支援を禁止するにはSPIn.CTRLBレジスタの従装置選択禁止(SSD)ビットに'1'を書いてくだ
- 8. SPIn.CTRLAレジスタの許可(ENABLE)ビットに'1'を書くことによってSPIを許可してください。

## 25.3.2. 動作

## 25.3.2.1. 主装置動作

SPIが主装置動作に構成設定されると、データ(SPIn.DATA)レジスタへの書き込みが新しい転送を開始します。SPI主装置は下で説明されるように2つの動作形態、標準と緩衝で動作することができます。

#### 25.3.2.1.1. 標準動作

標準動作で、システムは送信方向で単一緩衝され、受信方向で2重緩衝されます。これは次のようにデータ処理に影響します。

- 1. 送られるべき次のバイトは転送全体が完了される前にデータ(SPIn.DATA)レジスタに書くことができません。早すぎる書き込みは送出されるデータの不正を引き起こし、割り込み要求フラグ(SPIn.INTFLAGS)レジスタの書き込み衝突(WRCOL)フラグが設定(1)されます。
- 2. 受信したバイトは伝送が完了した後、直ちに受信データレジスタに書かれます。
- 3. 受信データレジスタは次の伝送が緩衝される、またはデータが失われる前に読まれなければなりません。このレジスタはSPIn.DATAを読むことによって読まれます。
- 4. 送信緩衝レシ、スタと受信データ緩衝レシ、スタは標準動作で使われません。

転送完了後、割り込み要求フラグ(SPIn.INTFLAGS)レジスタで割り込み要求フラグ(IF)が設定(1)されます。これはこの割り込みと全体割り込みが許可されている場合に実行されるべき対応する割り込みを引き起こします。割り込み制御(SPIn.INTCTRL)レジスタの割り込み許可(IE)ビットが割り込みを許可します。

#### 25.3.2.1.2. 緩衝動作

緩衝動作は制御B(SPIn.CTRLB)レジスタの緩衝動作許可(BUFEN)ビットに'1'を書くことによって許可されます。SPIn.CTRLBの緩衝動作受信待機(BUFWR)ビットは主装置動作に影響を及ぼしません。緩衝動作のシステムは送信方向で2重緩衝、受信方向で3重緩衝されます。これは次のようにデータ処理に影響します。

- 1. 新しい、「小は割り込み要求フラク(SPIn.INTFLAGS)レシ、スタのデータレジ、スタ空割り込み要求フラク(DREIF)が設定(1)されている限り、データ(SPIn.DATA)レシ、スタに書くことができます。最初の書き込みは直ちに送信され、後続する書き込みは送信データ緩衝レジ、スタへ行きます。
- 2. 受信したバイトは伝送が完了した後、直ちに受信データレジスタと受信データ緩衝レジスタで構成される2つの記録の受信先入れ先出し(RX FIFO)待ち行列に置かれます。
- 3. RX FIFOから読むのにデータ(SPIn.DATA)レシブスタが使われます。どのデータ損失も避けるため、RX FIFOは最低毎回の第2転送毎に読まれなければなりません。

移動レジ、スタと送信データ緩衝レジ、スタの両方が空になる場合、割り込み要求フラグ、(SPIn.INTFLAGS)レジ、スタの転送完了割り込み要求フラグ (TXCIF)が設定(1)されます。これはこの割り込みと全体割り込みが許可されている場合に実行されるべき対応する割り込みを引き起こします。割り込み制御(SPIn.INTCTRL)レジ、スタの割り込み許可(IE)ビットが転送完了割り込みを許可します。

## 25.3.2.1.3. 主装置動作でのSSピンの機能 - 複数主装置支援

主装置動作ではSPIがSSピンをどう使うのかを制御B(SPIn.CTRLB)レジスタの従装置選択禁止(SSD)ビットが制御します。

- ・SPIn.CTRLBnのSSDが'0'なら、SPIは主装置動作から従装置動作への遷移にSSピンを使うことができます。これは同じSPIバスで複数SPI主装置を許します。
- ・SPIn.CTRLBnのSSDが'0'でSSピンが出力ピンとして構成設定される場合、そのピンは通常の入出力として、または他の周辺機能単位部によって使うことができ、SPIシステムに影響を及ぼしません。
- SPIn.CTRLBnのSSDが'1'なら、SPIはSSピンを使いません。通常の入出力として、または他の周辺機能単位部によって使うことができます。

SPIn.CTRLBnのSSDビットが'0'でSSが入力ピンとして構成設定される場合、SSピンは主装置SPI動作を保証するためにHighを保たれなければなりません。Lowレベルは別の主装置がバスの制御を取ることを試みていると解釈されます。これはSPIを従装置に切り替えてSPIのハードウェアが以下の活動を実行します。

- 1. 制御A(SPIn.CTRLA)レシ、スタの主/従装置選択(MASTER)ヒ、ットが解除(0)され、SPIシステムは従装置になります。SPIピンの方向は表 25-2.の条件を満たす時に切り替えられます。
- 2. 割り込み要求フラグ(SPIn.INTFLAGS)レジスタの割り込み要求フラグ(IF)ピットが設定(1)されます。割り込みが許可されて全体割り込みが許可されているなら、その割り込みルーチンが実行されます。

| 表25-2. SPIn.CTRLBのSSDが'0'の時のSSピン機能の概要 |          |                  |  |  |  |  |
|---------------------------------------|----------|------------------|--|--|--|--|
| SS構成設定                                | SSピン レベル | 説明               |  |  |  |  |
| 入力                                    | High     | 主装置有効(選択)        |  |  |  |  |
| 人分                                    | Low      | 主装置無効、従装置動作へ切り替え |  |  |  |  |
| 出力                                    | High     | 主装置有効(選択)        |  |  |  |  |
| ЩЛ                                    | Low      | 土茶直有劝(迭代)        |  |  |  |  |

注: デバイスが主装置動作で、2つの送信の間にSSピンがHighに留まることを保証できない場合、新しいバイトが書かれる前にSPIn.CTR LAレジスタの主/従装置選択(MASTER)ビットが調べられなければなりません。SS線のLowレベルによってMASTERビットが解除(0)されてしまった後、SPI主装置動作を再許可するには応用によって設定(1)されなければなりません。

## 25.3.2.2. 従装置動作

従装置動作で、SPI周辺機能は主装置からSPIクロックと従装置選択を受け取ります。従装置動作は3つの動作形態、1つの標準動作と 緩衝動作用の2つの構成設定を支援します。従装置動作で、制御論理回路はSCKピンでやって来る信号を採取します。

#### 253221 標進動作

標準動作で、SPI周辺機能はSSピンがHighに駆動される限りアイドルに留まります。この状態ではソフトウェアがデータ(SPIn.DATA)レジスタの内容を更新するかもしれませんが、SSピンがLowに駆動されるまで、データはSCKピンでやって来るクロック パルスによって移動されません。SSピンがLowに駆動された場合、従装置は最初のSCKクロック パルスでデータの移動を開始します。1バイトが完全に移動されると、割り込み要求フラグ(SPIn.INTFLAGS)レシ、スタのSPI割り込み要求フラグ(IF)が設定(1)されます。

使用者応用は到着データを読む前にDATAレシ、スタに送る新しいデータの配置を続けるかもしれません。送るべき新しい、小小は(直前の) 転送全体が完了されるのに先立ってDATAに書くことができません。早すぎる書き込みは無視され、ハードウェアがSPIn.INTFLAGSレシスタの書き込み衝突(WRCOL)フラグを設定(1)します。

SSピンがHighに駆動されると、SPI論理回路は停止され、SPI従装置は新しいどのデータも受け取りません。移動レジスタ内のどの部分的に受信したパケットも失われます。

図25-2.は標準動作での送信手順を示します。値\$45がDATAレジスタに書かれますが、何故決して送信されないかに注目してください。



上図は3つの転送と、SPIが転送で多忙の間でのDATAレジスタへの1つの書き込みを示します。この書き込みは無視され、SPIn.INTFL AGSレジスタの書き込み衝突(WRCOL)フラケが設定(1)されます。

#### 25.3.2.2.2. 緩衝動作

データ衝突を避けるため、SPI周辺機能は制御B(SPIn.CTRLB)レジスタの緩衝動作許可(BUFEN)ビットに'1'を書くことによって緩衝動作に構成設定することができます。この動作では2つの受信緩衝部と1つの送信緩衝部を持ちます。双方は独立した割り込み要求フラグの送信完了と受信完了を持ちます。図25-1.は追加の緩衝部を示します。緩衝動作が許可される時に2つの異なる方法で動くことができます。制御B(SPIn.CTRLB)レジスタの緩衝動作受信待機(BUFWR)ビットは緩衝動作がどう動くかを制御します。タイミング構成図を含みそれらがどう動くかの詳細が下で記述されます。

注: 緩衝動作で従装置として動作し、SPIクロックが最大周波数に近いと、従装置は連続転送間の最初の採取端に対して時間内にデータを準備できないかもしれません。詳細については「電気的特性」の「SPI」項を参照してください。

#### 緩衝動作受信待機(BUFWR)=0での従装置緩衝動作

従装置動作で、SPIn.CTRLBレジスタの緩衝動作受信待機(BUFWR)ビットが'0'を書かれると、使用者データの送信を開始する前に偽装 ハ・ハ・か送られます。図25-3.はこの構成設定での送信手順を示します。値\$45がデータ(SPIn.DATA)レジスタに書かれますが、何故決して送信されないかに注目してください。



SPIn.CTRLBレシ、スタの緩衝動作受信待機(BUFWR)と、かが、0°を書かれると、データ(SPIn.DATA)レシ、スタへの全ての書き込みが送信データ緩衝レシ、スタへ行きます。上の図は\$43が直ちに移動レシ、スタへ送られずにデータ(SPIn.DATA)レシ、スタに書かれ、故に最初に送られるが小が偽装が、付であることを示します。偽装が、什の値はその時の移動レシ、スタにあった値に等しい値です。最初の偽装転送が完了された後、移動レシ、スタに値\$43が転送されます。その後に\$44がデータ(SPIn.DATA)レシ、スタへ書かれて送信データ緩衝レシ、スタへ行きます。新しい転送が開始され、\$43が送られます。値\$45がデータ(SPIn.DATA)レシ、スタに書かれますが、送信データ緩衝レシ、スタが\$44を含み既に満杯で、SPIn.INTFLAGSレシ、スタのデータレシ、スタ空割り込み要求フラグ(DREIF)が、0°のため、送信データ緩衝レシ、スタは更新されません。値\$45は失われます。転送(完了)後、値\$44が移動レシ、スタに移動されます。次の転送の間、\$46転送がデータ(SPIn.DATA)レシ、スタに書かれ、\$44が送られます。転送完了後、\$46が移動レシ、スタに複写されて次の転送で送り出されます。

SPIn.INTFLAGSレシ、スタのデータレシ、スタ空割り込み要求フラケ(DREIF)は送信データ緩衝レシ、スタが書かれる毎に'0'になり、送信データ緩衝レジ、スタ内の直前の値が移動レジ、スタに複写される時の転送後に'1'になります。SPIn.INTFLAGSレジ、スタの受信完了割り込み要求フラケ(RXCIF)はDREIFフラケが'1'になった1周期後に設定(1)されます。転送完了割り込み要求フラケ(TXCIF)は移動レジ、スタと送信データ緩衝レジ、スタで両方の値が送られてしまった時に受信完了割り込み要求フラケ(RXCIF)が設定(1)された1周期後に設定(1)されます。

#### 緩衝動作受信待機(BUFWR)=1での従装置緩衝動作

従装置動作で、SPIn.CTRLBレシブスタの緩衝動作受信待機(BUFWR)ビットが'1'を書かれると、使用者データの送信はSSピンがLowに駆動されると直ぐに開始します。図25-4.はこの構成設定での送信手順を示します。値\$45がデータ(SPIn.DATA)レジスタに書かれますが、何故決して送信されないかに注目してください。



データ(SPIn.DATA)レジスタへの全ての書き込みは送信データ緩衝レジスタへ行きます。上の図は値\$43がデータ(SPIn.DATA)レジスタに書かれ、SSピンがHighのためにそれが次の周回で移動レジスタに複写されることを示します。その後の次の書き込み(\$44)は送信データ緩衝部に行きます。最初の転送の間に値\$43が移動出力されます。上図で値\$45がデータ(SPIn.DATA)レジスタに書かれますが、SPIn.INTFLAGSレジスタのデータレジスタ空割り込み要求フラグ(DREIF)が'0'のため、送信データ緩衝レジスタは更新されません。転送完了後、送信データ緩衝レジスタから値\$44が移動レジスタに複写されます。値\$46が送信データ緩衝レジスタに書かれます。次の2つの転送の間に\$44と\$46が移動出力されます。フラグの動きは'0'に設定されたSPIn.CTRLBレジスタの緩衝動作受信待機(BUFWR)ヒットでと同じです。

## 25.3.2.2.3. 従装置動作でのSSピンの機能

従装置選択(SS)ピンはSPIの操作で中心的な役割を演じます。SPIの動作形態とこのピンの構成設定に応じて、これは装置を有効または無効にするのに使うことができます。SSピンはチップ選択ピンとして使われます。

従装置動作で、 $\overline{SS}$ ,MOSI,SCKは常に入力です。MISOピンの動きはポート周辺機能でのピンのデータ方向構成設定と $\overline{SS}$ の値に依存します。 $\overline{SS}$ ピンがLowに駆動されると、SPIは有効にされ、使用者がMISOピンのデータ方向を出力として構成設定した場合にMISOでデータ出力をクロック駆動するためのSCKパルスを受け取る責任があります。 $\overline{SS}$ ピンがHighに駆動されると、SPIは無効にされ、やって来るデータを受け取らないことを意味します。 $\overline{MISO}$ ピンのデータ方向が出力として構成設定される場合、 $\overline{MISO}$ ピンはHi-Zにされます。 $\overline{SS}$ 5-3.は $\overline{SS}$ 1と機能の上書きを示します。

| 表25-3. SSピン機能の概要 |        |             |          |          |  |  |  |  |
|------------------|--------|-------------|----------|----------|--|--|--|--|
| に推出記点            |        |             | MISOŁ    | ゚ン動作     |  |  |  |  |
| SS構成設定           | 336777 | 高光 9月       | ポート方向=出力 | ポート方向=入力 |  |  |  |  |
| 常に入力             | High   | 従装置無効 (非選択) | Hi-Z     | 入力       |  |  |  |  |
| 布(こ入力            | Low    | 従装置有効 (選択)  | 出力       | 入力       |  |  |  |  |

注: 従装置動作で、SPI状態機構はSSピンがHighに駆動される時にリセットされます。伝送中にSSピンがHighに駆動される場合、SPIは直ちにデータの送受信を停止し、受信と送信の両データが失われたと見做されなければなりません。SSピンが転送の開始と終わりを合図するのに使われるため、パケット/バイト同期を達成するのと主装置クロック発生器で同期された従装置ビット計数器を維持するのに有用です。

#### 25.3.2.3. データ転送形態

直列データに関してSCKの位相と極性の4つの組み合わせがあります。望む組み合わせは制御B(SPIn.CTRLB)レジスタの動作形態(MODE)ビットに書くことによって選ばれます。

SPIデータ転送形式は以下で示されます。データ ビットはSCK信号の逆端で移動出力されてラッチされ、データ信号を安定にするための充分な時間を保証します。

先行端はクロック周期の最初のクロック端です。後行端はクロック周期の最終クロック端です。



#### 25.3.2.4. 事象

SPIは以下の事象を生成することができます。

## 表25-4. SPIでの事象生成部

|    | 生    | <b></b> | 説明         | 事象型          | 生成クロック領域 | 事象長           |  |
|----|------|---------|------------|--------------|----------|---------------|--|
| 周道 | 辺機能  | 事象      | נפיתם      | 事家至 工风7477限以 |          | 尹豕攻           |  |
| S  | SPIn | SCK     | SPI主装置クロック | レベル          | CLK_PER  | 最小2 CLK_PER周期 |  |

SPIは事象使用部を持ちません。

事象型と事象システム構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照してください。

#### 25.3.2.5. 割り込み

## 表25-5. 利用可能な割り込みべりなと供給元

| 夕뜏         | へ、クタ説明  |                                                                |                                                                                                           |  |  |
|------------|---------|----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|--|--|
| 名称   ベクタ説明 |         | 標準動作                                                           | 緩衝動作                                                                                                      |  |  |
| SPI        | SPI割り込み | <ul><li>・IF : 割り込み要求割り込み</li><li>・WRCOL : 書き込み衝突割り込み</li></ul> | <ul><li>SSI : 従装置選択起動割り込み</li><li>DRE: データレジスタ空割り込み</li><li>TXC: 転送完了割り込み</li><li>RXC: 受信完了割り込み</li></ul> |  |  |

割り込み条件が起こると、周辺機能の割り込み要求フラグ(SPIn.INTFLAGS)レジスタで対応する割り込み要求フラグが設定(1)されます。 割り込み元は周辺機能の割り込み制御(SPIn.INTCTRL)レジスタで対応する許可ビットを書くことによって許可または禁止にされます。 割り込み要求は対応する割り込み元が許可され、割り込み要求フラグが設定(1)される時に生成されます。割り込み要求は割り込み要求フラグが解除(0)されるまで活性に留まります。割り込み要求フラグを解除する方法の詳細についてはSPIn.INTFLAGSレジスタをご覧ください。

# 25.4. レジスタ要約

| 変位    | 略称       | ビット位置        | ヒ゛ット7 | ピット6  | ピット5   | ピット4  | ピット3 | ピット2 | ピット1  | ビット0   |
|-------|----------|--------------|-------|-------|--------|-------|------|------|-------|--------|
| +\$00 | CTRLA    | 7 <b>~</b> 0 |       | DORD  | MASTER | CLK2X |      | PRES | SC1,0 | ENABLE |
| +\$01 | CTRLB    | 7 <b>~</b> 0 | BUFEN | BUFWR |        |       |      | SSD  | MOE   | E1,0   |
| +\$02 | INTCTRL  | 7 <b>~</b> 0 | RXCIE | TXCIE | DREIE  | SSIE  |      |      |       | IE     |
| +\$03 | INTFLAGS | 7~0          | IF    | WRCOL |        |       |      |      |       |        |
| +∌05  | INTEAGS  | 7,00         | RXCIF | TXCIF | DREIF  | SSIF  |      |      |       | BUFOVF |
| +\$04 | DATA     | 7~0          |       |       |        | DAT   | A7~0 |      |       |        |

# 25.5. レジスタ説明

**25.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位:+\$00 リセット: \$00 特質:-

| ピット    | 7 | 6    | 5      | 4     | 3 | 2    | 1     | 0      |
|--------|---|------|--------|-------|---|------|-------|--------|
|        |   | DORD | MASTER | CLK2X |   | PRES | SC1,0 | ENABLE |
| アクセス種別 | R | R/W  | R/W    | R/W   | R | R/W  | R/W   | R/W    |
| リセット値  | 0 | 0    | 0      | 0     | 0 | 0    | 0     | 0      |

## ▶ 'ット6 - DORD: データ順 (Data Order)

| 値  | 0               | 1               |
|----|-----------------|-----------------|
| 説明 | 語のMSBが先に送信されます。 | 語のLSBが先に送信されます。 |

## ● ビット5 - MASTER: 主/従装置選択 (Master/Slave Select)

このビットは望む動作形態を選びます。

SSが入力として構成設定され、このビットが'1'の間にLowへ駆動される場合、このビットが解除(0)され、割り込み要求フラグ(SPIn.INTFL AGS)レジスタの割り込み要求フラグ(IF)が設定(1)されます。使用者はSPI主装置動作を再び許可するためにMASTER='1'を再び書かなければなりません。

この動きは制御B(SPIn.CTRLB)レジスタの従装置選択禁止(SSD)ビットによって制御されます。

| 値  | 0          | 1          |
|----|------------|------------|
| 説明 | SPI従装置動作選択 | SPI主装置動作選択 |

## ● ビット4 - CLK2X: クロック倍速 (Clock Double)

このビットが、1、2を書かれると、SPI速度(内部前置分周された後のSCK周波数)が主装置動作で2倍にされます。

| 値  | 0                       | 1                           |
|----|-------------------------|-----------------------------|
| 説明 | SPI速度(SCK周波数)は2倍にされません。 | SPI速度(SCK周波数)は主装置動作で倍にされます。 |

## ● ビット2,1 - PRESC1,0: 前置分周器 (Prescaler)

このビット領域は主装置動作で構成設定されるSCK速度を制御します。これらのビットは従装置動作で無効です。SCKと周辺機能クロック周波数(fCLK\_PER)間の関連は下で示されます。

SPI前置分周器の出力はクロック倍速(CLK2X)ビットに'1'を書くことによって2倍にすることができます。

| 値  | 0 0       | 0 1        | 1 0        | 11          |
|----|-----------|------------|------------|-------------|
| 名称 | DIV4      | DIV16      | DIV64      | DIV128      |
| 説明 | CLK_PER/4 | CLK_PER/16 | CLK_PER/64 | CLK_PER/128 |

#### ● ビット0 - ENABLE: SPI許可 (SPI Enable)

| 値  | 0     | 1     |
|----|-------|-------|
| 説明 | SPI禁止 | SPI許可 |

#### **25.5.2. CTRLB - 制御B** (Control B)

名称: CTRLB 変位:+\$01 リセット: \$00 特質:-

| ピット    | 7     | 6     | 5 | 4 | 3 | 2   | 1   | 0    |
|--------|-------|-------|---|---|---|-----|-----|------|
|        | BUFEN | BUFWR |   |   |   | SSD | MOI | E1,0 |
| アクセス種別 | R/W   | R/W   | R | R | R | R/W | R/W | R/W  |
| リセット値  | 0     | 0     | 0 | 0 | 0 | 0   | 0   | 0    |

#### ● ビット7 - BUFEN:緩衝動作許可(Buffer Mode Enable)

このビットに'1'を書くことが緩衝動作を許可します。これは2つの受信緩衝部と1つの送信緩衝部を許可します。両方とも送信完了と受信完了の独立した割り込み要求フラグを持ちます。

## ● ビット6 - BUFWR: 緩衝動作受信待機 (Buffer Mode Wait for Receive)

このビットに'0'を書くと、最初に転送されるデータは偽装採取です。

| 値  | 0                                             | 1                                                           |
|----|-----------------------------------------------|-------------------------------------------------------------|
| 説明 | データが移動レジスタに複写される前に<br>1つのSPI転送が完了されなければなりません。 | SPIが許可され、SSがHighの時にデータレジスタへ書かれると、<br>最初の書き込みは移動レジスタへ直接行きます。 |

## ● ビット2 - SSD: 従装置選択禁止 (Slave Select Disable)

SPI主装置(制御A(SPIn.CTRLA)レジスタの主/従装置選択(MASTER)=1)として動く時にこのビットが設定(1)される場合、SS(のLow)は主装置動作を禁止しません。

| 値  | 0                       | 1                       |
|----|-------------------------|-------------------------|
| 説明 | SPI主装置としての動作時、従装置選択線を許可 | SPI主装置としての動作時、従装置選択線を禁止 |

#### ● ビット1,0 - MODE1,0:動作形態 (Mode)

これらのビットは転送動作形態を選びます。直列データに関してSCKの位相と極性の4つの組み合わせが下で示されます。これらのビッ トはクロック周期の先頭端(先行端)が上昇または下降のどちらか、データの設定と採取が先行端または後行端のどちらで起こるかを決めます。先行端が上昇の時のSCK信号はアイドル時にLowで、先行端が下降の時のSCK信号はアイドル時にHighです。

| 値  | 0 0 | 0 1                        | 1 0 | 1 1 |  |
|----|-----|----------------------------|-----|-----|--|
| 名称 | 0   | 1                          | 2   | 3   |  |
| 説明 |     | 先行端:上昇、出力設定<br>後行端:下降、入力採取 |     |     |  |

## 25.5.3. INTCTRL - 割り込み制御 (Interrupt Control)

名称:INTCTRL 変位:+\$02 リセット:\$00 特質:-

| ピット    | 7     | 6     | 5     | 4    | 3 | 2 | 1 | 0   |
|--------|-------|-------|-------|------|---|---|---|-----|
|        | RXCIE | TXCIE | DREIE | SSIE |   |   |   | ΙE  |
| アクセス種別 | R/W   | R/W   | R/W   | R/W  | R | R | R | R/W |
| リセット値  | 0     | 0     | 0     | 0    | 0 | 0 | 0 | 0   |

## ● ビット7 - RXCIE: 受信完了割り込み許可 (Receive Complete Interrupt Enable)

緩衝動作ではこのビット(=1)が受信完了割り込みを許可します。許可した割り込みは割り込み要求フラグ(SPIn.INTFLAGS)レジスタの受信完了割り込み要求フラグ(RXCIF)が設定(1)される時に起動されます。非緩衝動作ではこのビットが'0'です。

# ● ビット6 - TXCIE: 転送完了割り込み許可 (Transter Complete Interrupt Enable)

緩衝動作ではこのビット(=1)が転送完了割り込みを許可します。許可した割り込みは割り込み要求フラグ(SPIn.INTFLAGS)レジスタの転送完了割り込み要求フラグ(TXCIF)が設定(1)される時に起動されます。非緩衝動作ではこのビットが゙0'です。

## ● ビット5 - DREIE: データ レジスタ空割り込み許可 (Data Register Empty Interrupt Enable)

緩衝動作ではこのビット(=1)がデータ レジスタ空割り込みを許可します。許可した割り込みは割り込み要求フラグ(SPIn.INTFLAGS)レジスタのデータ レジスタ空割り込み要求フラグ(DREIF)が設定(1)される時に起動されます。非緩衝動作ではこのビットが'0'です。

#### ● ビット4 - SSIE: 従装置選択割り込み許可 (Slave Select trigger Interrupt Enable)

緩衝動作ではこのビット(=1)が従装置選択割り込みを許可します。許可した割り込みは割り込み要求フラグ(SPIn.INTFLAGS)レジスタの従装置選択割り込み要求フラグ(SSIF)が設定(1)される時に起動されます。非緩衝動作ではこのビットが<sup>'</sup>0'です。

#### ● ビット0 - IE:割り込み許可 (Interrupt Enable)

このビット(=1)はSPIが緩衝動作でない時のSPI割り込みを許可します。許可した割り込みは割り込み要求フラグ(SPIn.INTFLAGS)レジスタでRXCIF/IFが設定(1)される時に起動されます。

# 25.5.4. INTFLAGS - 割り込み要求フラグ - 標準動作 (Interrupt Flags - Normal Mode)

名称: INTFLAGS 変位: +\$03 リセット: \$00 特質: -

| ピット    | 7   | 6     | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|-----|-------|---|---|---|---|---|---|
|        | IF  | WRCOL |   |   |   |   |   |   |
| アクセス種別 | R/W | R/W   | R | R | R | R | R | R |
| リセット値  | 0   | 0     | 0 | 0 | 0 | 0 | 0 | 0 |

## ● ビット7 - IF:割り込み要求フラグ(Interrupt Flag)

このフラグは直列転送が完了して1バイトがデータ(SPIn.DATA)レジスタで完全に移動入出力された時に設定(1)されます。SPIが主装置動作の時にSSが入力として構成設定されてLowに駆動される場合、これもこのフラグを設定(1)します。IFはそれに'1'を書くことによって解除(0)されます。代わりに、IFはIFが設定(1)の時に最初にSPIn.INTFLAGSレジスタを読み、その後にSPIn. DATAレジスタをアクセスすることによって解除(0)することができます。

## ● ビット6 - WRCOL:書き込み衝突フラグ(Write Collision Flag)

WRCOLフラグはバイトが完全に送り出される前にデータ(SPIn.DATA)レジスタが書かれた場合に設定(1)されます。このフラグはWRCOLが設定(1)の時に最初にSPIn.INTFLAGSレジスタを読み、SPIn.DATAレジスタをアクセスすることによって解除(0)されます。

# 25.5.5. INTFLAGS - 割り込み要求フラグ - 緩衝動作 (Interrupt Flags - Buffer Mode)

名称: INTFLAGS 変位: +\$03 リセット: \$00 特質:-

| ヒット 7      | 6       | 5     | 4    | 3 | 2 | 1 | 0      |
|------------|---------|-------|------|---|---|---|--------|
| RXCII      | F TXCIF | DREIF | SSIF |   |   |   | BUFOVF |
| アクセス種別 R/W | R/W     | R/W   | R/W  | R | R | R | R/W    |
| リセット値 0    | 0       | 0     | 0    | 0 | 0 | 0 | 0      |

#### ● ビット7 - RXCIF: 受信完了割り込み要求フラグ (Receive Complete Interrupt Flag)

このフラグは受信データ緩衝レジスタに未読データがある時に設定(1)され、受信データ緩衝レジスタが空(即ち、どの未読データも含まない)時に解除(0)されます。

割り込み駆動データ受信が使われると、受信完了割り込みルーチンはRXCIFを解除(0)するためにデータ(SPIn.DATA)レジスタから受信したデータを読まなければなりません。そうしなければ、現在の割り込みから戻った直後に新しい割り込みが起きます。このフラグはこのビット位置へ'1'を書くことによっても解除(0)することができます。

## ● ビット6 - TXCIF: 転送完了割り込み要求フラグ(Transfer Complete Interrupt Flag)

このフラグは送信移動レジスタ内の全データが移動出力されてしまい、送信緩衝(SPIn.DATA)レジスタに新しいデータがない時に設定(1)されます。このフラグはこのビット位置へ'1'を書くことによって解除(0)されます。

## ● ビット5 - DREIF: データ レジスタ空割り込み要求フラグ(Data Register Empty Interrupt Flag)

このフラグは送信データ緩衝レシ、スタが新しいデータを受け取る準備が整っているかどうかを示します。このフラグは送信緩衝部が空の時に'1'で、送信緩衝部が未だ移動レジスタに移動されてしまっていない送信されるべきデータを含む時に'0'です。DREIFは送信部が準備可なことを示すためにリセット後に解除(0)されます。

DREIFはDATAレジスタ書き込みによって解除(0)されます。割り込み駆動データ送信が使われると、データレジスタ空割り込みルーチンは DREIFを解除(0)するためにDATAレジスタに新しいデータを書くか、またはデータレジスタ空割り込みを禁止するかのどちらかを行わなければなりません。そうしなければ、現在の割り込みから戻った直後に新しい割り込みが起きます。

#### ● ビット4 - SSIF: 従装置選択割り込み要求フラグ(Slave Select Trigger Interrupt Flag)

このフラグはSPIが主装置動作でSSピンが外部的にLowへ引かれ、故にSPIが今や従装置動作で動くことを示します。このフラグは従装置選択禁止(SSD)が'1'でない場合にだけ設定(1)されます。このフラグはこのビット位置へ'1'を書くことによって解除(0)されます。

#### ● ビット0 - BUFOVF: 緩衝部溢れフラグ(Buffer Overflow)

このフラケ は受信データ緩衝部満杯状態のためのデータ消失を示します。このフラケ は緩衝部溢れ状態が検出された場合に設定(1)されます。緩衝部溢れは受信緩衝部が満杯(2 バイト)で移動レシ 、スタで3つ目の バイトが受信される時に起きます。送信データがなければ、緩衝部溢れは新しい直列転送の開始前に設定(1)されません。このフラケ はDATAレシ 、スタが読まれる時か、またはこの ビット位置に '1'を書くことによって解除(0)されます。

# **25.5.6. DATA** - データ (Data)

名称: DATA 変位:+\$04 リセット: \$00 特質:-

| ピット    | 7   | 6   | 5   | 4   | 3    | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|------|-----|-----|-----|
|        |     |     |     | DAT | A7~0 |     |     |     |
| アクセス種別 | 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 - DATA7~0: データ (SPI Data)

DATAレジスタはデータの送受信に使われます。このレジスタへの書き込みは主装置動作の時にデータ送信を開始し、従装置動作では送るデータを準備します。このレジスタに書かれたバイトは処理が開始された時にSPI出力線へ移動出力されます。

SPIn.DATAレシ、スタは物理的なレシ、スタではありません。構成設定された動作形態に応じて、下で記述されるように他のレシ、スタに割り当てられます。

#### · 標準動作:

- DATAレジスタ書き込みは移動レジスタを書きます。
- DATAレジスタからの読み込みは受信データレジスタから読みます。

#### · 緩衝動作:

- DATAレジスタ書き込みは送信データ緩衝レジスタを書きます。
- DATAレジスタからの読み込みは受信データ緩衝レジスタから読みます。その後に受信データレジスタの内容が受信データ緩衝レジスタ に移動されます。

# 26. TWI - 2線インターフェース

## 26.1. 特徴

- ・2線通信インターフェース
- · Phillips社I2C適合
  - 標準動作
  - 高速動作
  - 高速動作+
- ・システム管理バス(SMBus)2.0適合
  - 開始条件/再送開始条件とデータ ビット間での調停を支援
  - アドレス解決規約(ARP)に対する支援を許す従装置調停
  - 構成設定可能なハートウェアでのSMBus階層1制限時間
- 独立した主装置と従装置の動作
  - 結合(同一ピン)
  - 完全な調停支援での単一または複数の主装置バス動作
- ・従装置アドレス一致に対するハードウェア支援
  - 全ての休止動作での動作
  - 7ビットアドレス認識
  - 一斉呼び出しアドレス認識
  - アドレス範囲遮蔽または第2アドレス一致に対する支援
- ・バス雑音消去用入力濾波器
- 簡便動作支援

## 26.2. 概要

2線インターフェース(TWI)は直列データ(SDA)線と直列クロック(SCL)線を持つ双方向2線通信インターフェース(バス)です。

TWIn'スは1つまたは複数の従装置を1つまたは複数の主装置に接続します。n'スに接続されたどの装置も主装置、従装置、または両方として働くことができます。主装置はボーレート発生器(BRG)を使ってSCLを生成し、1つの従装置をアドレス指定してデータを送るまたは受け取るのどちらを望むかを告げることによってデータ処理を始めます。BRGは100kHzから1MHzまでの標準動作(Sm)と高速動作(Fm、Fm+)n'ス周波数を生成することができます。

TWIは開始条件、停止条件、パス衝突、パス異常を検出します。協調損失、異常、衝突、クロック保持も検出され、主装置と従装置の両動作で利用可能な独立した状態フラグで示されます。

TWIは複数主装置のバス動作と調停を支援します。 調停の仕組みは複数の主装置が同時にデータを送信しようとする場合を処理します。 TWIは自動起動操作ができ、故にソフトウェアの複雑さを減らすことができる簡便動作も支援します。 TWIはデータ交換なしに主装置が従装置をアドレス指定することができる迅速指令動作を支援します。

#### 26.2.1. 構成図



## 26.2.2. 信号説明

| 信号  | 形式      | 説明      |
|-----|---------|---------|
| SCL | デジタル入出力 | 直列クロック線 |
| SDA | デジタル入出力 | 直列データ線  |

## 26.3. 機能的な説明

## 26.3.1. 一般的なTWIバスの概念

TWIは以下から成る簡素な双方向2線通信バスを提供します。

- ・パケット転送用の直列データ(SDA)線
- ・ バス クロック用の直列クロック(SCL)線

2つの線は開放コレクタ(ドレイン)線(ワイヤードAND)です。

TWIハ、ス形態は直列ハ、スで複数装置を接続する簡単で効率的な方法です。ハ、スに接続された装置は主装置または従装置にできます。主装置だけがハ、スとハ、ス通信を制御できます。

ハベスに接続した各従装置に固有のアドレスが割り当てられ、主装置は従装置を制御して処理を始めるのにこれを使います。複数の主装置を同じハベスに接続することができ、複数主装置環境と呼ばれます。何時でも1つの主装置だけがハベスを自身のものにできるので、主装置間でハベス所有権を解決するために調停機構が提供されます。

主装置はバス上に開始条件(S)を発行することによって転送処理の開始を指示します。主装置は転送処理用のクロック信号を提供します。アビット従装置アドレス(ADDRESS)と、主装置がデータを読みまたは書きどちらをしたいのかを表す方向(R/W)ビットを持つアドレス パケットがその後に送られます。

アト・レス指定されたI<sup>2</sup>C従装置はその後にアト・レスを<mark>確認応答</mark>(ACK)し、データ ハ<sup>°</sup>ケット転送処理を始めることができます。毎回の9ビット データ ハ<sup>°</sup>ケットは8つのデータ ビットとそれに続き、受信側によってデータが受け取られたか否かのどちらかを示す1ビット応答から成ります。

全てのデータ パケット(DATA)転送後、主装置は転送処理を終わるためにバス上で停止条件(P)を発行します。



### 26.3.2. TWI基本動作

#### 26.3.2.1. 初期化

使われるなら、TWI周辺機能を許可する前に以下のビットを構成設定してください。

- ・制御A(TWIn.CTRLA)レシ、スタのSDA保持時間(SDAHOLD)ビット領域
- ・制御A(TWIn.CTRLA)レジスタの高速動作+(FMPEN)ビット

#### 26.3.2.1.1. 主装置初期化

有効なTWIへ、クロック周波数になる値を主装置ボーレート(TWIn.MBAUD)レシ、スタに書いてください。主装置制御A(TWIn.MCTRLA)レシ、スタのTWI主装置許可(ENABLE)と、ットに、1、を書くことがTWI主装置を開始します。 へ、ス状態をアイト・ル(IDLE)に強制するために主装置状態(TWIn.MSTATUS)レシ、スタのハ、ス状態(BUSSTATE)と、小り間域が、01、に設定されなければなりません。

## 26.3.2.1.2. 従装置初期化

従装置を初期化するには以下のこれらに従ってください。

- 1. TWI従装置を許可する前に制御A(TWIn.CTRLA)レシブスタのSDA準備時間(SDASETUP)ビットを構成設定してください。
- 2. 従装置アドレスを従装置アドレス(TWIn.SADDR)レジスタに書いてください。
- 3. TWI従装置を許可するため、従装置制御A(TWIn.SCTRLA)レジスタの従装置許可(ENABLE)ビットに'1'を書いてください。 TWI従装置は主装置が開始条件を発行して従装置アドレスと一致するのを待ちます。

#### 26.3.2.2. TWI主装置動作

TWI主装置は各バイ後の任意選択の割り込みを持つバイトを向です。主装置の書き込みと読み込みの操作に対して独立した割り込み要求フラグがあります。割り込み要求フラグはポーリング操作にも使うことができます。専用の状態フラグが受信した(ACK)確認応答/(NACK)で認応答(RXACK)、バス異常(BUSERR)、調停敗退(ARBLOST)、クロック保持(CLKHOLD)、バス状態(BUSSTATE)を示します。

割り込み要求フラグが'1'に設定されると、SCLはLowを強制され、応答または何れかのデータを扱う時間を主装置に与え、殆どの場合でソフトウェアの介在を必要とするでしょう。割り込み要求フラグの解除(0)がSCLを開放します。生成された割り込み数は殆どの条件を自動的に処理することによって最小に留められます。

# 26.3.2.2.1. クロック生成

TWIは次のような異なる周波数制限を持ついくつかの送信動作形態を支援します。

- 100kHzまでの標準動作(Sm)
- 400kHzまでの高速動作(Fm)
- ・1MHzまでの高速動作+(Fm+)

主装置ボーレート(TWIn.MBAUD)レシ、スタは送信動作形態に応じてそれらの周波数制限以下のTWIハ、スクロック周波数になる値を書かれなければなりません。

Low(t<sub>LOW</sub>)とHigh(t<sub>HIGH</sub>)の時間は主装置ボーレート(TWIn.MBAUD)レジスタによって決められる一方で、上昇(t<sub>R</sub>)と下降(t<sub>OF</sub>)の時間はハース形態によって決められます。



- ・tLOWはSCLクロックのLow期間です。
- ・ t<sub>HIGH</sub>はSCLクロックのHigh期間です。
- ・tRは内部プルアップに対するバス インピーダンスによって決められます。詳細については「電気的特性」を参照してください。
- ・toFはオープントレイン電流制限とバス インピーダンスによって決められます。詳細については「電気的特性」を参照してください。

#### SCLクロックの特性

SCL周波数は右式によって与えられます。

SCLクロックは50/50のデューティ サイクルを持つように設計され、デューティ サイクルのLow部分は $t_{OF}$ と $t_{LOW}$ から成ります。 $t_{HIGH}$ はSCLのHigh状態が検出されるまで始まりません。TWIn.MBAUDレジスタのボーレート(BAUD)ヒット領域とSCL周波数は右式(式1)によって関連付けられます。

式1はBAUDを表すように変形(式2)することができます。

$$f_{SCL} = \frac{1}{t_{LOW} + t_{HIGH} + t_{OF} + t_{R}}$$
 [Hz]
$$f_{CLK PER}$$

$$f_{\text{SCL}} = \frac{f_{\text{CLK\_PER}}}{10 + 2 \times \text{BAUD} + f_{\text{CLK\_PER}} \times t_{\text{R}}}$$
 (1)

BAUD = 
$$\frac{f_{\text{CLK\_PER}}}{2 \times f_{\text{SCL}}} - \left(5 + \frac{f_{\text{CLK\_PER}} \times t_{\text{R}}}{2}\right)$$
 (2)

#### BAUD値の計算

望む速度動作(Sm、Fm、Fm+)の仕様内での動作を保証するため、これらの手順に従ってください。

- 1. 式2を使ってBAUDビット領域用の値を計算してください。
- 2. 手順1.からのBAUD値を使ってt<sub>LOW</sub>を計算してください。

$$t_{LOW\_Fm} = t_{LOW\_Fm^+} = \frac{BAUD + 6 + min(SCLDUTY, BAUD)}{f_{CLK\_PER}} - t_{OF} \quad \textbf{(3.1)} \qquad t_{LOW\_Sm} = \frac{BAUD + 6}{f_{CLK\_PER}} - t_{OF} \quad \textbf{(3.2)}$$

- 3. 式3.からのt<sub>LOW</sub>が望む動作形態で指定された最小(t<sub>LOW\_Sm</sub>=4700ns、t<sub>LOW\_Fm</sub>=1300ns、t<sub>LOW\_Fm</sub>+=500ns)を超えるか調べてください。
  - 計算されたt<sub>LOW</sub>が限度を超える場合、式2からのBAUDを使ってください。
  - 限度に合わない場合、右の**式4**を使って新しいBAUD値を計算してください。ここでの $t_{LOW\_mode}$ は動作仕様からの $t_{LOW\_Sm}$ 、 $t_{LOW\_Fm}$ 、 $t_{LOW\_Fm}$ + のどれかです。

BAUD = 
$$f_{\text{CLK\_PER}} \times (T_{\text{LOW\_mode}} + t_{\text{OF}}) - 3$$
 (4)

#### 26.3.2.2.2. TWIバス状態論理

バス状態論理回路は主装置動作が許可された時にTWIバス上の動きを継続的に監視します。それはパワーダウンを含む全ての休止動作形態で動作を続けます。

ハ、ス状態論理回路は開始条件と停止条件の検出器、衝突検出、不活性ハ、ス時間超過検出、ピット計数器を含みます。これらはハ、ス状態を決めるのに使われます。ソフトウェアは主装置状態(TWIn.MSTATUS)レシ、スタのハ、ス状態(BUSSTATE)ピット領域を読むことによって現在のハ、ス状態を得ることができます。

バス状態は未知、アイドル、使用中、所有者になることができ、 右で示される状態遷移図に従って決められます。



- 1. 未知: バス状態機構はTWI主装置が許可される時に有効です。TWI主装置許可、システム リセット実行、またはTWI主装置禁止後、 バス状態は未知です。
- 2. アイドル: バス状態(BUSSTATE)ビット領域に'01'を書くことによってバス状態機構をアイドル状態に入ることを強制することができます。 n゙ス状態論理回路を他のどの状態にも強制することはできません。最初の停止条件が検出される時に応用ソフトウェアによって状態が設定されなければ、バス状態はアイドルになります。主装置制御A(TWIn.MCTRLA)レジスタの主装置不活性バス時間制限(TIMEOUT)ビット領域が0以外の値に構成設定される場合、バス状態は時間超過の発生でアイドルに変わります。
- 3. 使用中: バスがアイドルの時に外部的に生成された開始条件が検出された場合、バス状態が使用中になります。バス状態は停止条件が検出されるか、または構成設定されている場合に制限時間超過が設定される時にアイドルへ変わります。
- 4. 所有者: バスがアイドルの時に内部的に開始条件が生成される場合、バス状態が所有者になります。妨害なしで完全な転送処理が 実行された場合、主装置は停止条件を発行し、バス状態がアイドルに戻ります。衝突が検出されて調停に敗れた場合、バ ス状態は停止条件が検出されるまで使用中になります。

#### 26.3.2.2.3. アトレス パケット送信

主装置は7ビット従装置アドレスとR/W方向ビットと共に主装置アドレス(TWIn.MADDR)レジスタが書かれる時にバス転送処理の実行を開始します。MADDRレジスタの値がその後に主装置データ(TWIn.MDATA)レジスタへ複写されます。バス状態が使用中の場合、TWI主装置は開始条件を発行する前にバス状態がアイドルになるまで待ちます。TWIは開始条件を発行し、移動レジスタがバス上でバイト送信動作を実行します。

調停とR/W方向ビットに依存して、アドレス パケットの送信後に4つの事例(M1~M4)の1つが起きます。



#### 26.3.2.2.3.1. 事例M1: アドレス パケット送信完了 - 方向ビット=0

従装置がアトンス パケットに対して確認応答(ACK)で応答する場合、TWIn.MSTATUSレシブスタで書き込み割り込み要求フラグ(WIF)が'1'に設定され、受信応答(RXACK)フラグが'0'に設定され、クロック保持(CLKHOLD)フラグが'1'に設定されます。WIF、RXACK、CLKHOLDのフラグは主装置状態(TWIn.MSTATUS)レシブスタに配置されます。

この時点でクロック保持が有効で、SCLにLowを強制し、クロック周波数全体を低下するようにクロックのLow期間を引き延ばし、データを処理するのに必要とされる遅延を強制してバスでの更なる活動を防ぎます。

ソフトウェアは以下の準備をすることができます。

・ 従装置ヘデータ パケット送信

#### 26.3.2.2.3.2. 事例M2: アドレス パケット送信完了 - 方向ビット=1

従装置がアトレス パケットに対して確認応答(ACK)で応答する場合、受信応答(RXACK)フラグが'0'に設定され、この時点で従装置がバスを所有するため、従装置はどんな遅延もなしに主装置へのデータ送出を開始することができます。この時点でクロック保持が有効で、SCLにLowを強制します。

ソフトウェアは以下の準備をすることができます。

・従装置から受け取ったデータパケットの読み込み

#### 26.3.2.2.3.3. 事例M3: アドレス パケット送信完了 - 従装置によるアドレス否認応答

従装置がアトレス パケットに応答しない場合、書き込み割り込み要求フラク (WIF)と受信応答(RXACK)フラグが '1'に設定されます。この時点でクロック保持が有効で、SCLにLowを強制します。

確認応答(ACK)欠落はI<sup>2</sup>C従装置が他の作業で多忙か、または休止動作で応答できないことを示し得ます。

ソフトウェアは以下の活動の1つを取るための準備をすることができます。

- アトレス パケットの再送信
- ・主装置制御B(TWIn.MCTRLB)レジスタの指令(MCMD)ビット領域で<mark>停止条件</mark>を発行することによって転送処理を完了、これが推奨される活動です。

#### 26.3.2.2.3.4. 事例M4: 調停敗退またはバス異常

調停で敗れた場合、主装置状態(TWIn.MSTATUS)レジスタで書き込み割り込み要求フラグ(WIF)と調停敗退(ARBLOST)のフラグが'1'に 設定されます。SDAは禁止されてSCLが開放されます。ハス状態が使用中に変わり、主装置はバス状態がアイデルに戻るまで、もはやバスでどの操作も実行することを許されません。

バス異常は調停敗退状態と同じように振舞います。この場合、WIFとARBLOSTのフラグに加えて、TWIn.MSTATUSレジスタでバス異常 (BUSERR)フラグが '1'に設定されます。

ソフトウェアは以下の準備をすることができます。

・TWIn.MSTATUSレシ`スタのハ`ス状態(BUSSTATE)ビット領域を読むことによってハ`ス状態がアイドルに変わるまで操作を中止して待機

#### 26.3.2.2.4. データ パケット送信

上の事例M1と仮定し、TWI主装置は主装置データ(TWIn.MDATA)レジスタへ書くことによってデータ送信を開始することができ、それは書き込み割り込み要求フラケ(WIF)も解除(0)します。データ転送の間、主装置は衝突と異常に関してバスを継続的に監視します。データパケット転送完了後、WIFフラケが、1、に設定されます。

送信が成功して主装置が従装置からACKビットを受け取る場合、受信応答(RXACK)フラグが'1'に設定され、従装置が新しいデータ パケットを受け取る準備が整っていることを意味します。

ソフトウェアは以下の活動の1つを取るための準備をすることができます。

- 新しいデータ パケットの送信
- ・新しいアドレスパケットの送信
- ・主装置制御B(TWIn.MCTRLB)レジスタの指令(MCMD)ビット領域で停止条件を発行することによって転送処理を完了

送信が成功して主装置が従装置から<mark>否認応答</mark>(NACK)ビットを受け取る場合、RXACKフラグが'1'に設定され、従装置がもっとデータを受け取ることができないか、または必要でないことを意味します。

ソフトウェアは以下の活動の1つを取るための準備をすることができます。

- ・新しいアドレスパケットの送信
- ・主装置制御B(TWIn.MCTRLB)レシ、スタの指令(MCMD)ヒ、ット領域で停止条件を発行することによって転送処理を完了

受信応答(RXACK)フラク・の状態はWIFフラク・が'1'に設定され場合にだけ有効で、調停敗退(ARBLOST)とハンス異常(BUSERR)のフラク・は'0'に設定されます。

送信は衝突が検出される場合、不成功になり得ます。その後、主装置は調停に敗れ、調停敗退(ARBLOST)フラグが'1'に設定されべる状態が使用中に変わります。データ パケット転送中の調停敗退は上の事例M4と同じように扱われます。

WIF、ARBLOST、BUSERR、RXACKのフラグは全て主装置状態(TWIn.MSTATUS)レジスタに配置されます。

### 26.3.2.2.5. データ パケット受信

上の事例M2と仮定し、クロックが1バイト間開放され。従装置がバス上に1バイトのデータを出すのを許します。主装置は従装置から1バイトのデータを受け取り、クロック保持(CLKHOLD)フラク。と共に読み込み割り込み要求フラク(RIF)が、1 に設定されます。指令が主装置制御B(TWIn.MCTRLB)レシ、スタの指令(MCMD)ヒ、ット領域に書かれる時に、TWIn.MCTRLBレシ、スタの応答動作(ACKACT)ヒットによって選ばれた活動が自動的にバス上で送られます。

ソフトウェアは以下の活動の1つを取るための準備をすることができます。

- ・主装置制御B(TWIn.MCTRLB)レシ<sup>†</sup>スタの応答動作(ACKACT)ビットに<sup>'</sup>0'を書くことによって<mark>確認応答</mark>(ACK)で応答し、新しいテ<sup>\*</sup>ータ ハ<sup>\*</sup>ケットを受け取る準備
- ・ACKACTビットに'1'を書くことによって否認応答(NACK)で応答し、その後に新しいアドレス パケットを送信
- ・ACKACTビットに'1'を書くことによってNACKで応答し、その後にTWIn.MCTRLBレジスタの指令(MCMD)ビット領域で停止条件を発行することによって転送処理を完了

NACK応答はその送信中に調停が失われ得るため、成功裏に実行しないかもしれません。衝突が検出される場合、主装置は調停を失い、調停敗退(ARBLOST)フラケが'1'に設定され、バス状態が使用中に変わります。NACK送出時に調停が失われた場合、またはこの手順中にバス異常が起きた場合に主装置書き込み割り込み要求フラケ(WIF)が設定(1)されます。データ パケット転送中の調停敗退は前の事例M4のように扱われます。

RIF、CLKHOLD、ARBLOST、WIFのフラケは全て主装置状態(TWIn.MSTATUS)レジスタに配置されます。

注: RIFとWIFのフラグは相互排他で、同時に設定(1)され得ません。

#### 26.3.2.3. TWI従装置動作

TWI従装置は各バイト後の任意選択の割り込みを持つバイト志向です。従装置データ用とアドレス/停止認識用に独立した割り込みフラグがあります。割り込みフラグはポーリング操作に使うこともできます。専用の状態フラグが受信した確認応答(ACK)/否認応答(NACK)、クロック保持、衝突、バス異常、R/W方向を示します。

割り込み要求フラグが'1'に設定されると、SCLはLowを強制され、応答または何かのデータを扱う時間を従装置に与え、殆どの場合でソフトウェアの介在を必要とするでしょう。生成された割り込み数は殆どの条件の自動処理によって最小に留められます。

従装置制御A(TWIn.SCTRLA)レジスタのアトレス認識動作(PMEN)ビットは受信した全てのアトレスに応答することを従装置に許すように構成設定することができます。

#### 26.3.2.3.1. アトレス パケット受信

TWIが従装置として構成設定されると、検出されるべき<mark>開始条件</mark>を待ちます。これが起こると、継続してアトンス パケットが受信されてアトンス一致論理回路によって調べられます。従装置は正しいアトンスに<mark>確認応答(ACK)し、従装置データ(TWIn.SDATA)レシンスタにアトンスを保存します。受信したアトンスが一致しなければ、従装置は応答やアトンスの保存をせず、新しい開始条件を待ちます。</mark>

開始条件が以下によって後続されると、従装置状態(TWIn.SSTATUS)レジブタの従装置アドレス/停止割り込み要求フラグ(APIF)が'1'に設定されます。

- ・有効なアトレスが従装置アトレス(TWIn.SADDR)レシ、スタのアトレス(ADDR7~1)ヒット領域に格納されたアトレスと一致
- ・一斉呼び出しアトンス(\$00)で従装置アトンス(TWIn.SADDR)レジスタのアトンス(ADDRo)ビットが'1'に設定
- ・従装置アトンス遮蔽(TWIn.SADDRMASK)レシ、スタでアトンス許可(ADDREN)ヒットが'1'に設定され、有効なアトンスがアトンス遮蔽(ADDR MASK)ヒット領域に格納されたアトンスと一致
- ・従装置制御A(TWIn.SCTRLA)レシ、スタのアト・レス認識動作(PMEN)ヒットが、11に設定された場合の全てのアト・レス

従装置状態(TWIn.SSTATUS)レジスタの読み/書き方向(DIR)ビットとバス状況に応じて、アドレス パケットの受信後に続いて4つの事例(S1 ~S4)の1つが起きます。



## 26.3.2.3.1.1. 事例S1: アドレス パケット受け入れ - 方向ビット=0

アト・レス パケット受信後に従装置によって<mark>確認応答</mark>(ACK)が送られ、従装置状態(TWIn.SSTATUS)レシ、スタの読み/書き方向(DIR)ヒ、ットが '0'に設定される場合、主装置が書き込み操作を指示します。

この時点でクロック保持が有効で、SCLにLowを強制し、クロック周波数全体を低下するようにクロックのLow期間を引き延ばし、データを処理するのに必要とされる遅延を強制してバスでの更なる活動を防ぎます。

ソフトウェアは以下の準備をすることができます。

主装置から受け取ったデータパケットの読み込み

#### 26.3.2.3.1.2. 事例S2: アドレス パケット受け入れ - 方向ビット=1

アトレス パケット受信後に従装置によって確認応答(ACK)が送られ、従装置状態(TWIn.SSTATUS)レジスタで読み/書き方向(DIR)ビットが '1'に設定される場合、主装置が読み込み操作を指示し、データ割り込み要求フラグ(DIF)が'1'に設定されます。

この時点でクロック保持が有効で、SCLにLowを強制します。

ソフトウェアは以下の準備をすることができます。

・主装置ヘデータパケット送信

#### 26.3.2.3.1.3. 事例S3: 停止条件受信

停止条件が受信されると、アドレス/停止条件フラケ(AP)が'0'に設定され、アドレス一致ではなく停止条件を示し、アドレス/停止割り込み要求フラケ(APIF)が有効(1)にされます。

APとAPIFのフラグは従装置状態(TWIn.SSTATUS)レジスタに配置されます。

ソフトウェアは以下の準備をすることができます。

・新しいアトレスパケットがアトレス指定するまで待機

#### 26.3.2.3.1.4. 事例S4: 衝突

従装置がHighレヘブルのデータ ビットまたは<mark>否認応答</mark>(NACK)を送ることができない場合、従装置状態(TWIn.SSTATUS)レジスタの衝突(COLL)フラグが'1'に設定されます。従装置はSDAでLow値が移動出力されないことを除き、通常動作を始めます。従装置論理回路からのデータと応答の出力が禁止されます。クロック保持は開放されます。開始条件と再送開始条件は受け入れられます。

COLLビットはアドレス解決規約(ARP)が使われるシステムに対して意図されています。非ARP状況で検出した衝突は規約違反があってバス異常として扱われなければならないことを示します。

#### 26.3.2.3.2. データ パケット受信

前の事例S1と仮定し、従装置はデータを受信する準備を整えなければなりません。データ パケットが受信されると、従装置状態(TWIn.SS TATUS)レジ、スタのデータ割り込み要求フラウ、(DIF)が、1、に設定されます。指令が従装置制御B(TWIn.SCTRLB)レジ、スタの指令(SCMD)ヒット領域に書かれる時に、TWIn.SCTRLBレジ、スタの応答動作(ACKACT)ヒットによって選ばれた活動が自動的にバス上で送られます。

ソフトウェアは以下の活動の1つを取るための準備をすることができます。

- ・TWIn.SCTRLBレジブスタのACKACTビットに'0'を書くことによって<mark>確認応答</mark>(ACK)で応答、従装置がもっとデータを受け取る準備が整っていることを示します。
- ・ACKACTビットに'1'を書くことによって<mark>否認応答</mark>(NACK)で応答、従装置がこれ以上データを受け取ることができず、主装置が<mark>停止条件</mark>または再送開始条件を発行しなければならないことを示します。

#### 26.3.2.3.3. データ パケット送信

上の事例S2と仮定し、従装置は従装置データ(TWIn.SDATA)レジスタへ書くことによってデータ送信を開始することができます。データハ°ケット送信が完了されると、従装置状態(TWIn.SSTATUS)レジスタのデータ割り込み要求フラグ(DIF)が'1'に設定されます。

ソフトウェアは以下の活動の1つを取るための準備をすることができます。

- ・TWIn.SSTATUSレジスタの受信応答(RXACK)ビットを読むことによって主装置が確認応答(ACK)で応答したかを調べ、新しいデータ パケット送信を開始
- ・RXACKを読むことによって主装置が否認応答(NACK)で応答したかを調べ、データ パケット送信を停止。主装置はNACK後に停止 条件または再送開始条件を送らなければなりません。

## 26.3.3. 付加機能

#### 26.3.3.1. SMBus

TWIをSMBus環境で使う場合、主装置制御A(TWIn.MCTRLA)レシ、スタの不活性バス制限時間(TIMEOUT)ビット領域が構成設定されなければなりません。これがホーレート設定に依存するため、この制限時間を設定する前に主装置ホーレート(TWIn.MBAUD)レシ、スタを書くことが推奨されます。

SMBus環境に対して100kHzの周波数を使うことができます。標準動作(Sm)と高速動作(Fm)に対して動作周波数はスリューレート制限された出力を持つ一方で、高速動作+(Fm+)に対しては10倍の出力駆動能力を持ちます。

TWIは制御A(TWIn.CTRLA)レジネタのSDA保持時間(SDAHOLD)ビット領域で構成設定されるSMBus互換SDA保持時間も許します。

## 26.3.3.1.1. SMBus仕様への適合性

#### ハート・ウェア仕様制限

SMBus 2.0仕様の第2章は電力断の装置は接地への漏れ経路を提供してはならないと述べられています。このデバイスに於いてSCLとSDAに使われるパットとVDD間に置かれたESDダイオートがあります。電力断の時にVDDが接地と等価と仮定すると、それらのESDダイオートが接地への経路を提供します。

#### ソフトウェアでの実装

SMBus 2.0仕様の以下の要素はハードウェアで実装されません。

- ・SMBus 2.0仕様の表1は25~35msの最大クロックLow制限時間(Ttimeout)を与え、これは事象システムを使ってSCLピンをTCB周辺機能に接続することによって実装することができます。望む制限時間値と共に制限時間検査動作でTCBを構成設定してください。
- ・第3層(網(Network)層)はハッケット誤り検査(PEC:Packet Error Check)、アドレス解決規約(ARP:Address Resolution Protocol)などが特徴です。これらは必要とされる場合にソフトウェアで実装することができます。

#### 26.3.3.2. 複数主装置

主装置はバスがアイ・ルなことを検出した場合にだけバス転送処理を開始することができます。複数の主装置がバス上にある場合、他の装置が同時に転送処理を始めようとするかもしれず、結果的に複数の主装置がバスを所有することになります。TWIはSDAでHighレベルのデータビットを送信することができず、主装置状態(TWIn.MSTATUS)レジスタのバス状態(BUSSTATE)ビット領域が使用中に変わる場

合に主装置がバスの制御を失うような調停の仕組みを使う ことによってこの問題を解決します。調停で敗れた主装置 はバス所有権の再取得を試みる前にバスがアイドルになるま で待たなければなりません。

(図で)両装置は<mark>開始条件</mark>を発行することができますが、主装置1は主装置2がLowレベルを送信している間にHighレベル(ビット5)の送信を試みる時、調停に敗れます。



#### 26.3.3.3. 簡便動作

TWIインターフェースは応用コードを簡単化してI<sup>2</sup>C規約を守るのに必要とされる使用者関係処理を最小にする簡便動作を持ちます。

TWI主装置に対し、簡便動作は主装置データ(TWIn.MDATA)レジスタが読まれると直ぐに確認応答(ACK)活動を自動的に送ります。この機能は主装置制御B(TWIn.MCTRLB)レジスタの応答動作(ACKACT)ビットが確認応答(ACK)に設定(=0)される時にだけ有効です。TWI主装置はACKACTが否認応答(NACK)に設定(=1)される場合にデータレジスタ読み込み後に否認応答(NACK)ビットを生成しません。この機能は主装置制御A(TWIn.MCTRLA)レジスタの簡便動作許可(SMEN)ビットが'1'に設定される時に許可されます。

TWI従装置に対し、簡便動作は従装置データ(TWIn.SDATA)レシ、スタが読まれると直ぐに確認応答(ACK)活動を自動的に送ります。簡便動作はTWInSDATAレジタが読み書きされた場合に従装置状態(TWIn.SSTATUS)レシ、スタのデータ割り込み要求フラグ(DIF)を自動的に、 $^{1}$ 0、に設定します。この機能は従装置制御A(TWIn.SCTRLA)レジ、スタの簡便動作許可(SMEN)ヒットが、 $^{1}$ 1、に設定される時に許可されます。

# 26.3.3.4. 迅速指令動作

迅速動作でのアドレス パケットのR/Wビットが指令を示します。この動作は主装置制御A(TWIn.MCTRLA)レジスタの迅速指令許可(QCEN) ビットに'1'を書くことによって許可されます。データの送受信はありません。

迅速指令はSMBus仕様で、R/Wビットを装置機能のON/OFF切り替え、または低電力待機動作の許可/禁止に使います。この動作は自動起動操作を許してソフトウェアの複雑さ減らすことができます。

主装置が従装置から確認応答(ACK)を受け取った後、R/Wt'ットの値に応じて主装置読み割り込み要求フラク'(RIF)または主装置書き割り込み要求フラク'(WIF)のどちらかが設定(1)されます。迅速指令発行後にRIFまたはWIFのフラクが設定(1)されると、TWIは主装置制御B(TWIn.MCTRLB)レシブスタの指令(MCMD)t'ット領域を書くことによって停止(停止条件)指令を受け入れます。最後の受信応答(RXACK)フラク と共にRIFとWIFのフラク は全て主装置状態(TWIn.MSTATUS)レシブスタに配置されます。



#### 26.3.3.5. 10ビット アドレス

転送処理が読みか書きかに関わらず、主装置はR/W方向ビットを'0'に設定して10ビット アドレスを送ることによって開始されなければなりません。

従装置アト・レス一致論理回路はアビット アドレスと一斉呼び出しアドレスの認識を支援するだけです。主装置がTWI従装置をアドレス指定したかを決めるため、従装置アドレス一致論理回路によって従装置アドレス(TWIn.SADDR)レジスタが使われます。

TWI従装置アドレス一致論理回路は10ビット アドレスの最初のバイトの認識を支援するだけで、第2バイトはソフトェアで処理されなければなりません。10ビット アドレスの最初のバイトは従装置アドレス(TWIn.SADDR)レジスタの上位5ビットが゙11110゚の場合に認識されます。従って、最初のバイトは5つの指示ビット、10ビット アドレスの上位2ビット(MSb)、R/W方向ビットから成ります。それに続く主装置からの下位側バイト(LSB)はデータ パケットの形式で来ます。

| 図26-9. 10ビット アドレス転送 | 処理                                                    |                          |
|---------------------|-------------------------------------------------------|--------------------------|
| S - 1               | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | A5 A4 A3 A2 A1 A0 -+A    |
| SW ソフトウェア関連処理       | 主装置がバス上にデータを供給                                        | アト・レス指定された従装置がバス上にデータを供給 |

# 26.3.4. 割り込み

| 表26-1. 和 | 可用可能な割り込みベクタと供給ラ | Ē                                                                                                             |
|----------|------------------|---------------------------------------------------------------------------------------------------------------|
| 名称       | ベクタ説明            | 条件                                                                                                            |
| Slave    | TWI従装置割り込み       | <ul> <li>DIF: TWIn.SSTATUSのデータ割り込み要求フラグを'1'に設定</li> <li>APIF: TWIn.SSTATUSのアドレス/停止割り込み要求フラグを'1'に設定</li> </ul> |
| Master   | TWI主装置割り込み       | <ul> <li>RIF: TWIn.MSTATUSの読み込み割り込み要求フラグを'1'に設定</li> <li>WIF: TWIn.MSTATUSの書き込み割り込み要求フラグを'1'に設定</li> </ul>    |

割り込み条件が起こると、主装置状態(TWIn.MSTATUS)レジスタまたは従装置状態(TWIn.SSTATUS)レジスタで対応する割り込み要求フラグが設定(1)されます。

いくつかの割り込み要求条件が割り込みへつりによって支援される時に、割り込み要求は割り込み制御器に対して1つの結合された割り込み要求へ共に論理和(OR)されます。使用者はどの割り込み条件が存在するかを決めるのにTWIn.MSTATUSまたはTWIn.SSTATUSのレシブスタから割り込み要求フラクブを読まなければなりません。

# 26.3.5. 休止形態動作

n'ス状態論理回路とアドレス認識ハードウェアは全ての休止動作形態で動作を続けます。TWI従装置が休止動作で開始条件に続いて従装置アドレスが検出された場合、主クロックが利用可能になるまでの起き上がり期間の間、クロック伸長が有効です。TWI主装置は全ての休止動作で動作を停止します。二元動作が有効な時は、開始条件がTWI従装置によって受信された時にだけTWI周辺機能が起き上がります。

# 26.3.6. デバッグ操作

走行時デバッグの間、TWIはそれの通常動作を続けます。デバッグ動作でのCPU停止はTWIの通常動作を停止します。TWIはデバッグ制御(TWIn.DBGCTRL)レジスタのデバッグ時走行(DBGRUN)ビットに、1'を書くことによって停止されたCPUでの動作を強制することができます。デバッグ動作でCPUが停止され、DBGRUNビットが、1'の時に、主装置データ(TWIn.MDATA)レジスタと従装置データ(TWIn.SDATA)レジスタの読み書きは決してバス操作を起動したり、送信を引き起こしてフラグを解除(0)しません。TWIが割り込みや同様のものを通してCPUによって定期的な処理を必要とするように構成設定される場合、停止されたデバッグの間に不正な動作やデータ損失になるかもしれません。

# 26.4. レジスタ要約

| 変位    | 略称        | ビット位置        | ヒ゛ットフ | じット6         じット5         じット4         じット3         じット2         じット1 |            |              |         |        |       | ピット0   |
|-------|-----------|--------------|-------|-----------------------------------------------------------------------|------------|--------------|---------|--------|-------|--------|
| +\$00 | CTRLA     | 7~0          |       |                                                                       |            | SDASETUP     | SDAH    | DLD1,0 | FMPEN |        |
| +\$01 | 予約        |              |       |                                                                       |            |              |         |        |       |        |
| +\$02 | DBGCTRL   | 7 <b>~</b> 0 |       |                                                                       |            |              |         |        |       | DBGRUN |
| +\$03 | MCTRLA    | 7 <b>~</b> 0 | RIEN  | WIEN                                                                  |            | QCEN         | TIMEC   | OUT1,0 | SMEN  | ENABLE |
| +\$04 | MCTRLB    | 7 <b>~</b> 0 |       |                                                                       |            |              |         |        |       | 1D1,0  |
| +\$05 | MSTATUS   | 7 <b>~</b> 0 | RIF   | WIF                                                                   | CLKHOLD    | RXACK        | ARBLOST | BUSERR | BUSST | ATE1,0 |
| +\$06 | MBAUD     | 7 <b>~</b> 0 |       |                                                                       |            | BAU          | D7~0    |        |       |        |
| +\$07 | MADDR     | 7 <b>~</b> 0 |       |                                                                       | ADDR7~0    |              |         |        |       |        |
| +\$08 | MDATA     | 7 <b>~</b> 0 |       |                                                                       | DATA7~0    |              |         |        |       |        |
| +\$09 | SCTRLA    | 7 <b>~</b> 0 | DIEN  | APIEN                                                                 | PIEN       | PIEN PMEN SM |         |        |       | ENABLE |
| +\$0A | SCTRLB    | 7 <b>~</b> 0 |       |                                                                       | ACKACT SCM |              |         |        | D1,0  |        |
| +\$0B | SSTATUS   | 7 <b>~</b> 0 | DIF   | APIF                                                                  | CLKHOLD    | RXACK        | COLL    | BUSERR | DIR   | AP     |
| +\$0C | SADDR     | 7~0          |       | ADDR7~0                                                               |            |              |         |        |       |        |
| +\$0D | SDATA     | 7~0          |       |                                                                       |            | DAT          | A7~0    |        |       |        |
| +\$0E | SADDRMASK | 7~0          |       |                                                                       | AI         | DDRMASK6     | ~0      |        |       | ADDREN |

# 26.5. レジスタ説明

# **26.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位: +\$00 リセット: \$00 特質: -

| ピット    | 7 | 6 | 5 | 4        | 3    | 2      | 1     | 0 |
|--------|---|---|---|----------|------|--------|-------|---|
|        |   |   |   | SDASETUP | SDAH | DLD1,0 | FMPEN |   |
| アクセス種別 | R | R | R | R/W      | R/W  | R/W    | R/W   | R |
| リセット値  | 0 | 0 | 0 | 0        | 0    | 0      | 0     | 0 |

# ● ビット4 - SDASETUP: SDA準備時間 (SDA Setup Time)

このビットはSDA出力信号での充分な準備時間を保証するためにSCLが伸長されるクロック数を制御します。このビットは従装置動作で動作する時に使われます。

| 値  | 0                  | 1                  |  |  |  |
|----|--------------------|--------------------|--|--|--|
| 名称 | 4CYC               | 8CYC               |  |  |  |
| 説明 | SDA準備時間は4クロック周期です。 | SDA準備時間は8クロック周期です。 |  |  |  |

# ● ビット3,2 - SDAHOLD1,0: SDA保持時間 (SDA Hold Time)

このビット領域はTWIに対するSDA保持時間を選びます。詳細については「電気的特性」章をご覧ください。

| 値  | 0 0     | 0 1   | 1 0                       | 11                        |
|----|---------|-------|---------------------------|---------------------------|
| 名称 | OFF     | 50NS  | 300NS                     | 500NS                     |
| 説明 | 保持時間OFF | 短保持時間 | 代表的条件下の<br>SMBus 2.0仕様に合致 | 全方面に渡って<br>SMBus 2.0仕様に合致 |

# ● ビット1 - FMPEN: 高速動作+許可 (Fast Mode Plus Enable)

このビットへの'1'書き込みはTWI既定構成設定でのTWIに対して1MHzバス速度(高速動作+、FM+)を選びます。

| 値  | 0              | 1             |  |  |  |
|----|----------------|---------------|--|--|--|
| 名称 | OFF            | ON            |  |  |  |
| 説明 | 標準動作または高速動作で動作 | 高速動作+(Fm+)で動作 |  |  |  |

# 26.5.2. DBGCTRL - デバッグ制御 (Debug Control)

名称 : DBGCTRL 変位 : +\$02 リセット : \$00 特質 : -

| ピット _  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|--------|---|---|---|---|---|---|---|--------|
|        |   |   |   |   |   |   |   | DBGRUN |
| アクセス種別 | R | R | R | R | R | R | R | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0      |

# ● ビット0 - DBGRUN: デバッグ時走行 (Debug Run)

詳細については「デバッグ操作」項を参照してください。

| 値  | 0                      | 1                        |
|----|------------------------|--------------------------|
| 説明 | TWIはデバッグ動作中断で停止し、事象を無視 | TWIはCPU停止中のデバッグ動作中断で走行継続 |

# **26.5.3. MCTRLA - 主装置制御A** (Host Control A)

名称: MCTRLA 変位:+\$03 リセット: \$00 特質:-

| RIEN WIEN QCEN TIMEOUT1,0 SMEN ENABLE アクセス種別 R/W R/W R R/W R/W R/W R/W | ピット    | 7    | 6    | 5 | 4    | 3     | 2      | 1    | 0      |
|------------------------------------------------------------------------|--------|------|------|---|------|-------|--------|------|--------|
|                                                                        |        | RIEN | WIEN |   | QCEN | TIMEC | OUT1,0 | SMEN | ENABLE |
|                                                                        | アクセス種別 | R/W  | R/W  | R | R/W  | R/W   | R/W    | R/W  | R/W    |
| リセット値 0 0 0 0 0 0 0 0 0 0                                              | リセット値  | 0    | 0    | 0 | 0    | 0     | 0      | 0    | 0      |

#### ● ビット7 - RIEN: 読み込み割り込み許可 (Read Interrupt Enable)

TWI主装置読み込み割り込みはこのビットとステータス レジスタ(CPU.SREG)の全体割り込み許可(I)ビットが'1'に設定される場合にだけ生成されます。

このビットへの'1'書き込みは主装置状態(TWIn.MSTATUS)レジスタの主装置読み込み割り込み要求フラグ(RIF)での割り込みを許可します。RIFフラグは主装置読み込み割り込みが起きた時に'1'に設定されます。

# ● ビット6 - WIEN: 書き込み割り込み許可(Write Interrupt Enable)

TWI主装置書き込み割り込みはこのビットとステータス レジスタ(CPU.SREG)の全体割り込み許可(I)ビットが'1'に設定される場合にだけ生成されます。

このビットへの'1'書き込みは主装置状態(TWIn.MSTATUS)レジスタの主装置書き込み割り込み要求フラグ(WIF)での割り込みを許可します。WIFフラグは主装置書き込み割り込みが起きた時に'1'に設定されます。

#### ● ビット4 - QCEN: 迅速指令許可(Quick Command Enable)

このビットへの'1'書き込みが迅速指令動作を許可します。迅速指令が許可されて従装置がアドレスに応答する場合、R/Wビットの値に応じて対応する読み込み割り込み要求フラグ(RIF)または書き込み割り込み要求フラグ(WIF)が設定(1)されます

ソフトウェアは主装置制御B(TWIn.MCTRLB)レシ、スタの指令(MCMD)ビット領域に(STOPを)書くことで停止条件を発行せねばなりません。

#### ● ビット3,2 - TIMEOUT1,0: 不活性バス制限時間 (Inactive Bus Timeout)

このビット領域に0以外の値を設定することが不活性バス制限時間監視を許可します。バスがTIMEOUT設定よりも長い間不活性の場合、バス状態論理回路はアイドル状態に移行します。

| 値           | 0 0                       | 0 1          | 1 0   | 11    |  |
|-------------|---------------------------|--------------|-------|-------|--|
| 名称 DISABLED |                           | 50US         | 100US | 200US |  |
| 説明          | バス制限時間禁止:I <sup>2</sup> C | 50μs : SMBus | 100µs | 200μs |  |

# ● ビット1 - SMEN: 簡便動作許可 (Smart Mode Enable)

このビットへの'1'書き込みが主装置簡便動作を許可します。簡便動作が許可されると、主装置データ(TWIn.MDATA)レジスタ読み込み直後に主装置制御B(TWIn.MCTRLB)レジスタの応答動作(ACKACT)ビットに存在する値が送られます。

#### ● ビット0 - ENABLE:主装置許可(Enable TWI Host)

このビットへの'1'書き込みがTWIを主装置として許可します。

# **26.5.4. MCTRLB - 主装置制御B** (Host Control B)

名称: MCTRLB 変位:+\$04 リセット: \$00 特質:-

| ビット    | 7 | 6 | 5 | 4 | 3     | 2      | 1   | 0    |
|--------|---|---|---|---|-------|--------|-----|------|
|        |   |   |   |   | FLUSH | ACKACT | MCM | D1,0 |
| アクセス種別 | R | R | R | R | R/W   | R/W    | R/W | R/W  |
| リセット値  | 0 | 0 | 0 | 0 | 0     | 0      | 0   | 0    |

#### ビット3 - FLUSH:解消(Flush)

このビットは主装置の内部状態を解消してバス状態をアイドルに変えます。TWIは主装置アドレス(TWIn.MADDR)レジスタに先立って主装置 データ(TWIn.MDATA)レジスタが書かれる場合に無効なデータを送信します。解消後の主装置アドレス(TWIn.MADDR)と主装置データ(TWIn.MDATA)への書き込みはハードウェアがSCLバス空きを検出すると直ぐに処理を開始させます。

このビットへの'1'書き込みは主装置を禁止する1クロック周期間の瞬発(ストローブ)信号を生成し、その後に主装置を再許可します。このビットへの'0'書き込みは無効です。

#### ● ビット2 - ACKACT: 応答動作 (Acknowledge Action)

ACKACT(注)じットはハ、ス状態とソフトウェア相互作用によって定義された或る条件下の主装置での動きを表します。主装置制御A(TWIn. MCTRLA)レジスタの簡便動作許可(SMEN)じットが(1)に設定される場合、応答動作は主装置データ(TWIn.MDATA)レジスタが読まれる時に実行されます。さもなければ指令が主装置制御B(TWIn.MCTRLB)レジスタの指令(MCMD)じット領域に書かれなければなりません。主装置データ(TWIn.MDATA)レジスタが書かれる時は主装置がデータを送っているため、応答動作は実行されません。

| 値  | 0           | 1            |
|----|-------------|--------------|
| 名称 | ACK         | NACK         |
| 説明 | 確認応答(ACK)送出 | 否認応答(NACK)送出 |

#### ビット1.0 - MCMD1.0:指令(Command)

MCMD(注)ビット領域は瞬発(ストローブ)信号です。このビット領域は常に'0'として読みます。

このビット領域への書き込みは下表によって定義されるような主装置動作を起動します。

#### 表26-2. 指令設定

| MCMD1,0 | 群構成設定     | データ方向 | 説明                                           |
|---------|-----------|-------|----------------------------------------------|
| 0 0     | NOACT     | ×     | (予約)                                         |
| 0 1     | REPSTART  | ×     | 再送開始条件が後続する応答動作を実行                           |
| 1.0     | RECVTRANS | W     | ハ・小書き込み操作が後続する応答動作(活動なし)を実行 ( <del>注</del> ) |
| 1 0     | KECVIKANS | R     | バイ読み込み操作が後続する応答動作を実行                         |
| 11      | STOP      | ×     | 停止条件発行が後続する応答動作を実行                           |

注: 主装置書き込み操作に対して、TWIは主装置データ(TWIn.MDATA)レジスタに書かれる新しいデータを待ちます。

注: ACKACTビットとMCMDビット領域は同時に書くことができます。

# **26.5.5. MSTATUS** - 主装置状態 (Master Status)

名称: MSTATUS 変位: +\$05 リセット: \$00 特質:-

正常なTWI操作はこのレジスタが純粋に読み込み専用レジスタと見做されることが必要とされます。状態フラグの何れかの解除(0)は主装置送信アドレス(TWIn.MADDR)レジスタ、主装置データ(TWIn.MDATA)レジスタ、主装置制御B(TWIn.MCTRLB)レジスタの指令(MCMD)ビットをアクセスすることによって間接的に行われます。

| ピット    | 7   | 6   | 5       | 4     | 3       | 2      | 1     | 0      |
|--------|-----|-----|---------|-------|---------|--------|-------|--------|
|        | RIF | WIF | CLKHOLD | RXACK | ARBLOST | BUSERR | BUSST | ATE1,0 |
| アクセス種別 | 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 - RIF: 読み込み割り込み要求フラグ(Read Interrupt Flag)

このフラグは主装置バイト読み込み動作が完了された時に'1'に設定されます。

RIFフラグは主装置読み込み割り込みを生成することができます。主装置制御A(TWIn.MCTRLA)レジスタの読み込み割り込み許可(RIE N)ビットの記述でより多くの情報を見つけてください。

このフラグは他のいくつかのTWIレジスタがアクセスされる時に自動的に解除(0)します。RIFフラグを解除(0)するのに以下の方法のどれをも使うことができます。

- ・これへの'1'書き込み
- ・主装置アドレス(TWIn.MADDR)レジスタへの書き込み
- 主装置データ(TWIn.MDATA)レシブスタの読み書き
- ・主装置制御B(TWIn.MCTRLB)レジブスタの指令(MCMD)ビットへの書き込み

#### ● ビット6 - WIF:書き込み割り込み要求フラグ(Write Interrupt Flag)

このフラグはどのバス異常の発生や調停敗退状況とも無関係に主装置のアドレス送信またはバイトの書き込みが完了された時に'1'に設定されます。

WIFフラグは主装置書き込み割り込みを生成することができます。主装置制御A(TWIn.MCTRLA)レジスタの書き込み割り込み許可(WIE N)ピットの記述でより多くの情報を見つけてください。

このフラグはRIFフラグに対して上で記述された方法のどれかを使って解除(0)することができます。

#### ビット5 - CLKHOLD: クロック保持(Clock Hold)

このビットが'1'として読まれると、それは主装置がTWIクロック(SCL)を現在Lowに保持してTWIクロック周期を引き延ばしていることを示します。

このフラグはRIFフラグに対して前で記述された方法のどれかを使って解除(0)することができます。

#### ● ビット4 - RXACK: 受信応答 (Received Acknowledge)

このビットが'0'として読まれると、それは従装置からの最新応答ビットが確認応答(ACK)で従装置がより多くのデータの準備が整っていることを示します。

このビットが'1'として読まれると、それは従装置からの最新応答ビットが<mark>否認応答</mark>(NACK)で従装置がより多くのデータの受信ができないかまたは必要でないことを示します。

#### ● ビット3 - ARBLOST:調停敗退(Arbitration Lost)

このビットが'1'として読まれると、それは主装置が調停で敗れたことを示します。これは以下の場合の1つで起き得ます。

- ・ Highデータ ビットを送信している間
- ・否認応答(NACK)を送信している間
- ・開始条件(S)を発行している間
- ・再送開始条件(Sr)を発行している間

このフラグはRIFフラグに対して記述される方法の1つを選ぶことによって解除(0)することができます。

# ● ビット2 - BUSERR: バス異常(Bus Error)

BUSERRフラクでは不正なバス状態が起きたことを示します。不正なバス操作はTWIバス線で規約違反の開始条件(S)、再送開始条件(Sr)、停止条件(P)が検出された場合に検知されます。開始条件直後に続く停止条件が規約違反の一例です。

BUSERR7ラグは以下の方法の1つを選ぶことによって解除(0)することができます。

- ・これへの'1'書き込み
- ・主装置アドレス(TWIn.MADDR)レジスタへの書き込み

TWIハ、ス異常検出部はTWI主装置回路の一部です。ハ、ス異常が検出されるには、TWI主装置が許可(主装置制御A(TWIn.MCTRLA)レジスタのTWI主装置許可(ENABLE)と、ットが、1、に)されて、主クロック周波数がSCL周波数の最低4倍でなければなりません。

#### ● ビット1,0 - BUSSTATE1,0 : バス状態フラグ (Bus State)

このビット領域は現在のTWIバス状態を示します。このビット領域への'01'書き込みはバス状態をアイドルに強制します。他の全ての値は無視されます。

| 値  | 0 0         | 0 1             | 1 0              | 1 1           |  |
|----|-------------|-----------------|------------------|---------------|--|
| 名称 | UNKNOWN     | IDLE            | OWNER            | BUSY          |  |
| 説明 | 未知のバス状態(未知) | アイドルのバス状態(アイドル) | このTWIがバスを制御(所有者) | 多忙なバス状態 (使用中) |  |

# 26.5.6. MBAUD - 主装置ボーレート (Master Baud Rate)

名称: MBAUD 変位: +\$06 リセット: \$00 特質:-



# ヒット7~0 - BAUD7~0: ホーレート (Baud Rate)

このビット領域はSCLのHighとLowの時間を得るのに使われます。主装置が禁止されている間に書かれなければなりません。主装置は主装置制御A(TWIn.MCTRLA)レジスタのTWI主装置許可(ENABLE)ビットに'0'を書くことによって禁止されます。

SCLの周波数を計算する方法のより多くの情報については「26.3.2.2.1. クロック生成」項を参照してください。

#### 26.5.7. MADDR - 主装置アドレス (Master Address)

名称: MADDR 変位: +\$07 リセット: \$00 特質: -

| ピット    | 7   | 6   | 5   | 4   | 3    | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|------|-----|-----|-----|
|        |     |     |     | ADD | R7∼0 |     |     |     |
| アクセス種別 | 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 - ADDR7~0: アドレス (Address)

このレシ、スタは外部従装置のアト・レスを含みます。このビット領域が書かれると、TWIは開始条件を発行し、移動レジスタがバス状態に応じてバス上でバイ送信動作を実行します。

このレジスタは、読み込みアクセスがバス規約に関連するどれかの操作を実行するために主装置論理回路を起動しないため、進行中のバス活動での妨害を除いて何時でも読むことができます。

主装置制御論理回路は読み書き(R/W)方向ビットとしてこのレジスタのビット0を使います。

# **26.5.8. MDATA** - 主装置データ (Master Data)

名称: MDATA 変位: +\$08 リセット: \$00 特質: -



# ヒット7~0 - DATA7~0: データ (Data)

このビット領域はバスでのデータ移動出力(送信)とバスから受け取るデータの移動入力(受信)に使われる主装置の物理的な移動レジスタへの直接アクセスを提供します。直接アクセスはバイト送信中にMDATAレジスタをアクセスすることができないことを意味します。

有効なデータの読み込みまたは送信されるべきデータの書き込みはクロック保持(CLKHOLD)ビットが゚1゚として読まれる時、または割り込み発生時にだけ成功することができます。

MDATAレジネタへの書き込みは主装置にバスでのバイ送信動作の実行を命じ、直後に従装置からの応答ビットを受け取ります。これは主装置制御B(TWIn.MCTRLB)レジネタの応答動作(ACKACT)ビットと無関係です。書き込み操作は主装置書き込み割り込み要求フラグ(WIF)が'1'に設定されるのに先立って調停に勝つか負けるかに関わらず実行されます。

主装置制御A(TWIn.MCTRLA)レシ、スタの簡便動作許可(SMEN)ヒ、ットが、1、に設定され場合、MDATAレシ、スタへの読み込みアクセスは主装置に応答動作の実行を命じます。これは主装置制御B(TWIn.MCTRLB)レシ、スタの応答動作(ACKACT)ヒ、ットの設定に依存します。

- 注: ・WIFとRIFの割り込み要求フラグはACKACTが'1'に設定されている間にMDATAレジスタが読まれる場合、自動的に解除(0)されます。
  - ・調停敗退(ARBLOST)とバス異常(BUSERR)のフラグは無変化のままです。
  - ・WIF、RIF、ARBLOST、BUSERRのフラケーはCLKHOLDビットと共に全て主装置状態(TWIn.MSTATUS)レシブスタに配置されます。

#### **26.5.9. SCTRLA - 従装置制御A** (Slave Control A)

名称: SCTRLA 変位:+\$09 リセット: \$00 特質:-

| ピット    | 7    | 6     | 5    | 4 | 3 | 2    | 1    | 0      |
|--------|------|-------|------|---|---|------|------|--------|
|        | DIEN | APIEN | PIEN |   |   | PMEN | SMEN | ENABLE |
| アクセス種別 | R/W  | R/W   | R/W  | R | R | R/W  | R/W  | R/W    |
| リセット値  | 0    | 0     | 0    | 0 | 0 | 0    | 0    | 0      |

# ● ビット7 - DIEN : データ割り込み許可 (Data Interrupt Enable)

このビットに'1'を書くことは従装置状態(TWIn.SSTATUS)レジスタのデータ割り込み要求フラグ(DIF)での割り込みを許可します。

TWI従装置データ割り込みは、このビット、DIFフラグ、ステータス レジスタ(CPU.SREG)の全体割り込み許可(I)ビットが全て'1'の場合にだけ生成されます。

#### ● ビット6 - APIEN: アドレス/停止条件割り込み許可(Address or Stop Interrupt Enable)

このビットに'1'を書くことは従装置状態(TWIn.SSTATUS)レジスタのアドレス/停止条件割り込み要求フラグ(APIF)での割り込みを許可します。

TWI従装置アトンス/停止条件割り込みは、このビット、APIFフラグ、ステータス レジスタ(CPU.SREG)の全体割り込み許可(I)ビットが全て'1'の場合にだけ生成されます。

- 注:・従装置停止条件割り込みは割り込みフラグとベクタを従装置アドレス割り込みと共有します。
  - ・従装置制御A(TWIn.SCTRLA)レジスタの停止条件割り込み許可(PIEN)ビットは停止条件でAPIFが設定されるために'1'を書かれなければなりません。
  - ・割り込み発生時、TWI従装置状態(TWIn.SSTATUS)レシ、スタのアドレス/停止条件(AP)ビットはアドレス一致か停止条件かのどちらが割り込みを起こしたかを決めます。

# ● ビット5 - PIEN: 停止条件割り込み許可 (Stop Interrupt Enable)

このビットに'1'を書くことは停止条件発生時にTWI従装置状態(TWIn.SSTATUS)レジスタのアドレス/停止条件割り込み要求フラグ(APIF)が設定(1)されることを許します。主クロック周波数はこの機能を使うためにSCL周波数の最低4倍でなければなりません。

#### ● ビット2 - PMEN: アドレス認識動作 (Address Recognition Mode)

このビットが、1、を書かれるなら、従装置アドレス一致論理回路は全ての受信アドレスに応答します。

このビットが'0'を書かれるなら、アドレス一致論理回路はどのアドレスを従装置のアドレスとして認識するかを決めるのに従装置アドレス(TWI n.SADDR)レジスタを使います。

# ● ビット1 - SMEN: 簡便動作許可 (Smart Mode Enable)

このビットに'1'を書くことが従装置簡便動作を許可します。簡便動作が許可されると、従装置制御B(TWIn.SCTRLB)レジスタの指令(SCMD)ビット領域への書き込みによる指令発行または従装置データ(TWIn.SDATA)レジスタのアクセスは割り込みをリセットして動作を続けます。 簡便動作が禁止される場合、従装置は続けるのに先立って常に新しい従装置指令を待ちます。

#### ● ビット0 - ENABLE: 従装置許可 (Enable TWI Slave)

このビットに'1'を書くことがTWI従装置を許可します。

# 26.5.10. SCTRLB - 従装置制御B (Slave Control B)

名称: SCTRLB 変位: +\$0A リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2      | 1   | 0     |
|--------|---|---|---|---|---|--------|-----|-------|
|        |   |   |   |   |   | ACKACT | SCM | ID1,0 |
| アクセス種別 | R | R | R | R | R | R/W    | R/W | R/W   |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0      | 0   | 0     |

# ● ビット2 - ACKACT : 応答動作 (Acknowledge Action)

ACKACT(注)じットはハ、ス規約状態とソフトウェア相互作用によって定義される或る条件下でのTWI従装置の動きを示します。従装置制御A(TWIn.SCTRLA)レシ、スタの簡便動作許可(SMEN)じットが、1、に設定される場合、応答動作は従装置データ(TWIn.SDATA)レシ、スタが読まれる時に実行されます、さもなければ従装置制御B(TWIn.SCTRLB)レシ、スタの指令(SCMD)じット領域に指令が書かれなければなりません。

従装置データ(TWIn.SDATA)レジスタが書かれる時は従装置がデータを送っているため、応答動作は実行されません。

| 値  | 0           | 1            |
|----|-------------|--------------|
| 名称 | ACK         | NACK         |
| 説明 | 確認応答(ACK)送出 | 否認応答(NACK)送出 |

#### ビット1.0 - SCMD1.0:指令(Command)

SCMD(注)ビット領域は瞬発(ストローブ)信号です。このビット領域は常に'0'として読みます。このビット領域への書き込みは次表によって定義されるような従装置動作を起動します。

注: ACKACTビットとSCMDビット領域は同時に書くことができます。ACKACTは指令が起動されるのに先立って更新されます。

#### 表26-3. 指令設定

| SCMD1,0 | 群構成設定     | DIR(方向)                 | 説明                                                |          |
|---------|-----------|-------------------------|---------------------------------------------------|----------|
| 0 0     | NOACT     | ×                       | 活動なし                                              |          |
| 0 1     | -         | ×                       | (予約)                                              |          |
| 1.0     | COMPTRANS | $\overline{\mathrm{W}}$ | 何れかの開始条件/再送開始条件(S/Sr)待機に先行する応答動作を実行               | 転送処理     |
| 1 0     | COMPTRANS | R                       | 何れかの開始条件/再送開始条件(S/Sr)待機                           | 完了に使用    |
|         |           | $\overline{\mathrm{W}}$ | 次バイトの受信に先行する応答動作を実行                               |          |
| 1 1     | RESPONSE  | D                       | アトンス割り込み要求フラケ(APIF)に対する応答で使用: 従装置データ割り込行する応答動作を実行 | み(DIF)に先 |
|         |           | R                       | データ割り込み要求フラグ(DIF)に対する応答で使用: 応答動作が後続する/<br>操作を実行   | がお読み取り   |

# 26.5.11. SSTATUS - 従装置状態 (Client Status)

名称: SSTATUS 変位: +\$0B リセット: \$00 特質:-

| ピット    | 7   | 6    | 5       | 4     | 3    | 2      | 1   | 0  |
|--------|-----|------|---------|-------|------|--------|-----|----|
|        | DIF | APIF | CLKHOLD | RXACK | COLL | BUSERR | DIR | AP |
| アクセス種別 | R/W | R/W  | R       | R     | R/W  | R/W    | R   | R  |
| リセット値  | 0   | 0    | 0       | 0     | 0    | 0      | 0   | 0  |

# ● ビット7 - DIF: データ割り込み要求フラグ(Data Interrupt Flag)

このフラグはバス異常なしで従装置のバイ・送信またはバイ・受信の操作が完了された時に'1'に設定されます。このフラグは衝突検出の場合での不成功転送処理で'1'に設定され得ます。衝突(COLL)ビットの記述でより多くの情報を見つけてください。

DIFフラグは従装置データ割り込みを生成することができます。従装置制御A(TWIn.SCTRLA)レジスタのデータ割り込み許可(DIEN)ビットの記述でより多くの情報を見つけてください。

このフラグは他のいくつかのTWIレジスタがアクセスされる時に自動的に解除(0)します。以下の方法のどれもDIFフラグを解除(0)するのに使うことができます。

- ・従装置データ(TWIn.SDATA)レジスタへの読み書き
- ・従装置制御B(TWIn.SCTRLB)レジスタの指令(SCMD)ビット領域への書き込み
- ビット6 APIF:アドレス/停止条件割り込み要求フラグ(Address or Stop Interrupt Flag)

このフラグは従装置アドレスが受信された時、または停止条件によって'1'に設定されます。

APIFフラグは従装置アドレス/停止条件割り込みを生成することができます。従装置制御A(TWIn.SCTRLA)レジスタのアドレス/停止条件割り込み許可(APIEN)ビットの記述でより多くの情報を見つけてください。

このフラグはDIFフラグに対して記述される方法のどれを使っても解除(0)することができます。

#### ● ビット5 - CLKHOLD: クロック保持(Clock Hold)

このビットが'1'として読まれると、それは従装置がTWIクロック(SCL)を現在Lowに保持してTWIクロック周期を引き延ばしていることを示します。

このビットはアドレス(APIF)またはデータ(DIF)の割り込みが起こる時に'1'に設定されます。対応する割り込みのリセットが間接的にこのビットを'0'に設定します。

#### ● ビット4 - RXACK: 受信応答 (Received Acknowledge)

このビットが'0'として読まれると、それは主装置からの最新応答ビットが確認応答(ACK)だったことを示します。 このビットが'1'として読まれると、それは主装置からの最新応答ビットが否認応答(NACK)だったことを示します。

# ● ビット3 - COLL: 衝突 (Collision)

このビットが'1'として読まれると、それは従装置が以下の1つを行うことができなかったことを示します。

- ・SDAでのHight'ット送信。不成功転送処理の内部完了のため、その最後でデータ割り込み要求フラグ(DIF)が'1'に設定されます。
- ・ <mark>否認応答(NACK)ビット送</mark>信。従装置アドレス一致が既に起こされたために衝突が起き、結果としてアドレス/停止条件割り込み要求フラ グ(APIF)が 1'に設定されます。

このビットへの'1'書き込みはCOLLフラグを解除(0)します。このフラグは何れかの開始条件(S)または再送開始条件(Sr)が検出される場合に自動的に解除(0)されます。

注: APIFとDIFのフラグは衝突を調べるのに使われ得る処理部の割り込みしか生成することができません。

#### ● ビット2 - BUSERR: バス異常(Bus Error)

BUSERR7ラグは不正なバス操作が起きたことを示します。不正なバス操作はTWIバス線で規約違反の開始条件(S)、再送開始条件(Sr)、停止条件(P)が検出された場合に検知されます。開始条件直後に続く停止条件が規約違反の1つの例です。

このビットへの'1'書き込みはBUSERRフラグを解除(0)します。

TWIハ、ス異常検出部はTWI主装置回路の一部です。ハ、ス異常が検出されるには、TWI主装置が許可されて、主クロック周波数がSCL周波数の最低4倍でなければなりません。TWI主装置は主装置制御A(TWIn.MCTRLA)レシ、スタのTWI主装置許可(ENABLE)ヒットに、1、を書くことによって許可することができます。

#### ● ビット1 - DIR: 読み/書き方向 (Rwad/Write Direction)

このビットは現在のTWIバス方向を示します。DIRビットはTWI主装置から受信した最後のアドレス パケットからの方向ビット値を反映します。 このビットが、1゚として読まれると、それは主装置読み込み操作が進行中です。

このビットが'0'として読まれると、それは主装置書き込み操作が進行中です。

# ● ビット0 - AP: アドレス/停止条件 (Address or Stop)

TWI従装置状態(TWIn.SSTATUS)レジスタのTWI従装置アドレス/停止条件割り込み要求フラグ(APIF)が'1'に設定されると、このビットは割り込みがアドレス検出のためかそれとも停止条件のためかを決めます。

| 値  | 0                     | 1                       |
|----|-----------------------|-------------------------|
| 名称 | STOP                  | ADR                     |
| 説明 | 停止条件がAPIFフラグでの割り込みを生成 | アドレス検出がAPIFフラグでの割り込みを生成 |

#### 26.5.12. SADDR - 従装置アドレス (Slave Address)

名称: SADDR 変位: +\$0C リセット: \$00 特質: -



#### ヒット7~0 - ADDR7~0: アトレス (Address)

従装置アト・レス(TWIn.ADDR)レジスタはTWI主装置がTWI従装置をアト・レス指定したかを判断する従装置アト・レス一致論理回路によって使われます。アト・レス ハプケットが受信された場合、従装置状態(TWIn.SSTATUS)レジスタのアト・レス/停止条件割り込み要求フラグ(APIF)とアト・レス/停止条件(AP)ビットが'1'に設定されます。

SADDRレシブスタの上位7ビット(ADDR7~1)は基本従装置アトレスを表します。

SADDRレシ、スタの最下位ビット(ADDRo)はI<sup>2</sup>C規約の一斉呼び出しアドレス(\$00)の認識に使われます。この機能はこのビットが'1'に設定される時に許可されます。

#### **26.5.13. SDATA** - 従装置データ(Slave Data)

名称: SDATA 変位:+\$0D リセット: \$00 特質:-

| ピット    | 7   | 6   | 5   | 4   | 3    | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|------|-----|-----|-----|
|        |     |     |     | DAT | A7~0 |     |     |     |
| アクセス種別 | 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 - DATA7~0: データ (Data)

このビット領域は従装置データ レジスタへのアクセスを提供します。

有効なデータの読み込みまたは送信されるべきデータの書き込みは従装置によってSCLがLowに保持される時(即ち、CLKHOLDビットが'1'に設定される時)にだけ順調に達成することができます。割り込みの使用または割り込み要求フラグの監視によってソフトウェアが現在の規約状態の経緯を保つ場合、SDATAレジスタをアクセスするのに先だって、ソフトウェアで従装置状態(TWIn.SSTATUS)レジスタのクロック保持(CLKHOLD)ビットを調べることは不要です。

従装置制御A(TWIn.SCTRLA)レジスタの簡便動作許可(SMEN)ビットが'1'に設定される場合、クロック保持が有効の時のSDATAレジスタ 読み込みは従装置にバス操作を自動起動して応答動作を実行することを命じます。これは従装置制御B(TWIn.SCTRLB)レジスタの応 答動作(ACKACT)ビットの設定に依存します。

# **26.5.14. SADDRMASK - 従装置アドレス遮蔽** (Slave Address Mask)

名称: SADDRMASK

変位:+\$0E リセット:\$00 特質:-

| ピット    | 7   | 6   | 5   | 4         | 3   | 2   | 1   | 0      |
|--------|-----|-----|-----|-----------|-----|-----|-----|--------|
|        |     | ,   | Α   | DDRMASK6~ | -0  |     |     | ADDREN |
| アクセス種別 | 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~1 - ADDRMASK6~0: アドレス遮蔽 (Address Mask)

ADDRMASKビット領域はアドレス許可(ADDREN)ビットに依存して第2アドレス一致またはアドレス遮蔽のレジスタとして働きます。

ADDRENt'ットが'0'を書かれる場合、ADDRMASKt'ット領域は7t'ット従装置アドレス遮蔽値を設定することができます。従装置アドレス遮蔽(TWIn.SADDRMASK)レジスタ内の各t'ットはTWI従装置アドレス(TWIn.SADDR)レジスタ内の対応するアドレス t'ットを遮蔽(禁止)することができます。この遮蔽のビットが'1'を書かれるなら、アドレス一致論理回路は着信アドレス t'ットと従装置アドレス(TWIn.SADDR)レジスタ内の対応するビット間の比較を無視します。換言すると、遮蔽されたビットは常に一致し、アドレスの範囲の認識を可能にします。

ADDRENが'1'を書かれる場合、従装置アトレス遮蔽(TWIn.SADDRMASK)レシ、スタは従装置アトレス(TWIn.SADDR)レシ、スタに加えて第2 従装置アトレスを設定することができます。この動作では従装置が2つの独自のアトレス、従装置アトレス(TWIn.SADDR)レシ、スタでの1つと従装置アトレス遮蔽(TWIn.SADDRMASK)レシ、スタでの別の1つを持ちます。

#### ヒット0 - ADDREN: アトレス許可 (Address Mask Enable)

このビットが、0'を書かれる場合、TWIn.SADDRMASKレジスタはTWIn.SADDRレジスタに対する遮蔽として働きます。

このビットが'1'を書かれる場合、従装置アドレス一致論理回路は従装置のTWIn.SADDRとTWIn.SADDRMASKでの2つの独自のアドレスに応答します。

# 27. CRCSCAN - 巡回冗長検査メモリ走査

# 27.1. 特徴

- · CRC-16-CCITT
- ・ 全フラッシュ メモリ、応用コート・と/またはブート領域の検査
- ・選択可能な不成功でのNMI起動
- ・使用者構成設定可能な内部リセット初期化中の検査

# 27.2. 概要

巡回冗長検査(CRC)はNVM(フラッシュ メモリ全体、ブート領域のみ、ブート領域と応用コード領域の両方)からバイトのデータの流れを取って チェックサムを生成します。CRC周辺機能(CRCSCAN)はプログラム メモリ内の異常を検出するのに使うことができます。

調べる領域の最終位置は比較のために予め計算された正しい16ビットチェックサム値を含まなければなりません。CRCSCANによって計算されたチェックサムと予め計算されたチェックサムが一致する場合、状態(OK)ビットが設定(1)されます。それらが一致しない場合、状態(CRCSCAN.STATUS)レジスタは失敗したことを示します。使用者はチェックサムが一致しない場合にCRCSCANに遮蔽不可割り込み(NMI)を生成させるように選ぶことができます。

任意長のデータ塊に適用されるnビットCRCは長さでnビットまでのどんな単一改変(連続誤り)も検出します。より長い連続誤りについては 1-2<sup>-n</sup>分の1が検出されます。

CRC生成部はCRC-16-CCITT)を支援します。

#### 多項式:

• CRC-16-CCITT :  $X^{16}+X^{12}+X^{5}+1$ 

CRCは検査に対して構成設定された領域の内容をハイトのから始めてハイト単位で読み、ハイト毎に新しいチェックサムを生成します。ハイトは最上位ビットから始めて下で描かれるような移動レジスタを通して送られます。領域の最後のハイトが正しいチェックサムを含む場合、CRCは(検査に)合格します。チェックサムがどう配置されるかについては「27.3.2.1. チェックサム」をご覧ください。チェックサムレジスタの初期値は \$FFFFです。



# 27.2.1. 構成図



# 27.3. 機能的な説明

# 27.3.1. 初期化

ソフトウェア(またはデバッカ)経由)でCRCを許可するには、

- 1. 望む供給元設定を選ぶために制御B(CRCSCAN.CTRLB)レシブスタの供給元(SRC)ビット領域を書いてください。
- 2. 制御A(CRCSCAN.CTRLA)レシ、スタの許可(ENABLE)ヒットに'1'を書くことによってCRCSCANを許可してください。
- 3. CRCは3周期後に開始します。CPUはこれらの3周期の間も実行を続けます。

CRCSCANはデバイスがリセットを去る前にコート、メモリ走査を実行するように構成設定することができます。この検査が失敗の場合、CPUは通常のコート、実行を許されません。この機能はシステム構成設定の(FUSE.SYSCFG0)ヒュース、のCRC供給元(CRCSRC)領域によって許可されて制御されます。より多くの情報については「ヒューズ」項をご覧ください。

この機能が許可された場合、成功したCRC検査は以下の結果を持ちます。

- ・ 通常コート 実行開始
- ・CRCSCAN.CTRLAレシブスタのENABLEビットが'1'です。
- ・ CRCSCAN.CTRLBレシブスタのSRCビット領域は検査した領域を反映します。
- ・状態(CRCSCAN.STATUS)レシブスタのCRC OK(OK)フラクブが'1'です。

この機能が許可された場合、不成功のCRC検査は以下の結果を持ちます。

- ・通常コート、実行は開始せず、CPUはコート、実行を停止します。
- ・ CRCSCAN.CTRLAレシブスタのENABLEビットが'1'です。
- ・CRCSCAN,CTRLBレジスタのSRCビット領域は検査した領域を反映します。
- ・状態(CRCSCAN.STATUS)レシブスタのOKフラグが'0'です。
- ・この状況はデバッグ「インターフェースを用いて観察することができるかもしれません。

#### 27.3.2. 動作

CRCが優先動作で動いている時は、CRC周辺機能がフラッシュメモリへのアクセス優先権を持ち、完了されるまでCPUを停止します。 優先動作で、またはCRC単位部が始動から走査を行うように設定される時に、CRCは第3主クロック周期毎に新しい語(16ビット)を取得します。

#### 27.3.2.1. チェックサム

検査される領域の最後の位置に予め計算されたチェックサムが存在しなければなりません。ブート(BOOT)領域が検査されるべきなら、チェックサムはブート領域の最後の(2)ハイトに保存されなければならず、応用(APPLICATION)とフラッシュ全体に対しても同様です。表27-1. は各種領域に対してチェックサムがどう格納されなければならないかを明確に示します。また、どの領域を検査するかを構成設定する方法については制御B(CRCSCAN.CTRLB)レシ、スタ記述を、ブートの最後(BOOTEND)と応用の最後(APPEND)のヒュース、を構成設定する方法についてはデハイスのヒュース、記述をご覧ください。

表27-1. フラッシュ メモリ内に予め計算された16ビット チェックサムを配置する方法

| 検査する領域                       | チェックサム上位バイト(ビット15~8) | チェックサム下位バイト(ビットフ~0) |  |  |
|------------------------------|----------------------|---------------------|--|--|
| ブート領域 (BOOT)                 | FUSE_BOOTEND × 256-2 | FUSE_BOOTEND×256-1  |  |  |
| ブート領域(BOOT)と応用領域(APLICATION) | FUSE_APPEND×256-2    | FUSE_APPEND×256-1   |  |  |
| 全フラッシュ メモリ                   | FLASHEND-1           | FLASHEND            |  |  |

# 27.3.3. 割り込み

| 表27-2 | 利用可 | 能な割り | 込みべ | かと供給元 |
|-------|-----|------|-----|-------|
|       |     |      |     |       |

| Ī | 大大   「 |          |       |  |  |  |  |  |
|---|--------|----------|-------|--|--|--|--|--|
|   | 名称     | ベクタ説明    | 条件    |  |  |  |  |  |
|   | NMI    | 遮蔽不可割り込み | CRC誤り |  |  |  |  |  |

割り込み条件が起こると、状態(CRCSCAN.STATUS)レシブスタのCRC OK(OK)フラグが'0'に解除されます。

遮蔽不可割り込み(NMI)は制御A(CRCSCAN.CTRLA)レシブスタの対応する許可(NMIEN)ビットに'1'を書くことによって許可されますが、 システム リセットでだけ禁止することができます。NMIはCRCSCAN.STATUSレシブスタのOKフラグが解除(0)され、NMIENビットが'1'の時に生成されます。NMI要求はシステム リセットまで活性に留まり、禁止することができません。

NMIは例え割り込みが全体的に許可されなくても起動することができます。

#### 27.3.4. 休止形態動作

CRCSCANは全ての休止動作で停止されます。全てのCPU休止動作に於いて、CRCSCAN周辺機能は停止され、CPUが起き上がる時に動作を再開します。

CRCSCANは制御A(CRCSCAN.CTRLA)レジスタのCRCSCAN許可(ENABLE)ビット書き込み後3周期で動作を開始します。これらの3周期の間に休止動作へ移行することが可能です。この場合、

- 1. CRCSCANはCPUが起き上がるまで開始しません。
- 2. CRCSCANが終了された後に何れかの割り込み処理部を実行します。

#### 27.3.5. デバッグ操作

テブブッガが周辺機能やメモリ位置を読み書きする時は必ずCRCSCAN周辺機能が禁止されます。

デバッカブがデバイスをアクセスする時にCRCSCANが多忙の場合、CRCSCANはデバッカブが内部レジスタをアクセスする時、またはデバッカブ切断時に進行中の動作を再始動します。

状態(CRCSCAN.STATUS)レシスタの多忙(BUSY)ビットはデバッカがこれを禁止にさせた時にCRCSCANが多忙だった場合に'1'を読みますが、デバッカがこれの禁止を保つ限りどの領域も能動的に検査しません。CRCSCANを禁止することなくデバッカによって読むことができる同期したCRC状態ビットがデバッカの内部レジスタ空間にあります。デバッカの内部CRC状態ビット読み込みはCRCSCANが許可されることを確実にします。

デバッガから直接CRCSCAN.STATUSレジスタ書き込みが可能なら、

- ・CRCSCAN.STATUSレジスタ内のBUSYビット
  - BUSYビットに'0'を書くことは(デバッガがそれを許す時にその動作を再始動しないように)進行中のCRC動作を止めます。
  - BUSYビットに'1'を書くことは制御B(CRCSCAN.CTRLB)レジスタの設定で単一検査をCRCに始めさせますが、デバッガがそれを許すまで動きません。

CRCSCAN.STATUSレシ、スタのBUSYビットが'1'である限り、制御A(CRCSCAN.CTRLA)レシ、スタの遮蔽不可割り込み許可(NMIEN)ビットとCRCSCAN.CTRLBレシ、スタは変えることができません。

- ・ CRCSCAN.STATUSレジスタ内のOKビット
  - OKビットに'0'を書くことはCRCSCAN.CTRLAレジスタのNMIENビットが'1'の場合に遮蔽不可割り込み(NMI)を起動することができます。NMIが起動された場合、CRCSCANへの書き込みが全く許されません。
  - OKビットに'1'を書くことはCRCSCAN.STATUSレジスタのBUSYビットが'0'の時にOKビットを'1'として読ませます。

デバッガからCRCSCAN.CTRLAとCRCSCAN.CTRLBのレジスタ書き込みはCPUからの書き込みと同様に扱われます。

# 27.4. レジスタ要約

| 変位    | 略称     | ピット位置        | ヒ゛ット7 | ピット6 | ピット5 | じット4 | ピット3 | ピット2 | ピット1  | ピット0   |
|-------|--------|--------------|-------|------|------|------|------|------|-------|--------|
| +\$00 | CTRLA  | 7~0          | RESET |      |      |      |      |      | NMIEN | ENABLE |
| +\$01 | CTRLB  | 7~0          |       |      | MOE  | E1,0 |      |      | SRO   | C1,0   |
| +\$02 | STATUS | 7 <b>~</b> 0 |       |      |      |      |      |      | OK    | BUSY   |

# 27.5. レジスタ説明

# **27.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位:+\$00 リセット: \$00 特質:-

NMIが起動されてしまった場合、このレジスタは書き込み不可です。

| ピット    | 7     | 6 | 5 | 4 | 3 | 2 | 1     | 0      |
|--------|-------|---|---|---|---|---|-------|--------|
|        | RESET |   |   |   |   |   | NMIEN | ENABLE |
| アクセス種別 | R/W   | R | R | R | R | R | R/W   | R/W    |
| リセット値  | 0     | 0 | 0 | 0 | 0 | 0 | 0     | 0      |

#### • ビット7 - RESET : CRCSCANリセット (Reset CRCSCAN)

このビットに'1'を書くことはCRCSCAN周辺機能をリセットします。CRCSCANの制御レジスタと状態レジスタ(CRCSCAN.CTRLA,CRCSCAN.CTRLB,CRCSCAN.STATUS)はRESETビットが'1'を書かれた後の1クロック周期で解除されます。

NMI起動許可(NMIEN)が'0'なら、このビットはCRCSCANが多忙(CRCSCAN.STATUSレジスタの多忙(BUSY)ビットが'1')と多忙でない (BUSYビットが'0')の両方の時に書き込み可能で、直ちに有効になります。

NMIENが'1'なら、このビットはCRCSCANが多忙でない(CRCSCAN.STATUSレジスタの多忙(BUSY)ビットが'0'の)時にだけ書き込み可能です。

RESETビットは瞬発(ストローブ)ビットです。

#### ● ビット1 - NMIEN: NMI起動許可 (Enable NMI Trigger)

このビットが'1'を書かれると、どのCRC不成功もNMIを起動します。

このビットはシステム リセットによってのみ解除(<mark>0</mark>)することができ、リセット(RESET)ビットへの書き込みによって解除(0)されません。

このビットはCRCSCANが多忙でない(CRCSCAN.STATUSレジスタの多忙(BUSY)ビットが゚0゚の)時に゚1゚へ書くことだけができます。

# ● ビット0 - ENABLE: CRCSCAN許可 (Enable CRCSCAN)

このビットに'1'を書くことは現在の設定でCRCSCAN周辺機能を許可します。これはCRC検査が完了した後も'1'に留まりますが、再びこれに'1'を書くことが新しい検査を開始します。

このビットに'0'を書くことは無効です。

CPUに通常のコート・実行を始めさせる前にフラッシュ メモリ領域を確認するため、MCU始動手順中に走査を走行するようにCRCSCANを構成設定することができます(「27.3.1. 初期化」項をご覧ください)。この機能が許可された場合、通常のコート・実行が始まると、ENABL Eビットが'1'として読みます。

CRCSCAN周辺機能が進行中の検査で多忙かどうかを知るには、状態(CRCSCAN.STATUS)レジスタの多忙(BUSY)ビットをポーリングしてください。

# **27.5.2. CTRLB - 制御B** (Control B)

名称: CTRLB 変位:+\$01 リセット: \$00 特質:-

CTRLBレジスタはCRCに関する動作形態と供給元の設定を含みます。これはCRCが多忙の時、またはNMIが起動されてしまった時に書き込み不可です。

| ピット    | 7 | 6 | 5   | 4    | 3 | 2 | 1   | 0    |
|--------|---|---|-----|------|---|---|-----|------|
|        |   |   | MOI | E1,0 |   |   | SRO | Ç1,0 |
| アクセス種別 | R | R | R/W | R/W  | R | R | R/W | R/W  |
| リセット値  | 0 | 0 | 0   | 0    | 0 | 0 | 0   | 0    |

#### ● ビット5.4 - MODE1.0:動作形態 (CRC Flash Access Mode)

CPUに通常のコート、実行を始めさせる前にフラッシュ メモリ領域を確認するために、内部リセット初期化中にCRCを許可することができます (ヒュース、の記述をご覧ください)。 CRCが内部リセット初期化中に許可された場合、通常のコート、実行が始まると、MODE ビット領域は非0を読み出されます。 コート、実行下でCRCの正しい動作を保証するため、MODE ビットに再び、00、を書いてください。

| 値  | 0 0                                               | その他  |
|----|---------------------------------------------------|------|
| 名称 | PRIORITY                                          | -    |
| 説明 | CRC単位部はフラッシュメモリへの優先権で単一検査を走ります。CPUはCRC完了まで停止されます。 | (予約) |

#### ● ビット1.0 - SRC1.0: CRC供給元 (CRC Source)

SRCビット領域はCRC単位部が検査するフラッシュ メモリの領域を選びます。領域の大きさを構成設定するにはヒューズ記述を参照してください。

CPUを開始させる前にフラッシュ メモリ領域を確認するために、内部リセット初期化中にCRCを許可することができます(「ヒューズ」項をご覧ください)。 CRCが内部リセット初期化中に許可された場合、通常のコード実行が始まると、(構成設定に依存して)FLASH、BOOTAPP、BOOTとして読み出されます。

| 値  | 0 0                                          | 0 1                                | 1 0                         | 1 1  |
|----|----------------------------------------------|------------------------------------|-----------------------------|------|
| 名称 | FLASH                                        | BOOTAPP                            | BOOT                        | -    |
| 説明 | CRCはフラッシュ メモリ全体(ブート、応用コート、、応用データの領域)で実行されます。 | CRCはフラッシュのブートと応用<br>コードの領域で実行されます。 | CRCはフラッシュのブート<br>領域で実行されます。 | (予約) |

# **27.5.3. STATUS - 状態** (Status)

名称: STATUS 変位: +\$02 リセット: \$02 特質: -

状態(STATUS)レシ、スタは多忙とOKの情報を含みます。これは書き込み不可で読み込みのみ可能です。

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0    |
|--------|---|---|---|---|---|---|----|------|
|        |   |   |   |   |   |   | OK | BUSY |
| アクセス種別 | R | R | R | R | R | R | R  | R    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 1  | 0    |

#### • L"y⊦1 - OK : CRC OK (CRC OK)

このビットが'1'として読まれると、直前のCRCは成功裏に完了しました。このビットはCRC走査が走るのに先立って既定で'1'に設定されます。このビットはCRC多忙(BUSY)が'0'でない限り有効ではありません。

# ● ビット0 - BUSY: CRC多忙(CRC Busy)

このビットが、1'として読まれると、CRCSCANは多忙です。単位部が多忙である限り、制御レジスタへのアクセスは制限されます。

# 28. CCL - 構成設定可能な注文論理回路

# 28.1. 特徴

- · 汎用PCB設計用接続用論理回路(glue logic)
- ・2つまでの設定可能な参照表(LUT1とLUT0)
- ・組み合わせ論理回路機能:3入力までの機能の全ての論理式
- 逐次制御器論理回路機能
  - 門付きDフリッププロップ
  - JKフリップ。フロッフ。
  - 門付きDラッチ
  - RSラッチ
- ・柔軟な参照表(LUT)入力選択
  - 入出力
  - 事象
  - 後続LUT出力
  - 内部周辺機能
    - ・アナログ比較器
    - タイマ/カウンタ
    - USART
    - SPI
- ・システムクロックまたは他の周辺機能によるクロック駆動
- ・入出力ピンまたは事象システムへ接続可能な出力
- 各LUT出力で利用可能な任意選択の同期化器、濾波器、端検出器

#### 28.2. 概要

構成設定可能な注文論理回路(CCL:Configurable Custom Logic)はデバイスのピン、事象、他の内部周辺機能に接続することができる設定可能な論理回路周辺機能です。CCLはデバイスの周辺機能と外部デバイス間の"接続用論理回路(glue logic)"として扱うことができます。CCLは外部の論理回路部品の必要を無くすことができ、CPUと無関係に応用の最も時間が重要な部分を処理するためにコアを独立した周辺機能と組み合わせることによって実時間制限を克服することで設計者を手助けすることもできます。

CCL周辺機能はいくつかの参照表(LUT:LookUp Table)を持ちます。各LUTは3つの入力、真理値表、濾波器/端検出器から成ります。各LUTは3つの入力を持つ使用者設定可能な論理式として出力を生成することができます。入力は個別に遮蔽することができます。

出力は組み合わせ的に入力から生成することができ、スパークを取り除くために濾波することができます。任意選択の逐次制御単位部を許可することができます。逐次制御単位部への入力は2つの独立した隣接LUT(LUT0/LUT1)出力によって個別に制御され、複雑な波形生成を許します。

# 28.2.1. 構成図



#### 28.2.2. 信号説明

| 信号         | 形式     | 説明       |
|------------|--------|----------|
| LUTn-OUT   | デジタル出力 | LUTからの出力 |
| LUTn-IN2~0 | デジタル入力 | LUTへの入力  |

この周辺機能に対するピン割り当ての詳細については「入出力多重化と考察」を参照してください。1つの信号を様々なピンに割り当てることができます。

# 28.2.3. システム依存性

この周辺機能を使うには、右で記述されるように、システムの他の部分が正しく構成設定されなければなりません。

| 表28-1. CCLシステム依存性 |         |         |  |  |  |  |  |  |
|-------------------|---------|---------|--|--|--|--|--|--|
| 依存性               | 適用性     | 周辺機能    |  |  |  |  |  |  |
| クロック              | $\circ$ | CLKCTRL |  |  |  |  |  |  |
| I/O線と接続           | 0       | PORT    |  |  |  |  |  |  |
| 割り込み              | ×       | _       |  |  |  |  |  |  |
| 事象                | 0       | EVSYS   |  |  |  |  |  |  |
| デバッグ              | 0       | UPDI    |  |  |  |  |  |  |

#### 28.2.3.1. クロック

既定によってCCLはデバイスの周辺機能クロック(CLK\_PER)を使います。

代わりに、CCLはLUTn入力線2(LUTn\_IN2)で利用可能な周辺機能入力によってクロック駆動することができます。これはLUTn制御A (CCL.LUTnCTRLA)レジスタのクロック元選択(CLKSRC)ビットに'1'を書くことによって構成設定されます。逐次制御部とLUT対の偶数 LUTは同じクロックによってクロック駆動されます(SEQn.clk=LUT2n.clk)。CCL.LUTnCTRLAのCLKSRCビットを構成設定する前に制御A (CCL.CTRLA)レジスタの許可(ENABLE)ビットに'0'を書くことによってこの周辺機能を禁止することが推奨されます。

代わりに、LUTと対応する逐次制御部をクロック駆動するのにLUTの入力線2(IN2)を使うことができます。これはCCL.LUTnCTRLAレジスタのCLKSRCビットに'1'を書くことによって許可されます。

CCLはLUTクロック元を変更する前に禁止されなければなりません。CCL.CTRLAのENABLE) ットに'0'を書いてください。

# 28.2.3.2. I/O線

CCLは入力を取り、入出力ピンを通して出力を生成することができます。これを正しく機能させるため、入出力ピンは参照表(LUT)によって使われるように構成設定されなければなりません。

#### 28.2.3.3. 割り込み

該当なし

#### 28.2.3.4. 事象

CCLは他の周辺機能からの事象を使うことと他の周辺機能によって使うことができる事象を生成することができます。この特徴を機能させるため、事象が正しく構成設定されなければなりません。事象使用部と事象生成部についてのより多くの情報に関しては下の関連リンクを参照してください。

## 28.2.3.5. デバッグ操作

デバック・動作形態でCPUが停止されると、CCLは通常動作を続けます。けれども、CPUがデバック・動作で停止される時にCCLを停止することができません。CPUによる定期的な助けを必要とするように構成設定された場合、デバック・の間に不適切な動作やデータ損失の可能性があります。

# 28.3. 機能的な説明

#### 28.3.1. 初期化

以下のビットはそれらが対応する偶数LUTが禁止(LUT0制御A(CCL.LUT0CTRLA)レジスタのLUT許可(ENABLE)=0)される時にだけ書くことができることを意味する、許可保護にされます。

・ 逐次制御器制御0(CCL.SEQCTRL0)レシブスタの逐次制御器選択(SEQSEL)

以下のレジスタはそれらが対応するLUTが禁止(LUTn制御A(CCL.LUTnCTRLA)レジスタのLUT許可(ENABLE)=0)される時にだけ書くことができることを意味する、許可保護にされます。

- ・CCL\_LUTnCTRLAレジスタのENABLEビットを除くLUTn制御x(CCL\_LUTnCTRLx)レジスタ
- ・真理値表n(CCL.TRUTHn)レジスタ

CCL.LUTnCTRLxレジスタで許可保護されたビットはCCL.LUTnCTRLAレジスタのENABLEビットが'1'に書かれるのと同じ時に書くことができますが、ENABLEビットが'0'に書かれるのと同じ時ではありません。

許可保護はレジスタ説明で許可保護された特質によって示されます。

#### 28.3.2. 動作

#### 28.3.2.1. 許可、禁止、リセット

CCLは制御A(CCL.CTRLA)レジスタの許可(ENABLE)ビットに'1'を書くことによって許可されます。CCLはそのENABLEビットに'0'を書くことによって禁止されます。

各LUTはLUT制御A(CCL.LUTnCTRLA)レジスタのLUT許可(ENABLE)ビットに'1'を書くことによって許可されます。各LUTはCCL.LUTnCTRLAレジスタのENABLEビットに'0'を書くことによって禁止されます。

#### 28.3.2.2. 参照表論理回路

各LUT部の参照表は3つまでの入力(IN2~0)の関数として組み合わせ論理出力を生成することができます。未使用入力は遮蔽(Low 接続に)することができます。組み合わせ論理式用の真理値表は真理値表(CCL.TRUTHn)レジスタ内のビットによって定義されます。入力(IN2~0)ビットの各組み合わせは下表で示されるようにCCL.TRUTHnレジスタ内の1ビットに対応します。

表28-2. LUTの真理値表

| IN2 | 0      | 0      | 0      | 0      | 1      | 1      | 1      | 1      |
|-----|--------|--------|--------|--------|--------|--------|--------|--------|
| IN1 | 0      | 0      | 1      | 1      | 0      | 0      | 1      | 1      |
| IN0 | 0      | 1      | 0      | 1      | 0      | 1      | 0      | 1      |
| OUT | TRUTH0 | TRUTH1 | TRUTH2 | TRUTH3 | TRUTH4 | TRUTH5 | TRUTH6 | TRUTH7 |

#### 28.3.2.3. 真理值表入力選択

#### 入力概要

入力は個別に以下のようにすることができます。

- 遮蔽
- ・周辺機能による駆動
  - アナログ比較器(AC)出力
  - タイマ/カウンタ(TC)波形出力
- ・事象システムからの内部事象による駆動
- ・他のCCL補助単位部による駆動

LUTnの各入力yに対する入力選択はLUTn制御x(CCL.LUTnCTRLBとCCL.LUTnCTRLC)レジスタの入力y供給元選択(INSELy)ビットを書くことによって構成設定されます。

- ・LUTn制御B(CCL.LUTnCTRLB)レシブスタの入力0供給元選択(INSEL0)
- ・ CCL.LUTnCTRLBレジスタの入力1供給元選択(INSEL1)
- ・LUTn制御C(CCL.LUTnCTRLC)レシブスタの入力2供給元選択(INSEL2)

#### 内部帰環入力(FEEDBACK)

選択(CCL.LUTnCTRLxレジスタのINSELy='0001'(FEEDBACK))されると、逐次制御(SEQ)出力が対応するLUTに対する入力として使われます。

内部逐次制御単位部からの出力はLUTに対する入力元として使うことができます。LUT0とLUT1に対する例については右図をご覧ください。各LUTに対する逐次制御選択は以下の式に従います。

IN[2N][i] = SEQ[N]IN[2N+1][i] = SEQ[N]

Nは逐次制御器番号を表し、iは0,1でLUT入力指標を表します。

詳細については「28.3.2.6. 逐次制御論理回路」を参照してください。

# 図28-2. 帰還入力選択 帰還(FEEDBACK) LUT0 TRUTH SEQ0 LUT1 TRUTH

#### 連結LUT (LINK)

LINK入力任意選択(INSELy='0010')選択時、次のLUTの直接出力がLUTの入力として使われます。一般的に、LUT[n+1]がLUT[n]の入力に連結されます。例として、LUT1はLUT0に対する入力です。LUT0は最後のLUTの入力に連結されます。



#### 内部事象入力選択 (EVENT)

事象システムからの非同期事象はLUTへの入力として使うことができます。2つの事象入力線(EVENT0とEVENT1)が利用可能で、LUTへの入力として選ぶことができます。LUTn制御BまたはC(CCL.LUTnCTRLBまたはCCL.LUTnCTRLC)レジスタへ書くことによってEV ENT(EVENT0(INSELy='0011')、EVENT1(INSELy='0100'))入力任意選択を選ぶ前に、事象システムが構成設定されなければなりません。

# I/Oピン入力 (IO)

IO(INSELy='0101')任意選択選択時、LUT入力は対応するI/Oピンに接続されます。 LUTnINyが配置される場所についてのより多くの詳細に関しては「入出力多重化と考察」 章を参照してください。



#### 周辺機能

各LUTの3つの入力線での各種周辺機能はLUTn制御B/C(CCL.LUTnCTRLBとCCL.LUTnCTRLC)レジスタの各々のLUTn入力y (INSELy)ビット領域へ書くことによって選ばれます。

- ・LUTn制御B(CCL.LUTnCTRLB)レジブスタの入力選択0(INSEL0)
- ・CCL.LUTnCTRLBレシブスタの入力選択1(INSEL1)
- LUTn制御C(CCL.LUTnCTRLC)レシブスタの入力選択2(INSEL2)

#### 28.3.2.4. 瀘波器

既定によって、LUT出力はLUT入力の組み合わせ関数です。これは入力が値を変える時にいくつかの短い不具合を起こし得ます。これらの不具合は応用の必要によって要求された場合に濾波器を通してクロック駆動することによって取り除くことができます。

LUTn制御A(CCL.LUTnCTRLA)レジスタの濾波器選択(FILTSEL)ピットはデジタル濾波器任意選択を定義(FILTSEL='10')します。濾波器が許可されると、出力は(周辺機能クロックか代替クロックで)2~5クロック周期遅らされます。全ての内部濾波器論理回路は対応するLUTが禁止された後の1クロック周期で解消されます。



# 28.3.2.5. 端検出器

端検出器はそれの入力で上昇端を検出する時にパルスを生成するのに使うことができます。下降端を検出するため、反転する出力を提供するように真理値表(CCL.TRUTHnレジスタ)を設定することができます。

端検出器はLUTn制御A(CCL.LUTnCTRLA)レシブスタの端検出(EDGEDET) ビットに'1'を書くことによって許可されます。予測不能な動きを避けるため、更に有効な濾波器任意選択も許可されなければなりません。

端検出はCCL.LUTnCTRLAレシ、スタのEDGEDETに'0'を書くことによって禁止されます。LUT禁止後、対応する内部端検出器論理回路は1クロック周期後に解消されます。



#### 28.3.2.6. 逐次制御論理回路

各LUT対は内部逐次制御部に接続することができます。逐次制御部はDフリッププロップ、JKフリッププロップ、門付きDラッチ、RSラッチのどれかとして機能することができます。この機能は逐次制御器制御n(CCL.SEQCTRLn)レシ、スタのは逐次制御器選択(SEQSEL)ビットを書くことによって選ばれます。

逐次制御部は構成設定に依存して、LUT、濾波器、端検出器のどれかから入力を受け取ります。

逐次制御部は周辺機能クロックかまたは入力線2(IN2)のどちらかである、対応するLUTと同じクロック元によってクロック駆動されます。これはLUTn制御A(CCL.LUTnCTRLA)レジスタのクロック元選択(CLKSRC)ビットによって構成設定されます。

偶数LUT(LUT2n)が禁止されると、ラッチはフリッププロップ リセット信号(R)が1クロック周期間許可を保たれる間に非同期に解消されます。

#### 門付きDフリッププロップ<sup>°</sup>(DFF)

D入力は偶数LUT(LUT2n)出力によって駆動され、G入力は奇数LUT(LUT2n+1)出力によって駆動されます。



| 表28-3. DFF特 | 寺性 |   |                      |
|-------------|----|---|----------------------|
| R           | G  | D | OUT                  |
| 1           | X  | X | 解除( <mark>0</mark> ) |
| 0           | 1  | 1 | 設定( <u>1</u> )       |
| 0           | 1  | 0 | 解除( <mark>0</mark> ) |
| 0           | 0  | Х | 状態保持(無変化)            |

# JKDフリップ<sup>°</sup>フロッフ<sup>°</sup> (JK)

J入力は偶数LUT(LUT2n)出力によって駆動され、K入力は奇数LUT(LUT2n+1)出力によって駆動されます。



| 表28-4. JK特 | 性 |   |                      |
|------------|---|---|----------------------|
| R          | J | K | OUT                  |
| 1          | X | X | 解除( <mark>0</mark> ) |
| 0          | 0 | 0 | 状態保持(無変化)            |
| 0          | 0 | 1 | 解除( <mark>0</mark> ) |
| 0          | 1 | 0 | 設定( <u>1</u> )       |
| 0          | 1 | 1 | 逆へ切り替え               |

#### 門付きDラッチ (DLATCH)

D入力は偶数LUT(LUT2n)出力によって駆動され、G入力は奇数LUT(LUT2n+1)出力によって駆動されます。



| 表28-5. Dラッチ特性 |   |                      |  |  |  |  |  |
|---------------|---|----------------------|--|--|--|--|--|
| G             | D | OUT                  |  |  |  |  |  |
| 0             | X | 状態保持(無変化)            |  |  |  |  |  |
| 1             | 0 | 解除( <mark>0</mark> ) |  |  |  |  |  |
| 1             | 1 | 設定( <u>1</u> )       |  |  |  |  |  |

# RSラッチ (RS)

S入力は偶数LUT(LUT2n)出力によって駆動され、R入力は奇数LUT(LUT2n+1)出力によって駆動されます。



| 表28-6. RSラッチ特性 |   |                      |  |  |  |  |  |
|----------------|---|----------------------|--|--|--|--|--|
| S              | R | OUT                  |  |  |  |  |  |
| 0              | 0 | 状態保持(無変化)            |  |  |  |  |  |
| 0              | 1 | 解除( <mark>0</mark> ) |  |  |  |  |  |
| 1              | 0 | 設定( <u>1</u> )       |  |  |  |  |  |
| 1              | 1 | 禁止状態                 |  |  |  |  |  |

#### 28.3.2.7. クロック元設定

濾波器、端検出器、逐次制御部は既定でシステム クロック(CLK\_PER)によってクロック駆動されます。これはそれらの区部をクロック駆動する(右図のCLK\_MUX\_OUT)のにLUT入力2(IN2)を使うことも可能です。これはLUTn制御A(CCL.LUTnCTRLA)レジ、スタのクロック元選択(CLKSRC)ビットに、1、を書くことによって構成設定されます。

クロック元選択(CLKSRC)ビットが'1'の時に対応する濾波器と端検出器をクロック駆動する(CLK\_MUX\_OUT)のにIN2が使われます。逐次制御部は対の偶数LUTのCLK\_MUX\_OUTによってクロック駆動されます。CLKSRCビットが'1'の時に真理値(TRUTH)表でIN2は遮蔽(='0')として扱われます。

CCL周辺機能は周辺機能からの未確定出力を避けるためにクロック元を変更する間は禁止されます。



#### 28.3.3. 事象

CCLは以下の出力事象を生成することができます。

· LUTnOUT:参照表出力值

CCLは以下の以下の入力事象での活動を取ることができます。

・INx:この事象は真理値(TRUTH)表に対する入力として使われます。

# 28.3.4. 休止形態動作

制御A(CCL.CTRLA)レジ、スタのスタンハ・イ時走行(RUNSTDBY)ビットに'1'を書くことはスタンハ・イ休止動作で許可されることをシステム クロックに 許します。

RUNSTDBYビットが'0'の場合、システム クロックはスタンバイ休止動作で禁止されます。濾波器、端検出器、または逐次論理回路が許可される場合、スタンバイ休止動作でLUT出力は'0'を強制されます。アイドル休止動作では、RUNSTDBYビットと関係なく、真理値(TRUTH)表復号部は動作を続け、それによってLUT出力が更新されます。

LUTn制御A(CCL.LUTnCTRLA)レジスタのクロック元選択(CLKSRC)が'1'を書かれる場合、LUT入力2(IN2)は常に濾波器、端検出器、逐次論理回路をクロック駆動します。休止動作形態でのIN2クロックの有効性は使う周辺機能の休止設定に依存します。

# 28.3.5. 構成設定変更保護

該当なし

# 28.4. レジスタ要約

| 変位                  | 略称        | ビット位置        | ビット7    | ピット6     | ヒ゛ット5 | ピット4  | ピット3  | ヒ゛ット2 | ピット1  | ピット0   |
|---------------------|-----------|--------------|---------|----------|-------|-------|-------|-------|-------|--------|
| +\$00               | CTRLA     | 7~0          |         | RUNSTDBY |       |       |       |       |       | ENABLE |
| +\$01               | SEQCTRL0  | 7 <b>~</b> 0 |         |          |       |       |       | SEQSI | EL3~0 |        |
| +\$02<br>-<br>+\$04 | 予約        |              |         |          |       |       |       |       |       |        |
| +\$05               | LUT0CTRLA | 7~0          | EDGEDET | CLKSRC   | FILTS | EL1,0 | OUTEN |       |       | ENABLE |
| +\$06               | LUT0CTRLB | 7 <b>~</b> 0 |         | INSEI    | L13~0 | 1     |       | INSEI | _03~0 |        |
| +\$07               | LUT0CTRLC | 7 <b>~</b> 0 |         |          |       |       |       | INSEI | L23~0 |        |
| +\$08               | TRUTH0    | 7 <b>~</b> 0 |         |          |       | TRUT  | `H7∼0 |       |       |        |
| +\$09               | LUT1CTRLA | 7 <b>~</b> 0 | EDGEDET | CLKSRC   | FILTS | EL1,0 | OUTEN |       |       | ENABLE |
| +\$0A               | LUT1CTRLB | 7 <b>~</b> 0 |         | INSEI    | L13~0 | 1     |       | INSEI | _03~0 |        |
| +\$0B               | LUT1CTRLC | 7~0          |         |          |       |       |       | INSEI | L23~0 |        |
| +\$0C               | TRUTH1    | 7~0          |         |          |       | TRUT  | `H7∼0 |       |       | 1      |

# 28.5. レジスタ説明

**28.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位:+\$00 リセット: \$00 特質:-

| ピット    | 7 | 6        | 5 | 4 | 3 | 2 | 1 | 0      |
|--------|---|----------|---|---|---|---|---|--------|
|        |   | RUNSTDBY |   |   |   |   |   | ENABLE |
| アクセス種別 | R | R/W      | R | R | R | R | R | R/W    |
| リセット値  | 0 | 0        | 0 | 0 | 0 | 0 | 0 | 0      |

# ● ビット6 - RUNSTDBY: スタンバイ時走行 (Run in Standby)

このビットはスタンバイ休止動作で周辺機能クロック(CLK\_PER)が走行を保つかを示します。CLK\_PERが必要とされない構成設定に対してはこの設定が無効にされます。

| 値  | 0                              | 1                           |
|----|--------------------------------|-----------------------------|
| 説明 | システム クロックはスタンハ・イ休止動作で必要とされません。 | システムクロックはスタンバイ休止動作で必要とされます。 |

# ● ビット0 - ENABLE : 許可 (Enable)

| 値  | 0      | 1      |
|----|--------|--------|
| 説明 | 周辺機能禁止 | 周辺機能許可 |

# **28.5.2. SEQCTRLO - 逐次制御器制御0** (Sequential Control 0)

名称: SEQCTRL0 変位: +\$01 リセット: \$00 特質: 許可保護

| <u> </u> | 7 | 6 | 5 | 4 | 3   | 2     | 1     | 0   |
|----------|---|---|---|---|-----|-------|-------|-----|
|          |   |   |   |   |     | SEQSI | EL3~0 |     |
| アクセス種別   | R | R | R | R | R/W | R/W   | R/W   | R/W |
| リセット値    | 0 | 0 | 0 | 0 | 0   | 0     | 0     | 0   |

# ● ビット3~0 - SEQSEL3~0:逐次制御器選択(Sequential Selection)

このビット領域はLUT0とLUT1用の逐次(論理回路)構成を選びます。

| 値  | Ī | 0 0 0    | 0 0 1       | 0 1 0        | 0 1 1  | 100   | 101 | 110  | 1 1 1 |
|----|---|----------|-------------|--------------|--------|-------|-----|------|-------|
| 名  | 称 | DISABLE  | DFF         | JK           | DLATCH | RS    |     | -    |       |
| 説印 | 明 | 逐次論理回路禁止 | Dフリップ。フロップ。 | JKフリップ。フロッフ。 | Dラッチ   | RSラッチ |     | (予約) |       |

# 28.5.3. LUTnCTRLA - LUTn制御A (LUT n Control A)

名称:LUT0CTRLA:LUT1CTRLA

変位:+\$05::+\$09

リセット: \$00 特質:許可保護

|                                       | ENABLE |
|---------------------------------------|--------|
| 710.5任即 2/10 2/10 2/10 2/10 2/10 2/10 |        |
| アクセス種別 R/W R/W R/W R/W R R            | R/W    |
| リセット値 0 0 0 0 0 0                     | 0      |

# ● ビット7 - EDGEDET: 端検出 (Edge Detection)

| 値  | 0      | 1      |
|----|--------|--------|
| 説明 | 端検出器禁止 | 端検出器許可 |

#### ● ビット6 - CLKSRC: クロック元選択 (Clock Source Selection)

このビットはLUT用のクロック(CLK\_MUX\_OUT)として周辺機能クロック(CLK\_PER)か、または入力2(IN2)に存在する何れかの入力のどちらが使われるかを選びます。

LUT対の逐次制御部をクロック駆動するのは偶数LUTのCLK\_MUX\_OUTが使われます。

| 値  | 0                      | 1                  |
|----|------------------------|--------------------|
| 説明 | CLK_PERがLUTをクロック駆動します。 | IN2がLUTをクロック駆動します。 |

# ● ビット5,4 - FILTSEL1,0: 濾波器選択 (Filter Selection)

このビット領域はLUT出力濾波器任意選択を選びます。

| 値  | 0 0     | 0 1    | 1 0    | 11   |
|----|---------|--------|--------|------|
| 名称 | DISABLE | SYNCH  | FILTER | -    |
| 説明 | 濾波器禁止   | 同期化器許可 | 濾波器許可  | (予約) |

# ● ビット3 - OUTEN: 出力許可(Output Enable)

このビットはLUTnOUTピンへのLUT出力を許可します。 '<mark>1</mark>'を書かれると、ポート制御器のピン構成設定が無効にされます。

| 値  | 0        | 1        |
|----|----------|----------|
| 説明 | ピンへの出力禁止 | ピンへの出力許可 |

# ● ビット0 - ENABLE: LUT許可(LUT Enable)

| 値  | 0     | 1     |
|----|-------|-------|
| 説明 | LUT禁止 | LUT許可 |

# 28.5.4. LUTnCTRLB - LUTn制御B (LUT n Control B)

名称:LUT0CTRLB:LUT1CTRLB

**変位**:+\$06 :+\$0A

リセット: \$00 特質:許可保護

CCLへのSPI接続は主装置SPI動作でだけ動きます。

CCLへのUSART接続は非同期/同期USART主装置動作でだけ動きます。

| ピット    | 7   | 6     | 5     | 4   | 3   | 2     | 1     | 0   |
|--------|-----|-------|-------|-----|-----|-------|-------|-----|
|        |     | INSEL | _13~0 |     |     | INSEI | _03~0 |     |
| アクセス種別 | 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~4 - INSEL13~0: LUTn入力1供給元選択(LUT n Input 1 Selection)

このビット領域はLUTnの入力1(IN1)に対する供給元を選びます。

次頁の表参照

| 値    | 名称       | 説明                 |
|------|----------|--------------------|
| 0000 | MASK     | 入力遮蔽('0'固定)        |
| 0001 | FEEDBACK | 帰還入力               |
| 0010 | LINK     | 入力元として他のLUTを連結     |
| 0011 | EVENT0   | 事象入力元0             |
| 0100 | EVENT1   | 事象入力元1             |
| 0101 | IO       | 入出力ピンのLUTn-IN1を入力元 |
| 0110 | AC0      | AC0のOUTを入力元        |
| 0111 | TCB0     | TCB0のWOを入力元        |
| 1000 | TCA0     | TCA0のWO1を入力元       |
| 1001 | TCD0     | TCD0のWOBを入力元       |
| 1010 | USART0   | USART0のTxDを入力元     |
| 1011 | SPI0     | SPIOのMOSIを入力元      |
| 1100 | AC1      | AC1のOUTを入力元        |
| 1101 | TCB1     | TCB1のWOを入力元        |
| 1110 | AC2      | AC2のOUTを入力元        |
| その他  | _        | (予約)               |

# ● ビット3~0 - INSEL03~0: LUTn入力0供給元選択(LUT n Input 0 Selection)

このビット領域はLUTnの入力0(IN0)に対する供給元を選びます。

| 値    | 名称       | 説明                         |
|------|----------|----------------------------|
| 0000 | MASK     | 入力遮蔽(' <mark>0</mark> '固定) |
| 0001 | FEEDBACK | 帰還入力                       |
| 0010 | LINK     | 入力元として他のLUTを連結             |
| 0011 | EVENT0   | 事象入力元0                     |
| 0100 | EVENT1   | 事象入力元1                     |
| 0101 | IO       | 入出力ピンのLUTn-IN0を入力元         |
| 0110 | AC0      | AC0のOUTを入力元                |
| 0111 | TCB0     | TCB0のWOを入力元                |
| 1000 | TCA0     | TCA0のWO0を入力元               |
| 1001 | TCD0     | TCD0のWOAを入力元               |
| 1010 | USART0   | USART0のXCKを入力元             |
| 1011 | SPI0     | SPI0のSCKを入力元               |
| 1100 | AC1      | AC1のOUTを入力元                |
| 1101 | TCB1     | TCB1のWOを入力元                |
| 1110 | AC2      | AC2のOUTを入力元                |
| その他  | _        | (予約)                       |

# 28.5.5. LUTnCTRLC - LUTn制御C (LUT n Control C)

名称:LUT0CTRLC:LUT1CTRLC

**変位**:+\$07::+\$0B

リセット: \$00 特質:許可保護

| ピット    | 7 | 6 | 5 | 4 | 3   | 2     | 1     | 0   |
|--------|---|---|---|---|-----|-------|-------|-----|
|        |   |   |   |   |     | INSEI | L23~0 |     |
| アクセス種別 | R | R | R | R | R/W | R/W   | R/W   | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0   | 0     | 0     | 0   |

# ● ビット3~0 - INSEL23~0: LUTn入力2供給元選択(LUT n Input 2 Selection)

このビット領域はLUTnの入力2(IN2)に対する供給元を選びます。

| 値    | 名称       | 説明                 |
|------|----------|--------------------|
| 0000 | MASK     | 入力遮蔽('0'固定)        |
| 0001 | FEEDBACK | 帰還入力               |
| 0010 | LINK     | 入力元として他のLUTを連結     |
| 0011 | EVENT0   | 事象入力元0             |
| 0100 | EVENT1   | 事象入力元1             |
| 0101 | IO       | 入出力ピンのLUTn-IN2を入力元 |
| 0110 | AC0      | AC0のOUTを入力元        |
| 0111 | TCB0     | TCB0のWOを入力元        |
| 1000 | TCA0     | TCA0のWO2を入力元       |
| 1001 | TCD0     | TCD0のWOAを入力元       |
| 1010 | ı        | (予約)               |
| 1011 | SPI0     | SPIOのMISOを入力元      |
| 1100 | AC1      | AC1のOUTを入力元        |
| 1101 | TCB1     | TCB1のWOを入力元        |
| 1110 | AC2      | AC2のOUTを入力元        |
| その他  | _        | (予約)               |

# 28.5.6. TRUTHn - 真理値表n (TRUTHn)

名称:TRUTH0 :TRUTH1 変位:+\$08 :+\$0C

リセット: \$00 特質:許可保護



# ● ビット7~0 - TRUTH7~0: 真理値表 (Truth Table)

このビット領域はIN2~0入力の関数として真理値論理回路の値を定義します。

# 29. AC - アナログ比較器

# 29.1. 特徴

- ・2.7V以上の供給電圧に対する50nsの応答時間
- ・0交差検出
- ・選択可能なヒステリシス
  - -なし
  - 10mV
  - 25mV
  - 50mV
- ・ピンで利用可能なアナログ比較器出力
- · 比較器出力反転利用可能
- ・柔軟な入力選択
  - 最大4つの正入力ピン
  - 最大2つの負入力ピン
  - D/A変換器(DAC)からの出力
  - 内部基準電圧
- ・以下での割り込み生成
  - 上昇端
  - 下降端
  - 両端
- 事象生成
  - 比較器出力

# 29.2. 概要

アナログ比較器(AC)は2つの入力の電圧水準を比較してその比較に基いたデジタル出力を与えます。ACは様々な異なる入力変化の組み合わせで割り込み要求や事象を生成するように構成設定することができます。

ACの動的な動きはヒステリシス機能によって調節することができます。 ヒステリシスは各応用に対する動作を最適化するために独自設定することができます。

入力選択はアナログ ポート ピン、D/A変換器(DAC)出力、内部参照基準電圧を含みます。アナログ比較器出力の状態は外部デバイスによって使うためにピン上に出力することもできます。

ACは1つの正入力と1つの負入力を持ちます。正入力元はアナログ入力ピンの1つです。負入力はアナログ入力ピンまたは内部基準電圧のような内部入力のどれかから選ばれます。

比較器からのデジタル出力は正と負の入力電圧間の差が正の時に'1'で、さもなければ'0'です。

# 29.2.1. 構成図



# 29.2.2. 信号説明

| 信号    | 形式     | 説明       |  |  |
|-------|--------|----------|--|--|
| AINNn | アナログ入力 | 負入力n     |  |  |
| AINPn | アナログ入力 | 正入力n     |  |  |
| OUT   | デジタル出力 | ACの比較器出力 |  |  |

#### 29.2.3. システム依存性

この周辺機能を使うには、右で記述されるように、システムの他の部分が正しく構成設定されなければなりません。

| 表29-1. ACシステム依存性 |     |         |  |  |  |  |
|------------------|-----|---------|--|--|--|--|
| 依存性              | 適用性 | 周辺機能    |  |  |  |  |
| クロック             | 0   | CLKCTRL |  |  |  |  |
| I/O線と接続          | 0   | PORT    |  |  |  |  |
| 割り込み             | 0   | CPUINT  |  |  |  |  |
| 事象               | 0   | EVSYS   |  |  |  |  |
| デバッグ             | 0   | UPDI    |  |  |  |  |

#### 29.2.3.1. クロック

この周辺機能は周辺機能クロック(CLK\_PER)に依存します。

# 29.2.3.2. I/O線と接続

I/OピンのAINPnとAINNnは全てACに対するアナログ入力です。

正しい動作のために、ピンはポート周辺機能とポート多重器周辺機能で構成設定されなければなりません。

AC使用時に汎用入出力(GPIO)を禁止することが推奨されます。

#### 29.2.3.3. 割り込み

使う周辺機能の割り込みは先に構成設定された割り込み制御器が必要です。

#### 29.2.3.4. 事象

この周辺機能の事象は事象システムに接続されます。

#### 29.2.3.5. デバッグ操作

この周辺機能はデバッグ動作移行によって影響を及ぼされません。

この周辺機能が割り込みや同様のものを通してCPUによる定期的な助けを必要とするように構成設定された場合、デバッグ停止の間に不適切な動作やデータ損失の可能性があります。

# 29.3. 機能的な説明

# 29.3.1. 初期化

基本的な操作については以下のこれらの手順に従ってください。

- 1. PORT周辺機能で望む入力ピンを構成設定してください。
- 2. 多重器制御A(ACn.MUXCTRLA)レジスタで正と負の入力多重器選択(MUXPOSとMUXNEG)のビット領域を書くことによって正と負の入力元を選んでください。
- 3. 任意選択: 制御A(ACn.CTRLA)レシブスタの出力ハット、許可(OUTEN)ヒットに'1'を書くことによって出力を許可してください。
- 4. AC.CTRLAレシブスタのAC許可(ENABLE)ビットに'1'を書くことによってACを許可してください。

AC許可後のAC始動時間の間、ACの出力は無効かもしれません。

ACそれ自体の始動時間は最大でも2.5μsです。内部参照基準が使われる場合、参照基準始動時間は通常AC始動時間よりも長くなります。VREF始動時間は最大でも60μsです。

#### 29.3.2. 動作

# 29.3.2.1. 入力ヒステリシス

入力ヒステリシスの印加は雑音に悩んでいる入力信号がお互いに近い時に出力の定常的な切り替わりを防ぐのを助けます。

入力ヒステリシスは禁止されるか、または3つのレベルの1つを持つかのどれかにすることができます。ヒステリシスは制御A(ACn.CTRLA)レジスタのヒステリシス動作選択(HYSMODE)ビット領域に書くことによって構成設定することができます。

# 29.3.2.2. 入力元

ACは1つの正入力と1つの負入力を持ちます。入力はピンと、基準電圧のような内部供給元にすることができます。

各入力は多重器制御A(ACn.MUXCTRLA)レジスタで正と負の入力多重器選択(MUXPOSとMUXNEG)のビット領域を書くことによって 選ばれます。

#### 29.3.2.2.1. ピン入力

ポート上の以下のアナログ入力ピンをアナログ比較器への入力として選ぶことができます。

- · AINN0 · AINN1 (注) · AINP0 · AINP1 (注) · AINP2 · AINP3 (注)
- 注: ポートの全てのピンが少ピン数デバイスで利用できるとは限りません。詳細についてはピン配置図や入出力多重化表を調べてください。

#### 29.3.2.2.2. 内部入力

ACは以下の内部入力を持ちます。

- ・D/A変換器(DAC)からの出力
- ・DACとAC用の参照基準電圧

#### 29.3.2.3. 低電力動作

電力を意識する応用に対して、ACは低減された消費電力と増された伝搬遅延を持つ低電力動作を提供します。 この動作は制御A(ACn.CTRLA)レジスタの低電力動作(LPMODE)ビットに'1'を書くことによって許可されます。

#### 29.3.3. 事象

ACはACが許可される時に以下の事象を自動的に生成します。

・ACからのデジタル出力(構成図でのOUT)が事象システム供給元として利用可能です。ACからの事象はデバイスのどのクロックに対しても非同期です。

ACは事象入力を持ちません。

# 29.3.4. 割り込み

| 表29-2. 和 | 表29-2. 利用可能な割り込みベクタと供給元 |                                                                    |  |  |  |  |  |
|----------|-------------------------|--------------------------------------------------------------------|--|--|--|--|--|
| 名称       | ベクタ説明                   | 条件                                                                 |  |  |  |  |  |
| COMP0    | アナログ比較器割り込み             | AC出力は割り込み制御(ACn.INTCTRL)レジスタの割り込み動作(INTMODE)によって構成設定されるように切り替わります。 |  |  |  |  |  |

割り込み条件が起こると、状態(ACn.STATUS)レジスタで対応する割り込み要求フラグが設定(1)されます。

割り込み元は周辺機能の割り込み制御(ACn.INTCTRL)レジスタで対応する許可ビットを書くことによって許可または禁止にされます。 割り込み要求は対応する割り込み元が許可され、割り込み要求フラケが設定(1)される時に生成されます。割り込み要求は割り込み要求フラケが解除(0)されるまで活性に留まります。割り込み要求フラケを解除する方法の詳細についてはACn.STATUSレジスタをご覧ください。

#### 29.3.5. 休止形態動作

アイドル休止動作でACは通常動作を続けます。

スタンハ・イ休止動作では、既定によってACが禁止されます。制御A(ACn.CTRLA)レシ、スタのスタンハ・イ休止動作時走行(RUNSTDBY)ヒットが、1'を書かれる場合、ACは動作を続けますが、状態(ACn.STATUS)レシ、スタは更新されず、他の単位部がCLK\_PERを要求しない場合に割り込みが全く生成されませんが、事象とハット、出力は更新されます。

パワーダウン休止動作では、ACとパッドへの出力が禁止されます。

# 29.3.6. 構成設定変更保護

該当なし

# 29.4. レジスタ要約

| 変位         | 略称       | ビット位置        | ヒ゛ット7    | ヒ゛ット6 | ビット5  | ヒ゛ット4  | ピット3   | ピット2  | ピット1   | ヒ゛ット0  |
|------------|----------|--------------|----------|-------|-------|--------|--------|-------|--------|--------|
| +\$00      | CTRLA    | 7~0          | RUNSTDBY | OUTEN | INTMO | DDE1,0 | LPMODE | HYSMO | DDE1,0 | ENABLE |
| +\$01      | 予約       |              |          |       |       |        |        |       |        |        |
| +\$02      | MUXCTRLA | 7~0          | INVERT   |       |       | MUXF   | OS1,0  |       | MUXN   | EG1,0  |
| +\$03<br>~ | 予約       |              |          |       |       |        |        |       |        |        |
| +\$05      | 3 7/13   |              |          |       |       |        |        |       |        |        |
| +\$06      | INTCTRL  | 7 <b>~</b> 0 |          |       |       |        |        |       |        | CMP    |
| +\$07      | STATUS   | 7~0          |          |       |       | STATE  |        |       |        | CMP    |

# 29.5. レジスタ説明

**29.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位:+\$00 リセット: \$00 特質:-

| ピット    | 7        | 6     | 5     | 4     | 3      | 2    | 1      | 0      |
|--------|----------|-------|-------|-------|--------|------|--------|--------|
|        | RUNSTDBY | OUTEN | INTMC | DE1,0 | LPMODE | HYSM | ODE1,0 | ENABLE |
| アクセス種別 | l 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 - RUNSTDBY: スタンバイ動作時走行(Run in Standby Mode)

このビットに'1'を書くことはスタンバイ休止動作でACに動作を続けることを許します。 クロックが停止されるため、割り込みと状態のフラグは更新されません。

| 値  | 0                    | 1                     |
|----|----------------------|-----------------------|
| 説明 | スタンバイ休止動作でACは停止されます。 | スタンバイ休止動作でACは動作を続けます。 |

● ビット6 - OUTEN: アナログ比較器出力パッド許可 (Analog Comparator Output Pad Enable)

このビットに'1'を書くことはOUT信号をピンで利用可能にします。

● ビット5,4 - INTMODE1,0: 割り込み動作 (Interrupt Modes)

このビット領域への書き込みはAC出力のどの端が割り込み要求を起動するかを選びます。

| 値  | 0 0      | 0 1  | 1 0     | 11      |  |
|----|----------|------|---------|---------|--|
| 名称 | BOTHEDGE | _    | NEGEDGE | POSEDGE |  |
| 説明 | 正負両端     | (予約) | 負端      | 正端      |  |

● ビット3 - LPMODE: 低電力動作 (Low Power Mode)

このビットへの'1'書き込みは比較器を通る電流を減らします。これは消費電力を減らしますが、ACの応答時間を増します。

| 値  | 0       | 1       |
|----|---------|---------|
| 説明 | 低電力動作禁止 | 低電力動作許可 |

● ビット2,1 - HYSMODE1,0: ヒステリシス動作選択 (Hysteresys Mode Select)

このビット領域を書くことはAC入力に対するヒステリシスを選びます。

| 値  | 0 0 | 0 1   | 1 0   | 11    |
|----|-----|-------|-------|-------|
| 名称 | OFF | 10    | 25    | 50    |
| 説明 | なし  | ±10mV | ±25mV | ±50mV |

● ビット0 - ENABLE: AC許可(Enable AC)

このビットに'1'を書くことがACを許可します。

**29.5.2. MUXCTRLA - 多重器制御A** (Mux Control A)

名称: MUXCTRLA

変位:+\$02 リセット:\$00 特質:-

ACn.MUXCTRLAはアナログ比較器多重器を制御します。

| ピット    | 7      | 6 | 5 | 4    | 3      | 2 | 1    | 0     |
|--------|--------|---|---|------|--------|---|------|-------|
|        | INVERT |   |   | MUXI | POS1,0 |   | MUXN | EG1,0 |
| アクセス種別 | R/W    | R | R | R/W  | R/W    | R | R/W  | R/W   |
| リセット値  | 0      | 0 | 0 | 0    | 0      | 0 | 0    | 0     |

● ビット7 - INVERT : AC出力反転 (Invert AC Output)

このビットに'1'を書くことはACの出力の反転を許可します。これはこの信号に接続される全ての周辺機能へ入力を効率的に反転し、内部状態信号にも影響を及ぼします。

#### ● ビット3 - MUXPOS: 正入力多重器選択 (Positive Input Mux Selection)

このビットを書くことはACの正入力への入力信号を選びます。

| 値  | 0 0    | 0 1    | 1 0    | 11     |
|----|--------|--------|--------|--------|
| 名称 | AINP0  | AINP1  | AINP2  | AINP3  |
| 説明 | 正入力ピン0 | 正入力ピン1 | 正入力ピン2 | 正入力ピン3 |

注: ポートの全てのピンが少ピン数デバイスで利用できるとは限りません。詳細についてはピン配置図や入出力多重化表を調べてください。

● ビット1,0 - MUXNEG1,0: 負入力多重器選択 (Negative Input Mux Selection)

このビット領域を書くことはACの負入力への入力信号を選びます。

| 値  | 0 0    | 0 1    | 1 0  | 11                                                           |
|----|--------|--------|------|--------------------------------------------------------------|
| 名称 | AINN0  | AINN1  | VREF | DAC                                                          |
| 説明 | 負入力ピン0 | 負入力ピン1 | 基準電圧 | D/A変換器(DAC)出力。ACの実体nはDACの実体n<br>を使用、例えば、AC0はDAC0、AC1はDAC1を使用 |

注: ポートの全てのピンが少ピン数デバイスで利用できるとは限りません。詳細についてはピン配置図や入出力多重化表を調べてください。

# 29.5.3. INTCTRL - 割り込み制御 (Interrupt Control)

名称:INTCTRL 変位:+\$06 リセット:\$00 特質:-

| ピット _  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|--------|---|---|---|---|---|---|---|-----|
|        |   |   |   |   |   |   |   | CMP |
| アクセス種別 | R | R | R | R | R | R | R | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0   |

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

このビットに'1'を書くことがアナログ比較器割り込みを許可します。

# 29.5.4. STATUS - 状態 (Status)

名称: STATUS 変位:+\$07 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4     | 3 | 2 | 1 | 0   |
|--------|---|---|---|-------|---|---|---|-----|
|        |   |   |   | STATE |   |   |   | CMP |
| アクセス種別 | R | R | R | R     | R | R | R | R/W |
| リセット値  | 0 | 0 | 0 | 0     | 0 | 0 | 0 | 0   |

# ● ビット4 - STATE: アナログ比較器状態 (Analog Comparator State)

これはACからのOUT信号の現在の状態を示します。これはI/Oレジスタで更新されるのに(3周期の)同期化遅延を持ちます。

● ビット0 - CMP: アナログ比較器割り込み要求フラグ(Analog Comparator Interrupt Flag)

これはACに対する割り込み要求フラグです。このビットへの'1'書き込みはこの割り込み要求フラグを解除(0)します。

# 30. ADC - A/D変換器

# 30.1. 特徴

- ・10ビット分解能
- ・0V~VDDのADC入力電圧範囲
- ・複数の内部ADC基準電圧
- 外部基準電圧入力
- 自由走行または単独の変換動作
- ・ADC変換完了で利用可能な割り込み
- 任意選択の変換結果での割り込み
- ・温度感知器入力チャネル
- 任意選択の事象起動変換
- ・正確な監視や定義された閾値用の窓比較器機能
- ・変換毎に64採取までの累積

# 30.2. 概要

A/D変換器(ADC)周辺機能は10ビットの結果を生じます。ADC入力は内部(例えば、基準電圧)またはアナログ、入力ピンを通す外部のどちらかにすることができます。ADCは多数のシングルエンド電圧入力を許すアナログ多重器に接続されます。シングルエンド電圧入力は0V (GND)を参照基準にします。

ADCは構成設定可能な変換結果数が単一ADC結果内に累積される集中での採取(採取累積)を支援します。更に、単一集中に関連するADC採取周波数を調節するために採取遅延を構成設定することができます。これは採取された信号から(集中内の)ADC採取周波数での折り返し雑音のどの高調波雑音からも離れた採取周波数に調節することです。自動採取遅延変動機能は採取間の時間を僅かに変えるためのこの遅延を無作為化するのに使うことができます。

ADC入力信号は採取中にADCへの入力電圧が一定水準で保たれることを保証する採取/保持(S/H)回路を通して供給されます。 内部基準電圧(VREF)周辺機能、VDD供給電圧、または外部VREF(VREFA)ピンから選択可能な基準電圧。

窓比較機能は入力信号を監視するのに使用可能で、必要な最小のソフトウェア介在で窓の下(未満)、上(超え)、内側、外側に対する使用者定義閾値でだけ割り込みを起動するように構成設定することができます。

周辺接触制御器(PTC)が許可されると、ADC0はPTC周辺機能によって完全に制御されます。

# 30.2.1. 構成図



アナログ入力チャネルは多重器正選択(ADCn.MUXPOS)レジスタの多重器正選択(MUXPOS)ビットに書くことによって選ばれます。ADC入力ピンのどれか、GND、内部基準電圧(VREF)、または温度感知器をADCへのシングルエンド入力として選ぶことができます。ADCは制御A(ADCn.CTRLA)レジスタのADC許可(ENABLE)ビットに'1'を書くことによって許可されます。基準電圧と入力チャネルの選択はADCが許可される前に有効になりません。ADCはADCn.CTRLAレジスタのENABLEビットが'0'の時に電力を消費しません。

ADCは結果(ADCn.RES)レシ、スタから読むことができる10ビットの結果を生成します。この結果は右揃えで表されます。

# 30.2.2. 信号説明

| 信号     | 形式     | 説明            |
|--------|--------|---------------|
| AINn∼0 | アナログ入力 | 変換されるべきアナログ入力 |
| VREFA  | アナログ入力 | アナログ・基準電圧入力   |

#### 30.2.3. 定義

理想nビットシングルェント,A/D変換はGNDとVREF間を $2^n$ 段階(LSB)で電圧を直線的に変換します。最低値符号は'0'として読まれ、最高値符号は $2^n$ -1として読まれます。Vくつかの項目は理想的な動きからの偏差を記述します。

変位(オフセット)誤差

理想遷移点(差0.5 LSB)と比べた最初の遷移(\$000から\$001)の偏差です。理想値:0 LSB



利得誤差

変位(オフセット)誤差補正後、利得誤差は理想遷移(最大1.5 LSB以下)と比べた最後の遷移(例えば、10ビットADCについては\$3FEから\$3FF)の偏差として見出されます。理想値:0 LSB



積分非直線性誤差 (INL)

変位(オフセット)誤差と利得誤差の補正後、INLは何れかの符号に対する理想遷移と比べた実際の遷移の最大偏差です。

理想值: 0 LSB



微分非直線性誤差 (DNL)

理想符号幅(1 LSB)から実際の符号幅(隣接する2つの遷移間の間隔)の最大偏差です。理想値:0 LSB



量子化誤差

有限数の符号への入力電圧の量子化のため、入力電圧範囲(1 LSB幅)は同じ値に符号化します。常に ±0.5 LSB

絶対精度

何れかの符号に対して理想遷移点と比べた(非補正の)実際の遷移の最大偏差です。これは全ての前述の誤差の複合作用です。理想値:±0.5 LSB

## 30.3. 機能的な説明

## 30.3.1. 初期化

ADC動作を初期化するには以下の手順が推奨されます。

- 1. 制御A(ADCn.CTRLA)レジスタの分解能選択(RESSEL)ビットに書くことによって分解能を構成設定してください。
- 2. 任意選択: ADCn.CTRLAの自由走行(FREERUN)ピットに'1'書くことによって自由走行動作を許可してください。
- 3. 任意選択: 制御B(ADCn.CTRLB)レジスタの採取累積数選択(SAMPNUM)ビットを書くことによって変換毎に累積すべき採取数を構成設定してください。
- 4. 制御C(ADCn.CTRLC)レシ、スタの基準選択(REFSEL)ヒットに書くことによって基準電圧を構成設定してください。
- 5. ADCn.CTRLCレシブスタの前置分周器(PRESC)ビット領域に書くことによってCLK\_ADCを構成設定してください。
- 6. 多重器正選択(ADCn.MUXPOS)レジスタの多重器正選択(MUXPOS)ビット領域に書くことによって入力を構成設定してください。
- 7. 任意選択: 事象制御(ADCn.EVCTRL)レジスタの事象入力で開始(STARTEI)ビットに'1'を書くことによって事象入力での変換開始を許可してください。
- 8. ADCn.CTRLAレシブスタのADC許可(ENABLE)ビットに'1'を書くことによってADCを許可してください。

これらの手順に従うことはADCを、(構成設定されるなら)事象によって、または指令(ADCn.COMMAND)レジスタの変換開始(STCONV) ビットに'1'を書くことによって起動することができる基本的な測定用に初期化します。

## 30.3.2. 動作

#### 30.3.2.1. 変換開始

多重器正選択(ADCn.MUXPOS)レジスタに書くことによって一旦入力チャネルが選ばれると、指令(ADCn.COMMAND)レジスタの変換開始 (STCONV))ビットに'1'を書くことによって変換が起動されます。このビットは変換が進行中である限り'1'です。単独変換動作では変換が完了された時にハードウェアによってSTCONVが解除(0)されます。

変換が進行中の間に違う入力チャネルが選ばれた場合、ADCはチャネルを変更する前に現在の変換を終えます。

累積器設定に依存して、変換結果は単独感知動作から、または一連の累積された採取からです。起動された操作が一旦終了されると、割り込み要求フラケ(ADCn.INTFLAGS)レシブスタの結果準備可割り込み要求(RESRDY)フラケが設定(1)されます。割り込み制御(ADCn.INTCTRL)レシブスタの結果準備可割り込み許可(RESRDY)ビットが'1'で、全体割り込み許可(I)ビットが'1'なら、対応する割り込みへブクタが実行されます。

単独変換はADCn.COMMANDレジスタのSTCONVビットに'1'を書くことによって開始することができます。STCONVピットは変換が進行中かを判断するのに使うことができます。STCONVピットは変換中に設定(1)され、一旦変換が完了すると解除(0)されます。

ADCn.INTFLAGSレジスタのRESRDY割り込み要求フラケーは例え指定された割り込みが禁止されても設定(1)され、このフラケーのポーリンケーによって変換終了を調べることをソフトウェアに許します。従って割り込み要求を起こすことなく変換を起動することができます。

代わりに、変換は事象によって起動することができます。これは事象制御(ADCn.EVCTRL)レジスタの事象入力で開始(STARTEI)ビットに、1、を書くことによって許可されます。事象システム(EVSYS)を通してADCに配線されたどの到着事象もADC変換を起動します。これは予測可能な間隔または特定条件で変換を開始する方法を提供します。

事象起動入力は端感知です。事象が起こると、ADCn.COMMANDレジスタのSTCONVが設定(1)されます。STCONVは変換が完了する時に解除(0)されます。

自由走行動作では、ADCn.COMMANDレジスタでSTCONVビットに'1'を書くことによって最初の変換が開始されます。新しい変換周回は直前の変換周回が完了された後、直ちに開始されます。変換完了はADCn.INTFLAGSレジスタのRESRDYフラグを設定(1)します。

#### 30.3.2.2. クロック生成

ADCは最大分解能に対して50kHz~1.5MHz間の入力クロック周波数を必要とします。10ビットよりも低い分解能が選ばれる場合、より高い採取速度を得るためにADC~の入力クロック周波数を1.5MHzよりも高くすることができます。

ADC単位部は100kHz以上のどのCPU周波数(CLK\_PER)からもADCクロック (CLK\_ADC)を生成する前置分周器を含みます。前置分周は制御C(ADCn. CTRLC)レジスタの前置分周器(PRESC)ビットへ書くことによって選ばれます。前置分周器は制御A(ADCn.CTRLA)レジスタのADC許可(ENABLE)ビットに '1'を書くことによってADCがONにされる瞬間から計数を始めます。前置分周器はENABLEビットが1である限り走行を保ちます。前置分周器の計数器はENABLEビットが'0'の時に'0'〜リセットされます。

指令(ADCn.COMMAND)レシ、スタの変換開始(STCONV)ビットへの'1'書き込みまたは事象によって変換を始めると、変換はCLK\_ADCクロック周期の次の上昇端で始まります。



前置分周器は進行中の変換が無い限りリセットを保ちます。これは次のようなCLK\_P ER周期での起動から実際の変換開始までの固定遅延を保証します。

開始遅延 = 
$$\frac{PRESC係数}{2}$$
 + 2



## 30.3.2.3. 変換タイミング

通常の変換は13 CLK\_ADC周期かかります。実際の採取/保持(S/H)は変換開始後2 CLK\_ADC周期に起こります。変換の開始は指令(ADCn.COMMAND)レジスタの変換開始(STCONV))ピットに'1'を書くことによって始められます。変換が完了すると、その結果が結果(ADCn.RES)レジスタで利用可能で、割り込み要求フラケ(ADCn.INTFLAGS)レジスタの結果準備可割り込み要求(RESRDY)フラケが設定(1)されます。この割り込み要求フラケは結果が結果(ADCn.RES)レジスタから読まれる時に、またはADCn.INTFLAGSレジスタのRESRD Yに'1'を書くことによって解除(0)されます。





自由走行動作ではSTCONVビットが'1'の間、新しい変換が変換完了後直ちに開始されます。自由走行動作での採取速度(Rs)は右式によって計算されます。





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

多重器正選択(ADCn.MUXPOS)レジ、スタの多重器正選択(MUXPOS)ヒ、ットと制御C(ADCn.CTRLC)レジ、スタの基準電圧選択(REFSEL) ヒ、ットはCPUが乱順にアクセスするための一時レジ、スタを通して緩衝されます。これはチャネルと基準電圧の選択が変換中の安全な個所でだけ行われることを保証します。チャネルと基準電圧の選択は変換が開始されるまで継続的に更新されます。

一旦変換が始まると、ADCに対して充分な採取/変換時間を保証するためにチャネルと基準電圧の選択は固定されます。継続的な更新は(割り込み要求フラグ(ADCn.INTFLAGS)レジスタの結果準備可割り込み要求(RESRDY)フラグが設定(1)される)変換完了前の最後のCLK\_ADCクロック周期で再開します。指令(ADCn.COMMAND)レジスタの変換開始(STCONV)ビットが'1'に書かれた後の次のCLK\_ADCクロック上昇端で変換が始まります。

#### 30.3.2.4.1. ADC入力チャネル

チャネル選択を変更する時に、使用者は正しいチャネルが選択されることを保証するために次の指針を守らなければなりません。

単独変換動作に於いて: チャネルは変換を開始する前に選ばれるべきです。チャネル選択はSTCONVピットへの'1'書き込み後の1 ADC クロック周期で変更されるかもしれません。

自由走行動作に於いて: チャネルは最初の変換を開始する前に選ばれるべきです。チャネル選択はSTCONVビットへの'1'書き込み後の1 ADCクロック周期で変更されるかもしれません。次の変換が既に自動的に開始されるため、次の結果は直前のチャネル選択を反映します。それに続く変換は新しいチャネル選択を反映します。

入力チャネル切り替え後にADCは準備時間を必要とます。詳細については「電気的特性」章を参照してください。

## 30.3.2.4.2. ADC基準電圧

ADC用基準電圧(V<sub>REF</sub>)はADCの変換範囲を制御します。選んだV<sub>REF</sub>を越える入力電圧はADCの最大結果値に変換されます。理想10ビットADCに対してそれは\$3FFです。

VREFは制御C(ADCn.CTRLC)レジスタの基準電圧選択(REFSEL)ビットを書くことによってVDD、外部基準電圧(VREFA)、または基準電圧(VREF)周辺機能からの内部基準電圧のどれかとして選ぶことができます。VDDは受動切り換え器を通してADCに接続されます。

外部基準電圧(VREFA)使用時、対応するVREF制御A(VREF.CTRLA)レジスタのADCn基準選択(ADCnREFSEL2~0)を最も近いけれども適用される基準電圧より上の値に構成設定してください。4.3Vよりも高い外部基準についてはADCnREFSEL2~0=011を使ってください。

内部基準電圧は内部増幅器を通して内部バンドギャップ基準電圧(VBG)から生成され、基準電圧(VREF)周辺機能によって制御されます。

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

アナログ回路は図30-11.で図解されます。ADCnに印加したアナログ供給元はそのチャネルがADCに対する入力として選択されているか否かに関わらず、ピン容量とそのピンの漏れ電流に左右されます。チャネルが選択されると、供給元は直列抵抗(入力経路の合成抵抗)を通してS/Hコンデンサを駆動しなければなりません。

ADCは概ね10kΩまたはそれ以下の出力インピーダンスを持つアナログ信号用に最適化されています。このような供給元が使われるなら、採取時間は無視してもよいでしょう。より高いインピーダンスを持つ供給元が使われる場合、採取時間は大幅に変化し得るS/Hコンデンサを充電するのに供給元がどれくらいの時間を必要とするかに依存します。



#### 30.3.2.5. A/D変換結果

変換が完了(RESRDYが'1'に)された後、変換結果(RES)はADC結果(ADCn.RES)レジスタで利用可能です。 10ビット変換に対する結果は右のように与えられます。

 $RES = \frac{V_{IN} \times 1023}{V_{REF}}$ 

ここでのVINは選んだ入力ピンの電圧で、VREFは選んだ基準電圧です(多重器正選択(ADCn.MUXPOS)レシスタと制御C(ADCn.CTRLC)レジスタの基準電圧選択(REFSEL)に対する記述をご覧ください)。

#### 30.3.2.6. 温度測定

温度測定はチップ上の温度感知器に基きます。温度測定については以下のこれらの手順に従ってください。

- 1. VREF周辺機能で構成設定することによって内部基準電圧を1.1Vに構成設定してください。
- 2. 制御C(ADCn.CTRLC)レジスタの基準電圧選択(REFSEL)ビットに'00'を書くことによって内部基準電圧を選んでください。
- 3. 多重器正選択(ADCn.MUXPOS)レジスタを構成設定することによってADC温度感知器チャネルを選んでください。
- 4. 制御D(ADCn.CTRLD)レシブスタで初期化遅延(INITDLY)を≧32µs×fCLK ADCに選んでください(**訳補**:脚注参照)。
- 5. 採取制御(ADCn.SAMPCTRL)レジスタで採取長(SAMPLEN)を≧32µs×fCLK ADCに選んでください(訳補:脚注参照)。
- 6. ADCn.CTRLCレジスタで採取容量選択(SAMPCAP)=1に選んでください。
- 7. 変換を開始することによって温度感知器出力を採取してください。
- 8. 下で記述されるように測定結果を処理してください。

測定した電圧は温度に対して直線的関係を持ちます。製法変化のため、温度感知器出力電圧は同じ温度に於いて個別デバイス間で変わります。個別補償要素は製造検査の間に測定されて以下のように識票列内に保存されます。

- ・SIGROW.TEMPSENSE0は利得/傾斜修正です。
- ・SIGROW.TEMPSENSE1は変位(オフセット)修正です。

正確な結果を達成ため、温度感知器測定の結果は工場校正値を用いて応用ソフトウェアで処理されなければなりません。(ケルビンでの)温度は以下のこの規則によって計算されます。

## 温度 = (((( RESH << 8 ) | RESL ) - TEMPSENSE1 ) × TEMPSENSE0 ) >> 8

RESHとRESLは結果(ADCn.RES)レジスタの上位バイトと下位バイトで、TEMPSENSEnは各々識票列からの値です。

使用者コート、に於いて以下のこれらの手順に従うことが推奨されます。

```
int8_t sigrow_offset = SIGROW. TEMPSENSE1; // 識票列から符号付き変位(オフセット)補正値読み込み uint8_t sigrow_gain = SIGROW. TEMPSENSE0; // 識票列から符号なし利得補正値読み込み uint16_t adc_reading = 0; // 1.1V内部基準電圧でのA/D変換結果 uint32_t temp = adc_reading - sigrow_offset; temp *= sigrow_gain; // 結果(10ピット×8ピット)は16ピット変数を溢れるかもしれません。 temp += 0x80; // 次の除算で正しい丸めを得るために1/2を加算 temp >>= 8; // ケルピン温度を得るために結果を除算 uint16_t temperature_in_K = temp;
```

#### 30.3.2.7. 窓比較器動作

ADCは変換の結果が或る閾値以上と/または以下の時に割り込み要求フラケ(ADCn.INTFLAGS)レシ、スタの窓比較器割り込み要求(WC MP)フラケを立てて割り込みを要求することができます。利用可能な動作形態は次のとおりです。

- 結果が閾値未満
- 結果が閾値超え
- ・結果が窓の内側(下側閾値以上、しかし上側閾値以下)
- ・結果が窓の外側(下側閾値未満または上側閾値超え)

閾値は窓比較器閾値(ADCn.WINLTとADCn.WINHT)レジスタに書くことによって定義されます。制御E(ADCn.CTRLE)レジスタの窓比較器動作(WINCM)ビット領域への書き込みはフラグが掲げられるまたは割り込みが要求される時の条件を選びます。

ADCが既に走行するように構成設定されるとの仮定で、窓比較動作を使うには以下のこれらの手順に従ってください。

- 1. 使うどれかの窓比較器を選び(ADCn.CTRLEレジスタのWINCM記述をご覧ください)、ADCn.WINLTと/またはADCn.WINHTのレジスタを書くことによって必要とされる閾値を設定してください。
- 2. 任意選択: 割り込み制御(ADCn.INTCTRL)レジスタの窓比較器割り込み許可(WCMP)ビットに'1'を書くことによって割り込み要求を許可してください。
- 3. ADCn.CTRLEレジスタのWINCMビット領域に0以外の値を書くことによって窓比較器を許可して動作形態を選んでください。 複数採取思稿時、結果と関値間の比較は最後の試料が採取された後で起きます。結果として、フラグは最終採取の思稿を取っ

複数採取累積時、結果と閾値間の比較は最後の試料が採取された後で起きます。結果として、フラグは最終採取の累積を取った後で1度だけ立てられます。

#### 30.3.2.8. PTC動作

周辺接触制御器(PTC:Peripheral Touch Controller)が許可されると、それはADC0の制御を完全に取ります。

PTCが禁止されると、ADC0は標準的なADCとして利用可能です。

更なる情報ついては「周辺機能接触制御器(PTC)」章を参照してください。

(<mark>訳注</mark>) レジスタ ビット領域をCLK\_ADC周期数で設定するため、≧32µs×fCLK ADCは32µs以上になるCLK\_ADC周期数の意味です。

## 30.3.3. 事象

A/D変換は事象制御(ADCn.EVCTRL)レシブスタの事象入力で開始(STARTEI)ビットが'1'を書かれる場合に事象入力によって自動的に起動することができます。

結果(ADCn.RES)レジスタから新しい結果を読むことができる時にADCは結果準備可事象を生成します。この事象は1クロック周期の長さを持つパルスで、事象システムによって扱われます。ADC結果準備可事象はADCが許可される時に常に生成されます。

事象システムの使用部nチャネル多重器(EVSYS.USERn)の記述もご覧ください。

#### 30.3.4. 割り込み

#### 表30-1. 利用可能な割り込みベクタと供給元

| 名称     | ベクタ説明     | 条件                                            |
|--------|-----------|-----------------------------------------------|
| RESRDY | 結果準備可割り込み | 変換結果が結果(ADCn.RES)レシブスタで利用可能です。                |
| WCMP   | 窓比較器割り込み  | 制御E(ADCn.CTRLE)レジスタの窓比較器動作(WINCM)によって定義されるように |

割り込み条件が起こると、割り込み要求フラグ(ADCn.INTFLAGS)レジスタで対応する割り込み要求フラグが設定(1)されます。

割り込み元は割り込み制御(ADCn.INTCTRL)レジスタで対応する許可ビットに書くことによって許可または禁止されます。

割り込み要求は対応する割り込み元が許可され、割り込み要求フラグが設定(1)される時に生成されます。割り込み要求は割り込み要求フラグが解除(0)されるまで活性(1)に留まります。割り込み要求フラグを解除(0)する方法の詳細については周辺機能のINTFLAGSレジスタをご覧ください。

## 30.3.5. 休止形態動作

ADCは既定によってスタンバイ休止動作で禁止されます。

ADCは制御A(ADCn.CTRLA)レシ、スタのスタンハ・イ時走行(RUNSTDBY)ヒットが'1'を書かれる場合にスタンハ・イ休止動作で完全に機能する状態に留まることができます。

RUNSTDBYが'1'の時にデバイスがスタンバイ休止動作へ移行すると、ADCは活性に留まり、故に進行中の変換は完了され、構成設定されるように割り込みが実行されます。

スタンバイ休止動作では、ADC変換が事象システム(EVSYS)経由で起動されなければならないか、またはADCが休止動作に移行する前にソフトウェアによって起動される初回変更での自由走行動作でなければなりません。周辺機能クロックは必要とされる場合に要求され、変換が完了された後にOFFへ切り替えられます。

入力事象起動が起こると、正端が検出され、指令(ADCn.COMMAND)レジスタの変換開始(STCONV)ビットが設定(1)され、変換が始まります。変換が完了されると、割り込み要求フラケ(ADCn.INTFLAGS)レジスタの結果準備可割り込み要求(RESRDY)フラケが設定(1)され、ADCn.COMMANDレジスタのSTCONVが解除(0)されます。

基準電圧元と供給基盤はスタンバイ休止動作で活性にされる時に安定のための時間が必要です。制御D(ADCn.CTRLD)レジスタの初期化遅延(INITDLY)ビットに0以外の値を書くことによって最初の変換の開始に対する遅延を構成設定してください。

ハプワーダウン休止動作では、変換が全くできません。進行中のどの変換も停止され、休止動作の外に出る時に再開されます。変換の最後で結果準備可(RESRDY)割り込み要求フラケが設定(1)されますが、ADCが変換の中間で停止されたため、結果(ADCn.RES)レジスタの内容は無効です。

# 30.4. レジスタ要約

| 変位                  | 略称       | ビット位置        | ヒ゛ットフ    | ピット6      | ヒ゛ット5 | じット4     | <b>ビット3</b> | じット2     | じット1     | ピット0    |
|---------------------|----------|--------------|----------|-----------|-------|----------|-------------|----------|----------|---------|
| +\$00               | CTRLA    | 7~0          | RUNSTDBY |           |       |          |             | RESSEL   | FREERUN  | ENABLE  |
| +\$01               | CTRLB    | 7~0          |          |           |       |          |             | S        | AMPNUM2~ | 0       |
| +\$02               | CTRLC    | 7~0          |          | SAMPCAP   | REFS  | EL1,0    |             |          | PRESC2~0 |         |
| +\$03               | CTRLD    | 7~0          |          | NITDLY2~0 |       | ASDV     |             | SAMPE    | LY3~0    |         |
| +\$04               | CTRLE    | 7 <b>~</b> 0 |          |           |       |          |             |          | WINCM2~0 |         |
| +\$05               | SAMPCTRL | 7 <b>~</b> 0 |          |           |       |          | S           | AMPLEN4~ | 0        |         |
| +\$06               | MUXPOS   | 7 <b>~</b> 0 |          |           |       |          | 1           | MUXPOS4~ | Ò        |         |
| +\$07               | 予約       |              |          |           |       |          |             |          |          |         |
| +\$08               | COMMAND  | 7 <b>~</b> 0 |          |           |       |          |             |          |          | STCONV  |
| +\$09               | EVCTRL   | 7 <b>~</b> 0 |          |           |       |          |             |          |          | STARTEI |
| +\$0A               | INTCTRL  | 7 <b>~</b> 0 |          |           |       |          |             |          | WCMP     | RESRDY  |
| +\$0B               | INTFLAGS | 7 <b>~</b> 0 |          |           |       |          |             |          | WCMP     | RESRDY  |
| +\$0C               | DBGCTRL  | 7 <b>~</b> 0 |          |           |       |          |             |          |          | DBGRUN  |
| +\$0D               | TEMP     | 7 <b>~</b> 0 |          |           |       | TEM      | P7~0        | '        | ·        |         |
| +\$0E<br>~<br>+\$0F | 予約       |              |          |           |       |          |             |          |          |         |
| +\$10               | RES      | 7 <b>~</b> 0 |          |           |       | RES      | 57~0        |          | 1        |         |
| +\$11               | KES      | 15~8         |          |           |       | RES      | 15~8        |          | 1        |         |
| +\$12               | WINLT    | 7 <b>~</b> 0 |          |           |       | WINLT7~0 |             |          |          |         |
| +\$13               | WIIND I  | 15~8         |          |           |       | WINL     | T15~8       |          |          |         |
| +\$14               | WINHT    | 7 <b>~</b> 0 |          |           |       | WINH     | HT7∼0       |          |          |         |
| +\$15               | VVIINITI | 15~8         |          |           |       | WINH     | T15~8       |          |          |         |
| +\$16               | CALIB    | 7 <b>~</b> 0 |          |           |       |          |             |          |          | DUTYCYC |

## 30.5. レジスタ説明

**30.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位:+\$00 リセット: \$00 特質:-

| ピット    | 7        | 6 | 5 | 4 | 3 | 2      | 1       | 0      |
|--------|----------|---|---|---|---|--------|---------|--------|
| R      | RUNSTDBY |   |   |   |   | RESSEL | FREERUN | ENABLE |
| アクセス種別 | R/W      | R | R | R | R | R/W    | R/W     | R/W    |
| リセット値  | 0        | 0 | 0 | 0 | 0 | 0      | 0       | 0      |

● ビット7 - RUNSTDBY: スタンバイ時走行(Run in Standby)

このビットはチップがスタンバイ休止動作の時にADCが走行することを必要(='1')かどうかを決めます。

● ビット2 - RESSEL:分解能選択(Resolution Selection)

このビットはADC分解能を選びます。

| 値     | 0 | 1                                                                                  |
|-------|---|------------------------------------------------------------------------------------|
| =D HH |   | 8ピット分解能。変換結果はそれらがADC結果(ADCn. RES)レジスタに累積または格納される前に(上位)8ピットに切り詰められます。下位2ピットは破棄されます。 |

## ● ビット1 - FREERUN:自由走行 (Free Running)

このビットへの'1'書き込みはデータ取得に関して自由走行動作を許可します。最初の変換は指令(ADCn.COMMAND)レジスタの変換開始(STCONV)ビットへの'1'書き込みによって始められます。自由走行動作では、直前の変換周回が完了された直後または直ぐに新しい変換が開始されます。これは割り込み要求フラグ(ADCn.INTFLAGS)レジスタの結果準備可割り込み要求(RESRDY)フラグによって合図されます。

● ビット0 - ENABLE: ADC許可 (ADC Enable)

| 値  | 0           | 1           |
|----|-------------|-------------|
| 説明 | ADCは禁止されます。 | ADCは許可されます。 |

## **30.5.2. CTRLB - 制御B** (Control B)

名称: CTRLB 変位:+\$01 リセット: \$00 特質:-

| ヒット7     | 6 | 5 | 4 | 3 | 2   | 1         | 0   |
|----------|---|---|---|---|-----|-----------|-----|
|          |   |   |   |   | (   | SAMPNUM2~ | 0   |
| アクセス種別 R | R | R | R | R | R/W | R/W       | R/W |
| リセット値 0  | 0 | 0 | 0 | 0 | 0   | 0         | 0   |

#### ● ビット2~0 - SAMPNUM2~0:採取累積数選択 (Sample Accumulation Select)

これらのビットは連続するADC採取結果がどれくらい自動的に累積されるかを選びます。このビットが0よりも大きな値を書かれると、1回の完全な変換で連続するADC採取結果の対応する数がADC結果(ADCn.RES)レジスタに累積されます。

| 値  | 000  | 0 0 1 | 0 1 0 | 0 1 1 | 100    | 101    | 1 1 0  | 111  |
|----|------|-------|-------|-------|--------|--------|--------|------|
| 名称 | NONE | ACC2  | ACC4  | ACC8  | ACC16  | ACC32  | ACC64  | _    |
| 説明 | 累積なし | 2回の累積 | 4回の累積 | 8回の累積 | 16回の累積 | 32回の累積 | 64回の累積 | (予約) |

## **30.5.3. CTRLC - 制御C** (Control C)

名称: CTRLC 変位:+\$02 リセット: \$00 特質:-

| ピット    | 7 | 6       | 5         | 4   | 3 | 2        | 1   | 0   |
|--------|---|---------|-----------|-----|---|----------|-----|-----|
|        |   | SAMPCAP | REFSEL1,0 |     |   | PRESC2~0 |     |     |
| アクセス種別 | R | R/W     | R/W       | R/W | R | R/W      | R/W | R/W |
| リセット値  | 0 | 0       | 0         | 0   | 0 | 0        | 0   | 0   |

## ● ビット6 - SAMPCAP: 採取容量選択 (Sample Capacitance Selection)

このビットは採取容量(コンデンサ)、故に入力インピーダンスを選びます。最良の値は基準電圧と応用の電気的特性に依存します。

| 値  | 0             | 1                      |
|----|---------------|------------------------|
| 説明 | 1V未満の基準電圧値に推奨 | 採取容量を減らします。より高い基準電圧に推奨 |

## ● ビット5,4 - REFSEL1,0: 基準電圧選択 (Reference Selection)

これらのビットはADCに対する基準電圧を選びます。

| 値  | 0 0       | 0 1 | 1 0           | 11   |
|----|-----------|-----|---------------|------|
| 名称 | INTERNAL  | VDD | VREFA         | _    |
| 説明 | 説明 内部基準電圧 |     | 外部基準電圧(VREFA) | (予約) |

#### ▶ ビット2~0 - PRESC2~0:前置分周器 (Prescaler)

これらのビットは周辺機能クロック(CLK\_PER)カッらADCクロック(CLK\_ADC)への整数分周比を定義します。

| 値  | 0 0 0     | 0 0 1     | 0 1 0     | 0 1 1      | 100        | 101        | 1 1 0       | 111         |
|----|-----------|-----------|-----------|------------|------------|------------|-------------|-------------|
| 名称 | DIV2      | DIV4      | DIV8      | DIV16      | DIV32      | DIV64      | DIV128      | DIV256      |
| 説明 | CLK_PER/2 | CLK_PER/4 | CLK_PER/8 | CLK_PER/16 | CLK_PER/32 | CLK_PER/64 | CLK_PER/128 | CLK_PER/256 |

## **30.5.4. CTRLD - 制御D** (Control D)

名称: CTRLD 変位:+\$03 リセット: \$00 特質:-

| ピット    | 7   | 6          | 5   | 4    | 3          | 2   | 1   | 0   |
|--------|-----|------------|-----|------|------------|-----|-----|-----|
|        |     | INITDLY2∼0 |     | ASDV | SAMPDLY3~0 |     |     |     |
| アクセス種別 | 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~5 - INITDLY2~0: 初期化遅延 (Initialization Delay)

これらのビットはADCを許可する、または内部基準電圧に対して変更する時に最初の採取前の初期化/始動の遅延を定義します。この遅延設定は参照基準(電圧)、多重器などが初回変換を開始する前に準備を整えることを保証します。初期化遅延は測定を行うために深い休止から起き上がる時にも起こります。

遅延はCLK\_ADC周期数として表されます。

| 値                | 0 0 0 | 0 0 1 | 0 1 0 | 0 1 1 | 100    | 101    | 1 1 0 | 111  |
|------------------|-------|-------|-------|-------|--------|--------|-------|------|
| 名称               | DLY0  | DLY16 | DLY32 | DLY64 | DLY128 | DLY256 | -     | -    |
| 説明[遅延CLK_ADC周期数] | 0     | 16    | 32    | 64    | 128    | 256    | (予約)  | (予約) |

#### ● ビット4 - ASDV: 自動採取遅延変動 (Automatic Sampling Delay Variation)

このビットに'1'を書くことはA/D変換間の自動採取遅延変動を許可します。採取の瞬間を変えることの目的は採取の瞬間を乱順、故に周波数分布での定在周波数を避けるためです。採取遅延選択(SAMPDLY)ビットの値は各採取後に自動的に1つ増されます。

自動採取遅延変動が許可されてSAMPDLY値が\$Fに達すると、\$0に丸めます。

| 値  | 0                | 1                |
|----|------------------|------------------|
| 名称 | ASVOFF           | ASVON            |
| 説明 | 自動採取遅延変動が禁止されます。 | 自動採取遅延変動が許可されます。 |

## ● ビット3~0 - SAMPDLY3~0:採取遅延選択 (Sampling Delay Selection)

これらのビットは連続するADC採取間の遅延を定義します。設定可能な遅延は、そうでなければ採取を乱すかもしれない周期的な雑音源を消すために、ハードウェア累積の間に採取周波数の変更を許します。SAMPDLY領域は自動採取遅延変動(ASDV)ビットを設定(1)することによって採取周期から別の採取周期へ自動的に変更することもできます。遅延はCLK\_ADC周期として表され、ビット領域設定によって直接的に与えられます。採取容量は遅延の間、開放を保ちます。

## **30.5.5. CTRLE - 制御E** (Control E)

名称 : CTRLE 変位 : +\$04 リセット : \$00 特質 : -

| ビット <u></u> | 7 | 6 | 5 | 4 | 3 | 2   | 1        | 0   |
|-------------|---|---|---|---|---|-----|----------|-----|
|             |   |   |   |   |   |     | WINCM2~0 |     |
| アクセス種別      | R | R | R | R | R | R/W | R/W      | R/W |
| リセット値       | 0 | 0 | 0 | 0 | 0 | 0   | 0        | 0   |

## ● ビット2~0 - WINCM2~0: 窓比較器動作 (Window Comparator Mode)

このビット領域は窓比較器動作で割り込み要求フラグが設定(1)される時を許可して定義します。(下の表で)結果は16ビット累積器の結果です。WINLTとWINHTは各々16ビットの下側閾値と16ビットの上側閾値です。

|   | 値  | 0 0 0     | 0 0 1    | 0 1 0    | 0 1 1          | 1 0 0               | その他  |
|---|----|-----------|----------|----------|----------------|---------------------|------|
| Γ | 名称 | NONE      | BELOW    | ABOVE    | INSIDE         | OUTSIDE             | _    |
|   | 説明 | 窓比較なし(既定) | 結果〈WINLT | 結果>WINHT | WINLT≦結果≦WINHT | 結果〈WINLTまたは結果〉WINHT | (予約) |

## 30.5.6. SAMPCTRL - 採取制御 (Sample Control)

名称: SAMPCTRL

変位 : +\$05 リセット : \$00 特質 : -

| ピット    | 7 | 6 | 5 | 4   | 3   | 2          | 1   | 0   |
|--------|---|---|---|-----|-----|------------|-----|-----|
|        |   |   |   |     |     | SAMPLEN4~( | )   |     |
| アクセス種別 | R | R | R | R/W | R/W | R/W        | R/W | R/W |
| リセット値  | 0 | 0 | 0 | 0   | 0   | 0          | 0   | 0   |

## ● ビット4~0 - SAMPLEN4~0:採取長(Sample Length)

これらのビットはいくつかのCLK\_ADC周期でADC採取長を延長します。既定によって採取時間は2 CLK\_ADC周期です。採取長増加はより高いインピーダンスを持つ供給元の採取を許します。総変換時間は選んだ採取長で増やされます。(<mark>訳補</mark>)このビット領域値が直接的に延長するCLK ADC周期数(0~31)を表します。

## 30.5.7. MUXPOS - 多重器正選択 (Multiplexed Positive Input Selection)

名称: MUXPOS 変位: +\$06 リセット: \$00 特質:-

| ヒ゛ット   | 7 | 6 | 5 | 4   | 3   | 2         | 1   | 0   |
|--------|---|---|---|-----|-----|-----------|-----|-----|
|        |   |   |   |     |     | MUXPOS4~0 |     |     |
| アクセス種別 | R | R | R | R/W | R/W | R/W       | R/W | R/W |
| リセット値  | 0 | 0 | 0 | 0   | 0   | 0         | 0   | 0   |

## ● ビット4~0 - MUXPOS4~0: 多重器正選択 (MUXPOS)

このビット領域はADCにどのシングル エンド アナログ入力が接続されるかを選びます。これらのビットが変換中に変えられる場合、その変更はこの変換が完了するまで有効ではありません。

| 値            | 00000 | 00001        | 00010 | 00011 | 1 00100       | 00101        | 00110 | 0 00111          | 01000 | 01001  | 01010 | 01011 |
|--------------|-------|--------------|-------|-------|---------------|--------------|-------|------------------|-------|--------|-------|-------|
| 名称           | AIN0  | AIN1         | AIN2  | AIN3  | AIN4          | AIN5         | AIN6  | AIN7             | AIN8  | AIN9   | AIN10 | AIN11 |
| 説明(アナログ入力ピン) | 0     | 1            | 2     | 3     | 4             | 5            | 6     | 7                | 8     | 9      | 10    | 11    |
| 値            | 110   | )11          | 1110  | 00    | 1             | 1101         |       | 111              | 110   | 11     | 111   | その他   |
| 名称           | P7    | rC .         | DAC   | 00    | IN            | TREF         |       | TEMP             | SENSE | G      | ND    | -     |
| 説明           |       | (予約)<br>DAC2 | DAC0  | 出力    | VREF周辺<br>内部基 | 2機能か<br>基準電圧 |       | ADC0: 温<br>ADC1: |       | 器 OV ( | (GND) | (予約)  |

## 30.5.8. COMMAND - 指令 (Command)

名称: COMMAND

変位:+\$08 リセット:\$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|--------|---|---|---|---|---|---|---|--------|
|        |   |   |   |   |   |   |   | STCONV |
| アクセス種別 | R | R | R | R | R | R | R | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0      |

## ● ビット0 - STCONV:変換開始(Start Conversion)

このビットへの'1'書き込みは単一の変換を開始します。自由走行動作の場合、これは初回変換を開始します。STCONVは変換が進行中である限り'1'として読みます。変換が完了すると、このビットは自動的に解除(0)されます。

変換進行中のこのビットへの'0'書き込みはその変換を中止します。

## 30.5.9. EVCTRL - 事象制御 (Event Control)

名称: EVCTRL 変位:+\$09 リセット: \$00 特質:-

| ピット _  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|--------|---|---|---|---|---|---|---|---------|
|        |   |   |   |   |   |   |   | STARTEI |
| アクセス種別 | R | R | R | R | R | R | R | R/W     |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0       |

## ● ビット0 - STARTEI: 事象入力開始 (Start Event Input)

このビットは変換開始用の供給元として事象入力を使うことを許可します。

## 30.5.10. INTCTRL - 割り込み制御 (Interrupt Control)

名称:INTCTRL 変位:+\$0A リセット:\$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0      |
|--------|---|---|---|---|---|---|------|--------|
|        |   |   |   |   |   |   | WCMP | RESRDY |
| アクセス種別 | R | R | R | R | R | R | R/W  | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0      |

● ビット1 - WCMP: 窓比較器割り込み許可 (Window Comparator Interrupt Enable)

このビットへの'1'書き込みは窓比較器割り込みを許可します。

ビット0 - RESRDY: 結果準備可割り込み許可 (Result Ready Interrupt Enable)
 このビットへの'1'書き込みは結果準備可(変換の終わり)割り込みを許可します。

## 30.5.11. INTFLAGS - 割り込み要求フラグ (Interrupt Flags)

名称: INTFLAGS 変位:+\$0B リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0      |
|--------|---|---|---|---|---|---|------|--------|
|        |   |   |   |   |   |   | WCMP | RESRDY |
| アクセス種別 | R | R | R | R | R | R | R/W  | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0      |

## ● ビット1 - WCMP: 窓比較器割り込み要求フラグ (Window Comparator Interrupt Flag)

この窓比較器割り込み要求フラグは測定が完了して結果が制御E(ADCn.CTRLE)レジスタの窓比較器動作(WINCM)によって定義されて選んだ窓比較動作に合致した場合に設定(1)されます。比較は変換の最後で行われます。このフラグはこのビット位置への'1'書き込み、または結果(ADCn.RES)レジスタ読み込みのどちらかによって解除(0)されます。このビットへの'0'書き込みは無効です。

## ● ビット0 - RESRDY: 結果準備可割り込み要求フラグ(Result Ready Interrupt Flag)

結果準備可割り込み要求フラグは測定が完了して新しい結果の準備が整った時に設定(1)されます。このフラグはこのビット位置への'1'書き込み、または結果(ADCn.RES)レジスク読み込みのどちらかによって解除(0)されます。このビットへの'0'書き込みは無効です。

## 30.5.12. DBGCTRL - テ、バック、制御 (Debug Control)

名称: DBGCTRL 変位: +\$0C リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|--------|---|---|---|---|---|---|---|--------|
|        |   |   |   |   |   |   |   | DBGRUN |
| アクセス種別 | R | R | R | R | R | R | R | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0      |

## ● ビット0 - DBGRUN: デバッグ時走行 (Debug Run)

| 値  | 0                      | 1                        |
|----|------------------------|--------------------------|
| 説明 | ADCはデバッグ動作中断で停止し、事象を無視 | ADCはCPU停止中のデバッグ動作中断で走行継続 |

## **30.5.13. TEMP - 一時レジスタ** (Temporary)

名称: TEMP 変位:+\$0D リセット: \$00 特質:-

一時レジスタはこの周辺機能の16ビット レジスタへの16ビット単一周期アクセスのためにCPUによって使われます。このレジスタはこの周辺機能の全ての16ビット レジスタに対して共通で、ソフトウェアによって読み書きすることができます。16ビット レジスタの読み書きのより多くの詳細については「AVR® CPU」章の「16ビット レジスタのアクセス」を参照してください。

| ピット    | 7   | 6   | 5   | 4   | 3    | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|------|-----|-----|-----|
|        |     |     |     | TEM | P7∼0 |     |     |     |
| アクセス種別 | 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 - TEMP7~0: 一時値 (Temporary)

16ビットレジスタでの読み書き用一時レジスタ。

#### **30.5.14**. **RES** - 結果 (Result)

名称: RES (RESH, RESL)

変位 : +\$10 リセット : \$0000 特質 : -

ADCn.RESHとADCn.RESLのレジスタ対は16ビット値のADCn.RESを表します。下位バイト[7~0](接尾辞L)は変位原点でアクセスできます。 上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

アナログ入力がADCの基準レベルよりも高い場合、10ビットADCの結果は\$3FFの最大値に等しくなります。同様に、入力が0V未満の場合、ADCの結果は\$000になります。ADCが\$3FFを超える結果を生成することができないため、累積された値は例え許された最大の64累積後でも、決して\$FFC0を超えません。

| <b>ビット</b> | 15 | 14  | 13 | 12  | 11   | 10 | 9        | 8   |
|------------|----|-----|----|-----|------|----|----------|-----|
|            |    |     |    | RES | 15~8 |    |          |     |
| アクセス種別     | R  | R   | R  | R   | R    | R  | R        | R   |
| リセット値      | 0  | 0   | 0  | 0   | 0    | 0  | 0        | 0   |
| ピット        | 7  | C   | _  | 4   | 0    | 0  | 1        | 0   |
| [ N)       | -7 | . 6 | 5  | 4   | 3    | 2  | <u> </u> | . 0 |
|            |    |     |    | KES | §7∼0 |    |          |     |
| アクセス種別     | R  | R   | R  | R   | R    | R  | R        | R   |
| リセット値      | 0  | 0   | 0  | 0   | 0    | 0  | 0        | 0   |

## ● ビット15~8 - RES15~8 : 結果上位バイト (Result high byte)

これらのビットはMSBがRES15のADCn.RESレジスタの上位バイトを構成します。ADC自体はMSBがADC9の10ビット出力(ADC9~0)を持ちます。ADCとデジタル累積でのデータ形式は\$0000が0を表し、\$FFFFが最大数(全尺)を表す2進数です。

## ● ビット7~0 - RES7~0: 結果下位バイト (Result low byte)

これらのビットはADC/累積器の結果(ADCn.RES)レジスタの下位バイトを構成します。ADC自体はMSBがADC9の10ビット出力(ADC9~0)を持ちます。ADCとデジタル累積でのデータ形式は\$0000が0を表し、\$FFFFが最大数(全尺)を表す2進数です。

## 30.5.15. WINLT - 窓比較器下側閾値 (Window Comparator Low Threshold)

名称: WINLT (WINLTH, WINLTL)

変位:+\$12 リセット:\$0000 特質:-

このレシ、スタは結果(ADCn.RES)レシ、スタを監視するデシ、タル比較器用の16ビット下側閾値です。ADC自体はMSBがRES9の10ビット出力 (RES9~0)を持ちます。ADCとデシ、タル累積でのデータ形式は\$0000が0を表し、\$FFFFが最大数(全尺)を表す2進数です。

ADCn.WINLTHとADCn.WINLTLのレジスタ対は16ビット値のADCn.WINLTを表します。下位バイト[7~0](接尾辞L)は変位原点でアクセスできます。上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

試料累積時、窓比較器閾値は採取毎ではなく、累積された値に適用されます。

| ピット        | 15  | 14  | 13       | 12     | 11          | 10       | 9        | 8   |
|------------|-----|-----|----------|--------|-------------|----------|----------|-----|
|            |     |     |          | . WINL | T15~8       |          |          |     |
| アクセス種別     | 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   | _        | 4      | 0           | 0        | 1        | 0   |
| <b>_ _</b> | (   | , 6 | <u>5</u> | 4      | 3           | <u>2</u> | <u> </u> | . 0 |
| L          |     |     |          | . WINL | <u>T7~0</u> |          |          |     |
| アクセス種別     | R/W | R/W | R/W      | R/W    | R/W         | R/W      | R/W      | R/W |
| リセット値      | 0   | 0   | 0        | 0      | 0           | 0        | 0        | 0   |

● **ビット15~8 - WINLT15~8**: 窓比較器下側閾値上位バイト (Window Comparator Low Threshold high byte) これらのビットは16ビット レジスタの上位バイトを保持します。

● **ビット7~0 - WINLT7~0**: 窓比較器下側閾値下位バイト (Window Comparator Low Threshold low byte) これらのビットは16ビット レシブスタの下位バイトを保持します。

## 30.5.16. WINHT - 窓比較器上側閾値 (Window Comparator High Threshold)

名称: WINHT (WINHTH, WINHTL)

変位:+\$14 リセット:\$0000 特質:-

このレシ、スタは結果(ADCn.RES)レシ、スタを監視するテ、シ、タル比較器用の16ピット上側閾値です。ADC自体はMSBがRES9の10ピット出力(RES9~0)を持ちます。ADCとデン、タル累積でのデータ形式は\$0000が0を表し、\$FFFFが最大数(全尺)を表す2進数です。

ADCn.WINHTHとADCn.WINHTLのレジスタ対は16ビット値のADCn.WINHTを表します。下位バイト[7~0](接尾辞L)は変位原点でアクセスできます。上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

試料累積時、窓比較器閾値は採取毎ではなく、累積された値に適用されます。

| ピット          | 15  | 14  | 13  | 12   | 11    | 10  | 9   | 8   |
|--------------|-----|-----|-----|------|-------|-----|-----|-----|
|              |     |     |     | WINH | T15~8 |     |     |     |
| アクセス種別       | R/W | R/W | R/W | R/W  | R/W   | R/W | R/W | R/W |
| リセット値        | 0   | 0   | 0   | 0    | 0     | 0   | 0   | 0   |
| <b>ビット</b> _ | 7   | 6   | 5   | 4    | 3     | 2   | 1   | 0   |
|              |     |     |     | WINH | T7~0  |     |     |     |
| アクセス種別       | R/W | R/W | R/W | R/W  | R/W   | R/W | R/W | R/W |
| リセット値        | 0   | 0   | 0   | 0    | 0     | 0   | 0   | 0   |
|              |     |     |     |      |       |     |     |     |

- **ビット15~8 WINHT15~8**: 窓比較器上側閾値上位**バイト** (Window Comparator High Threshold high byte) これらのビットは16ビット レシブスタの上位バイトを保持します。
- ビット7~0 WINHT7~0: 窓比較器上側閾値下位バイ (Window Comparator High Threshold low byte) これらのビットは16ビットレジスタの下位バイトを保持します。

# 30.5.17. CALIB - 校正 (Calibration)

名称: CALIB 変位:+\$16 リセット: \$01 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|--------|---|---|---|---|---|---|---|---------|
|        |   |   |   |   |   |   |   | DUTYCYC |
| アクセス種別 | R | R | R | R | R | R | R | R/W     |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1       |

## • ビット0 - DUTYCYC : デューティ サイクル (Duty Cyacle)

このビットはADCクロックのデューティサイクルを決めます。

ADCclk>1.5MHzは2.7Vの最小動作電圧を必要とします。

| 値  | 0                                                | 1                                                                  |
|----|--------------------------------------------------|--------------------------------------------------------------------|
| 説明 | 50%デューティ サイクルはADCclk>1.5MHzの場合に<br>使われなければなりません。 | 25%デューティ サイクル(High=25%,Low=75%)は<br>ADCclk≦1.5MHzに対して使われなければなりません。 |

## 31. DAC - D/A変換器

## 31.1. 特徴

- ・8ビット分解能
- ・最大350kspsの変換時間
- ・ 高い駆動能力
- ・アナログ比較器(AC)またはA/D変換器(ADC)への入力としての機能

## 31.2. 概要

D/A変換器(DAC)はデータ(DACn.DATA)レジスタに書かれたデンタル値をアナロケ値に変換します。変換範囲はGNDと選択した基準電圧間です。

DACは毎秒350,000採取(350ksps)の変換能力の8ビット抵抗列型DACが特徴です。DACは変換用の上限として内部基準電圧(VRE F)を使い、 $5k\Omega$ と/または30pFの負荷を駆動することができる高い駆動能力を持つ1つの連続時間出力を持ちます。データ(DACn. DATA)レジスタに書くことによって応用からDAC変換を開始してください。

## 31.2.1. 構成図



#### 31.2.2. 信号説明

| 信号  | 形式     | 説明       |
|-----|--------|----------|
| OUT | アナログ出力 | D/A変換器出力 |

注: DAC0だけが外部ピンに対する出力駆動部を持ちます。

## 31.2.3. システム依存性

この周辺機能を使うには、右で記述されるように、システムの他の部分が正しく構成設定されなければなりません。

| 表31-1. DACシステム依存性 |     |         |  |  |  |  |  |  |
|-------------------|-----|---------|--|--|--|--|--|--|
| 依存性               | 適用性 | 周辺機能    |  |  |  |  |  |  |
| クロック              | 0   | CLKCTRL |  |  |  |  |  |  |
| I/O線と接続           | 0   | PORT    |  |  |  |  |  |  |
| 割り込み              | ×   | -       |  |  |  |  |  |  |
| 事象                | ×   | -       |  |  |  |  |  |  |
| デバック              | 0   | UPDI    |  |  |  |  |  |  |

#### 31.2.3.1. クロック

この周辺機能は周辺機能クロック(CLK\_PER)に依存します。

#### 31.2.3.2. I/O線と接続

この周辺機能のI/O線を使うにはI/Oピンの構成設定が必要です。

DAC0はそれが使われ得る前に構成設定されなければならない1つのアナログ出力(OUT)ピンを持ちます。

DACは内部的にアナログ比較器(AC)とA/D変換器(ADC)にも接続されます。この内部OUTを入力として使うには、出力と入力の両方がそれら各々のレジスタで構成設定されなければなりません。

注: DAC0だけが外部ピンに対する出力駆動部を持ちます。

# 表31-2. I/O線 実体 信号 I/O線 周辺機能 DAC0 OUT PA6 DAC7ナロゲ出力

#### 31.2.3.3. 割り込み

該当なし

## 31.2.3.4. 事象

該当なし

#### 31.2.3.5. デバッグ操作

この周辺機能はデバッグ動作に入ることによって影響を及ぼされません。

この周辺機能が割り込みや同様のものを通してCPUによる定期的な助けを必要とするように構成設定された場合、停止されたデバッグの間に不適切な動作やデータ損失の結果になるかもれません。

## 31.3. 機能的な説明

## 31.3.1. 初期化

DACを操作するには、以下の手順が必要とされます。

- 1. DAC0については基準電圧(VREF)周辺機能で制御x(VREF.CTRLx)レジスタのDACn/ACn基準電圧選択(DACnREFSEL)ビットを書くことによってDAC基準電圧を選んでください。
- 2. 変換範囲はGNDと選択した基準電圧間です。
- 3. DAC出力の更なる使い方を構成設定してください。
  - 3.1. DAC出力を使う内部周辺機能(例えば、アナロク比較器(AC)やA/D変換器(ADC))を構成設定してください。一致する周辺機能の記述を参照してください。
  - 3.2. 制御A(DACn.CTRLA)レジスタの出力許可(OUTEN)ビットに'1'を書くことによってピンへ出力を許可してください。 DAC0については1つまたは両方の任意選択が有効です。他のDACの実体は内部信号だけを支援します。
- 4. 初期デジタル値をデータ(DACn.DATA)レジスタに書いてください。
- 5. DACn.CTRLAレジスタのDAC許可(ENABLE)ビットに'1'を書くことによってDACを許可してください。

## 31.3.2. 動作

## 31.3.2.1. 許可、禁止、リセット

DACは制御A(DACn.CTRLA)レジブスタのDAC許可(ENABLE)ビットに'1'を書くことによって許可され、このビットに'0'を書くことによって禁止されます。

ピンへのOUT出力はDACn.CTRLAレジスタの出力許可(OUTEN)ビットを('1'に)書くことによって許可されます。

#### 31.3.2.2. 変換開始

DACが許可(DACn.CTRLAレジスタのENABLE=1)されると、データ(DACn.DATA)レジスタが書かれると直ぐに変換が始まります。

DACが禁止(DACn.CTRLAレシ、スタのENABLE=0)されると、DACn.DATAレシ、スタ書き込みは変換を起動しません。逆に、変換はDACn.CTRLAレシ、スタのENABLEに、1、2を書くことで始まります。

#### 31.3.2.3. 内部周辺機能用供給元としてのDAC

DACのアナログ出力はアナログ比較器(AC)とA/D変換器(ADC)の両方へ内部的に接続され、DACが許可(DACn.CTRLAレジスタのENAB LE=1)された時にこれらの周辺機能に対して利用可能です。DACアナログ出力が内部的にだけ使われている時に、ピン出力駆動部を許可することは不要です(即ち、DACn.CTRLAレジスタでのOUTEN=0は受け入れられます)。

## 31.3.3. 休止形態動作

制御A(DACn.CTRLA)レシ、スタのスタンハ、イ時走行(RUNSTDBY)ビットが、1、を書かれ、CLK\_PERが利用可能なら、スタンハ、イ休止動作でDA Cは動作を続けます。RUNSTDBYビットが0、の場合、DACはスタンハ、イ休止動作で変換を停止します。

スタンハイ休止動作で変換が停止された場合、消費電力を減らすためにDACと出力緩衝部が禁止されます。デバイスがスタンハイ休止動作を抜け出すと、DACと(DACn.CTRLAレジスタで出力許可(OUTEN)=1によって構成設定されるなら)出力緩衝部は再び許可されます。従って、新しい変換が始められるのに先立って或る始動時間が必要とされます。

パワーダウン休止動作では、消費電力を減らすためにDACと出力緩衝部が禁止されます。

#### 31.3.4. 構成設定変更保護

該当なし

# 31.4. レジスタ要約

| 変位    | 略称    | ビット位置        | ピット7     | ヒ゛ット6 | ピット5 | じット4 | ピット3 | ピット2 | ピット1 | ピット0   |
|-------|-------|--------------|----------|-------|------|------|------|------|------|--------|
| +\$00 | CTRLA | 7 <b>~</b> 0 | RUNSTDBY | OUTEN |      |      |      |      |      | ENABLE |
| +\$01 | DATA  | 7 <b>~</b> 0 |          |       |      | DAT  | A7~0 | 1    |      |        |

## 31.5. レジスタ説明

## **31.5.1. CTRLA - 制御A** (Control A)

名称: CTRLA 変位:+\$00 リセット: \$00 特質:-

| ピット    | 7        | 6     | 5 | 4 | 3 | 2 | 1 | 0      |
|--------|----------|-------|---|---|---|---|---|--------|
| F      | RUNSTDBY | OUTEN |   |   |   |   |   | ENABLE |
| アクセス種別 | R/W      | R/W   | R | R | R | R | R | R/W    |
| リセット値  | 0        | 0     | 0 | 0 | 0 | 0 | 0 | 0      |

● ビット7 - RUNSTDBY: スタンバイ動作時走行 (Run in Standby Mode)

このビットが、0'を書かれた場合、デバイスがスタンバイ休止動作に入る時にDACや出力緩衝部が自動的に禁止されます。

● ビット6 - OUTEN : 出力緩衝部許可 (Output Buffer Enable)

このビットへの'1'書き込みは出力緩衝部を許可してOUT信号をピンへ送ります。

ビット0 - ENABLE: DAC許可(DAC Enable)このビットへの'1'書き込みがDACを許可します。

## **31.5.2. DATA** - データ (Data)

名称: DATA 変位:+\$01 リセット: \$00 特質:-



ヒット7~0 - DATA7~0: データ (Data)

このビット領域はアナログ電圧に変換されるデジタル データを含みます。

## 32. PTC - 周辺機能接触制御器

## 32.1. 特徴

- ・低電力、高感度、環境的に強い容量性接触の釦、摺動子、輪
- ・スタンバイ休止動作から接触での起き上がりを支援
- 相互容量と自己容量の感知を支援
  - 相互と自己の容量性感知部の上手い組み合わせ
- ・電極毎に1つのピン 外部部品なし
- 負荷補償電荷感知
  - 寄生容量補償と優れた感度のための調整可能な利得
- ・温度とVDDの範囲に渡る0変動
  - 感知器の自動校正と再校正
- ・単発と自由走行の電荷測定
- ・高い導電耐性のためのハートウェア雑音濾波と雑音信号脱同期化
- ・より良い雑音耐性と耐湿のための駆動型遮蔽
  - 駆動型遮蔽にどのX/Y線も使用可能
  - 許可された全ての感知器が走査される感知器と同じ電位で駆動
- ・必要とされるように、新しいチャネルでの静定時間を選ぶことを許す選択可能なチャネル変更遅延
- ・命令によって、または自動起動機能を通して起動される採取開始
- ・採取完了での割り込みを通した低いCPU使用率
- ・信号変換と採取にADC周辺機能を使用

## 32.2. 概要

周辺機能接触制御器(PTC:Peripheral Touch Controller)は容量性感知部での接触を検知するために信号を取得します。外部の容量性接触感知部は代表的に印刷回路基板(PCB)配置の一部として設計され、感知部電極はデバイスの入出力ピンを通してPTCのアナロゲ前処理部に接続されます。PTCは自己と相互の両容量性感知部を支援します。

相互容量動作に於いて、検知は酸化インジウム錫(ITO:Indium tin oxide)感知格子を含む、様々なX-Y構成設定で容量性接触行列を用いて行われます。PTCはX線毎に1つのピン、Y線毎に1つのピンが必要です。

自己容量動作に於いて、PTCは各接触感知部に対して1つのピン(Y線)だけが必要です。

利用可能なピン数とXとYの線の割り当ては外囲器形式とデバイス構成設定の両方に依存します。更なる詳細については「製品形態要約」項と「入出力多重化と考察」章を参照してください。

## 32.3. 構成図





## 32.4. 信号説明

| 信号   | 形式      | 説明      |
|------|---------|---------|
| Ym∼0 | アナログ入出力 | Y線(入出力) |
| Xn∼0 | デジタル出力  | X線(出力)  |

注: XとYの線数はデバイス依存です。詳細については「製品形態要約」を参照してください。

この周辺機能に対するピン割り当ての詳細については「入出力多重化と考察」を参照してください。1つの信号が様々なピンに割り当てられ得ます。

## 32.5. システム依存性

この周辺機能を使うには、以降の項で記述されるように、システムの他の部分を構成設定してください。

#### 32.5.1. I/O線

アナログのX線とY線に使われるI/O線は外部容量性接触感知部電極に接続されなければなりません。通常の動作に対して外部部品は必要とされません。けれども、EMC性能を改善するために、X線とY線で1kΩまたはそれ以上の直列抵抗を使うことができます。

#### 32.5.1.1. 相互容量感知部配置

相互容量感知部は送出用のX電極と感知用のY電極の2つの入出力線間に印刷回路基板(PCB)配置の一部として設計されます。XとYの電極間の相互容量は周辺機能接触制御器によって測定されます。



#### 32.5.1.2. 自己容量感知部配置

自己容量感知部は信号感知用のY電極を通して周辺機能接触制御器の単一ピンに接続されます。電極容量感知は周辺機能接触制御器によって測定されます。

接触感知部の設計についてのより多くの情報に関しては「AN2934:容量性接触感知部設計の指針(DS00002934)」を参照してください。



## 32.5.2. クロック

PTCはCLK\_PERクロックによってクロック駆動されます。CLK\_PER構成設定の詳細については「クロック制御器(CLKCTRL)」章を参照してください。

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

PTCは信号の変換と採取にADCを使っています。ADCはPTCの正しい動きを許すように許可されて適切に構成設定されなければなりません。更なる詳細については「A/D変換器(ADC)」章を参照してください。

## 32.6. 機能的な説明

PTCにアクセスするため、使用者は応用コート・とQTouchライブラリファームウェアを構成設定してリンクするのにAtmel START QTouch構成設定部を使わなければなりません。QTouchライブラリは単一インターフェースに於いて種々の組み合わせで釦、摺動子、輪の実装に使うことができます。



QTouchライブラリについてのより多くの情報に関しては「QTouch®部品化ライブラリ周辺機能接触制御器使用者の手引き(DS40001986)」を参照してください。

## 33. UPDI - 統一プログラム/デバッグ インターフェース

## 33.1. 特徴

- ・外部プログラミングとチップ上デバッグ(OCD)用UPDI単線インターフェース
  - 高電圧またはヒューズによるプログラミング許可
  - プログラミングに対してデバイスのRESETピンを使用
  - 操作中に汎用入出力(GPIO)ピン占有なし
  - 書き込み器に対する非同期半二重UART規約
- ・プログラミング
  - 組み込み誤り検出と誤り識票生成
  - より速いプログミングのための応答生成無効
- ・デバッグ
  - デバイスのアドレス空間(NVM,RAM,I/O)に対するメモリ割り当てアクセス
  - デバイスのクロック周波数での制限なし
  - 制限なしの使用者プログラム中断点(ブレークポイント)
  - 2つのハートヴェア中断点
  - 高度なOCD機能に対する支援
    - ・コード鑑定のためのCPUプログラム カウンタ(PC)、スタック ポインタ(SP)、ステータス レシブスタ(SREG)の走行時読み出し
    - ・CRCでの中断/停止状況の検出と合図
    - ・実行、停止、リセットのデバッグ命令用プログラムの流れ制御
  - システム レシ スタのアクセスなしでの非干渉走行時チップ 監視
  - 施錠されたデバイスでのフラッシュ メモリのCRC検査結果を読むためのインターフェース

## 33.2. 概要

統一プログラム/デバック「インターフェース(UPDI)は外部書き込み器とデバイスのOCD用の専用インターフェースです。

UPDIは不揮発性メモリ(NVM)空間のフラッシュメモリ、EEPROM、ヒュース、施錠ビット、そして使用者列のプログラミングを支援します。いくつかのメモリ割り当てレジスタは許可された正しいアクセス特権(鍵、施錠ビット)でだけ、そしてOCD停止動作または或るプログラミング動作でだけアクセス可能です。これらの動作はUPDIに正しい鍵を送ることによって解錠されます。NVM制御器経由のプログラミングとNVM制御器指令の実行については「NVMCTRL - 不揮発性メモリ制御器」章をご覧ください。

UPDIは3つの分離された規約層、UPDI物理(PHY)層、UPDIデータリンク(DL)層、UPDIアクセス(ACC)層に分割されます。既定PHY層は接続された書き込み器/デバッカに対してUPDIピン線を渡る双方向UART通信を扱い、単線通信動作で到着データフレームでのデータ再生とクロック再生を提供します。受け取った命令と対応するデータはDL層によって処理され、復号された命令に基づいてACC層との通信の準備をします。システム バスとメモリ割り当てレシ、スタへのアクセスはACC層を通して許されます。

プログラミングとディブッグはデータの受信と送信にRESETピンを使う半二重インターフェースに基づく単線UARTです。PHY層のクロック駆動は専用内部発振器によって行われます。

ACC層はUPDIと接続されたバス配列間のインターフェースです。この層はメモリ、NVM、周辺機能のようなシステム部へのメモリ割り当てアクセスを持つバス配列に対してUPDI経由でのアクセスを許します。

非同期システム インターフェース(ASI:Asynchronous System Interface)はOCD、NVM、システム管理系で機能を選ぶための直接インターフェース アクセスを提供します。これはバス アクセスを要求することなく、システム情報への直接アクセスをデバッガに与えます。

## 33.2.1. 構成図



#### 33.2.2. クロック

PHY層とACC層は違うクロック領域で動くことができます。PHY層クロックは専用内部発振器から得られ、ACC層クロックは周辺機能クロックと同じです。PHY層とACC層間にはクロック領域間の正しい動作を保証する同期境界があります。UPDIクロック出力周波数はASIを通して選ばれ、UPDI許可またはリセット後の既定UPDIクロック始動周波数は4MHzです。UPDIクロック周波数はASI制御A(UPDI,ASI\_CTRLA)レジ、スタのUPDIクロック分周器選択(UPDICLKSEL)ビット領域を書くことによって変更することができます。



## 33.2.3. 物理層

PHY層は接続された書き込み器/デバッガとデバイス間の通信インターフェースです。PHY層の主な機能は次のように要約することができます。

- UPDIピンで半二重UART通信を使い、UPDI単線非同期動作を支援
- ・内部ボーレート検出、UARTフレームでのクロックとデータの再生
- ・異常検出(パリティ、クロック再生、フレーム、システム異常)
- ·送信応答生成(ACK)
- 動作中の異常識票の生成
- 保護時間制御

## 33.2.4. I/O線と接続

UPDIを操作するには、RESETt°ンがUPDI動作に設定されなければなりません。これは通常のI/Ot°ン用としてPORT I/Ot°ン構成設定を通してではなく、「33.3.2.1.2. RESETt°ンのヒュース、無効化でのUPDI許可」で記述されるようにシステム構成設定0(FUSE.SYSCFG0) ヒュース、のRESETt°ン構成設定(RSTPINCFG)ヒットを( $^{'}$ 01'に)設定することを通して、または「33.3.2.1.3. RESETt°ンの高電圧無効化でのUPDI許可」からのUPDI高電圧許可手順に従うことによって行われます。プルアップ許可、入力許可、出力許可の設定は活性の時にUPDIによって自動的に制御されます。

## 33.3. 機能的な説明

## 33.3.1. 動作の原理

UPDIを通す通信は固定フレーム形式、クロックとデータの再生に対する自動ホーレート検出を用いる標準USART通信に基づきます。データフレームに加えて、通信のためにいくつかの制御フレーム(DATA、IDLE、BREAK、SYNCH、ACK)が重要です。



| フレーム  | 説明                                                                                                                                                                                                                                               |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DATA  | DATAフレームは常にLowの1開始(St)ビット、8データ ビット、偶数パリティ用の1パリティ(P)ビット、常にHighの2停止(S1とS2)ビット から成ります。 パリティ ビットまたは停止ビットが不正な値を持つ場合、誤りが検出されてUPDIによって合図されます。 UP DIでのパリティ ビット検査は制御A(UPDI.CTRLA)レジスタのパリティ禁止(PARD)ビットに('1'を)書くことによって禁止することができ、その場合、 デバッガからのパリティ生成は無視されます。 |
| IDLE  | これは12個のHight゙ットから成る特別なフレームです。これは送信線をアイドル(IDLE)状態で維持するのと同じです。                                                                                                                                                                                     |
| BREAK | 12個のLowt'ットから成る特別なフレームです。UPDIを既定状態に戻してリセットするのに使われ、代表的に異常回復に使われます。                                                                                                                                                                                |
| SYNCH | SYNCHフレームは到着する伝送に対してボーレートを設定するため、ボーレート生成部によって使われます。SYNCH文字は毎回の新しい命令の前とBREAKが成功裏に送信された後でUPDIによって常に期待されます。                                                                                                                                         |
| ACK   | ACKフレームはSTまたはSTSの命令が成功裏に同期境界を渡ってバスアクセスを得られた時に必ずUPDIから送信されます。デバッガによってACKが受信されると、次の送信を開始することができます。                                                                                                                                                 |

#### 33.3.1.1. UPDI UART

通信は主装置のディッカ/書き込み器側から開始され、毎回の送信はSYNCH文字で開始しなければならず、これはUPDIが送信ボーレートを再生して到着データ用にこの設定を格納するのに使うことができます。SYNCH文字によって設定されるボーレートは後続する命令とデータのバイトの受信と送信の両方に使われます。次のSYNCH文字が命令の流れで予期される時の詳細については「33.3.3. UPDI命令一式」項をご覧ください。

UPDIには書き込み可能なボーレートレジスタがなく、故にデータ バイトを採取する時のデータ再生にSYNCH文字から採取されたボーレートが使われます。

PHY層の送信ホーレートは選んだUPDIクロックに関連付けされ、ASI制御A(UPDI.ASI\_CTRLA)レシ、スタのUPDIクロック分周器選択(UPDICLK SEL)ヒット領域を書くことによって調整することができます。送受信のホーレートは自動ホーレートの精度内で常に同じです。

UPDIボーレート生成部は送信誤差を最小にするために分数ボーレート 計数を利用します。UPDIによって使われる固定フレーム形式での最大と推奨される受信部転送誤差限度は下表で見ることができます。

| 表33-1. UPDICLKSEL設定に基づく推奨UARTボーレート |          |         |  |  |  |  |
|------------------------------------|----------|---------|--|--|--|--|
| UPDICLKSEL1,0 最大推奨ボーレート 最小推奨ボー     |          |         |  |  |  |  |
| 0 1 (16MHz)                        | 0.9Mbps  | 300 bps |  |  |  |  |
| 1 0 (8MHz)                         | 450 kbps | 150 bps |  |  |  |  |
| 11(4MHz)-既定                        | 225 kbps | 75 bps  |  |  |  |  |

#### 表33-2. 受信部ボーレート誤差

| データ+パリティビット | R <sub>slow</sub> (%) | Rfast(%) | 最大総合許容誤差(%) | 推奨最大受信許容誤差(%) |
|-------------|-----------------------|----------|-------------|---------------|
| 9           | 96.39                 | 104.76   | -3.61∼+4.76 | ±1.5          |

#### 33.3.1.2. BREAK文字

中断(BREAK)文字はUPDIの内部状態を既定設定にリセットするのに用いられます。これは通信異常のためにUPDIが異常状態に入った場合、またはデバッカとUPDI間の同期が失われた時に有用です。

全ての場合でBREAKがUPDIによって成功裏に受信されるのを保証するため、デバッかは2つの連続するBREAK文字を送らなければなりません。最初のBREAKはUPDIがアイドル状態の場合に検出され、(非常に低いボーレートで)UPDIが受信または送信している間にそれが送られた場合に検出されません。けれども、これは受信(RX)に対するフレーム異常または送信(TX)に対する衝突異常を引き起こし、進行中の操作を中止します。その後、UPDIは次のBREAKを成功裏に検出します。

BREAK受信で、ASI制御A(UPDI.ASI\_CTRLA)レシブスタのUPDI発振器設定が4MHzの既定UPDIクロック選択にリセットされます。これは表33-1.に従ってUPDIのボーレート範囲を変更します。

## 33.3.1.2.1. 単線動作でのBREAK

非同期動作で、書き込み器/デバッガとUPDIは完全に同期が外れることがあり、UPDIがそれを検出できることを保証するためにBREAK文字の最悪長を必要とします。4MHz(250ns)の最低UPDIクロック速度と仮定し、16ビットに含まれ得る8ビットSYNCH様式値の最大長は、 $65535 \times 250ns = 16.4ms/$ バイト=16.4ms/8ビット=2.05ms/ビットです。

これは最低の前置分周器設定に対して2.05ms×12ビット≒24.6msの最悪BREAKフレーム持続時間を与えます。前置分周器設定が既知なら、BREAKフレームの時間は右表からの値に従って緩和されます。

#### 表33-3. 推奨中断(BREAK)文字持続時間

| UPDICLKSEL1,0 | 推奨BREAK文字持続時間 |
|---------------|---------------|
| 0 0           | (予約)          |
| 0 1 (16MHz)   | 6.15 ms       |
| 1 0 (8MHz)    | 12.30 ms      |
| 11(4MHz)-既定   | 24.60 ms      |

#### 33.3.1.3. SYNCH文字

同期(SYNCH)文字は8ビットを持ち、通常のUPDIフレーム形式に従います。これは'\$55'の固定データ ビット値を持ちます。SYNCH文字は以下の2つの主な目的を持ちます。

- 1. 禁止後にUPDIに対する許可文字として働きます。
- 2. 後続する伝送用にボーレートを設定するため、ボーレート生成部によって使われます。無効なSYNCH文字が送られた場合、次の伝送は正しく採取されません。

#### 33.3.1.3.1. 単線動作でのSYNCH

SYNCH文字は各新規命令の前に使われます。REPEAT命令を使う時に、SYNCH文字はREPEAT後の最初の命令の前でだけ期待されます。

SYNCHは既知の文字で、各ビットに対する交互切り替わりの特性を通して、8ビットSYNCH様式を採取するのにどの位のUPDIクロック周期が必要とされるかの測定をUPDIに許します。この採取を通して得られた情報は受信での非同期クロック再生と非同期データ再生を提供するのと送信動作を行う時に接続された書き込み器のボーレートを保つのに使われます。

## 33.3.2. 操作

UPDIはUART通信が開始され得るのに先立って許可されなければなりません。

#### 33.3.2.1. UPDI許可

UPDI用許可手順はデバイスと無関係で以下の項で記述されます。

#### 33.3.2.1.1. 単線許可

UPDIピンは絶えず許可されたプルアップを持ち、200nsを超える間UPDIピンをLowに駆動することにより、接続された書き込み器が始動手順を始めます。

負端遷移が(複数電圧システムの場合に、高電圧領域に置かれた)端検出器にUPDIピンのLow駆動を始めさせ、故に書き込み器が線を開放した時に要求したUPDI発振器の準備が整うまでLowに留まります。クロックに対して期待される到来時間は精度、行き過ぎ、発振器校正の読み出しに関する発振器実装に依存します。複数電圧システムについて、線は調整器が正しい水準になるまでLowに駆動され、システムは選んだ発振器の準備が整って安定な状態で通電されます。書き込み器はピンが再びHighに遷移する時を検出するためにそれを開放した後、最初にUPDIピンをポーリングしなければなりません。この遷移は端検出器がピン(プルアップ゚)を開放し、UPDIがSYNCH文字を受信することができることを意味します。SYNCH文字の成功裏の検出で、UPDIは許可され、最初の命令の受信に対して準備します。

伝送許可手順は次の図で示され、書き込み器と端検出器に対する駆動活動期間が含まれます。"UPDIt°ン"波形は常にピン値を示します。

端検出器駆動活動期間に対して与えられる遅延は代表的に16MHz発振器での256周期間の始動時間待ち+校正読み出しです。予測される始動時間の詳細については「電気的特性」章を参照してください。

注: 許可手順のSYNCHが最初の命令に対してボーレート生成部を準備するため、最初の許可SYNCH後に発行される最初の命令は余分なSYNCHが不要です。



端検出器の予期せぬ起動が起きた場合に許可され続けるUPDIを避けるため、UPDIは自身を自動的に禁止してそれのクロック要求を下げます。より多くの詳細については「始動中の禁止」項をご覧ください。

#### 33.3.2.1.2. RESET L°ンのヒュース 無効化でのUPDI許可

システム構成設定の(FUSE.SYSCFGの)ヒュース・のRESET ピン構成設定(RSTPINCFG)ビットが、01、の時に、RESET ピンは無効にされ、UPDIがこのピンの制御を取ってプルアップで付き入力として構成設定します。接続されたデバッカーによってプルアップが検出されると、下で描かれるようにUPDI許可手順が開始されます。



プルアップが検出されると、デバッガは線をTDebo間Lowに駆動することによって許可手順を始めます。

UPDIクロックを開始する負端がUPDIによって検出されます。UPDIはクロックが安定するまで線をLowに駆動し続け、UPDIが使う準備が整います。TuPDIの持続時間はUPDIが許可される時の発振器の状態に依存して変わります。この持続時間後、データ線がUPDIによって解放され、Highにプルアップされます。

線がHighであることをデバッカが検出すると、UPDI通信データ速度と同期するために最初の同期(SYNCH)文字(\$55)が送信されなければなりません。同期(SYNCH)文字の開始ビットが最大TDebZ以内に送られなければ、UPDIは自身を禁止し、UPDI許可手順は再び開始されなければなりません。予期せずUPDIが許可されるのを避けるため、タイング違反の場合、UPDIは禁止されます。

同期(SYNCH)文字送信成功後、最初の命令フレームを送信することができます。

## 33.3.2.1.3. RESETL シの高電圧無効化でのUPDI許可

RESET ピンの汎用入出力(GPIO)またはリセットの機能は高電圧(HV)プログラミングを使うことでUPDIによって無効にすることが<u>できま</u>す。 RESETピンにHVパルスを印加すると、ピンの機能をUPDIに切り替えます。これはシステム構成設定0(FUSE.SYSCFG0)ヒューズのRESETピン 構成設定(RSTPINCFG)と無関係です。ピン機能を無効化するには以下のこれらの手順に従ってください。

- 1. 推奨: HV許可手順を開始する前にデバイスをリセットしてください。
- 2. 下図で記述されるようにHV信号を印加してください。
- 3. 最初の同期(SYNCH)文字後にKEY命令を使ってNVMPROG鍵を送ってください。
- 4. プログラミング終了後、STCS命令を使って制御B(UPDI.CTRLB)レジスタのUPDI禁止(UPDIDIS)ビットに'1'を書くことによってUPDIをリセットしてください。

電源投入中、電源ONJセット(POR:Power-On Reset)はHVパルスが印加され得る前に開放されなければなりません。パルスの持続時間はHi-Zになる前に100μsから1msの範囲が推奨されます。HVパルスの上昇端印加時、UPDIはJセットになります。Hi-Z後、UPDIはデバッガによってRESETピンがLowに駆動されるまでJセットに留まります。これはUPDIJセットを開放し、「33.3.2.1.2. RESETピンのヒュース無効化でのUPDI許可」での説明と同じ許可手順を始めます。



HVパルスによって許可されると、電源ONリセット(POR)はRESETピンでのUPDI構成設定を禁止して既定設定に復元するだけです。制御B(UPDI.CTRLB)レジスタのUPDI禁止(UPDIDIS)ビットを通してUPDI禁止指令を発行する場合、UPDIはリセットしてクロック要求が取り消されますが、RESETピンはUPDI構成設定に留まります。

注: UPDIピンに加えられる外部保護が不充分な場合、ESDパルスがデバイスによってHV上書きとして解釈されてUPDIを許可し得ます。

注: UPDI HV活性化に対する実際の閾値電圧はVDDに依存します。詳細については「電気的特性」をご覧ください。

#### 33.3.2.1.4. 汎用入出力(GPIO)に対する出力許可計時器保護

システム構成設定の(FUSE.SYSCFG0)ヒュース、のRESETビン構成設定(RSTPINCFG)ビットが、00、の時に、RESETビンは汎用入出力(GPIO)として構成設定されます。GPIOが出力を活動的に駆動するのとUPDI高電圧(HV)許可手順開始の間での潜在的な衝突を避けるため、GPIO出力駆動部はシステム リセット後に最小8.8ms間禁止されます。

HVプログラミング手順に入るのに先立って常にシステムリセットを発行することが推奨されます。

#### 33.3.2.2. UPDI禁止

#### 33.3.2.2.1. 始動中の禁止

許可手順中、UPDIは無効な許可手順の場合に自身を禁止することができます。UPDIが電源管理に与えたどの要求もリセットしてUDP Iを禁止状態に設定するために実装された2つの機構があります。新しい許可手順はその後にUPDIを許可することから始めなければなりません。

## 制限時間超過禁止

UPDIがそれのクロックを受け取った後に始動負端検出器がピンを開放する時、または複数電圧システムで調整器が安定でシステムが電力を持つ時、既定プルアップはPUDIピンをHighに駆動します。ピンがHighであることを書き込み器が検出せず、UPDIがピンを開放した後の4MHz UPDIクロックでの164ms内にSYNCH文字の送信を始めない場合、UPDIは自身を禁止します。

注: 始動発振周波数はデバイス依存です。UPDIは制限時間超過を発行するのに先立ってUPDIクロックで65536周期間計数します。

#### 不正なSYNCH様式

不正なSYNCH様式は、SYNCH文字長がUPDIホーレートレジスタが含むことができる採取数よりも長い(溢れ)、または各ビットの採取長に対して扱うことができる最小分数計数よりも短い場合に検出されます。それらのどんな異常が検出された場合も、UPDIは自身を禁止します。

## 33.3.2.2.2. UPDI正常禁止

書き込み器切断後にUPDIからのどの特定操作も必要としないどのプログラミングまたはデバッグの作業も制御B(UPDI.CTRLB)レジスタの UPDI禁止(UPDIDIS)ビットに('1'を)書くことによって終了されなければならず、そこでUPDIはシステム リセットを発行して自身を禁止します。このリセットは直前の状態と無関係にCPUを走行状態に戻します。システムに対するUPDIクロック要求も下げて全てのUPDI鍵と設定もリセットします。

禁止操作が実行されない場合、UPDIと発振器の要求は許可に留まります。これは応用に対して消費電力増加を引き起こします。

## 33.3.2.3. UPDI通信異常処理

UPDIは異常の筋書きから回復する時にデバッガへ情報を提供する包括的な異常検出システムを含みます。この異常検出はパリティ誤り、衝突異常、フレーム異常のような物理転送異常から、アクセス制限時間超過異常のようなもっと上位の異常に至る検出から成ります。利用可能な異常識票の概要については状態B(UPDI.STATUSB)レジスタのUPDI異常識票(PESIG)と、外領域をご覧ください。

望まれないシステム通信を避けるため、UPDIは異常を検出する度、直ちに内部異常状態へ移行します。異常状態でUPDIはBREAK文字が受信される時を除き、全ての着信データ要求を無視します。異常状態から回復する時は常に以下の手続きが適用されなければなりません。

- 1. BREAK文字を送ってください。推奨されるBREAK文字の扱いについては「33.3.1.2. BREAK文字」をご覧ください。
- 2. 次のデータ転送に対して望むボーレートでSYNCH文字を送ってください。
- 3. 状態B(UPDI.STATUSB)レジスタのUPDI異常識票(PESIG)ビット領域を読んで発生した異常についての情報を得るために制御/状態取得(LDCS)命令を実行してください。
- 4. UPDIは今や異常状態から回復され、次のSYNCH文字と命令を受け取る準備が整います。

#### 33.3.2.4. 方向変更

半二重UART動作に対して正しいタイシクで保証するため、UPDIはRX動作からTX動作へ方向を変更する時のタイシクでを緩和するための組み込み保護時間機構を持ちます。保護時間は次の最初の応答が小の開始ビットが送出される前に複数のアイドル(IDLE)ビットが挿入されることによって表されます。アイドルビット数は制御A(UPDI.CTRLA)レジスタの保護時間値(GTVAL)ビット領域を通して構成設定することができます。各アイドルビットの持続時間は現在の送信で使われるボーレートによって与えられます。



UPDI保護時間は接続されたディッカがUPDIからのデータを待っている時に経験する最小アイトル時間です。最大アイトル時間は制限時間と同じです。送信前のアイトル時間は同期時間+データ バス アクセス時間が保護時間よりも長い時に意図した保護時間を超えるでしょう。

常にUPDI側で最小2保護時間ビットの挿入、デバッガ側で1保護時間周期挿入を使うことが推奨されます。

## 33.3.3. UPDI命令一式

UPDIを通す通信は小さな命令一式に基づきます。これらの命令はUPDIデータリンク(DL)層の一部です。UPDIレジスタがメモリ割り当てシステム空間だけでなく、"ASIの制御と状態(CS)空間"と呼ばれる内部メモリ空間にも割り当てられるため、命令はUPDIレジスタをアクセスするのにも使われます。全ての命令はハイト命令で、通信に対するボーレートを決めるためにSYNCH文字が先行されなければなりません。送信に対するボーレート設定についての情報に関しては「33.3.1.1. UPDI UART」をご覧ください。次図はUPDI命令一式の概要を与えます。

| 図33-8. UPDI命令一式概要 |            |         |             |         |                                                 |      |     |               |                           |
|-------------------|------------|---------|-------------|---------|-------------------------------------------------|------|-----|---------------|---------------------------|
|                   | 指令         |         | A量          | D量      |                                                 |      |     |               |                           |
| LDS               | 0 0 0      | 0 0     | x 0         | X       | 指                                               | 令    |     |               |                           |
| STS               | 0 1 0      | 0 0     | x 0         | X       | 0 (                                             | 0 0  |     | DS (直接アドレン    | ス指定データ取得)                 |
|                   | 1          | PT      | R種別 A       | (/D量    | 0 (                                             | 0 1  | L   | D (間接アドレス     | 指定データ取得)                  |
| LD                | 0 0 1      | 0 x     | x 0         | X       | 0                                               | 1 0  | S   | TS (直接アドレン    | ス指定データ設定)                 |
| ST                | 0 1 1      | 0 x     | x 0         | X       | 0                                               | 1 1  | S   | T (間接アト・レス    | 指定データ設定)                  |
|                   |            |         | CSアトレ       | ス       | 1 (                                             | 0 0  | L   | DCS (LDS 制行   | 御/状態レシブスタ)                |
| LDCS              | 1 0 0      | 0 x     | X X         | X       | 1 (                                             | 0 1  | R   | EPEAT (繰りむ    | 豆し指定)                     |
| STCS              | 1 1 0      | 0 x     | X X         | . X     | 1                                               | 1 0  | S   | TCS (STS 制御   | 即/状態レジスタ)                 |
|                   |            |         |             | D量      | 1                                               | 1 1  | K   | EY(作動鍵)       |                           |
| REPEAT            | 1 0 1      | 0 0     | 0 0         | 0       | CII                                             | ) (s | 177 | テム情報部選択       |                           |
|                   |            |         |             | K量      |                                                 |      |     |               | .)                        |
| KEY               | 1   1   1  | 0 0     | x 0         | X       | 0     鍵受信       1     SIB送出                     |      |     |               |                           |
|                   |            |         |             |         | 1 ,                                             | MD.  |     | Ц             |                           |
| A量 (アト            |            |         | 量(データー      | 長)      |                                                 | 量 (  |     | .,            | PTR種別                     |
| 0 0 1ハ            | '          | 0       | 0 1バイト      |         | 0 (                                             | 0 6  | 4Ľ  | 'ット (8ハ'イト)   | 00 (ptr) (ポインタ間接データ)      |
|                   | 丫仆(語) ≦64년 | 〈Bメモリ 0 | 1 2バイト      | (語)     | 0 1 128ビット (16バイト)     0 1 *(ptr++) (上記+ポインタ進行) |      |     |               |                           |
| 1 0 3/1           | `{\h > 64F | KBメモリ 1 | 0 (予約)      |         | 1   0   (予約)                                    |      |     |               |                           |
| 1 1 (予            | 約)         | 1       | 1 (予約)      |         | 1                                               | 1 (  | 予約  | 约)            | 1 1 (予約)                  |
| CS71°L            | ス(制御/状態レ   | ベン・スタ)  |             |         |                                                 |      |     |               |                           |
|                   | 0 STATUSA  | 0 1 0 0 | (予約) (A     | SI)     | 1 0                                             | 0    | 0   | ASI_RESET_R   | EQ 1 1 0 0 ASI_CRC_STATUS |
| 0 0 0             | 1 STATUSB  | 0 1 0 1 |             |         | 1 0                                             |      | -   | ASI_CTRLA     | 1 1 0 1 (予約)              |
|                   | O CTRLA    | 0 1 1 0 |             | · ·     | $\begin{array}{c c} 1 & 0 \\ 1 & 0 \end{array}$ | +    | 0   | ASI_SYS_CTR   |                           |
| 0 0 1             | 1 CTRLB    | 0 1 1 1 | ASI_KEY_    |         |                                                 | -    | 1   | ASI_SYS_STA   |                           |
| 0 0 1             | TOTALD     |         | 1, 101-1101 | 5171105 | 1 0                                             | 1    | 1   | 7101_010_0171 |                           |

#### 33.3.3.1. LDS - 直接アドレス指定を使うデータ空間からのデータ取得

LDS命令は直列読み出しのためにシステム バスからPHY層移動レジスタ内へデータを取得するのに使われます。LDS命令は直接アドレス指定に基き、アドレスはデータ転送を開始するために命令の引数として与えられなければなりません。アドレスとデータに対して支援される最大の大きさは32ビットです。LDS命令はREPERT命令と組み合わせた時に繰り返しメモリ アクセスを支援します。

LDS命令発行後、A量領域によって示されるような望むアトレス バイト数、続いてD量領域によって選ばれる出力データの大きさが送信さればければなりません。出力データは指定された保護時間(GT)後に発行されます。REPERT命令と組み合わせると、繰り返しの反復毎にアトレスが送られなければならず、毎回の出力データ採取後に行われることを意味します。LDSでのREPERT使用時、直接アトレス指定の規約を使うため、自動アトレス進行はありません。



命令が復号され、復号された命令によって指示されるようにアドレス バイが受信されると、DL層は要求された全情報をACC層に同期し、これはバス要求を処理してバスから緩衝されたデータを再びDL層に戻して同期します。これはUPDIからのデータ受信で考慮されなければならない同期化遅延を引き起こします。

## 33.3.3.2. STS - 直接アドレス指定を使うデータ空間へのデータ格納

STS命令はPHY層へ直列に移動されたデータをシステム バス アドレス空間へ格納するのに使われます。STS命令は直接アドレス指定に基づき、アドレスはデータ転送を開始するための命令に対する被演算子として与えられなければなりません。アドレスは被演算子の最初の組でデータが次の組です。アドレスとデータの被演算子の大きさは下図で提示される大きさ(量)領域で与えられます。アドレスとデータの両方の最大の大きさは32ビットです。

STS命令はREPERT命令と組み合わせた時に繰り返しメモリ アクセスを支援します。



STS命令に関する転送規約は上図で描かれ、以下のこの手順に従ってください。

- 1. アドレスを送られます。
- 2. 転送が成功した場合にUPDIから応答(ACK)が送り返されます。
- 3. STS命令で指定されるバイ数が送られます。
- 4. データが成功裏に送信されてしまった後に応答(ACK)が受信されます。

#### 33.3.3.3. LD - 間接アドレス指定を使うデータ空間からのデータ取得

LD命令は直列読み出しのためにデータ空間からPHY層移動レジスタ内へデータを取得するのに使われます。LD命令は間接アトレス指定に基き、UPDIのアトレスポークタがデータ空間読み込みアクセスに先立って書かれる必要があることを意味します。自動ポーインタ事後増加動作が支援され、LD命令がREPERT命令と共に使われる時に有用です。それはUPDIポーインタレジスタからLDを行うことも可能です。アトレスとデータの取得に対して支援される最大の大きさは32ビットです。



上図は保護時間区間後にデータが受信される代表的なLD手順の例を示します。UPDIポインタレジスタからのデータ取得は同じ転送処理規約に従います。

データ空間からのLD命令に対し、ポインタレジスタはST命令を使うことによってUPDIポインタレジスタを設定しなければなりません。ポインタレジスタ書き込み成功でACKが受信された後、LD命令は望むデータ量被演算子で設定しなければなりません。UPDIポインタレジスタに対する取得はLD命令で直接行われます。

## 33.3.3.4. ST - 間接アドレス指定を使うデータ空間へのデータ格納

ST命令はUPDI PHY移動レジスタからのデータをデータ空間へ格納するのに使われます。ST命令はPHY層へ直列に移動されるデータを格納するのに使われます。ST命令は間接アトレス指定に基き、UPDIのアトレスポークタがデータ空間に先立って書かれる必要があることを意味します。自動ポークタ事後増加動作が支援され、ST命令がREPERT命令と共に使われる時に有用です。ST命令はポークタレジスタにUPDIアトレスポークタを格納するのにも使われます。アトレスとデータを格納することに対して支援される最大の大きさは32ビットです。



上図はUPDIポインタレジスタへのST命令と通常のデータの格納の例を与えます。各命令の前に同期(SYNCH)文字が送られます。両方の場合でST命令が成功した場合にUPDIによって応答(ACK)が送り返されます。

UPDIポインタレジスタを書くには、以下の手順に従わなければなりません。

- 1. ST命令内のPTR種別領域を識別符'10'に設定してください。
- 2. アドレス量(A量)領域を望むアドレス量(長)に設定してください。
- 3. ST命令発行後、A量のバイト数のアドレス データを送ってください。
- 4. アトレスレジスタへの書き込み成功を意味するACK文字を待ってください。

アトレスレジスタが書かれた後、データ送出が同様に行われます。

- 1. UPDIポインタ レジスタによって指定されるアドレスに書くために、ST命令内のPTR種別領域を定義'00'に設定してください。PTR種別領域が'01'に設定されるなら、PUDIポインタは書き込みが実行された後で命令のデータ量(D量)領域に従って次のアドレスへ自動的に更新されます。
- 2. 命令内のデータ量(D量)領域を望むデータ量(長)に設定してください。
- 3. ST命令送出後、D量のバイト数のデータを送ってください。
- 4. バス配列への書き込み成功を意味するACK文字を待ってください。

REPERT命令と共に使われる時は、アト・レスレシ、スタを書かれるべき塊の開始アト・レスで設定して、各繰り返し周回に対してアト・レスを自動的に増加するためにホペインタ事後増加レシ、スタを使うことが推奨されます。REPERT命令使用時、各ACK受信後にデータ量(D量)ハ、イトのデータフレームを送ることができます。

#### 33.3.3.5. LDCS - 制御/状態レジスタ空間からのデータ取得

LDCS命令はDL層に置かれたUPDI制御/状態(CS)レジスタ空間からの直列読み出しデータをPHY層移動レジスタに取得するのに使われます。LDCS命令はアトレスが命令被演算子の一部である直接アトレス指定に基づきます。LDCS命令はUPDI CSレジスタ空間だけをアクセスすることができます。この命令はバイトアクセスだけを支援し、データ量(長)は構成設定不可です。



上図はLDCSデータ送信の代表的な例を示します。CS空間からのデータ バイトは保護時間が完了した後にUPDIから送信されます。

#### 33.3.3.6. STCS - 制御/状態レジスタ空間へのデータ格納

STCS命令はUPDI制御/状態(CS)レシ、スタ空間へデータを格納するのに使われます。データはPHY層移動レシ、スタに直列で移動され、選んだCSレシ、スタに完全なハ、イトとして書かれます。STCS命令はアト・レスが命令被演算子の一部である直接アト・レス指定に基づきます。STCS命令は内部UPDIレシ、スタ空間だけをアクセスすることができます。この命令はハ、イトアクセスだけを支援し、データ量(長)は構成設定不可です。



上図はSYNCH文字と命令フレーム後に送信されるデータフレームを示します。STCS命令は直ちにデータ バイトを続けることができます。CS 空間からのデータ バイトは保護時間が完了した後にUPDIから送信されます。STとSTSと同様に、STCS命令から生成される応答はありません。

## 33.3.3.7. REPEAT - 命令繰り返し計数器設定

REPEAT命令はDL層でUPDI繰り返し計数器レジスタに繰り返し計数値を格納するのに使われます。命令がREPEATと共に使われると、REPEATが発行された後の最初の命令を除いて全ての命令でSYNCHと命令のフレームに対する規約付随作業を省略することができます。REPEATはメモリ命令(LD,ST,LDS,STS)に対して最も有用で、REPEAT命令自身を除き、全ての命令を繰り返すことができます。

データ量(D量)被演算子領域は繰り返し値の大きさを示します。256までの繰り返しだけが支援されます。REPEAT命令直後に設定される命令はRPT\_0(の値)+1回発行されます。繰り返し計数器レジスタが'0'の場合、命令は1度だけ動きます。進行中の繰り返しはBRE AK文字を送ることによってのみ中止することができます。



上図はポインタ事後増加操作を用いるST命令での繰り返し操作の例を与えます。REPEAT命令がRPT\_0=nで送られた後、最初のST命令はSYNCHと命令のフレームで発行される一方で、次からのn回のST命令はST被演算子のデータ量に従ってデータ バイルだけを送って応答(ACK)ハント・シェーク規約を維持することによって実行されます。



LDに対して、データはLD命令後、継続的に出て来ます。最初のデータ塊での保護時間に注意してください。

間接アトンス指定(LD/ST)命令を使う場合、REPEATと組み合わされる時は常にポインタ事後増加任意選択を使うことが推奨されます。 LD/ST命令は最初の(データ量によって決められるデータ ハイト数の)データ塊の前にだけ必要です。さもなければ、繰り返される全てのアクセス操作で同じアトンスがアクセスされます。直接アトンス指定(LDS/STS)命令については、データが受け取られ(LDS)または送られ(STS)得るのに先立って、命令規約で指定されるようにアトンスが常に送信されなければなりません。

#### 33.3.3.8. KEY - 活性化鍵設定またはシステム情報部送出

KEY命令はデバイスで保護された機能を実行するために開くUPDIへの鍵(KEY)が小通信、またはシステム情報部(SIB:System Informati on Block)を書き込み器に提供するのに使われます。鍵(KEY)によって有効にされる機能の概要ついて表33-4.をご覧ください。KEY命令に対しては64ビット鍵(KEY)の大きさだけが支援されます。SIBに対して支援される最大量は128ビットです。



上図は鍵(KEY)の送信とSIBの受信を示します。両方の場合で、被演算子のK量領域は送受信されるフレーム数を決めます。UPDIへの鍵(KEY)送出後に応答(ACK)は有りません。SIB要求時、現在の保護時間設定に従ってデータがUPDIから送信されます。

## 33.3.4. ブート間でのフラッシュ メモリのCRC検査

いくかのデバイスはブート処理の一部としてフラッシュ メモリ内容のCRC検査走行を支援します。この検査は例えデバイスが施錠されていても実行することができます。このCRC検査の結果はASI CRC状態(ASI\_CRC\_STATUS)レジスタで読むことができます。この機能のより多くの情報については「CRCSCAN」章を参照してください。

#### 33.3.5. UPDIでのシステム クロック測定

入力捕獲機能を持つTCBへ接続されたUPDI事象を利用することにより、システム クロック周波数の正確な測定を得るのにUPDIを使うことが可能です。この機能のための推奨される構成の流れは以下の手順によって与えられます。

- ・計時器動作(CNTMODE)='011'(計数捕獲周波数測定動作)設定でTCB制御B(TCBn.CTRLB)レジスタを構成設定してください。
- ・事象割り込みを許可するためにTCB事象制御(TCBn.EVCTRL)レジスタで捕獲事象入力許可(CAPTEI)='1'を書いてください。TC Bn.EVCTRLレジスタの事象端選択(EDGE)='0'を保ってください。
- ・UPDI SYNCH事象(生成部)をTCB(使用部)に配線するように事象システムを構成設定してください。
- ・UPDI事象を生成するのに使われる同期(SYNCH)文字については、各UPDI事象間で計時器によって捕獲される値でのもっと正確な測定を得るために10~50kbpsの範囲の低いボーレートを使うことが推奨されます。1つの特別な事は、捕獲が割り込みを起動するように構成設定される場合、最初の捕獲値が無視されるべきことです。入力事象に基づいて次に捕獲された値が測定に使われるべきです。計時器に対して200μsの捕獲窓を与える10kbpsのUPDI同期(SYNCH)文字を使う例については下図をご覧ください。
- ・TCB比較/捕獲(TCBn.CCMP)レシブスタを読むことによって同期(SYNCH)文字直後の捕獲値を読み出すことが可能で、また、値は一旦捕獲が行われると、CPUによってメモリに書くこともできます。



## 33.3.6. バ 仆間遅延

複数バイト転送(REPEATと組み合わせたLD)実行またはシステム情報部(SIB)読み出し時、出力データは継続的な流れで出て来ます。応用に依存して、受信側ではデータが早過ぎで送り出されるかもしれず、次の開始ビット到着の前に処理されるべきデータに対して充分な時間がないかもしれません。

バイト間遅延は複数バイト転送間に固定数のアイドルビットを挿入することによって動きます。バイト間遅延を追加する理由は全てのデータが同じ方向で進んでいる時に挿入される保護時間がないからです。

バイト間遅延機能は制御A(UPDI.CTRLA)レンブスタのバイト間遅延許可(IBDLY)ビットに'1'を書くことによって許可することができます。結果として、デバッカーに対して採取時間を緩和するために各バイト間で2つの余分なアイデルビットが挿入されます。



- 注: 1. △GTは保護時間挿入を表します。
  - **2.** SBは停止ビット用です。
  - 3. IBは挿入されたバイト間遅延です。
  - 4. フレームの残りは命令とデータです。

#### 33.3.7. システム情報部

システム情報部(SIB:System Information Block)は「33.3.3.8. KEY - 活性化 鍵設定またはシステム情報部送出」からKEY命令に従ってSIBビットを設定(1) することによって何時でも読み出すことができます。SIBは施錠ビット設定に 関わらず、常にデ゙バッガのためにアクセス可能で、デ゙バイスとデ゙バッガ用のシステム 要素についての情報提供の簡潔な形式を提供します。この情報はデ゙バイス との正しい通信チャネルを認識して準備することに於いて重要です。SIBの出 力はASCII符号として解釈されます。K量領域は完全なSIBを読み出す時 に16バイトに設定されなければならず、8バイトの大きさは系統IDだけを読み 出すのに使うことができます。SIB形式記述とどのデータが異なる読み出し量 で利用可能かについては右図をご覧ください。

| 図33-20. システム情報部形式 |       |       |      |           |  |  |  |  |
|-------------------|-------|-------|------|-----------|--|--|--|--|
| K量(               | (バイト) | バイト   | ピット  | 領域名       |  |  |  |  |
| 16                | 8     | 717   | L 7F |           |  |  |  |  |
| 0                 | 0     | 6~0   | 55~0 | 系統ID      |  |  |  |  |
| $\circ$           | 0     | 7     | 7~0  | (予約)      |  |  |  |  |
| $\circ$           | X     | 10~8  | 23~0 | NVM版番号    |  |  |  |  |
| $\circ$           | X     | 13~11 | 23~0 | OCD版番号    |  |  |  |  |
| $\circ$           | ×     | 14    | 7~0  | (予約)      |  |  |  |  |
|                   | ×     | 15    | 7~0  | デバッグ発振周波数 |  |  |  |  |

## 33.3.8. 鍵保護されたインターフェースの許可

いくつかの内部インターフェースと機能へのアクセスはUPDI鍵機構によって保護されます。鍵を認証するには、「33.3.3.8. KEY - 活性化鍵設定またはシステム情報部送出」で記述されるように、KEY命令を用いることによって正しい鍵データが送信されなければなりません。下表は利用可能な鍵と鍵有効で操作を行う時に必要とされる条件を記述します。

## 表33-4. 鍵認証概要

| 鍵名             | 説明                     | 動作の必要条件                                                              | リセット                    |
|----------------|------------------------|----------------------------------------------------------------------|-------------------------|
| チップ消去          | NVMチップ消去開始。<br>施錠ビット解除 | なし                                                                   | UPDI禁止/UPDIリセット         |
| NVMPROG        | NVMプログラミング活性           | 施錠ビット解除。ASIシステム状態(ASI_SYS_STATUS)レシブスタのNVMプログラミング開始(NVMPROG)を設定(1)。  | プログラミング終了/<br>UPDIJセット  |
| 2 47 11 11 7 7 | 施錠されたデバイスで<br>使用者列書き込み | 施錠ビット設定。ASIシステム状態(ASI_SYS_STATUS)レジスタの使用者列プログラミング開始(UROWPROG)を設定(1)。 | 鍵状態ビット書き込み/<br>UPDIリセット |

右表はインターフェースを活性にするために移動入力されなければならない利用可能な鍵符号の概要を与えます。

| 主つつ に           |       |
|-----------------|-------|
| <b>衣又ひひ</b> つり. | 鍵認証符号 |

| 农60 0. 疑心脏的方 |                     |        |  |  |  |
|--------------|---------------------|--------|--|--|--|
| 鍵名           | 鍵符号(LSB先行で書かれています。) | 大きさ    |  |  |  |
| チップ消去        | \$4E564D4572617365  |        |  |  |  |
| NVMPROG      | \$4E564D50726F6720  | 64Ľ*ット |  |  |  |
| 使用者列書き込み     | \$4E564D5573267465  |        |  |  |  |

#### 33.3.8.1. チップ 消去

チップ消去を発行するには次の手順に従わなければなりません。

- 1. KEY命令を使うことによってチップ消去鍵を入力してください。チップ消去符号については「鍵認証符号」表をご覧ください。
- 2. KEY命令を使うことによってNVMプログラミング鍵を入力してください。NVMPROG識票については「鍵認証符号」表を御覧ください。これは新たに消去されたデバイスを(有効にされている場合の)CRC失敗から守ります。
- 3. チップ。消去鍵状態(CHIPERASE)ビットとNVMプ。ログラミング。鍵状態(NVMPROG)ビットの両方が設定(1)されているのを確認するために ASI鍵状態(UPDI.ASI\_KEY\_STATUS)レジスタを読んでください。
- **4.** ASIリセット要求(UPDI.ASI\_RESET\_REQ)レジスタのリセット要求(RESREQ)ピット領域に識票を書いてください。 これはシステム リセットを発行します。
- 5. システム リセットを解除するためにUPDI/ASI\_RESET\_REQレジスタに\$00を書いてください。
- 6. ASIシステム状態(UPDI.ASI\_SYS\_STATUS)レシブスタのNVM施錠状態(LOCKSTATUS)ビットを読んでください。
- 7. チップ消去はUPDI.ASI\_SYS\_STATUSレジスタのLOCKSTATUSビットが'0'の時に終わります。LOCKSTATUSビットが'1'なら、手順5. に戻ってください。

チップ消去成功後、施錠ビットが解除され、UPDIはシステムに対して完全なアクセス(権)を持ちます。施錠ビットが解除されるまで、UPDIはシステム バスをアクセスすることができず、制御/状態(CS)空間操作だけを実行することができます。

△注音

チップ消去中、BODは制御A(BOD.CTRLA)レシ、スタの活動/アイトル時動作(ACTIVE)ヒ、ット領域に書くことによってONを強制され、BOD構成設定(FUSE.BODCFG)ヒュース、のBOD基準(LVL)ヒ、ット領域と制御B(BOD.CTRLB)レシ、スタのBOD基準(LVL)ヒ、ット領域を使います。供給電圧(VDD)がその関値基準未満の場合、デバイスはVDDが充分に増されるまで使用不能です。より多くの詳細については「BOD - 低電圧検出器」章をご覧ください。

#### 33.3.8.2. NVMプログラミング

デバイスが解錠されているなら、UPDIを用いてNVM制御器またはフラッシュ メモリに直接書くことが可能です。これはNVMプログラミング中にCPUが活性の場合に予測不能なコード実行になるでしょう。これを避けるため、以下のNVMプログラミング手順が実行されなければなりません。

- 1. 「33.3.8.1. チップ消去」で記述されるようにチップ消去手順に従ってください。デバイスが既に解錠されているなら、この点(1.)を飛ば すことができます。
- 2. KEY命令を使うことによってNVMPROG鍵を入力してください。NVMPROG符号については表33-5.をご覧ください。
- 3. 任意選択: 鍵が認証されたかを知るためにASI鍵状態(UPDI.ASI\_KEY\_STATUS)レジスタのNVMプログラミング鍵状態(NVMPROG)ビットを読んでください。
- 4. ASIリセット要求(UPDI.ASI\_RESET\_REQ)レジスタのリセット要求(RESREQ)ビット領域に識票を書いてください。 これはシステム リセットを発行します。
- 5. システム リセットを解除するためにUPDI.ASI\_RESET\_REQレシ、スタに\$00を書いてください。
- 6. ASIシステム状態(UPDI.ASI SYS STATUS)レシブスタのNVMプログラミング開始(NVMPROG)と、小を読んでください。
- 7. NVMプログラミングはNVMPROGが'1'の時に開始することができます。NVMPROGが'0'なら、手順6.に戻ってください。
- 8. UPDIを通してNVMにデータを書いてください。
- 9. UPDI.ASI RESET REQレシ、スタのRESREQビット領域に識票を書いてください。これはシステム リセットを発行します。
- 10. システム リセットを解除するためにUPDI.ASI\_RESET\_REQレシブスタに\$00を書いてください。
- 11. プログラミングは完了です。

#### 33.3.8.3. 使用者列プログラミング

使用者列プログラミング機能は施錠されたデバイスで使用者列(USERROW)に新しい値を書くことを許します。許可されたこの機能で書き込むには、以下の手順に従わなければなりません。

- 1. KEY命令を使うことによって**表33-5**.で示される使用者列書き込み(UROWWRITE)鍵を入力してください。UROWWRITE符号については**表33-5**.をご覧ください。
- 2. 任意選択: 鍵が認証されたかを知るためにASI鍵状態(UPDI.ASI\_KEY\_STATUS)レジスタの使用者列書き込み鍵状態(UROWWRIT E)ビットを読んでください。
- 3. ASIJセット要求(UPDI.ASI\_RESET\_REQ)レシ、スタのリセット要求(RESREQ)ヒ、ット領域に識票を書いてください。 これはシステム リセットを発行します。
- 4. システム リセットを解除するためにUPDI.ASI\_RESET\_REQレジスタに\$00を書いてください。
- 5. ASIシステム状態(UPDI.ASI\_SYS\_STATUS)レシブスタの使用者列プログラミング開始(UROWPROG)ビットを読んでください。
- 6. 使用者列プログラミングはUROWPROGが'1'の時に開始することができます。UROWPROGが'0'なら、手順5.に戻ってください。
- 7. 使用者列に書かれるデータは最初にRAM内の緩衝部に書かれなければなりません。RAMの書き込み可能な領域は64小小で、SRAMの最初の64小小のアドレスにだけ使用者列データを書くことが可能です。このメモリ範囲外のアドレス指定は実行されない書き込みに終わります。書き込み手順の完了でデータが使用者列データに複写される時に、このデータが使用者列空間と1対1で割り当てられます。
- 8. 全ての使用者列データがSRAMに書かれると、ASIシステム制御A(UPDI.ASI\_SYS\_CTRLA)レシブスタの使用者列書き込み終了(URO WWRITE\_FINAL)ヒットに('1'を)書いてください。
- 9. UPDI.ASI SYS STATUSレシ、スタのUROWPROGビットを読んでください。
- 10. 使用者列プログラミングはUROWPROGが'0'の時に完了されます。UROWPROGが'1'なら、手順9.に戻ってください。
- 11. ASI鍵状態(UPDI.ASI\_KEY\_STATUS)レシブスタの使用者列書き込み鍵状態(UROWWRITE)ビットを書いてください。
- **12**. ASIJセット要求(UPDI.ASI\_RESET\_REQ)レジスタのリセット要求(RESREQ)ビット領域に識票を書いてください。 これはシステム リセットを発行します。
- 13. システム リセットを解除するためにUPDI.ASI\_RESET\_REQレシ、スタに\$00を書いてください。
- 14. 使用者列プログラミングは完了です。
- この動作形態でSRAMからデータを読み戻すことはできません。SRAMの最初の64バイトへの書き込みだけが許されます。

#### 33.3.9. 事象

UPDIは以下の事象を生成することができます。

# 表33-6. UPDIでの事象生成部 生成部名 説明 事象型 生成クロック領域 事象長 UPDI SYNCH 同期(SYNC)文字 レヘ・ル CLK\_UPDI CLK\_UPDIに同期した UPDIにシン入力でのSYNC文字

この事象はSYNCH文字で検出される各正端に対してUPDIクロックで設定され、UPDIからこの事象を禁止することはできません。 UPDIに事象使用部はありません。

事象型と事象システム構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照してください。

#### 33.3.10. 休止形態動作

UPDI PHY層は全ての休止動作と無関係に動き、UPDIはデバイスの休止状態と無関係に接続したデバッカ に対して常にアクセス可能です。システムがシステム クロックをOFFにする休止動作へ入る場合、UPDIはシステム バスのアクセス及びメモリと周辺機能の読み込みができません。許可されると、UPDIはUPDIが常にデバイスの残りとの接触を持つようにシステム クロックを要求します。従って、UPDI PHY層クロックは休止動作の設定によって影響を及ぼされません。ASIシステム状態(UPDI.ASI\_SYS\_STATUS)レジスタのシステム領域休止中(INSLEEP)ビットを読むことにより、システム領域が休止動作かを監視することが可能です。

ASIシステム制御A(UPDI.ASI\_SYS\_CTRLA)レシ、スタのシステム クロック要求(CLKREQ)ヒ、ットを書くことにより、休止動作へ行く時に停止すること からシステム クロックを守ることが可能です。このヒ、ットが設定(1)される場合、システム休止動作状態が模倣され、例え最も深い休止動作でも、UPDIはシステム ハ、スをアクセスして周辺機能レジ、スタを読むことができます。

CLKREQビットはUPDIが許可される時に既定で'1'で、これは既定操作が休止動作中にシステム クロックをON状態に保つことを意味します。

# 33.4. レジスタ要約

| 変位                  | 略称             | ビット位置        | ビット7  | ピット6  | ピット5      | ピット4    | ピット3      | ピット2     | ピット1                | ピット0       |
|---------------------|----------------|--------------|-------|-------|-----------|---------|-----------|----------|---------------------|------------|
| +\$00               | STATUSA        | 7~0          |       | UPDIR | EV3~0     |         |           |          |                     |            |
| +\$01               | STATUSB        | 7 <b>~</b> 0 |       |       |           |         |           |          | PESIG2~0            |            |
| +\$02               | CTRLA          | 7 <b>~</b> 0 | IBDLY |       | PARD      | DTD     | RSD       |          | GTVAL2~0            |            |
| +\$03               | CTRLB          | 7 <b>~</b> 0 |       |       |           | NACKDIS | CCDETDIS  | UPDIDIS  |                     |            |
| +\$04<br>~<br>+\$06 | 予約             |              |       |       |           |         |           |          |                     |            |
| +\$07               | ASI_KEY_STATUS | 7~0          |       |       | UROWWRITE | NVMPROG | CHIPERASE |          |                     |            |
| +\$08               | ASI_RESET_REQ  | 7~0          |       |       |           | RSTRI   | EQ7~0     |          |                     |            |
| +\$09               | ASI_CTRLA      | 7~0          |       |       |           |         |           |          | UPDICL              | KSEL1,0    |
| +\$0A               | ASI_SYS_CTRLA  | 7~0          |       |       |           |         |           |          | UROWWRITE<br>_FINAL | CLKREQ     |
| +\$0B               | ASI_SYS_STATUS | 7~0          |       |       | RSTSYS    | INSLEEP | NVMPROG   | UROWPROG |                     | LOCKSTATUS |
| +\$0C               | ASI_CRC_STATUS | 7 <b>~</b> 0 |       |       |           |         |           | CF       | C_STATUS2           | ~0         |

#### 33.5. レジスタ説明

これらのレジスタは特別な命令でUPDIを通してだけ読み込み可能で、CPUを通して読み込み可能ではありません。

#### **33.5.1. STATUSA -** 状態A (Status A)

名称: STATUSA 変位: +\$00 リセット: \$10 特質:-

| ヒ゛ット   | 7 | 6     | 5     | 4 | 3 | 2 | 1 | 0 |
|--------|---|-------|-------|---|---|---|---|---|
|        |   | UPDIR | EV3~0 |   |   |   |   |   |
| アクセス種別 | R | R     | R     | R | R | R | R | R |
| リセット値  | 0 | 0     | 0     | 1 | 0 | 0 | 0 | 0 |

#### ● ビット7~4 - UPDIREV3~0: UPDI改訂 (UPDI Revision)

このビット領域は現在のUPDI実装の改訂(番号)を含みます。

#### **33.5.2. STATUSB - 状態B** (Status B)

名称 : STATUSB 変位 : +\$01 リセット : \$00 特質 : -

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1        | 0 |
|--------|---|---|---|---|---|---|----------|---|
|        |   |   |   |   |   |   | PESIG2~0 |   |
| アクセス種別 | R | R | R | R | R | R | R        | R |
| リセット値  | ^ | 0 | 0 | 0 | 0 | 0 | 0        | 0 |

#### ● ビット2~0 - PESIG2~0: UPDI異常識票 (UPDI Error Signature)

このビット領域はUPDI異常識票を記述し、内部UPDI異常状態発生時に設定されます。PESIGビット領域はデバッガからの読み込みで解消されます。

表33-7. 有効な異常識票

| PESIG2~0 | 異常形式          | 異常説明                              |
|----------|---------------|-----------------------------------|
| 0 0 0    | 異常なし          | 検出された異常なし(既定)                     |
| 0 0 1    | パリティ誤り        | パリティビットの不正な採取                     |
| 0 1 0    | フレーム異常        | 停止ビットの不正な採取                       |
| 0 1 1    | アクセス層制限時間超過異常 | UPDIはアクセス層からデータや応答を得られないことが有り得ます。 |
| 100      | クロック再生異常      | 開始ビットの不正な採取                       |
| 101      | -             | (予約)                              |
| 1 1 0    | バス異常          | アドンス異常またはアクセス優先権異常                |
| 111      | 競合異常          | UPDIピンでの駆動競合を示します。                |

#### **33.5.3. CTRLA - 制御A** (Contorl A)

名称: CTRLA 変位: +\$02 リセット: \$00 特質: -

| ピット    | 7     | 6 | 5    | 4   | 3   | 2   | 1        | 0   |
|--------|-------|---|------|-----|-----|-----|----------|-----|
|        | IBDLY |   | PARD | DTD | RSD |     | GTVAL2~0 |     |
| アクセス種別 | R/W   | R | R/W  | R/W | R/W | R/W | R/W      | R/W |
| リセット値  | 0     | 0 | 0    | 0   | 0   | 0   | 0        | 0   |

#### ● ビット7 - IBDLY: バイト間遅延許可 (Inter-Byte Delay Enable)

このビットへの'1'書き込みが複数バイトLD(S)命令を行う時にUPDIから送信される各データ バイト間に固定長のバイト間遅延を許可します。固定長は2つのアイドル ビットです。

#### ビット5 - PARD: パリティ禁止 (Parity Disable)

このビットに'1'を書くことがパリティビットを無視することによってUPDIでのパリティ検出を禁止します。この機能は試験中にだけ使うことが推奨されます。

#### ● ビット4 - DTD: 制限時間検出禁止 (Disable Time-Out Detection)

このビットに'1'を書くことがPHY層での制限時間検出を禁止し、これは指定された時間(65536 UPDIクロック周期)内にACC層からの応答を要求します。

#### ● ビット3 - RSD: 応答符号禁止 (Response Signature Disable)

このビットに'1'を書くことがUPDIによって生成されるどの応答符号も禁止します。これはNVM空間に大きな塊のデータを書く時に規約の付随処理を最小に減らします。システム バスをアクセスする時にUPDIは遅れを経験するかもしれません。遅れが予測可能な場合、応答符号を禁止することができ、さもなければデータの消失が起こるかもしれません。

#### ● ビット2~0 - GTVAL2~0: 保護時間値 (Guard Time Value)

このビット領域は転送方向が受信から送信に切り替わる時にUPDIによって使われる保護時間値を選びます。

| 値                 | 0 0 0   | 0 0 1 | 0 1 0 | 0 1 1 | 100 | 101 | 1 1 0 | 111  |
|-------------------|---------|-------|-------|-------|-----|-----|-------|------|
| 説明(保護時間:追加ビット周期数) | 128(既定) | 64    | 32    | 16    | 8   | 4   | 2     | (予約) |

#### **33.5.4. CTRLB - 制御B** (Contorl B)

名称: CTRLB 変位:+\$03 リセット: \$00 特質:-

| ピット    | 7 | 6 | 5 | 4       | 3        | 2       | 1 | 0 |
|--------|---|---|---|---------|----------|---------|---|---|
|        |   |   |   | NACKDIS | CCDETDIS | UPDIDIS |   |   |
| アクセス種別 | R | R | R | R/W     | R/W      | R/W     | R | R |
| リセット値  | 0 | 0 | 0 | 0       | 0        | 0       | 0 | 0 |

#### ● ビット4 - NACKDIS: NACK応答禁止 (Disable NACK Response)

このビットに'1'を書くことがLD(S)またはST(S)操作進行中にシステム リセットが発行される時にUPDIによって送られるNACK符号を禁止します。

#### ● ビット3 - CCDETDIS: 衝突/競合検出禁止 (Collision and Contention Detection Disable)

このビットに'1'を書くことが競合検出を禁止します。このビットへ'0'を書くことが競合検出を許可します。

#### ● ビット2 - UPDIDIS: UPDI禁止 (UPDI Disable)

このビットに'1'を書くことがUPDI PHYインターフェースを禁止します。UPDIからのクロック要求は下げられ、UPDIはリセットされます。UPDIが禁止されると、全てのUPDI PHY層構成設定と鍵がリセットされます。

#### 33.5.5. ASI\_KEY\_STATUS - ASI鍵状態 (ASI Key Status)

名称: ASI\_KEY\_STATUS

変位:+\$07 リセット:\$00 特質:-

| ピット    | 7 | 6 | 5         | 4       | 3         | 2 | 1 | 0 |
|--------|---|---|-----------|---------|-----------|---|---|---|
|        |   |   | UROWWRITE | NVMPROG | CHIPERASE |   |   |   |
| アクセス種別 | R | R | R/W       | R       | R         | R | R | R |
| リセット値  | 0 | 0 | 0         | 0       | 0         | 0 | 0 | 0 |

#### ● ビット5 - UROWWRITE : 使用者列書き込み鍵状態 (User Row Write Key Status)

このビットは使用者列書き込み(UROWWRITE)鍵が成功裏に復号された場合に'1'に設定されます。このビットはプログラミング作業を正しくリセットするために使用者列書き込み手順の最後の部分として書かれなければなりません。

#### ● ビット4 - NVMPROG: NVMプログラミング鍵状態(NVM Programming Key Status)

このビットはNVMPROG鍵が成功裏に復号された場合に'1'に設定されます。このビットはNVMプログラミング手順が開始される時に解除 (0)され、ASIシステム状態(ASLSYS\_STATUS)レジスタのNVMプログラミング開始(NVMPROG)ビットが設定(1)されます。

#### ● ビット3 - CHIPERASE: チップ消去鍵状態 (Chip Erase Key Status)

このビットはチップ消去(CHIPERASE)鍵が成功裏に復号された場合に'1'に設定されます。このビットは「33.3.8.1. チップ消去」項で記述されるチップ消去手順の一部として発行されるリセット要求によって解除(0)されます。

#### 33.5.6. ASI\_RESET\_REQ - ASIリセット要求 (ASI Reset Request)

名称: ASI RESET REQ

変位:+\$08 リセット:\$00 特質:-

このアドレスにリセット識票を書く時にシステムへリセットが合図されます。

| <u> </u> | 7         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |
|----------|-----------|-----|-----|-----|-----|-----|-----|-----|--|--|--|
|          | RSTREQ7~0 |     |     |     |     |     |     |     |  |  |  |
| アクセス種別   | R/W       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |  |  |  |
| リセット値    |           | 0   | 0   | 0   | 0   | 0   | 0   | 0   |  |  |  |

#### ● ビット7~0 - RSTREQ7~0: リセット要求 (Reset Request)

UPDIはこのレシ、スタからシステムリセットを発行する時にリセットされません。

| 値  | \$00     | \$59   | その他            |
|----|----------|--------|----------------|
| 名称 | RUN      | RESET  | -              |
| 説明 | リセット条件解除 | 標準リセット | リセット条件が解除されます。 |

#### 33.5.7. ASI\_CTRLA - ASI制御A (ASI Control A)

名称: ASI\_CTRLA

変位:+\$09 リセット:\$03 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0       |
|--------|---|---|---|---|---|---|--------|---------|
|        |   |   |   |   |   |   | UPDICL | KSEL1,0 |
| アクセス種別 | R | R | R | R | R | R | R/W    | R/W     |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 1      | 1       |

#### ● ビット1,0 - UPDICLKSEL1,0: UPDIクロック選択 (UPDI Clock Select)

これらのビット書き込みはUPDIクロック出力周波数を選びます。リセット後の既定設定は4MHzで許可されます。他の何れかのクロック出力選択はBODが最高レベルの時にだけ推奨されます。他の全てのBOD設定に対しては、既定の4MHz選択が推奨されます。

| 値  | 0 0  | 0 1            | 1 0           | 11                 |
|----|------|----------------|---------------|--------------------|
| 説明 | (予約) | 16MHz UPDIクロック | 8MHz UPDIクロック | 4MHz UPDIクロック (既定) |

#### 33.5.8. ASI\_SYS\_CTRLA - ASIシステム制御A (ASI System Control A)

名称: ASI\_SYS\_CTRLA

変位:+\$0A リセット:\$00 特質:-

| ピット    | 7 | 6 | 5 | 4 | 3 | 2 | 1                   | 0      |
|--------|---|---|---|---|---|---|---------------------|--------|
|        |   |   |   |   |   |   | UROWWRITE<br>_FINAL | CLKREQ |
| アクセス種別 | R | R | R | R | R | R | R/W                 | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0                   | 0      |

#### ● ビット1 - UROWWRITE\_FINAL: 使用者列書き込み終了 (User Row Programming Done)

このビットは使用者列データがSRAMに書かれてしまった時に書かれなければなりません。このビットへの'1'書き込みはフラッシュ メモリへの使用者列データ書き込みの処理を開始します。

UPDIによって使用者列データがSRAMに書かれる前にこのビットが('1'を)書かれた場合、CPUは書かれるデータなしで進行します。このビットは使用者列書き込み鍵が成功裏に復号された場合にだけ書き込み可能です。

#### ビット0 - CLKREQ:システム クロック要求 (Request System Clock)

このビットが゚1゚を書かれた場合、ASIはシステムの休止動作と無関係にシステム クロックを要求します。これはUPDIに対してシステムが休止動作の場合でもアクセス(ACC)層をアクセスすることを可能にします。

このビットへの'0'書き込みはクロック要求を降ろします。

このビットはUPDIが禁止される時にリセットされます。

このビットはUPDIがどの動作形態(ヒューーズまたは12V)で許可された時でも既定によって設定(1)されます。

#### 33.5.9. ASI\_SYS\_STATUS - ASIシステム状態 (ASI System Status)

名称: ASI SYS STATUS

変位:+\$0B リセット:\$01 特質:-

| ピット _  | 7 | 6 5 4 3 2 |        | 4 3 2   |         | 4 3 2    |   | 3 2        |  | 3 2 |  | 3 2 |  | 0 |
|--------|---|-----------|--------|---------|---------|----------|---|------------|--|-----|--|-----|--|---|
|        |   |           | RSTSYS | INSLEEP | NVMPROG | UROWPROG |   | LOCKSTATUS |  |     |  |     |  |   |
| アクセス種別 | R | R         | R      | R       | R       | R        | R | R          |  |     |  |     |  |   |
| リセット値  | 0 | 0         | 0      | 0       | 0       | 0        | 0 | 1          |  |     |  |     |  |   |

#### • ビット5 - RSTSYS : システム リセット活性 (System Reset Active)

このビットが'1'に設定されると、システム領域で有効なリセットがあります。このビットが'0'に設定されると、システムはリセット状態ではありません。

このビットは読み込みで'0'に設定されます。

ASIJセット要求(UPDI.ASI\_RESET\_REQ)レジンスタで保持されるリセットもこのビットに影響を及ぼします。

#### ● ビット4 - INSLEEP: システム領域休止中 (System Domain in Sleep)

このビットが'1'に設定されると、システム領域はアイドルまたはより深い休止動作です。このビットが'0'に設定されると、システムはどの休止動作でもありません。

#### ● ビット3 - NVMPROG: NVMプログラミング開始 (Start NVM Programming)

このビットが'1'に設定されると、UPDIからNVMプログラミングを開始することができます。

UPDIが終了される時にシステムはUPDIリセット要求(ASI\_RESET\_REQ)レシ、スタを通してリセットされなければなりません。

#### ● ビット2 - UROWPROG: 使用者列プログラミング開始 (Start User Row Programming)

このビットが、1、に設定されると、UPDIから使用者列プログラミングを開始することができます。

使用者列データがRAMに書かれてしまうと、ASIシステム制御A(UPDI.ASI\_SYS\_CTRLA)レジスタの使用者列書き込み終了(UROWWRITE\_FINAL)ヒットは('1'を)書かなければなりません。

#### ● ビット0 - LOCKSTATUS: NVM施錠状態(NVM Lock Status)

このビットが'1'に設定されると、デバイスは施錠されています。チップ消去が行われて施錠ビットが'0'に設定された場合、このビットは'0'として読みます。

#### 33.5.10. ASI\_CRC\_STATUS - ASI CRC状態 (ASI CRC Status)

名称: ASI CRC STATUS

変位:+\$0C リセット:\$00 特質:-

| ビット    | 7 | 6 | 5 | 4 | 3 | 2 | 1          | 0  |
|--------|---|---|---|---|---|---|------------|----|
|        |   |   |   |   |   |   | RC_STATUS2 | ~0 |
| アクセス種別 | R | R | R | R | R | R | R          | R  |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0          | 0  |

#### ● ビット2~0 - CRC STATUS2~0: CRC実行状況 (CRC Execution Status)

このビット領域はCRC換算の状態を示します。このビット領域は(どれか1つのビットだけが'1'の)単一ビット活性符号化されます。

| 値  | 0 0 0 | 0 0 1    | 0 1 0             | 1 0 0                 | その他  |
|----|-------|----------|-------------------|-----------------------|------|
| 説明 | 不許可   | CRC許可、多忙 | CRC許可、成功(OK)符号で終了 | CRC許可、失敗(FAILED)符号で終了 | (予約) |

# 34. 命令一式要約

命令一式要約はwww/microchip.com/DS40002198に置かれた「AVR命令一式手引書」の一部として見つけることができます。この データシートで文書化されたデバイスに関する詳細についてはAVRxtと呼ばれるCPU版を参照してください。

# 35. 規定

# 35.1. 数字表記法

#### 表35-1. 数字表記法

| シンホ゛ル  | 説明                                                                  |
|--------|---------------------------------------------------------------------|
| 165    | 10進数値                                                               |
| 0b0101 | 2進数値 ( <mark>訳注</mark> :本書ではCコード例内以外では不使用)                          |
| '0101' | 明白な場合に接頭辞で与えられる2進数値 ( <mark>訳注</mark> :本書では基本的に赤文字で表現)              |
| 0x3B24 | 16進数値(訳注:本書ではCコート・例内以外では不使用、代わりに\$接頭辞で「\$3B24」形式で表記)                |
| Х      | 未知またはどうでもよい値を表す。                                                    |
| Z      | 信号またはバスのどちらかに対して高インピーダンス(浮き)状態を表す。( <mark>訳注</mark> :本書では「Hi-Z」と表記) |

#### 35.2. メモリの大きさと形式

#### 表35-2 メモリの大きさとビット速度

| シンホ゛ル   | 説明                                                                         |
|---------|----------------------------------------------------------------------------|
| Kバイト    | キロ バイト (2 <sup>10</sup> =1024バイト)                                          |
| Mバイト    | メガ゛ハ゛イト(2 <sup>20</sup> =1024Kハ゛イト)                                        |
| Gバイト    | ギガ バイト (2 <sup>30</sup> =1024Mバイト)                                         |
| b       | ビット (2進数値の' <mark>0</mark> 'または'1') ( <mark>訳注</mark> :本書では不使用、直接「ビット」と表記) |
| В       | バイト (8ビット) ( <mark>訳注</mark> :本書では不使用、直接「バイト」と表記)                          |
| 1kビット/s | 1,000ビット/s速度 (1,024ビット/sではない)                                              |
| 1Mビット/s | 1,000,000ビット/s速度                                                           |
| 1Gビット/s | 1,000,000,000ピット/s速度                                                       |
| word    | 16ビット ( <mark>訳注</mark> :本書では「語」と表記)                                       |

## 35.3. 周波数と時間

#### 表35-3. 周波数と時間

| シンホ゛ル | 説明                                      |
|-------|-----------------------------------------|
| kHz   | 1kHz=10 <sup>3</sup> Hz=1,000Hz         |
| MHz   | 1MHz=10 <sup>6</sup> Hz=1,000,000Hz     |
| GHz   | 1GHz=10 <sup>9</sup> Hz=1,000,000,000Hz |
| ms    | 1ms=10 <sup>-3</sup> s=0.001秒           |
| μs    | 1µs=10 <sup>-6</sup> s=0.000001秒        |
| ns    | 1ns=10 <sup>-9</sup> s=0.000000001秒     |

#### 35.4. レジスタとビット

| 表35-4. レジスタとじ | ットの簡略記法                                                                                                                                             |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| シンホ゛ル         | 説明                                                                                                                                                  |
| R/W           | 読み書きアクセス可能なレジスタ ビット。このビットに対して読み書きすることができます。                                                                                                         |
| R             | 読み込み専用アクセス可能なレジスタ ビット。このビットを読むことだけできます。書き込みは無視されます。                                                                                                 |
| W             | 書き込み専用アクセス可能なレジスタ ビット。このビットを書くことだけできます。このビットの読み込みは未定義の値を返します。                                                                                       |
| ピット領域         | ビット名は大文字で支援されます(例:INTMODE)。                                                                                                                         |
| ビット領域[n:m]    | ビットn~m(n>m)のビットの組。 ( <mark>訳注</mark> :本書では不使用、「FIELDn~m」形式で表記)<br>( <b>例</b> :PINA[3:0] <mark>(</mark> 不使用)=PINA3~0(本書表記)={PINA3,PINA2,PINA1,PINA0} |
| 予約            | 予約されたビット、ビット領域、ビット領域値は使われず、将来に使うために予約されます。将来のデバイスとの互換性のため、そのレジスタが書かれ時に予約ビットに常に'0'を書いてください。予約ビットは読む時に常に'0'を返します。                                     |
| 周辺機能n         | 少数の周辺機能の実体が存在する場合、周辺機能名は1つの実体を識別するために単一番号によって後続されます。例:USARTnはUSART単位部の全実体の集合で、一方でUSART3はUSART単位部の1つの特定実体を指定します。                                     |
| 周辺機能x         | 少数の周辺機能の実体が存在する場合、周辺機能名は1つの実体を識別するために単一大文字(A~Z)によって後続されます。例:PORTxはPORT単位部の全実体の集合で、一方でPORTBはOIRT単位部の1つの特定実体を指定します。                                   |
| リセット          | 電源ONリセット後のレシ、スタの値。これはデバック・制御レシ、スタを除き、周辺機能のソフトウェアリセットを実行した後の周辺機能のレシ、スタの値でもあります。                                                                      |
|               | SET/CLR/TGL接尾辞を持つレジスタは「読み-変更-書き」操作を行うことなく、レジスタ内のビットの設定(1)と解除(0)を使用者に許します。各SET/CLR/TGLレジスタはそれが影響を及ぼすレジスタと対にされます。レジスタ対の両レジスタは読む時に同じ値を返します。            |
| SET/CLR/TGL   | 例: PORT周辺機能に於いて、OUTとOUTSETのレジスタがこのようなレジスタ対を形成します。OUTの内容は<br>OUTSETへの書き込みによって変更されます。OUTとOUTSETの読み込みは同じ値を返します。                                        |
|               | CLRレシ、スタ内のビットへの'1'書き込みは両レシ、スタで対応するビットを解除(0)します。                                                                                                     |
|               | SETレジスタ内のビットへの'1'書き込みは両レジスタで対応するビットを設定(1)します。                                                                                                       |
|               | TGLレジスタ内のビットへの'1'書き込みは両レジスタで対応するビットを反転します。                                                                                                          |

#### 35.4.1. ヘッダ ファイルからのレジスタ アクセス

供給したCへッダブァイルでレジスタをアドレス指定するには以下の規則が適用されます。

- 1. レジスタはく周辺機能実体名>、<レジスタ名>、例えば、CPU.SREG、USART2.CTRLA、PORTB.DIRによって識別されます。
- 2. 周辺機能名は「周辺機能と基本構造」章の「周辺機能単位部アトンス配置」で与えられます。
- 3. 〈周辺機能実体名〉は周辺機能名の何れかのnまたはxを正しい実体識別子で置き換えることによって得られます。
- 4. 周辺機能レジスタに予め定義された値を割り当てる時に、その値は次のような規則に従って構築されます。 〈周辺機能名〉、〈ビット領域名〉、〈ビット領域値〉。gc

〈周辺機能名〉は〈周辺機能実体名〉ですが、どの実体識別子も取り去られます。

<ビット領域値>は周辺機能レジスタのビット領域を記述する「レジスタ説明」章内の表の「名称」列で見つけることができます。

#### 例35-1. レジスタ割り当て

// EVSYSチャネル0はTCB3のOVF事象によって駆動されます。

EVSYS. CHANNELO = EVSYS\_CHANNELO\_TCB3\_OVF\_gc;

// USART0のRXMODEは2倍速伝送を使います。

USARTO. CTRLB = USART\_RXMODE\_CLK2X\_gc;

注: 違う動作形態に於いて異なるレシブスター式を持つ周辺機能に対して、〈周辺機能実体名〉と〈周辺機能名〉は動作形態名が後続されなければならず、例えば以下です。

// 標準(SINGLE)動作のTCA0は周波数動作で波形生成器を使います。

TCAO. SINGLE. CTRL=TCA\_SINGLE\_WGMODE\_FRQ\_gc;

#### 35.5. ADCパラーメータ定義

理想nビットシングルェント、A/D変換はGNDとVREF間を $2^n$ 段階(LSB)で電圧を直線的に変換します。最低値符号は、 $10^2$ として読まれ、最高値符号は $10^2$ として読まれます。 $10^2$ といくつかの項目は理想的な動きからの偏差を記述します。

変位(オフセット)誤差

理想遷移点(差0.5 LSB)と比べた最初の遷移(\$000から\$001)の偏差です。理想値:0 LSB



利得誤差

変位(オフセット)誤差補正後、利得誤差は理想遷移(最大1.5 LSB以下)と比べた最後の遷移(例えば、10ビットADCについては\$3FEから\$3FF)の偏差として見出されます。理想値:0 LSB



積分非直線性誤差 (INL)

変位(オフセット)誤差と利得誤差の補正後、INLは何れかの符号に対する理想遷移と比べた実際の遷移の最大偏差です。

理想值: 0 LSB



微分非直線性誤差 (DNL)

理想符号幅(1 LSB)から実際の符号幅(隣接する2つの遷移間の間隔)の最大偏差です。理想値:0 LSB



量子化誤差

有限数の符号への入力電圧の量子化のため、入力電圧範囲(1 LSB幅)は同じ値に符号化します。常に ±0.5 LSB

絶対精度

何れかの符号に対して理想遷移点と比べた(非補正の)実際の遷移の最大偏差です。これは全ての前述の誤差の複合作用です。理想値:±0.5 LSB

#### 36. 電気的特性

#### 36.1. お断り

代表値は別に指定がなければ、T=25℃とVDD=3Vで測定されます。全ての最小と最大の値は別に指定がなければ、動作温度と動作電圧に渡って有効です。

#### 36.2. 絶対最大定格

本項で一覧にされるこれらを超える負荷はデバイスに定常的な損傷を引き起こすかもしれません。これは負荷定格だけで、本仕様の動作部分で示されるこれらを超える他の条件やそれらでのデバイスの機能的な動作は含まれません。長時間絶対最大定格状態に晒すことはデバイスの信頼性に影響を及ぼすかもしれません。

表36-1. 絶対最大定格

| シンホ゛ル            | 説明                     | 条件                                                         | 最小   | 最大      | 単位                     |
|------------------|------------------------|------------------------------------------------------------|------|---------|------------------------|
| VDD              | 電源電圧                   |                                                            | -0.5 | 6       | V                      |
| Ivon             | VDDピンへの電流              | T=-40~85°C                                                 |      | 200     |                        |
| IVDD             | VDDC 7、V07电侧           | T=85~125°C                                                 |      | 100     | mA                     |
| Ionib            | GNDピンの電流出力             | T=-40~85°C                                                 |      | 200     | ША                     |
| IGND             | GNDCグの电弧山力             | T=85~125℃                                                  |      | 100     |                        |
| Vrst             | GNDに対するRESETピン電圧       |                                                            | -0.5 | 13      | V                      |
| VPIN             | GNDに対するピン電圧            |                                                            | -0.5 | VDD+0.5 | V                      |
| IPIN             | 入出力ピン吸い込み/吐き出し電流       |                                                            | -40  | 40      |                        |
| Ic1 ( <b>注</b> ) | RESETt°ンを除く入出力t°ン注入電流  | Vpin < GND-0.6Vまたは<br>5.5V < Vpin ≤ 6.1V、4.9V < VDD ≤ 5.5V | -1   | 1       | mA                     |
| Ic2 ( <b>注</b> ) | RESETt°ンを除く入出力t°ン注入電流  | Vpin < GND-0.6VまたはVpin ≦5.5V<br>VDD ≦4.9V                  | -15  | 15      | шд                     |
| Ictot            | RESETt°ンを除く入出力t°ン総注入電流 |                                                            | -45  | 45      |                        |
| Tstorage         | 保存温度                   |                                                            | -65  | 150     | $^{\circ}\!\mathbb{C}$ |

- 注: VpinがGND-0.6Vよりも低い場合、電流制限抵抗が必要とされます。負DC注入電流制限抵抗はR=(GND-0.6V-Vpin)/Icnとして計算されます。
  - VpinがVDD+0.6Vよりも高い場合、電流制限抵抗が必要とされます。正DC注入電流制限抵抗はR=(Vpin-(VDD+0.6V))/Icn として計算されます。

#### △注意

#### V<sub>RST</sub>MAX=13V

RESETt°ンを12V供給元に接続する時に行き過ぎ(過電圧)を避けるために注意が払われるべきです。t°ンを絶対最大定格を超える電圧に晒すことはt°ンのESD保護回路を活性にし得て、それは電圧が概ね10V以下に持ってこられるまで活性に留まります。12V駆動部は(過電圧状態によって活動にされているなら、)活動状態でESD保護を保ち、同時にそれを通して電流を駆動し、潜在的にデバイスへ恒久的な損傷を引き起こし得ます。

#### 36.3. 全般動作定格

デバイスは有効であるべきデバイスの他の全ての電気的特性と代表特性のために、本項で一覧にされる定格内で動作しなければなりません。

#### 表36-2. 全般動作条件

| シンホ゛ル | 説明   | 条件         | 最小                | 最大  | 単位 |
|-------|------|------------|-------------------|-----|----|
| VDD   | 電源電圧 |            | 1.8 ( <b>注2</b> ) | 5.5 | V  |
| Т     |      | 標準温度範囲     | -40               | 105 | %  |
| 1     |      | 拡張温度範囲(注3) | -40               | 125 | C  |

注1: デバイス温度範囲についてはデバイス注文符号を参照してください。

注2: 動作は1.8VまたはBOD起動基準(VBOD)まで保証されます。VBODはいくつかのデバイスについて最低動作供給電圧以下かもしれません。この場合、デバイスは製造中にVDD=VBODに下げて検査されます。

- チップ。消去の間にBODはONを強制されます。VDD供給電圧が構成設定したVBOD以下の場合、チップ。消去は失敗します。「チップ。消去」をご覧ください。

注3: 拡張温度範囲は最小2.7Vが保証されるだけです。

#### 表36-3. 動作電圧と周波数

| シンホ゛ル   | 説明            | 条件                                    | 最小 | 最大 | 単位  |
|---------|---------------|---------------------------------------|----|----|-----|
|         |               | VDD=1.8~5.5V,T=-40~105℃ ( <b>注1</b> ) | 0  | 5  |     |
|         |               | VDD=2.7~5.5V,T=-40~105℃ ( <b>注2</b> ) | 0  | 10 |     |
| CLK_CPU | 動作システムクロック周波数 | VDD=4.5~5.5V,T=-40~105℃ ( <b>注3</b> ) | 0  | 20 | MHz |
|         |               | VDD=2.7~5.5V,T=-40~125℃ ( <b>注2</b> ) | 0  | 8  |     |
|         |               | VDD=4.5~5.5V,T=-40~125℃ ( <b>注3</b> ) | 0  | 16 |     |

**注1**: BODLEVEL0のVBODでの最小BOD起動レヘールで保証される動作 **注2**: BODLEVEL2のVBODでの最小BOD起動レヘールで保証される動作 **注3**: BODLEVEL7のVBODでの最小BOD起動レヘールで保証される動作

最高動作周波数はVDDに依存します。次図で示されるように、最高周波数対VDDは1.8<VDD<2.7Vと2.7<VDD<4.5V間で直線です。





#### 36.4. 消費電力

値は特記される場所を除き、以下の条件下で測定された消費電力です。

- VDD=3V
- T=25°C
- ・別の指定を除き、システム クロック元としてOSC20Mを使用
- ・禁止された周辺機能、I/O駆動無しで測定されたシステム消費電力

#### 表36-4. 活性とアイドルの動作での消費電力

| 動作   | 説明         | 条件                               |        | 最小 | 代表   | 最大      | 単位   |
|------|------------|----------------------------------|--------|----|------|---------|------|
|      |            | CLK_CPU=20MHz (OSC20M)           | VDD=5V | -  | 10.0 | -       |      |
|      |            | CLK_CPU=10MHz                    | VDD=5V | -  | 5.3  | -       |      |
|      |            | (2分周OSC20M)                      | VDD=3V | 1  | 3.0  | _       | mA   |
|      |            |                                  | VDD=5V | 1  | 3.0  | _       | IIIA |
| 活動   | 活動動作消費電力   | CLK_CPU=5MHz (4分周OSC20M)         | VDD=3V | 1  | 1.7  | _       |      |
|      |            |                                  | VDD=2V | 1  | 1.1  | _       |      |
|      |            | CLV CDU-90 7001 II               | VDD=5V | -  | 19.2 | _       |      |
|      |            | CLK_CPU=32.768kHz<br>(OSCULP32K) | VDD=3V | -  | 10.9 | -       | μA   |
|      |            | (OSCOLI SZIV)                    | VDD=2V | -  | 7.4  | _       |      |
|      |            | CLK_CPU=20MHz (OSC20M)           | VDD=5V | 1  | 2.9  | 6.3 (注) |      |
|      |            | CLK_CPU=10MHz                    | VDD=5V | 1  | 1.5  | 3.1 (注) |      |
|      |            | (2分周OSC20M)                      | VDD=3V | -  | 0.85 | 1.9 (注) | mA   |
|      |            |                                  | VDD=5V | -  | 0.75 | 1.6 (注) | IIIA |
| アイドル | アイドル動作消費電力 | CLK_CPU=5MHz (4分周OSC20M)         | VDD=3V | 1  | 0.4  | 1.2     |      |
|      |            |                                  | VDD=2V | -  | 0.3  | _       |      |
|      |            | CLV CDU 90 700 U                 | VDD=5V | -  | 5.7  | 20 (注)  | μА   |
|      |            | CLK_CPU=32.768kHz<br>(OSCULP32K) | VDD=3V | -  | 2.9  | 15 (注)  |      |
|      |            | (OSCOLI SZIV)                    | VDD=2V | -  | 1.9  | -       |      |

**注**: これらの値は特性付けに基づき、製造限度検査によって含まれません。

| 表36-5 パワーダウン           | スタンバイとリセット動作での消費電力             |
|------------------------|--------------------------------|
| - 4230 J. M. J. 3 772. | ・ヘノノハ 1( )! ハニハート し リノル 日 日 ノー |

|   | 動作               | 説明                                     | 条件                                       |        | 代表<br>(25℃) | 最大<br>(25℃) | 最大<br>(85℃)( <u>注</u> ) | 最大<br>(125℃) | 単位 |
|---|------------------|----------------------------------------|------------------------------------------|--------|-------------|-------------|-------------------------|--------------|----|
| 7 | スタンバイ            | スタンバイ動作消費電力                            | 外部XOSC32Kからの1.024<br>kHzでRTC走行(CL=7.5pF) | VDD=3V | 0.69        | -           | -                       | 1            |    |
|   | <i>X92/</i> 1/4  | スタンハ 1 動作 相 貨 竜 刀                      | 内部OSCULP32Kからの<br>1.024kHzでRTC走行         | VDD=3V | 0.71        | 3.0         | 6.0                     | 8.0          |    |
|   | ハリーダリン<br>/フタンバイ | 全ての周辺機能が停止される時のパワーダウンとスタンバイの消費電力は同じです。 |                                          | VDD=3V | 0.1         | 2.0         | 5.0                     | 7.0          | μА |
|   | リセット             | リセット消費電力                               | リセット線プルダウン                               | VDD=3V | 100         | -           | -                       | -            |    |

注: これらの値は特性付けに基づき、製造限度検査によって含まれません。

#### 36.5. 起き上がり時間

休止動作からの起き上がり時間は起き上がり信号の(有効)端から最初に実行される命令までが測定されます。 動作条件:

- VDD=3V
- T=25℃
- ・別の指定を除き、システム クロック元としてOSC20Mを使用

#### 表36-6. OSC20Mからの始動、リセット、起き上がりの時間

| シンホ゛ル   | 説明                           | 条件                   | 最小 | 代表  | 最大 | 単位 |
|---------|------------------------------|----------------------|----|-----|----|----|
|         | 何れのリセット開放からの始動時間             |                      | _  | 200 | -  |    |
|         |                              | OSC20M: 20MHz,VDD=5V | -  | 1   | 1  |    |
| twakeup | アパル休止動作から起き上がり時間             | OSC20M: 10MHz,VDD=3V | 1  | 2   | 1  | μs |
|         |                              | OSC20M: 5MHz,VDD=2V  | 1  | 4   | 1  |    |
|         | スタンハブイとハプワーダウンの休止動作から起き上がり時間 |                      | -  | 10  | _  |    |

#### 36.6. 周辺機能消費電力

下表は様々な動作形態で各種入出力周辺機能に対して追加消費電流を計算するのに使うことができます。 動作条件:

- VDD=3V
- T=25℃
- ・別の指定を除き、システム クロック元としてOSC20Mを1MHzで使用
- ・別の指定を除き、アイデル休止動作に於いて

#### 表36-7. 周辺機能消費電力

| 衣30 <sup>-</sup> /. 同型機能消貨電力      |                              |        |    |  |  |  |  |
|-----------------------------------|------------------------------|--------|----|--|--|--|--|
| 周辺機能                              | 条件                           | 代表(注1) | 単位 |  |  |  |  |
| BOD - 低電圧検出器                      | 継続動作                         | 19     |    |  |  |  |  |
| DOD KELL快山奋                       | 1kHzでの採取動作                   | 1      |    |  |  |  |  |
| TCA - タイマ/カウンタA型                  | 1MHzでの16ビット計数                | 13     |    |  |  |  |  |
| TCB - タイマ/カウンタB型                  | 1MHzでの16ビット計数                | 7.5    |    |  |  |  |  |
| RTC - 実時間計数器                      | OSCULP32Kの32.768kHzでの16ビット計数 | 1      |    |  |  |  |  |
| WDT - ウォッチト・ック・タイマ (OSCULP32Kを含む) |                              | 1      |    |  |  |  |  |
| OSC20M - 内部16/20MHz RC発振器         |                              | 125    |    |  |  |  |  |
| AC - アナログ比較器                      | 高速動作 ( <mark>注2</mark> )     | 92     |    |  |  |  |  |
| AC - / / L/ CLEX 备                | 低電力動作(注2)                    | 45     | μA |  |  |  |  |
| ADC - A/D変換器                      | 50ksps                       | 325    |    |  |  |  |  |
| ADC = A/D发换的                      | 100ksps                      | 340    |    |  |  |  |  |
| XOSC32K - 外部32.768kHzクリスタル用発振器    | CL=7.5pF                     | 0.5    |    |  |  |  |  |
| OSCULP32K - 内部32kHz超低電力発振器        |                              | 0.5    |    |  |  |  |  |
| USART - 万能同期非同期送受信器               | 9600bpsで許可                   | 13     |    |  |  |  |  |
| SPI - 直列周辺インターフェース (主装置)          | 100kHzで許可                    | 2      |    |  |  |  |  |
| TWI - 2線インターフェース (主装置)            | 100kHzで許可                    | 24     |    |  |  |  |  |
| TWI - 2線インターフェース (従装置)            | 100kHzで許可                    | 17     |    |  |  |  |  |
| フラッシュ メモリ プログラミング                 | 消去動作                         | 1.5    | A  |  |  |  |  |
| フノッシュ アモッ ノ ロケ ノミング               | 書き込み動作                       | 3.0    | mA |  |  |  |  |

注1: 単位部の消費電流のみです。システムの総消費電力を計算するには、この値を「消費電力」で一覧にされるような基礎消費電力 に加えてください。

注2: スタンバイ休止動作でのCPU。

#### 36.7. BODとPORの特性

#### 表36-8. 電源特性

| シンホ゛ル | 説明     | 条件 | 最小 | 代表 | 最大  | 単位   |
|-------|--------|----|----|----|-----|------|
| SRON  | 電源ON傾斜 |    | -  | -  | 100 | V/ms |

#### 表36-9. 電源ONリセット(POR)特性

| シンホ゛ル | 説明             | 条件             | 最小  | 代表 | 最大  | 単位 |
|-------|----------------|----------------|-----|----|-----|----|
|       | VDD下降でのPOR閾値電圧 | 0.5V/msまたはより遅い | 0.8 | -  | 1.6 | V  |
| Vpor  | VDD上昇でのPOR閾値電圧 | VDD下降/上昇       | 1.4 | 1  | 1.8 | V  |

| 来26-10   | 低電圧検出( | (BUD)(特性 |
|----------|--------|----------|
| 衣 ひひ しし. | 以用、圧恢山 | ロロロノイサーエ |

| シンホ゛ル  | 説明               | 条件              | 最小  | 代表  | 最大  | 単位   |
|--------|------------------|-----------------|-----|-----|-----|------|
|        |                  | BODLEVEL7       | 3.9 | 4.2 | 4.5 |      |
| VBOD   | BOD起動基準(下降/上昇)   | BODLEVEL2       | 2.4 | 2.6 | 2.9 | V    |
|        |                  | BODLEVEL0       | 1.7 | 1.8 | 2.0 |      |
|        |                  | BOD.VLMLVL='00' | -   | 4   | 1   |      |
| VVLM   | BOD起動基準に対するVLM閾値 | BOD.VLMLVL='01' | -   | 13  | -   | %    |
|        |                  | BOD.VLMLVL='10' | -   | 25  | -   |      |
|        |                  | BODLEVEL7       | -   | 80  | -   |      |
| VHYS   | ヒステリシス           | BODLEVEL2       | -   | 40  | 1   | mV   |
|        |                  | BODLEVEL0       | _   | 25  | -   |      |
|        |                  | 継続動作            | -   | 7   | -   | μs   |
| TBOD   | 検出時間             | 1kHzでの採取動作      | -   | 1   | -   | to a |
|        |                  | 125kHzでの採取動作    | _   | 8   | -   | ms   |
| TStart | 始動時間             | 許可から準備可までの時間    | _   | 40  | _   | μs   |

#### 36.8. 外部リセット特性

#### 表36-11. 外部リヤット特性

| シンホ゛ル    | 説明             | 条件                     | 最小               | 代表 | 最大               | 単位 |
|----------|----------------|------------------------|------------------|----|------------------|----|
| VHVRST   | 確実な高電圧リセット検出   |                        | 11.5             | -  | 12.5             |    |
| Vrst_vih | RESET用High入力電圧 |                        | $0.8 \times VDD$ | -  | VDD+0.2          | V  |
| Vrst_vil | RESET用Low入力電圧  |                        | -0.2             | -  | $0.2 \times VDD$ |    |
| trst     | RESETt°ン最小パルス幅 |                        | 2.5              | -  | -                | μs |
| Rrst     | RESETプルアップ、抵抗  | V <sub>Reset</sub> =0V | 20               | -  | 60               | kΩ |

#### 36.9. 発振器とクロック

動作条件:

・別の指定を除き、VDD=3V

#### 表36-12. 20MHz内部発振器(OSC20M)特性

| シンホ゛ル           | 説明             |                              | 条件                                                  |      | 代表  | 最大   | 単位  |
|-----------------|----------------|------------------------------|-----------------------------------------------------|------|-----|------|-----|
|                 | 工場格納周波数値に対す    | VDD=3V工場校正後(注1)              | $T=0\sim70^{\circ}C,VDD=1.8\sim4.5V($ <b>注3</b> $)$ | -2.0 | _   | 2.0  |     |
| $f_{ m OSC20M}$ | る16/20MHz選択時精度 | VDD=5V工場校正後( <b>注1</b> )     | $T=0\sim70^{\circ}C,VDD=4.5\sim5.5V($ <b>注3</b> )   | -2.0 | _   | 2.0  |     |
|                 |                |                              | T=25°C,VDD=3.0V                                     | -3.0 | -   | 3.0  | %   |
|                 | 16/20MHz選択時精度  | 工場校正後                        | $T=0\sim70^{\circ}C,VDD=1.8\sim3.6V($ <b>注3</b> $)$ | -4.0 | _   | 4.0  |     |
|                 |                |                              | 全動作範囲(注3)                                           | -5.0 | _   | 5.0  |     |
| $f_{ m CAL}$    | 使用者校正範囲        | OSC20M ( <b>注2</b> ) = 16MHz |                                                     | 14.6 | _   | 17.5 | MII |
| JCAL            | 使用有仪正軋囲        | OSC20M ( <b>注2</b> ) = 20MHz |                                                     | 18.5 | -   | 21.5 | MHz |
| %CAL            | 校正段階量          |                              |                                                     |      | 1.5 | -    | %   |
| DC              | デューティ サイクル     |                              |                                                     | _    | 50  | _    | 70  |
| TStart          | 始動時間           | 2%精度内                        |                                                     | _    | 8   | ı    | μs  |

注1: 校正でのOSC20Mの説明をご覧ください。

注2: 速度仕様を超える発振器周波数はCPUクロックが常に仕様内であるように分周されなければなりません。

注3: これらの値は特性付けに基づき、製造検査限度によって含まれません。

# 表36-13. 32.768kHz内部発振器(OSCULP32K)特性

| シンホ゛ル      | 説明         |       | 条件                                    | 最小  | 代表  | 最大 | 単位 |
|------------|------------|-------|---------------------------------------|-----|-----|----|----|
|            |            |       | T=25°C,VDD=3.0V                       | -3  | 1   | 3  |    |
| fosculp32K | 精度         | 工場校正後 | $T=0\sim70$ °C, $VDD=1.8\sim3.6V$ (注) | -10 | 1   | 10 | %  |
|            |            |       | 全動作範囲(注)                              | -30 | 1   | 30 | 70 |
| DC         | デューティ サイクル |       |                                       | _   | 50  | _  |    |
| TStart     | 始動時間       |       |                                       | -   | 250 | _  | μs |

注: これらの値は特性付けに基づき、製造検査限度によって含まれません。

#### 表36-14. 32.768kHz外部発振器(XOSC32K)特性

| シンホ゛ル              | 説明        | 条件                     | 最小  | 代表     | 最大   | 単位   |
|--------------------|-----------|------------------------|-----|--------|------|------|
| Fout               | 周波数       |                        | -   | 32.768 | 1    | kHz  |
| T <sub>Start</sub> | 始動時間      | CL=7.5pF               | 1   | 300    | 1    | ms   |
| CL                 | クリスタル負荷容量 |                        | 7.5 | 1      | 12.5 |      |
| CTOSC1             | 宏比宏昌台古    |                        | 1   | 5.5    | -    | рF   |
| CTOSC2             | 寄生容量負荷    |                        | -   | 5.5    | 1    |      |
| ESR                | 等価直列抵抗    | CL=7.5pF               | -   | _      | 80   | kΩ   |
| Lon                | (安全係数=3)  | C <sub>L</sub> =12.5pF | -   | _      | 40   | K 22 |



#### 表36-15. 外部クロック特性

|   | シンホ゛ル | 説明            | VDD=1.8∼5.5V |    | VDD=2.7∼5.5V |    | VDD=4.5∼5.5V |    | 単位  |
|---|-------|---------------|--------------|----|--------------|----|--------------|----|-----|
|   | ノノハル  | 5元 <b>ツ</b> カ | 最小           | 最大 | 最小           | 最大 | 最小           | 最大 | 単位  |
| f | CLCL  | クロック周波数       | 0            | 5  | 0            | 10 | 0            | 20 | MHz |
| t | CLCL  | クロック周期        | 200          |    | 100          |    | 50           |    |     |
| t | CHCX  | Highレヘール時間    | 80           |    | 40           |    | 20           |    | ns  |
| t | CLCX  | Lowレヘブル時間     | 80           |    | 40           |    | 20           |    |     |

#### 36.10. 入出力ピン特性

表36-16. 入出力ピン特性 (別に特記無き場合、T=-40~105℃、VDD=1.8~5.5V)

| シンホ゛ル                            | 説明                                  | 条件                 | 最小               | 代表     | 最大               | 単位     |  |
|----------------------------------|-------------------------------------|--------------------|------------------|--------|------------------|--------|--|
| VIL                              | Lowレヘブル入力電圧(RESETt°ンを除く)            |                    | -0.2             | _      | $0.3 \times VDD$ |        |  |
| V <sub>I</sub> L <sub>2</sub>    | Lowレヘール入力電圧(RESETt°ン)               |                    | -0.2             | -      | $0.3 \times VDD$ |        |  |
| VIH                              | Highレヘブル入力電圧(RESET ピンを除く)           |                    | $0.7 \times VDD$ | -      | VDD+0.2          |        |  |
| V <sub>IH2</sub>                 | Highレヘブル入力電圧(RESET ピン)              |                    | $0.7 \times VDD$ | -      | VDD+0.2          |        |  |
|                                  | Lレヘブル出力電圧                           | VDD=1.8V,IOL=1.5mA | -                | -      | 0.36             |        |  |
| Vol                              | Lレヘル田万竜圧<br> (I/OとしてのRESETt°ンを除く)   | VDD=3V,IOL=7.5mA   | -                | -      | 0.6              |        |  |
|                                  | (I/OCO (VARLOLIEV EM()              | VDD=5V,IOL=15mA    | -                | -      | 1                |        |  |
|                                  | Hレヘブル出力電圧                           | VDD=1.8V,IOH=1.5mA | 1.44             | -      | -                | V      |  |
| Vон                              | 「I/OとしてのRESETt°ンを除く)                | VDD=3V,IOH=7.5mA   | 2.4              | -      | -                | V      |  |
|                                  | (i) OCO CONTENDE LEO ENNO           | VDD=5V,IOH=15mA    | 4                | -      | -                |        |  |
|                                  | <br>  Lレヘブル出力電圧                     | VDD=1.8V,IOL=0.1mA | -                | -      | 0.36             |        |  |
| Vol2                             | 「I/OとしてのRESETt°ン)                   | VDD=3V,IOL=0.25mA  | -                | -      | 0.6              |        |  |
|                                  | (I) OCO CONLIGHTON                  | VDD=5V,IOL=0.5mA   | _                | -      | 1                |        |  |
|                                  | Hレヘ・ル出力電圧<br>(I/OとしてのRESETt°ン)      | VDD=1.8V,IOH=0.1mA | 1.44             | -      | -                |        |  |
| Voh2                             |                                     | VDD=3V,IOH=0.25mA  | 2.4              | -      | -                |        |  |
|                                  |                                     | VDD=5V,IOH=0.5mA   | 4                | -      | -                |        |  |
| I <sub>IH</sub> /I <sub>IL</sub> | I/Oビン入力漏れ電流                         | VDD=5.5V,High入力    | -                | < 0.05 | -                | μA     |  |
| III/IIL                          | (I/OとしてのRESETt°ンを除く)                | VDD=5.5V,Low入力     | -                | < 0.05 | -                | μΛ     |  |
| I <sub>total</sub>               | ピン群毎の最大結合吸い込み電流( <mark>注1</mark> )  |                    | -                | -      | 100              | mΑ     |  |
| Hotal                            | ピン群毎の最大結合吐き出し電流 ( <mark>注1</mark> ) |                    | -                | _      | 100              | 111/-1 |  |
| ${ m t_{RISE}}$                  | <br> 上昇時間                           | VDD=3V,負荷=20pF     | -                | 2.5    | -                |        |  |
| CRISE                            | 147 N IN                            | VDD=5V,負荷=20pF     | -                | 1.5    | -                | ns     |  |
| tfall                            | 下降時間                                | VDD=3V,負荷=20pF     | -                | 2.0    | -                | 113    |  |
| TALL                             |                                     | VDD=5V,負荷=20pF     | -                | 1.3    | -                |        |  |
|                                  | TOSCとTWIピンを除くI/Oピン容量                |                    | -                | 3      | -                |        |  |
| CPIN                             | TOSCピン容量                            |                    | -                | 5.5    | -                | pF     |  |
|                                  | TWIピン容量                             |                    | -                | 10     | -                |        |  |
| Rp                               | プルアップ抵抗                             |                    | 20               | 35     | 50               | kΩ     |  |

注1: ピン群x(Px7~0)。全ての入出力ポートに対して結合した連続的な吸い込み/吐き出しの電流はこの限度を超えるべきではありません。

#### 36.11. TCD

#### 動作条件:

・ 最大CLK\_TCD\_SYNCを超えるCLK\_TCDは、同期部クロックがそれらの仕様に合うように、同期前置分周器(TCDn.CTRLAのSYNC PRES)で前置分周されなければなりません。

| 表36-17. | タイマ/: | カウンタD型最大周波数 |
|---------|-------|-------------|
|---------|-------|-------------|

| シンホ゛ル           | 説明                | 条            | 最大           | 単位 |     |
|-----------------|-------------------|--------------|--------------|----|-----|
|                 |                   | VDD=1.8∼5.5V | TA=-40~125°C | 8  |     |
| for k mon gynio | CLV TCD CYNC見十国本数 | VDD=2.7∼5.5V | 1A40'~125 C  | 16 | MHz |
| JCLK_ICD_SYNC   | CLK_TCD_SYNC最大周波数 | NDD 45 FEW   | TA=-40~105℃  | 32 |     |
|                 |                   | VDD=4.5∼5.5V | TA=-40~125℃  | 20 |     |

注: これらの要素は設計の指針専用で、製造限度検査によって含まれません。

#### 36.12. USART

#### 図36-4. 主装置SPI動作でのUSART - 主装置動作でのタイミング必要条件 SS (従装置選択) $\leftarrow$ t<sub>MOS</sub> $\rightarrow$ $t_{SCKR} \rightarrow \leftarrow t_{SCKF} \rightarrow$ XCK (INVEN=0) t<sub>SCKW</sub> t<sub>SCK</sub> XCK (INVEN=1) $t_{MIS}$ MISO (データ入力) MSb LSb → t<sub>MOH</sub> $t_{MOH}$ LSb MOSI (データ出力) MSb

| 表36-18. 主          | 装置SPI動作でのUSART - タイミング特性 |     |     |                      |    |     |
|--------------------|--------------------------|-----|-----|----------------------|----|-----|
| シンホ゛ル              | 説明                       | 条件  | 最小  | 代表                   | 最大 | 単位  |
| <i>f</i> SCK       | SCK周波数                   | 主装置 | -   | -                    | 10 | MHz |
| $t_{SCK}$          | SCK周期                    | 主装置 | 100 | -                    | -  |     |
| $t_{SCKW}$         | SCK High/Low期間           | 主装置 | -   | $0.5 \times t_{SCK}$ | -  |     |
| $t_{SCKR}$         | SCK上昇時間                  | 主装置 | -   | 2.7                  | -  |     |
| ${ m t}_{ m SCKF}$ | SCK下降時間                  | 主装置 | _   | 2.7                  | -  |     |
| $t_{ m MIS}$       | 入力データ 準備時間               | 主装置 | -   | 10                   | -  | ns  |
| t <sub>MIH</sub>   | 入力データ 保持時間               | 主装置 | _   | 10                   | -  |     |
| $t_{MOS}$          | SCK先行端対、出力データ 準備時間       | 主装置 | -   | $0.5 \times t_{SCK}$ | -  |     |
| t <sub>MOH</sub>   | SCKからの出力遅延時間             | 主装置 | -   | 1.0                  | _  |     |

#### 36.13. SPI

# 図36-5. SPI - 主装置動作でのタイミング必要条件 SS (従装置選択) XCK (INVEN=0) XCK (INVEN=1) MISO (データ入力) MSb LSb LSb LSb LSb



|                     | PI - タイミング特性<br>    | AT IIL | F .I.                  | /s <del>+</del>      | 日上   | 224 / L |
|---------------------|---------------------|--------|------------------------|----------------------|------|---------|
| シンホ゛ル               | 説明                  | 条件     | 最小                     | 代表                   | 最大   | 単位      |
| <i>f</i> sck        | SCKクロック周波数          | 主装置    | _                      | _                    | 10   | MHz     |
| $t_{SCK}$           | SCK周期               | 主装置    | 100                    | _                    | _    |         |
| $t_{SCKW}$          | SCK High/Low期間      | 主装置    | _                      | $0.5 \times t_{SCK}$ | _    |         |
| $t_{SCKR}$          | SCK上昇時間             | 主装置    | -                      | 2.7                  | -    |         |
| $t_{SCKF}$          | SCK下降時間             | 主装置    | -                      | 2.7                  | _    | 200     |
| $t_{MIS}$           | 入力データ準備時間           | 主装置    | -                      | 10                   | -    | ns      |
| t <sub>MIH</sub>    | 入力データ保持時間           | 主装置    | -                      | 10                   | -    |         |
| $t_{ m MOS}$        | SCK先行端対、出力データ準備時間   | 主装置    | _                      | $0.5 \times t_{SCK}$ | -    |         |
| $t_{MOH}$           | SCKからの出力遅延時間        | 主装置    | -                      | 1.0                  | _    |         |
| fSSCK               | 従装置SCKクロック周波数       | 従装置    | ı                      | 1                    | 5    | MHz     |
| $t_{\mathrm{SSCK}}$ | 従装置SCK周期            | 従装置    | 6×t <sub>CLK_PER</sub> | 1                    | _    |         |
| $t_{ m SSCKW}$      | SCK High/Low期間      | 従装置    | 3×t <sub>CLK_PER</sub> | 1                    | -    |         |
| ${ m t}_{ m SSCKR}$ | SCK上昇時間             | 従装置    | -                      | 1                    | 1600 |         |
| ${ m t}_{ m SSCKF}$ | SCK下降時間             | 従装置    | -                      | 1                    | 1600 |         |
| $t_{SIS}$           | 入力データ準備時間           | 従装置    | 0                      | -                    | _    |         |
| $t_{SIH}$           | 入力データ保持時間           | 従装置    | 3×t <sub>CLK_PER</sub> | 1                    | _    | ne      |
| $t_{SSS}$           | SCK先行端に対するSS↓準備時間   | 従装置    | _                      | tclk_per             | -    | ns      |
| ${ m t_{SSH}}$      | SCK後行端からのSS Low保持時間 | 従装置    | -                      | tclk_per             | -    |         |
| $t_{ m SOS}$        | SCKからの出力遅延時間        | 従装置    | -                      | 8.0                  | -    |         |
| $t_{SOH}$           | SCKからの出力保持時間        | 従装置    | -                      | 13                   | -    |         |
| $t_{ m SOSS}$       | SS↓からの出力準備時間        | 従装置    | _                      | 11                   | -    |         |
| $t_{SOSH}$          | SS↑からの出力保持時間        | 従装置    | _                      | 8.0                  | -    |         |

(訳注) 表36-19.の<sup>t</sup>SOHは図36-6.で対応するシンボル記載がありません。

#### 36.14. TWI



|                     | WI - タイミング特性                                    |                                      | - 1.1                                |                         |    |                                              |     |
|---------------------|-------------------------------------------------|--------------------------------------|--------------------------------------|-------------------------|----|----------------------------------------------|-----|
| シンホ゛ル               | 説明                                              |                                      | <u> </u>                             | 最小                      | 代表 | 最大                                           | 単位  |
| <i>f</i> scl_       | SCLクロック周波数                                      | (注)                                  |                                      | 0                       | _  | 1000                                         | kHz |
| VIH                 | Highレベル入力電圧                                     |                                      |                                      | $0.7 \times \text{VDD}$ | _  | -                                            |     |
| VIL                 | Lowレベル入力電圧                                      |                                      |                                      | -                       | _  | 0.3×VDD                                      |     |
| V <sub>H</sub> YS   | シュミットトリカ・入力ヒステリシス電圧                             | 1.3                                  | L. et al.                            | 0.1×VDD                 | _  | 0.4×VDD                                      | V   |
|                     |                                                 | IOL=20mA,高速                          |                                      | -                       | _  | 0.2×VDD                                      | ,   |
| Vol                 | Lowレベル出力電圧                                      |                                      | 動作,VDD>2V                            | -                       | _  | 0.4                                          |     |
|                     |                                                 | IOL=3mA,標準                           | 動作,VDD≦2V                            | -                       | _  | 0.2×VDD                                      |     |
| IOL                 | Lowレベル出力電流                                      | VOL=0.4V                             | $f_{\text{SCL}} \leq 400 \text{kHz}$ | 3                       | _  | -                                            | mA  |
| OL .                | Bonn pagy Pagy                                  |                                      | f <sub>SCL</sub> ≤1MHz               | 20                      | _  | -                                            | 1   |
|                     |                                                 | $f_{\text{SCL}} \leq 100 \text{kHz}$ |                                      | -                       | _  | 400                                          |     |
| $C_{\mathrm{B}}$    | 各バス線に対する容量性負荷                                   | $f_{\text{SCL}} \leq 400 \text{kHz}$ | Z                                    | -                       | _  | 400                                          | рF  |
|                     |                                                 | $f_{\text{SCL}} \leq 1 \text{MHz}$   |                                      | -                       | _  | 550                                          |     |
|                     |                                                 | $f_{\text{SCL}} \leq 100 \text{kHz}$ |                                      | -                       | _  | 1000                                         |     |
| $t_{R}$             | SDAとSCL両方の出力上昇時間                                | $f_{\text{SCL}} \leq 400 \text{kHz}$ |                                      | 20                      | _  | 300                                          |     |
|                     |                                                 | $f_{\text{SCL}} \leq 1 \text{MHz}$   |                                      | -                       | -  | 120                                          | ne  |
| $t_{ m OF}$         | 出力下降時間(V <sub>IHmin</sub> →V <sub>ILmax</sub> ) |                                      | $f_{\text{SCL}} \leq 400 \text{kHz}$ | 20×(VDD/5.5V)           | -  | 300                                          | ns  |
| UOF                 | 四分1   年刊刊(AIHIIII AAITIIISX)                    | 量<400pF                              | $f_{SCL} \leq 1MHz$                  | 20×(VDD/5.5V)           | -  | 120                                          |     |
| $t_{SP}$            | 入力濾波による尖頭雑音消去                                   |                                      |                                      | 0                       | _  | 50                                           |     |
| II                  | 入力電流(ピン単位)                                      | $0.1 \times VDD < V_1$               | $1 < 0.9 \times VDD$                 | -                       | _  | 1                                            | μA  |
| $C_{\mathrm{I}}$    | ピン入力容量                                          |                                      |                                      | -                       | -  | 10                                           | рF  |
|                     |                                                 | · ·                                  |                                      | (VDD-VOL(max))/IOL      | _  | $1000 \text{ns} / (0.8473 \times \text{CB})$ |     |
| Rp                  | プルアップ抵抗値                                        | f <sub>SCL</sub> ≤400kHz             |                                      |                         |    | 300ns/(0.8473×CB)                            | Ω   |
|                     |                                                 | f <sub>SCL</sub> ≦1MHz               |                                      | _                       | _  | 120ns/(0.8473×CB)                            |     |
|                     |                                                 | $f_{\text{SCL}} \leq 100 \text{kHz}$ | Z                                    | 4.0                     | _  | -                                            |     |
| t <sub>HD:STA</sub> | (再送)開始条件保持時間                                    | $f_{\text{SCL}} \leq 400 \text{kHz}$ | Z                                    | 0.6                     | _  | -                                            |     |
|                     |                                                 | f <sub>SCL</sub> ≤1MHz               |                                      | 0.26                    | _  | -                                            |     |
|                     |                                                 | $f_{\text{SCL}} \leq 100 \text{kHz}$ | Z                                    | 4.7                     | -  | -                                            |     |
| $t_{LOW}$           | SCLクロックLowレヘブル時間                                | $f_{\text{SCL}} \leq 400 \text{kHz}$ | Z                                    | 1.3                     | -  | -                                            |     |
|                     |                                                 | f <sub>SCL</sub> ≤1MHz               |                                      | 0.5                     | _  | -                                            |     |
|                     |                                                 | $f_{\text{SCL}} \leq 100 \text{kHz}$ | Z                                    | 4.0                     | -  | -                                            |     |
| $t_{HIGH}$          | SCLクロックHighレヘ・ル時間                               | $f_{\text{SCL}} \leq 400 \text{kHz}$ |                                      | 0.6                     | _  | -                                            | μs  |
|                     |                                                 | f <sub>SCL</sub> ≤1MHz               |                                      | 0.26                    | _  | -                                            | •   |
|                     |                                                 | $f_{\text{SCL}} \leq 100 \text{kHz}$ | <br>Z                                | 4.7                     | _  | -                                            |     |
| t <sub>SU:STA</sub> | 再送開始条件準備時間                                      | $f_{\text{SCL}} \leq 400 \text{kHz}$ |                                      | 0.6                     | _  | -                                            |     |
| 50.51.1             |                                                 | f <sub>SCL</sub> ≤1MHz               |                                      | 0.26                    | _  | -                                            |     |
|                     |                                                 | $f_{\text{SCL}} \leq 100 \text{kHz}$ | <br>Z                                | 0                       | _  | 3.45                                         |     |
| t <sub>HD:DAT</sub> | テータ保持時間                                         | $f_{\text{SCL}} \leq 400 \text{kHz}$ |                                      | 0                       | _  | 0.9                                          |     |
| TID.DITT            | > > bled 4 : 4 lind                             | f <sub>SCL</sub> ≤1MHz               |                                      | 0                       | _  | 0.45                                         |     |
|                     |                                                 | $f_{\text{SCL}} \leq 100 \text{kHz}$ | 7.                                   | 250                     | _  | -                                            |     |
| t <sub>SU:DAT</sub> | テ゛ータ準備時間                                        | $f_{\text{SCL}} \leq 400 \text{kHz}$ |                                      | 100                     | _  | _                                            | ns  |
| *50.D/11            | ) 1- Mm. 2 167                                  | $f_{\text{SCL}} \leq 1 \text{MHz}$   |                                      | 50                      | _  | _                                            | 110 |
|                     |                                                 | $f_{\text{SCL}} \leq 100 \text{kHz}$ | 7.                                   | 4                       | _  | -                                            |     |
| t <sub>SU:STO</sub> | 停止条件準備時間                                        | $f_{\text{SCL}} \leq 400 \text{kHz}$ |                                      | 0.6                     | _  | _                                            |     |
| <b>~</b> 50.510     | 12 TONE LA LANGUAGE                             | $f_{\text{SCL}} \leq 1 \text{MHz}$   | -                                    | 0.26                    | _  | _                                            |     |
|                     |                                                 | $f_{\text{SCL}} \leq 100 \text{kHz}$ | 7                                    | 4.7                     | _  | -                                            | μs  |
| $t_{ m BUF}$        | 停止条件→開始条件間                                      | $f_{\text{SCL}} \leq 400 \text{kHz}$ |                                      | 1.3                     | _  | -                                            |     |
| CBUF                | バス開放時間                                          | $f_{\text{SCL}} \leq 1 \text{MHz}$   | <u>u</u>                             | 0.5                     | _  | _                                            |     |
|                     |                                                 | JSCL = IMHZ                          |                                      | 0.0                     |    | _                                            |     |

注: 最大周波数は10MHzのシステム クロックを必要とし、同様にVDD=2.7~5.5VとT=-40~105℃を必要とします。

#### 表36-21. SDA保持時間(注1,2)

| シンホ゛ル   | 説明       |                         | 条件                |              | 最小  | 代表   | 最大   | 単位 |
|---------|----------|-------------------------|-------------------|--------------|-----|------|------|----|
|         |          |                         |                   | SDAHOLD='00' | 1   | 800  | 1    |    |
|         |          |                         | fclk_per=5MHz     | SDAHOLD='01' | 830 | 850  | 950  |    |
|         |          |                         | JCLK_PER-5WII IZ  | SDAHOLD='02' | 830 | 850  | 950  |    |
|         |          |                         |                   | SDAHOLD='03' | 830 | 850  | 1270 |    |
|         |          |                         |                   | SDAHOLD='00' | 1   | 400  | 1    |    |
|         |          | 主装置 (注3) fCLK_PER=10MHz | SDAHOLD='01'      | 430          | 450 | 550  |      |    |
|         |          | 土衣恒 ( <u>/土</u> 3)      | JCLK_PER-TUNIAZ F | SDAHOLD='02' | 430 | 450  | 580  |    |
| tup pam | テ゛ータ保持時間 |                         | SDAHOLD='03'      | 430          | 550 | 1270 | na   |    |
| tHD:DAT | / 一分木竹时间 |                         |                   | SDAHOLD='00' | 1   | 200  | 220  | ns |
|         |          |                         | fclk_per=20MHz    | SDAHOLD='01' | 230 | 250  | 350  |    |
|         |          |                         | JCLK_PER-20MI IZ  | SDAHOLD='02' | 260 | 450  | 580  |    |
|         |          |                         |                   | SDAHOLD='03' | 380 | 600  | 1270 |    |
|         |          |                         |                   | SDAHOLD='00' | 90  | 150  | 220  |    |
|         |          | <br> 従装置 ( <b>注4</b> )  | <b>今</b> 国油粉      | SDAHOLD='01' | 130 | 200  | 350  |    |
|         |          | ( <u>/</u> 14)          | 至向波数              | SDAHOLD='02' | 260 | 400  | 580  |    |
|         |          |                         |                   | SDAHOLD='03' | 390 | 550  | 1270 |    |

注1: これらの要素は設計の指針専用で、製造限度検査によって含まれません。

注2: SDAHOLDはSCL信号がLowとして検出された後のデータ保持時間です。実際の保持時間は、従って、構成設定された保持時間よりも長くなります。

注3: 主装置動作について、データ保持時間は以下の最大のものです。

- 4×t<sub>CLK PER</sub>+50ns(代表)

- SDAHOLD構成設定+SCL濾波遅延

注4: 従装置動作について、保持時間は以下によって与えられます。

- SDAHOLD構成設定+SCL濾波遅延

#### 36.15. VREF

#### 表36-22. 内部基準電圧特性

| X00 22. 图 加至于电压的位 |                   |    |      |    |     |    |  |
|-------------------|-------------------|----|------|----|-----|----|--|
| シンホ゛ル             | 説明                | 条件 | 最小   | 代表 | 最大  | 単位 |  |
| tStart            | 始動時間              |    | 1    | 25 | 1   | μs |  |
| VDDINT055V        | INT055Vに対する電源電圧範囲 |    | 1.8  | 1  | 5.5 |    |  |
| VDDINT11V         | INT11Vに対する電源電圧範囲  |    | 1.8  | -  | 5.5 |    |  |
| VDDINT15V         | INT15Vに対する電源電圧範囲  |    | 1.9  | -  | 5.5 | V  |  |
| VDDINT25V         | INT25Vに対する電源電圧範囲  |    | 2.9  | 1  | 5.5 |    |  |
| VDDINT43V         | INT43Vに対する電源電圧範囲  |    | 4.75 | _  | 5.5 |    |  |

#### 表36-23. ADCの内部基準電圧特性(注1)

| 又50 150 / 16 50 / 16 至于尼江市区 ( <del>区</del> /) |                             |                              |      |    |     |    |  |
|-----------------------------------------------|-----------------------------|------------------------------|------|----|-----|----|--|
| シンホ・ル (注2)                                    | 説明                          | 条件                           | 最小   | 代表 | 最大  | 単位 |  |
| INT11V                                        | 内部1.1V基準電圧                  | VDD=1.8∼3.6V,                | -2.0 | -  | 2.0 |    |  |
| INT055V,INT15V,INT25V                         | 内部0.55/1.5/2.5V基準電圧         | T=0~105°C                    | -3.0 | -  | 3.0 | %  |  |
| INT055V,INT11V,INT15V,<br>INT25V,INT43V       | 内部0.55/1.1/1.5/2.5/4.3V基準電圧 | VDD=1.8~5.5V,<br>T=-40~105°C | -5.0 | -  | 5.0 | 70 |  |

注1: これらの値は特性付けに基づき、製造限度検査によって含まれません。

注2: シンボルのINTnnVはVREF制御A(VREF.CTRLA)レシブスタのADC0基準選択(ADC0REFSEL)ビット領域の各々の値を参照します。

#### 表36-24. DACとACの内部基準電圧特性 (注1)

| シンボル (注2)                               | 説明                          | 条件                           | 最小   | 代表 | 最大  | 単位 |
|-----------------------------------------|-----------------------------|------------------------------|------|----|-----|----|
| INT055V,INT11V,<br>INT15V,INT25V        | 内部0.55/1.1/1.5/2.5V基準電圧     | VDD=1.8~3.6V,<br>T=0~105℃    | -3.0 | -  | 3.0 | %  |
| INT055V,INT11V,INT15V,<br>INT25V,INT43V | 内部0.55/1.1/1.5/2.5/4.3V基準電圧 | VDD=1.8~5.5V,<br>T=-40~105°C | -5.0 | -  | 5.0 | 70 |

注1: これらの値は特性付けに基づき、製造検査限度によって含まれません。

**注2**: シンボルのINTnnVはVREF制御A/C/D(VREF.CTRLA/CTRLC/CTRLD)レシ、スタのADCn基準選択(ADCnREFSEL)とACnとDACn 基準選択(DACnREFSEL)のビット領域の各々の値を参照します。

#### 36.16. ADC

#### 動作条件:

- VDD=1.8∼5V
- ・温度=-40~125℃
- ・ デューティ サイクル(DUTYCYC)=25%
- ・CLKADC=13×fADC、fADCは採取周波数(sps)
- ・採取容量選択(SAMPCAP)は0.55V基準電圧に対して10pF(=0)、一方VREF≥1.1Vに対しては5pF(=1)に設定されます。
- ・特記無き限り、VREF選択と採取速度の許された全ての組み合わせに対して適用

#### 表36-25. 電源、基準電圧、入力範囲

|       | M、全十 电圧、八刀 和四 |                      | I    | ı . |         |     |
|-------|---------------|----------------------|------|-----|---------|-----|
| シンホ゛ル | 説明            | 条件                   | 最小   | 代表  | 最大      | 単位  |
| VDD   | 供給電圧          |                      | 1.8  | -   | 5.5     |     |
|       |               | REFSEL=内部基準電圧        | 0.55 | -   | VDD-0.4 | V   |
| Vref  | 基準電圧          | REFSEL=VDD           | 1.8  | -   | 5.5     | V   |
|       |               | REFSEL=外部基準電圧(VREFA) | 1.1  | -   | VDD     |     |
| Cny   | 入力容量          | SAMPCAP=5pF          | -    | 5   | -       | υE  |
| CIN   |               | SAMPCAP=10pF         | -    | 10  | -       | pF  |
| RIN   | 入力抵抗          |                      | -    | 14  | -       | kΩ  |
| VIN   | 入力電圧範囲        |                      | 0    | _   | Vref    | V   |
| IBAND | 入力帯域          | 1.1V≦VREF            | _    | -   | 57.5    | kHz |

#### 表36-26. クロックとタイミングの特性

| シンホ゛ル        | 説明       | 条件                               | 最小  | 代表 | 最大       | 単位       |
|--------------|----------|----------------------------------|-----|----|----------|----------|
|              |          | 1.1V≦V <sub>REF</sub>            | 15  | -  | 115      |          |
| $f_{ m ADC}$ | 採取速度     | 1.1V≦V <sub>REF</sub> (8ピット分解能)  | 15  | -  | 150      | ksps     |
|              |          | VREF=0.55V (10ビット分解能)            | 7.5 | -  | 20       |          |
|              |          | VREF=0.55V (10ビット分解能)            | 100 | -  | 260      |          |
| CLKADC       | クロック周波数  | 1.1V≦V <sub>REF</sub> (10ビット分解能) | 200 | -  | 1500     | kHz      |
|              |          | 1.1V≦V <sub>REF</sub> (8ビット分解能)  | 200 | -  | 2000 (注) |          |
| Ts           | 採取時間     |                                  | 2   | 2  | 33       | CLKADC周期 |
| TCONV        | 変換時間(遅延) | 採取時間=2CLKADC                     | 8.7 | -  | 50       | 110      |
| TSTART       | 始動時間     | 内部VREF                           | 1   | 22 | -        | μs       |

注: 1500kHzを超えるクロック周波数には50%デューティサイクルが必要とされます。

#### 表36-27. 精度特性(注2)

| シンホ゛ル | 説明          | 条                                             | 件      |              | 最小 | 代表   | 最大 | 単位  |
|-------|-------------|-----------------------------------------------|--------|--------------|----|------|----|-----|
| Res   | 分解能         |                                               |        |              | 1  | 10   | 1  | ピット |
|       |             | REFSEL=内部基準電圧                                 | VREF=0 | .55V,7.7ksps | 1  | 1.0  | 1  |     |
| INL   | 積分非直線性誤差    | DEECEL 由如甘淮岳区                                 | 15ksps |              | I  | 1.0  | 1  |     |
| IINL  | 19月7月四州江州左  | REFSEL=内部基準電圧<br>またはVDD                       | 1.1V≦V | /REF,77ksps  | ı  | 1.0  | -  |     |
|       |             | \$1C1\$ VDD                                   | 1.1V≦V | /REF,115ksps | 1  | 1.2  | 1  |     |
|       |             | REFSEL=内部基準電圧                                 | VREF=0 | .55V,7.7ksps | 1  | 0.6  | 1  |     |
|       |             | REFSEL=内部基準                                   | 15ksps |              | I  | 0.4  | I  |     |
| DNL   | 微分非直線性誤差    | 電圧またはVDD                                      | 1.1V≦V | /REF,77ksps  | I  | 0.4  | 1  |     |
| (注1)  |             | REFSEL=内部基準電圧                                 | 1.1V≦V | /REF,115ksps | I  | 0.6  | 1  |     |
|       |             | REFSEL=VDD                                    | 1.1V≦V | /REF,115ksps | -  | 0.6  | -  | LSb |
|       |             | REFSEL=内部基準電圧,                                | ,      | T=0∼105°C    | -  | 3    | -  | LSD |
| EABS  | 絶対精度(誤差)    | V <sub>REF</sub> =1.1V,V <sub>DD</sub> =1.8∼3 | 3.6V   | T=-40~125°C  | ı  | 3    | -  |     |
| LADS  | 心(风)的人(风)   | REFSEL=VDD                                    |        |              | -  | 2    | -  |     |
|       |             | REFSEL=内部基準電圧                                 |        |              | I  | 3    | 1  |     |
|       |             | REFSEL=内部基準電圧,                                | ,      | T=0∼105°C    | -  | 5    | -  |     |
| EGAIN | 利得誤差        | VREF=1.1V,VDD=1.8∼3                           | 3.6V   | T=-40~125°C  | -  | 5    | -  |     |
| EGAIN | 们付映左        | REFSEL=VDD                                    |        |              | ı  | 2    | -  |     |
|       |             | REFSEL=内部基準電圧                                 |        |              | -  | 5    | -  |     |
| EOFF  | 変位(オフセット)誤差 |                                               |        |              | _  | -0.5 | _  |     |

**注1**: 1 LSb以下のDNL誤差は消失符号なしでの単調伝達関数を保証します。 **注2**: これらの値は特性付けに基づき、製造限度検査によって含まれません。

#### 36.17. TEMPSENSE

#### 動作条件:

- VDD=3V
- ・別の言及を除き、TA=25℃

## 表36-28. 温度感知器、精度特性

|   | 及00 20. /皿 | <u> </u>                    |              |     |      |     |    |
|---|------------|-----------------------------|--------------|-----|------|-----|----|
|   | シンホ゛ル      | 説明                          | 条件           | 最小  | 代表   | 最大  | 単位 |
| I | VDD        | 供給電圧                        |              | 1.8 | -    | 5.5 | V  |
| I | TACC       | 感知器精度 ( <mark>注1,2</mark> ) | TA=25°C      | -   | ±3   | -   | °C |
|   | TRES       | 変換分解能                       | 10ピット        | 1   | 0.55 | -   | C  |
|   | tcnv       | 変換時間                        | 1MHz ADCクロック | -   | 13   | -   | μs |

注1: これらの値は特性付けに基づき、製造限度検査によって含まれません。

注2: 温度に渡る特性は「代表特性」章で見つけることができます。

#### 36.18. DAC

#### 動作条件:

- ・別の言及を除き、VDD=3V
- ・DAC出力の5%~95%に基づいて計算された精度特性

# 表36-29. 電源、基準、出力範囲

| <b>五00 20. 柜</b> |                         |    |     |    |         |    |  |  |
|------------------|-------------------------|----|-----|----|---------|----|--|--|
| シンホ゛ル            | 説明                      | 条件 | 最小  | 代表 | 最大      | 単位 |  |  |
| VDD              | 供給電圧 ( <mark>注</mark> ) |    | 1.8 | 3  | 5.5     | V  |  |  |
| RLOAD            | 抵抗性外部負荷                 |    | 5   | -  | -       | kΩ |  |  |
| CLOAD            | 容量性外部負荷                 |    | 1   | 1  | 30      | рF |  |  |
| Vout             | 出力電圧範囲                  |    | 0.2 | -  | VDD-0.2 | V  |  |  |
| Iout             | 出力吸い込み/吐き出し電流           |    | _   | 1  | _       | mA |  |  |

注:供給電圧はDAC基準電圧として使うVREFレベルに対するVDD仕様に合致しなければなりません。

#### 表36-30. クロックとタイミングの特性

| シンホ゛ル        | 説明     | 条件                           | 最小 | 代表  | 最大 | 単位    |
|--------------|--------|------------------------------|----|-----|----|-------|
| foxo         | 最大変換速度 | $0.55V \le V_{REF} \le 2.5V$ | -  | 350 | 1  | Irana |
| <i>J</i> DAC | 取八多换坯及 | V <sub>REF</sub> =4.3V       | 1  | 270 | 1  | ksps  |

#### 表36-31. 精度特性(注3)

| シンホ゛ル                 | 説明          | 条件                                                   | 最小   | 代表   | 最大  | 単位  |
|-----------------------|-------------|------------------------------------------------------|------|------|-----|-----|
| RES                   | 分解能         |                                                      | -    | -    | 8   | ピット |
| INL                   | 積分非直線性誤差    | 0.55V≦VREF≦4.3V                                      | -1.2 | 0.3  | 1.2 | LSb |
| DNL                   | 微分非直線性誤差    | 0.55V≦VREF≦4.3V                                      | -1   | 0.25 | 1   | LSD |
| FOFF                  |             | 0.55V≦V <sub>REF</sub> ≦1.5V                         | -25  | -3   | 20  |     |
| EOFF<br>( <b>注1</b> ) | 変位(オフセット)誤差 | V <sub>REF</sub> =2.5V                               | -30  | -6   | 10  | mV  |
| (/±1)                 |             | V <sub>REF</sub> =4.3V                               | -40  | -10  | 0   |     |
| EGAIN                 | 利得誤差        | V <sub>REF</sub> =1.1V, V <sub>DD</sub> =3.0V, T=25℃ | _    | ±1   | _   | LSb |
| (注2)                  | 71. 行决定     | 0.55V≦VREF≦4.3V                                      | -10  | -1   | 10  | LSD |

注1: DAC出力緩衝部変位を含む変位、これはDAC出力ピンで測定されます。

注2: VREF精度は利得精度仕様に含まれます。

注3: これらの値は特性付けに基づき、製造限度検査によって含まれません。

#### 36.19. AC

# 表36-32. アナログ比較器特性、低電力動作禁止

| シンホ゛ル           | 説明            | 条件                                 | 最小   | 代表  | 最大  | 単位    |
|-----------------|---------------|------------------------------------|------|-----|-----|-------|
| VIN             | 入力電圧          |                                    | -0.2 | _   | VDD | V     |
| C <sub>IN</sub> | 入力ピン容量        | PA6                                | 1    | 9   | 1   | pF    |
| CIN             | 八分に、谷里        | PA7,PB5,PB4                        | 1    | 5   | 1   | þI,   |
| Voff            | 入力変位(オフセット)電圧 | $0.7V < V_{IN} < (V_{DD} - 0.7V)$  | -20  | ±5  | 20  | mV    |
| VOFF            | 八刀发位(47年)的电压  | $V_{IN}$ =-0.2 $V$ $\sim$ $V_{DD}$ | -40  | ±20 | 40  | 111 V |
| $I_{L}$         | 入力漏れ電流        |                                    | -    | 5   | -   | nA    |
| TSTART          | 始動時間          |                                    | -    | 1.3 | -   | μs    |
|                 |               | HYSMODE='00' (OFF)                 | 0    | 0   | 10  |       |
| VHYS            | ヒステリシス        | HYSMODE='01'                       | 0    | 10  | 30  | mV    |
| VHYS            |               | HYSMODE='10'                       | 10   | 30  | 90  | 111 V |
|                 |               | HYSMODE='11'                       | 20   | 55  | 150 |       |
| tpD             | 伝搬遅延          | VDD≧2.7V,25mV過駆動                   | -    | 50  | 1   | ns    |

#### 表36-33. アナログ比較器特性、低電力動作許可

| シンホ゛ル           | 説明              | 条件                                              | 最小  | 代表  | 最大  | 単位    |
|-----------------|-----------------|-------------------------------------------------|-----|-----|-----|-------|
| VIN             | 入力電圧            |                                                 | 0   | -   | VDD | V     |
| CIN             | 入力ピン容量          | PA6                                             | 1   | 9   | -   | nE    |
| CIN             | 八八八十日里          | PA7,PB5,PB4                                     | 1   | 5   | -   | pF    |
| Vore            | 入力変位(オフセット)電圧   | 0.7V <v<sub>IN&lt;(V<sub>DD</sub>-0.7V)</v<sub> | -30 | ±10 | 30  | mV    |
| Voff            | 八刀爱位(47 ピッド) 电圧 | V <sub>IN</sub> =0V~V <sub>DD</sub>             | 50  | ±30 | 50  | III V |
| $I_{L}$         | 入力漏れ電流          |                                                 | 1   | 5   | -   | nA    |
| TSTART          | 始動時間            |                                                 | I   | 1.3 | -   | μs    |
|                 |                 | HYSMODE='00' (OFF)                              | 0   | 0   | 10  |       |
| VHYS            | ヒステリシス          | HYSMODE='01'                                    | 0   | 10  | 30  | mV    |
| VHYS            |                 | HYSMODE='10'                                    | 5   | 30  | 90  | 111 V |
|                 |                 | HYSMODE='11'                                    | 12  | 55  | 190 |       |
| t <sub>PD</sub> | 伝搬遅延            | VDD≧2.7V,25mV過駆動                                | -   | 150 | -   | ns    |

#### 36.20. PTC

#### 表36-34. 周辺機能接触制御器特性 - 動作定格

| シンホ゛ル  | 説明              | 条件             | 最小  | 代表  | 最大   | 単位  |
|--------|-----------------|----------------|-----|-----|------|-----|
| CLOAD  | 最大負荷            |                | 1   | 48  | -    |     |
| CINT   | 積分コンテンサの最大量     |                | -   | 30  | -    | рF  |
| CDS    | 駆動型遮蔽容量性駆動      |                | -   | 300 | -    |     |
| CLVADO | 古塔されるADCクロック用油粉 | 25%デ、ューティ サイクル | 200 | -   | 1500 | kHz |
| CLKADC | 支援されるADCクロック周波数 | 50%デューティ サイクル  | 200 | ı   | 2000 | КПХ |

#### 表36-35. 周辺機能接触制御器特性 - パット 容量

| シンホ゛ル      | 説明       | 条件           | 最小  | 代表 | 最大 | 単位  |
|------------|----------|--------------|-----|----|----|-----|
|            |          | PA4, X0/Y0   | -   | 4  | -  |     |
|            |          | PA5, X1/Y1   | -   | 24 | -  |     |
|            |          | PA6, X2/Y2   | 1   | 9  | -  |     |
|            |          | PA7, X3/Y3   | 1   | 6  | -  |     |
|            |          | PB5, X12/Y12 | 1   | 4  | -  |     |
|            |          | PB4, X13/Y13 | 1   | 4  | -  |     |
| $C_{ m Y}$ | パッド容量Y線  | PB1, X4/Y4   | 1   | 13 | -  | pF  |
| Сү         | 八分子在里」「除 | PB0, X5/Y5   | -   | 13 | -  | pr, |
|            |          | PC0, X6/Y6   | -   | 6  | -  |     |
|            |          | PC1, X7/Y7   | -   | 6  | -  |     |
|            |          | PC2, X8/Y8   | -   | 6  | -  |     |
|            |          | PC3, X9/Y9   | _   | 6  | _  |     |
|            |          | PC4, X10/Y10 | - 1 | 6  | -  |     |
|            |          | PC5, X11/Y11 | -   | 6  | _  |     |

#### 36.21. UPDIタイミング

#### 図36-8. ヒューズによって許可されたUPDIパッドでのUPI許可手順



#### 表36-36. UPDIタイミング 特性 (注)

| シンホ゛ル             | 説明                                | 最小  | 最大    | 単位  |
|-------------------|-----------------------------------|-----|-------|-----|
| TRES              | RESETでのハント・シェーク/BREAKの持続時間        | 10  | 200   |     |
| TUPDI             | UPDI.txd= <mark>0</mark> の持続時間    | 10  | 200   | 110 |
| T <sub>Deb0</sub> | テブハブッカブ.txd= <mark>0</mark> の持続時間 | 0.2 | 1     | μs  |
| T <sub>DebZ</sub> | デバッガ.txd=z(Hi-Z)の持続時間             | 200 | 14000 |     |

注: これらの要素は設計の指針専用で、製造限度検査によって含まれません。

#### 表36-37. UPDI最大Linh速度対VDD(注)

| シンホ゛ル         | 説明        | 条         | 件           | 最大  | 単位   |
|---------------|-----------|-----------|-------------|-----|------|
|               |           |           | VDD1.8∼5.5V | 225 |      |
| <i>f</i> updi | UPDIボーレート | TA=0∼50°C | VDD2.2∼5.5V | 450 | kbps |
|               |           |           | VDD2.7∼5.5V | 900 |      |

注: これらの要素は設計の指針専用で、製造限度検査によって含まれません。

#### 36.22. プログラミング時間

フラッシュ メモリとEEPROMに対する代表的なプログラミング時間については次表をご覧ください。

#### 表36-38. メモリ プログラミング仕様

| シンホ゛ル            | 説明                  | 最小             | 代表 (†) | 最大     | 単位      | 条件              |
|------------------|---------------------|----------------|--------|--------|---------|-----------------|
| データ用EEPROMメモリ仕様  |                     |                |        |        |         |                 |
| EEE(*)           | データEEPROMハ イト耐久性    | 100000         | ı      | ı      | 消去/書き回数 | -40°C≦TA≦+105°C |
| tee_ret          | 保持特性                | 1              | 40     | 1      | 年       | TA=55℃          |
| tee_pbc          | へ°ージ緩衝部解消時間 (PBC)   | 1              | 7      | 1      | CLKCPU数 |                 |
| tee_eeer         | EEPROM全体消去時間 (EEER) | 1              | 4      | 1      | ms      |                 |
| tee_wp           | ~゚ージ書き込み時間 (WP)     | -              | 2      | -      |         |                 |
| tee_er           | ぺージ消去時間 (ER)        | -              | 2      | -      |         |                 |
| tee_erwp         | ページ消去/書き込み時間(ERWP)  | 1              | 4      | 1      |         |                 |
| プログラム用フラッシュメモリ仕様 |                     |                |        |        |         |                 |
| EFL(*)           | フラッシュメモリセル耐久性       | 10000          | 1      | 1      | 消去/書き回数 | -40°C≦TA≦+105°C |
| tfl_ret          | 保持特性                | -              | 40     | -      | 年       | TA=55℃          |
| VFL_UPDI         | チップ消去操作用VDD         | VBODLEVEL0(注1) | -      | VDDMAX | V       |                 |
| tFL_PBC          | へ゜ーシ゛緩衝部解消時間 (PBC)  | -              | 7      | -      | CLKCPU数 |                 |
| tfl_CHER         | チップ消去時間 (CHER)      | -              | 4      | _      |         |                 |
| tFL_WP           | ~゚ージ書き込み時間 (WP)     | -              | 2      | -      | ms      |                 |
| tfl_er           | ぺージ消去時間 (ER)        | -              | 2      | -      |         |                 |
| tfl_erwp         | ~゜ージ消去/書き込み時間(ERWP) | -              | 4      | -      |         |                 |
| tfl_updi         | UPDIでのチップ消去時間       | _              | -      | -      |         |                 |

<sup>†: &</sup>quot;代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

<sup>\*:</sup> これらの要素は特性付けされますが、製造で検査されません。

注1: チップ消去の間、BODLEVEL0で構成設定された低電圧検出器(BOD)がONを強制されます。VDD供給電圧がBODLEVEL0 に対するVBOD未満の場合、消去の試みは失敗するでしょう。

# 37. 代表特性

#### 37.1. 消費電力

#### 37.1.1. 活動動作消費電流











#### 37.1.2. アイ ル動作消費電流









#### 37.1.3. スタンバイ動作消費電流







#### 37.1.4. パワーダウン動作消費電流





#### 37.2. GPIO (汎用入出力)

#### 37.2.1. GPIO入力特性









#### 37.2.2. GPIO出力特性

















## 37.2.3. GPIOプルアップ。特性







## 37.3. VREF特性









## 37.4. BOD特性

## 37.4.1. BOD電流 対 動作電圧







## 37.4.2. BOD閾値 対 動作温度







## 37.5. ADC特性









































## 37.6. TMPSENSE特性



## 37.7. AC特性

















## 37.8. OSC20M特性









## 37.9. OSCULP32K特性





# 37.10. TWI SDA保持タイミング



## 38. 注文情報

- ・利用可能な注文任意選択は以下によって見つけることができます。
  - 以下の製品頁リンクの1つでのクリック
    - ATtiny3216製品頁
    - · ATtiny3217製品頁
  - microchipdirect.comで製品名による検索
  - 最寄りの販売代理店へのお問い合わせ

## 38.1. 製品情報

**注**: 利用可能な注文符号の最新情報については製品頁で見つかる「ATtiny3216/3217シリコン障害とデータシート説明」(www/microchip.com/DS80000887)を参照してください。

| 注文符号(注1)       | フラッシュ/SRAM | 最大CPU速度 | 供給電圧        | 温度範囲          | 外囲器形式 (注2,3) |
|----------------|------------|---------|-------------|---------------|--------------|
| ATtiny3216-SNR |            | 20MHz   | 1.8~5.5V    | -40°C∼105°C   |              |
| ATtiny3216-SN  |            | ZUMITZ  | 1.0, 50.0   | -40 C ~ 105 C | SOIC         |
| ATtiny3216-SFR |            | 16MHz   | 2.7~5.5V    | -40°C∼125°C   | SOIC         |
| ATtiny3216-SF  |            | TOMITZ  | 2.7 - 5.5 V | -40 C ~ 125 C |              |
| ATtiny3217-MNR |            | 20MHz   | 1.8~5.5V    | -40°C∼105°C   |              |
| ATtiny3217-MN  |            | ZUMITZ  | 1.0, 50.0   | -40 C ~ 105 C | VOEN         |
| ATtiny3217-MFR |            | 16MHz   | 2.7~5.5V    | -40°C∼125°C   | VQFN         |
| ATtiny3217-MF  |            | IOMITZ  | 2.7 9.50    | -40 C - 125 C |              |

注1: 有害物質使用制限に関する欧州指令(RoHS指令)適合の鉛フリー製品。またハロケン化合物フリーで完全に安全。

注2: テープとリール、チューブまたはトレイ梱包媒体で利用可能。

注3: 外囲器外形図は「39. 外囲器図」章で見つけることができます。

## 38.2. 製品識別システム

注文や、例えば価格や供給の情報を得るには工場または一覧にされた営業所を参照してください。



## 39. 外囲器図

## 39.1. オンライン外囲器図

最新の外囲器図については、

- 1. http://www.microchip.com/packagingへ行ってください。
- 2. 外囲器形式特定頁、例えばVQFNへ行ってください。
- 3. 最新の外囲器図を見つけるために図番号と型式を探してください。

| 表39-1. | 図番号   |           |     |
|--------|-------|-----------|-----|
| ピン数    | 外囲器型式 | 図番号       | 型式  |
| 20     | SOIC  | C04-00094 | SO  |
| 24     | VQFN  | C04-21386 | RLB |

注: 最新の外囲器図についてはhttp://www.microchip.com/packagingに置かれたMicrochip外囲器仕様をご覧ください。

## 39.2. 2011-F'SOIC

20リート、プラスティック小型外形(SO) - 広幅7.50mm本体 [SOIC]





| 表39-2. デバイスと外囲器 | <b>器最大重量</b> | 表39-3. 外囲器参照基 | 準    |
|-----------------|--------------|---------------|------|
| 最大重量            | 542mg        | JEDEC作図参照基準   | 該当なし |
|                 |              | JESD97分類      | E3   |

# 39.3. 24パット VQFN

24パット、極薄プラスティック4方向平板リート、なし外囲器(RLB) - 4×4mm本体 [VQFN] (Atmel伝承全般外囲器符号ZHA)





|                  | 単位 |      | mm     |      |
|------------------|----|------|--------|------|
| 寸法               | 限度 | 最小   | 標準     | 最大   |
| 接触子間隔            | Е  | 0    | .50 BS | 3    |
| 任意選択中央パッド幅       | X2 | -    | -      | 2.75 |
| 任意選択中央パッド長       | Y2 | -    | -      | 2.75 |
| 接触パッド間隔          | C1 | -    | 4.00   | -    |
| 接触パッド間隔          | C2 | -    | 4.00   | -    |
| 接触パッド幅(×20)      | X1 | -    | -      | 0.30 |
| 接触パッド長(×16)      | Y1 | -    | -      | 0.85 |
| 接触パッド~中央パッド(×20) | G1 | 0.20 | -      | -    |
| 接触パッド~接触パッド(×16) | G2 | 0.20 | -      | -    |
| 放熱ビア直径           | ØV | -    | 0.30   | -    |
| 放熱ビア間隔           | EV | -    | 1.00   | -    |

注1: ASME Y14.5Mによる寸法と公差

BSC: 基本寸法。公差なしで示される理論的に正確な値。

**注2**: 最善の半田結果に関して使われる場合に放熱ビアはリフロー処理中に半田欠損を避ける ために満たされる、またはテンティングされるべきです。

Microchip Technology作図C04-23386改訂A

## 表39-4. デバイスと外囲器最大重量

最大重量 41.4mg

#### 表39-5. 外囲器参照基準

| 表00 0. 기四m 5 // 至· | т-   |
|--------------------|------|
| JEDEC作図参照基準        | 該当なし |
| JESD97分類           | E3   |

## 39.4. 熱的考察

#### 39.4.1. 熱抵抗データ

右表は外囲器に依存する熱抵抗データを要約します。

# 表39-6. 熱抵抗データ L°ン数 外囲器型式 のJA [°C/W] のJC [°C/W] 20 SOIC 44 21 24 VQFN 60.6 25

#### 39.4.2. 接合部温度

℃での平均チップ接合部温度のT」は以下の式から得ることができます。

式1.  $T_J=T_A+(P_D\times\theta_{JA})$ 

式2.  $TJ=TA+(PD\times(\theta HEATSINK+\theta JC))$ 

#### ここで、

- ・ θJA=接合部/周囲間の外囲器熱抵抗(℃/W)、表39-6.をご覧ください。
- ・ θ<sub>J</sub>C=接合部/ケース間熱抵抗の外囲器熱抵抗(℃/W)、**表39-6**.をご覧ください。
- ・ θHEATSINK=外部冷却装置の熱抵抗(℃/W)特性
- PD=デバイス消費電力(W)
- · TA=周囲温度(℃)

最初の式から、使用者はチップの推定寿命を得て、冷却装置が必要か否かを決めることができます。冷却装置がチップに取り付けられなければならない場合、℃での平均チップ接合部温度のTJの結果を計算するのに2つ目の式が使われるべきです。

# 40. 障害情報

# 40.1. 障害 - ATtiny3216/3217

障害情報はATtiny3216/3217シリコン障害とデータシート説明(www.microchip.com/DS80000887)で見つけることができます。 (訳主) 本書では上記文書の内容も含みます。

## 40.2. シリコン問題要約

## 凡例

- 障害は適用されません。
- × 障害が適用されます。

| E 77 1/8 41 | <b>(25. 27. 17. 17. 17. 17. 17. 17. 17. 17. 17. 1</b> |      | シリコン | 改訂 | に対する有効性 |
|-------------|-------------------------------------------------------|------|------|----|---------|
| 周辺機能        | 簡単な説明                                                 | 間    | Α    | С  |         |
| ディバイス       | 40.3.1. 校正値の自動設定を妨げるFUSE.OSCCFGのOSCLOCKヒューズの'1'書き込    | み    | X    | ×  |         |
|             | 40.4.1. ADCを禁止すると立往生する保留中の事象                          |      | X    | _  |         |
| ADC         | 40.4.2. 1.5MHzを超えるCLKADCと25%デューティサイクル設定で保証できないADC機能   | 3137 | X    | ×  |         |
| ADC         | 40.4.3. 1.5MHzを超えるCLKADCとVDD<2.7Vで低下するADC性能           |      | X    | ×  |         |
|             | 40.4.4. ADC自由走行動作禁止後に実行される1つの余分な測定                    |      | X    | ×  |         |
|             | 40.5.1. OUTENが'1'に設定されることを必要とする連結動作でのLUT接続            |      | X    | _  |         |
| CCL         | 40.5.2. 機能しないDラッチ                                     |      | X    | _  |         |
|             | 40.5.3. 単一LUT構成変更にCCLの禁止が必要                           |      | X    | ×  |         |
| NVMCTRL     | 40.6.1. NVMCTRL.CTRLAレジスタの不正なリセット値                    |      | X    | ×  |         |
| RTC         | 40.7.1. RTC.CTRLAレジスタへのどの書き込みもRTCとPITの前置分周器をリセット      |      | X    | _  |         |
| KIC         | 40.7.2. RTC禁止がPITを停止                                  |      | X    | _  |         |
| TCA         | 40.8.1. NORMALとFRQの動作で計数方向をリセットする再始動                  |      | X    | ×  |         |
|             | 40.9.1. 選んだクロック周期を超えなければならない最小事象持続期間                  |      | X    | ×  |         |
| TCB         | 40.9.2. TCBの再始動を強制しないTCA再始動指令                         |      | X    | ×  |         |
|             | 40.9.3. 8ビットPWM動作で16ビット レジスタとして機能するCCMPとCNTのレジスタ      |      | X    | ×  |         |
| TCD         | 40.10.1. TCD計数器前置分周器使用時に動かない非同期入力事象                   |      | ×    | ×  |         |
| ICD         | 40.10.2. 比較A値が'0'または2傾斜動作使用時に動かないTCD停止とソフトウェア再開行      | 持ち   | X    | ×  |         |
|             | 40.11.1. 送信部禁止時に解除されないTxDピン無効化                        |      | X    | ×  |         |
|             | 40.11.2. 誤った開始ビットを起こすかもしれない直前のメッセージでのフレーム異常           |      | X    | _  |         |
| USART       | 40.11.3. TxDが出力として構成設定される時に動かないオープントレイン動作             |      | X    | ×  |         |
| USAKI       | 40.11.4. LIN同期領域確認時に支援されない全範囲デューティ サイクル               |      | X    | -  |         |
|             | 40.11.5. 活動動作で意図せず許可され得るフレーム開始検出                      |      | -    | ×  |         |
|             | 40.11.6. 矛盾する同期領域検出後に機能しない受信部                         |      | _    | ×  |         |

次のシリコン改訂は製品として発売されませんでした。: 改訂B

## 40.3. デバイス

#### 40.3.1. 校正値の自動設定を妨げるFUSE.OSCCFGのOSCLOCKLュースでの'1'書き込み

発振器構成設定(FUSE.OSCCFG)の発振器施錠(OSCLOCK)ヒュースで、1'書き込みは識票列からの自動校正値設定を妨げます。デバイスは未校正のOSC20M発振器で動きます。

#### 対策/対処:

発振器校正値を施錠するのにOSCLOCKを使わないでください。発振器校正値は主クロック元としてOSC20M発振器使用時に主クロック施錠(CLKCTRL.MCLKLOCK)の施錠許可(LOCKEN)に'1'を書くことによって施錠することができます。

#### 影響を及ぼされるシリコン改訂

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | X | × |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 40.4. ADC - A/D変換器

#### 40.4.1. ADCを禁止すると立往生する保留中の事象

事象起動変換中にADCが禁止された場合、事象が解除されません。

#### 対策/対処

ADCを禁止する前に事象制御レジスタの事象入力開始(ADCn.EVCTRL.STARTEI)ビットを解除(0)して変換完了を待ってください。

#### 影響を及ぼされるシリコン改訂

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | × | - |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 40.4.2. 1.5MHzを超えるCLKADCと25%デューティサイクル設定で保証できないADC機能

'1'に設定したADC校正レジスタのデューティサイクル(ADCn.CALIB.DUTYCYC)でCLKADC>1.5MHzの場合、ADC機能は保証することができません。

#### 対策/対処:

ADCがCLKADC>1.5MHzで動作する場合、ADCn.CALIB.DUTYCYCは'0'(50%デューティサイクル)に設定されなければなりません。

## 影響を及ぼされるシリコン改訂

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | X | × |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 40.4.3. 1.5MHzを超えるCLKADCとVDD<2.7Vで低下するADC性能

VDD<2.7Vの間にCLK<sub>ADC</sub>>1.5MHzでADCn.CALIB.DUTYCYCが'0'に設定される場合、ADCの積分非直線性誤差(INL)性能が低下します。

#### 対策/対処:

ありません。

#### 影響を及ぼされるシリコン改訂

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | × | X |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 40.4.4. ADC自由走行動作禁止後に実行される1つの余分な測定

ADC制御Aレジスタの自由走行(ADCn.CTRLA.FREERUN)解除(0)後にADCは1つの追加測定を実行するかもしれません。

#### 対策/対処:

自由走行動作を直ちに停止するにはADC制御Aレジスタの許可(ADCn.CTRLA.ENABLE)に'0'を書いてください。

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | × | × |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 40.5. CCL - 構成設定可能な注文論理回路

## 40.5.1. OUTENが'1'に設定されることを必要とする連結動作でのLUT接続

連結動作でのLUT接続は入力元を提供するLUTに対して出力許可(LUTnCTRLA.OUTEN)が'1'に設定されることを必要とします。 対策/対処:

LUTを連結するのに事象チャネルを使うか、または対応する入出力ピンを他の目的に使わないでください。

## 影響を及ぼされるシリコン改訂

| 改訂 | А | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | × | _ |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 40.5.2. 機能しないDラッチ

CCLのDラッチが機能しません。

#### 対策/対処:

ありません。

#### 影響を及ぼされるシリコン改訂

| 改訂 | A | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | × | - |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 40.5.3. 単一LUT構成変更にCCLの禁止が必要

LUTを再構成設定するには初めにCCL周辺機能が禁止(制御A(CCL.CTRLA)レジスタの許可(ENABLE)に'0'書き込み)されなければなりません。ENABLEへの'0'書き込みは全てのLUTを禁止し、再構成設定下でないLUTに影響を及ぼします。

#### 対策/対処:

ありません。

#### 影響を及ぼされるシリコン改訂

| Г | ⊒h≣T | Λ | C |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---|------|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| - | 以如   | Λ |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   | 影響   | × | × |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 40.6. NVMCTRL - 不揮発性メモリ制御器

## 40.6.1. NVMCTRL.CTRLAレジスタの不正なリセット値

或る場合に制御A(NVMCTRL.CTRLA)のリセット値が'\$00'でありません。予約ビットでさえリセット後に'1'として読むことが有り得ます。 対策/対処:

# 初期値を無視してください。

TARRE L - ALL - TARRET - TARRE

## 影響を及ぼされるシリコン改訂

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | X | × |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 40.7. RTC - 実時間計数器

#### 40.7.1. RTC.CTRLAレジスタへのどの書き込みもRTCとPITの前置分周器をリセット

RTC制御A(RTC.CTRLA)レジスタへのどの書き込みも15ビット前置分周器をリセットします。次の計数はリセット後に1/2前置分周器周期を引き起こし、リセット発生時に応じて意図した周期の0.5~1.5倍の周期長になります。

#### 対策/対処:

ありません。

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | × | _ |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 40.7.2. RTC禁止がPITを停止

RTC許可(RTC.CTRLA.RTCEN)への'0'書き込みはPITを停止します。

周期割り込み計時器許可(RTC.PITCTRLA.PITEN)への'0'書き込みはRTCを停止します。

#### 対策/対処:

この単位部の何れかが使われている場合にRTCやPITを禁止しないでください。

#### 影響を及ぼされるシリコン改訂

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | X | _ |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 40.8. TCA - タイマ/カウンタA型

## 40.8.1. NORMALとFRQの動作で計数方向をリセットする再始動

TCAが標準(NORMAL)または周波数(FRQ)の動作(制御B(TCAn.CTRLB)の波形生成動作(WGMODE)が'000'または'001')に構成設定されると、強制再始動(RESTART)指令や再始動事象は方向を既定にリセットします。既定は上昇計数です。

#### 対策/対処:

ありません。

#### 影響を及ぼされるシリコン改訂

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | × | X |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 40.9. TCB - タイマ/カウンタB型

#### 40.9.1. 選んだクロック周期を超えなければならない最小事象持続期間

事象検出はTCBnが選んだクロック元(制御A(TCBn.CTRLA)のクロック選択(CLKSEL))の周期よりも短いHigh/Low期間を持つ入力事象を受け取る場合に失敗します。これは制限時間検査(TIMEOUT)、計数捕獲(CAPT)、計数捕獲周波数/パルス幅測定(FRQPW)のTCB動作(制御B(TCBn.CTRLB)の計時器動作(CNTMODE))に適用します。

#### 対策/対処:

入力事象のHigh/Low期間が選んだクロック元(制御A(TCBn.CTRLA)のクロック選択(CLKSEL))周期と等しいか長いことを確実にしてください。

#### 影響を及ぼされるシリコン改訂

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | X | X |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 40.9.2. TCBの再始動を強制しないTCA再始動指令

TCBが同期更新(SYNCUPD)動作で動いている時にTCA再始動指令がTCBの再始動を強制しません。TCBはTCA溢れ(OVF)後にだけ再始動されます。

#### 対策/対処:

ありません。

#### 影響を及ぼされるシリコン改訂

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | X | X |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 40.9.3. 8ビットPWM動作で16ビットレジスタとして機能するCCMPとCNTのレジスタ

TCBが8ビットPWM動作(制御B(TCBn.CTRLB)の計時器動作(CNTMODE)が'111')で動く時に、計数(CNT)と比較/捕獲(CCMP)のレジスタに対する下位と上位のハイトは読み書きに関して16ビット レジスタとして機能します。これらは独立して読み書きすることができません。

#### 対策/対処:

16ビット レジスタ アクセスを使ってください。

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | × | X |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 40.10. TCD - タイマ/カウンタD型

## 40.10.1. TCD計数器前置分周器使用時に動かない非同期入力事象

TCDを非同期入力事象を使うよう(事象制御x(TCDn.EVCTRLx)の事象構成設定(CFG)が'10')に構成設定し、制御A(TCDn.CTRL A)のTCD計数器前置分周器(CNTPRES)が'00'と異なると、事象を失うかもしれません。

#### 対策/対処:

TCD計数器前置分周器の代わりにTCDn.CTRLAのTCD同期前置分周器(SYNCPRES)を使ってください。代わりに、入力事象がCL K\_TCD\_CNT周期よりも長い場合、同期入力事象(TCDn.EVCTRLxの事象構成設定(CFG)が'0x')を使ってください。

#### 影響を及ぼされるシリコン改訂

| 改訂 | A | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | × | X |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 40.10.2. 比較A値が '0' または2傾斜動作使用時に動かないTCD停止とソフトウェア再開待ち

TCD停止とソフトウェア再開待ち(入力制御A(TCDn.INPUTCTRLA)の入力動作(INPUTMODE)が '111')は、比較A値が '0'(比較A設定 (TCDn.CMPASET)の比較A設定(CMPASET)が '0x0')または2傾斜動作が使われる(制御B(TCDn.CTRLB)の波形生成動作(WGMO DE)が '11')の場合に動きません。

#### 対策/対処:

比較A値(TCDn.CMPASETのCMPASET)を'0'と異なるように構成設定し、2傾斜動作を使わない(TCDn.CTRLBのWGMODE)が非 '11')でください。

#### 影響を及ぼされるシリコン改訂

| 改訂 |   | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | 3 | × | × |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 40.11. USART - 万能同期/非同期送受信器

#### 40.11.1. 送信部禁止時に解除されないTxDピン無効化

USARTは次の場合にTxDピンの無効化を解除しません。

- ・USART受信部が禁止されている(制御B(USARTn.CTRLB)の受信許可(RXEN)が'0'の)間にUSARTn.CTRLBの送信許可(TXEN) ビットへの'0'書き込みによってUSART送信部が禁止される場合
- ・USARTn,CTRLBでTXENとRXENのビットに'0'を書くことによってUSARTの送信部と受信部の両方が同時に禁止される場合

#### 対策/対処:

次の2つの可能な対策があります。

- ・送信部を禁止する(USARTn.CTRLBのTXENへの'0'書き込みの)間、受信部が許可されている(USARTn.CTRLBのRXENが'1' である)ことを確実にしてください。
- ・送信部禁止後にUSART内の何れかのレジスタに書いてください。これはTxDピンのピン無効化を解除するために充分長い間USART を開始します。

#### 影響を及ぼされるシリコン改訂

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | × | × |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 40.11.2. 誤った開始ビットを起こすかもしれない直前のメッセージでのフレーム異常

設定(1)されたフレーム異常フラグ(RXDATAH.FERR)を持つフレームを受信してRxD線がHighになる前に受信データ下位パイト(RXDATAL)を読む場合、誤った開始ビット検出が起動します。

## 対策/対処:

例えばRxDピンが配置されたポート入力(PORTn.IN)のビットをポーリングすることにより、RXDATAを読む前にRxDピンがHighになるのを 待ってください。

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | X | - |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 40.11.3. TxDが出力として構成設定される時に動かないオープントレイン動作

USART TxDピンが出力として構成設定されると、オープントレイン動作が許可されて居るか否かに関わらず、ピンをHighに駆動し得ます。 対策/対処:

オープン ドレイン動作使用時に対応する方向(PORTx.DIR)ビットに'0'を書くことによってTxDピンを入力として構成設定してください。

#### 影響を及ぼされるシリコン改訂

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | X | × |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 40.11.4. LIN同期領域確認時に支援されない全範囲デューティ サイクル

LIN同期領域に対して、USARTはLIN仕様で記述されるような下降端間の時間の代わりに±15%内で各ビットを確認し、これは43.5%の最小デューティサイクルと57.5%の最大デューティサイクルを許します。

#### 対策/対処:

ありません。

#### 影響を及ぼされるシリコン改訂

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | X | _ |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 40.11.5. 活動動作で意図せず許可され得るフレーム開始検出

フレーム開始検出機能はデータ受信でスタンハイ休止動作から起こすためにUSARTを許可します。フレーム開始検出器はデハイスが活動動作で制御B(USARTn.CTRLB)レジスタのフレーム開始検出許可(SFDEN)ビットが設定(1)される時に意図せず起動され得ます。新しいデータを受信している間に受信データ(RXDATA)レジスタが読まれる場合、状態(USARTn.STATUS)レジスタの受信完了割り込み要求フラグ(RXCIF)が解除(0)されます。これはフレーム開始検出器が起動されて後続する下降端を誤って開始ビットとして検出することに帰着します。フレーム開始検出器が開始条件を検出すると、フレーム受信が再始動され、不正な受信データに帰着します。活動動作時にUSART受信開始割り込み要求フラグ(RXSIF)は常に、0、であることに注意してください。割り込みは起動されません。

#### 対策/対処:

デバイスが活動動作の時はUSART制御B(USARTn.CTRLB)レジスタのフレーム開始検出許可(SFDEN)ビットに'0'を書くことによってフレーム開始検出器を禁止してください。スタンバイ休止動作へ遷移する前にこのビットに'1'を書くことによって再びそれを許可してください。この対策はフレーム開始検出を再許可する時に新しくやって来るフレームを防ぐ規約に依存します。新しいフレームが既にやって来ている間でのフレーム開始検出再許可は不正な受信データになります。

#### 影響を及ぼされるシリコン改訂

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | _ | × |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 40.11.6. 矛盾する同期領域検出後に機能しない受信部

USART受信部は状態(USARTn.STATUS)レシ、スタで矛盾同期領域割り込み要求フラケ、(ISFIF)が設定(1)されると、機能しなくなります。 ISFIF割り込み要求フラケ、は制御B(USARTn.CTRLB)レシ、スタの受信動作(RXMODE)ヒ、ット領域が標準自動ホーレート動作(GENAUTO)またはLIN制限自動ホーレート動作(LINAUTO)に構成設定され、受信した同期フレームがデータシートで記述されたような条件に準拠していない時に設定(1)されます。このフラケの解除、0、はUSART受信部を再許可しません。

#### 対策/対処:

ISFIF割り込み要求フラケが設定'1'された時は制御B(USARTn.CTRLB)レジスタの受信許可(RXEN)ビットへ最初に'0'その後に'1'を書くことによってUSART受信部を禁止して再許可してください。

| 改訂 | Α | С |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|---|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | _ | × |  |  |  |  |  |  |  |  |  |  |  |  |  |

# 41. データシート改訂履歴

注: データシートの改訂はダイ改訂とデバイス変種(注文番号の最後の文字)と無関係です。

# 41.1. 改訂A - 2020年5月

| 章        | 変更                                                                  |
|----------|---------------------------------------------------------------------|
|          | · 初回文書公開                                                            |
|          | この文書で記述されたデバイスに対する内容は                                               |
|          | • ATtiny1614データシート                                                  |
|          | • ATtiny1616/3216データシート                                             |
|          | ・ ATtiny1617/3217データシート                                             |
|          | から                                                                  |
|          | • ATtiny1614/1616/1617データシート                                        |
|          | ・ ATtiny3216/3217データシート (本文書)<br>に再構築されました。                         |
| 文書       |                                                                     |
|          | 更なる詳細については「41.2. 追補 - 廃止された改訂履歴」を参照してください。                          |
|          | 以下の項目は廃止された文書の最新改訂と本文書間の変更を参照しています。                                 |
|          | ・文書をMicrochip編集規格に更新                                                |
|          | <ul><li>関連リンクを削除</li></ul>                                          |
|          | ・「頭字語と略語」章を削除                                                       |
|          | ・「命令一式要約」章の内容削除。本章は今や代わりに外部の命令一式手引書を参照します                           |
|          | ・周辺機能部分からデバイス特定情報を削除<br>・周辺機能部分内でシステム依存性に関連する部分を再構築                 |
|          |                                                                     |
|          | ・本文書で文書化されたデバイスに適応するために再構成/変更されたデバイス特定情報                            |
|          | - 特徴                                                                |
|          | - ピン配置<br>- 入出力多重化と考察                                               |
|          | - 八山刀多里化と考察<br>- 注文情報                                               |
|          | - 外囲器図                                                              |
|          | <ul><li>更新されたピン配置図</li></ul>                                        |
|          | - 20リート`SOIC                                                        |
|          | - 24パットVQFN                                                         |
|          | ・ メモリ                                                               |
| _, ,     | - メモリ配置図更新                                                          |
| デバイス     | - メモリ アクセス(FUSE.LOCKBIT無効鍵)表更新                                      |
|          | - GPIORについての文書追加<br>国内機能は其本様性                                       |
|          | ・周辺機能と基本構造<br>- 周辺機能アドレス配置表に周辺機能接触制御器(PTC)追加                        |
|          | - 割り込みへどか配置表更新                                                      |
|          | ・プログラムアドレス(語)に改名された基準アドレス                                           |
|          | ・周辺機能元列を浄化                                                          |
|          | ・説明列を追加                                                             |
|          | <ul><li>・外囲器図</li></ul>                                             |
|          | - 図番号表更新                                                            |
|          | - MSL番号削除                                                           |
|          | - 熱的考察部分を外囲器図章内に移動                                                  |
|          | ・フラッシュ メモリ変位アドレス(\$8000)について欠けていた情報を追加(注1)                          |
|          | ・AVR CPU基本構造後の重複した情報を除去                                             |
|          | ・算術論理演算論理回路部(ALU)がレジスタ ファイルの作業レジスタに対する動作を行うことを強<br>・スタック ポインタ命令表を追加 |
|          | ・以下で文書を再構築して改善                                                      |
|          | - レジスタファイル項                                                         |
| AVR® CPU | - X,Y,Zレジスタ項                                                        |
|          | - 16ピットレジスタのアクセス項                                                   |
|          | ・チップ上デバッグ能力項を追加                                                     |
|          | ・状態レジスタ(SREG)でビット名を更新                                               |
|          | - ビット複写記憶から転送ビットへ                                                   |
|          | - 符号ビットから符号フラグへ                                                     |

| 前頁から続く  |                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 章       | 変更                                                                                                                                                                                                                                                                                                                                                                                          |
| NVMCTRL | ・NVMCTRL構成図更新<br>・欠けていたフラッシュ メモリ部の図を追加 ( <mark>注1</mark> )<br>・リセット後の書き込みアクセス項を追加                                                                                                                                                                                                                                                                                                           |
| CLKCTRL | ・CLK_TCDでの付加的文書を追加                                                                                                                                                                                                                                                                                                                                                                          |
| SLPCTRL | ・休止動作活動概要表を更新・デバッグ操作を追加                                                                                                                                                                                                                                                                                                                                                                     |
| RSTCTRL | ・図追加<br>- MCU始動、VDDに繋がれたRESET<br>- MCU始動、外部的に延長されたRESET<br>- 低電圧検出リセット<br>- 外部リセット特性                                                                                                                                                                                                                                                                                                        |
| CPUINT  | ・最小割り込み応答時間表を追加<br>・文書とその構造の全般的な改善                                                                                                                                                                                                                                                                                                                                                          |
| EVSYS   | ・レジスタ名更新 - ASYNCCHからASYNCCHnへ - SYNCCHからSYNCCHnへ - ASYNCUSERからASYNCUSERnへ - SYNCUSERからSYNCUSERnへ                                                                                                                                                                                                                                                                                            |
| PORT    | <ul> <li>・構成図更新</li> <li>・非同期感知ピン特性項を追加</li> <li>・デバッグ操作項を追加</li> <li>・PORTxでの事象生成部表を追加</li> <li>・文書とその構造の全般的な改善</li> </ul>                                                                                                                                                                                                                                                                 |
| BOD     | <ul> <li>・構成図更新</li> <li>・利用可能な割り込みへ」クタと供給元表の変位を除去</li> <li>・ビット領域説明表に名称列を追加</li> <li>- CTRLA.AVTIVE</li> <li>- CTRLA.SLEEP</li> <li>- INTCTRL,VLMCFG</li> </ul>                                                                                                                                                                                                                            |
| WDT     | ・周期ビット領域の値を更新                                                                                                                                                                                                                                                                                                                                                                               |
| TCA     | <ul> <li>・構成図更新</li> <li>・タイマ/カウンタ クロック論理回路図更新</li> <li>・信号説明表更新</li> <li>・分割動作タイマ/カウンタ構成図更新</li> <li>・TCAでの事象生成部表追加</li> <li>・TCAでの事象使用部表追加</li> <li>・両方の利用可能な割り込みへつタと供給元表の変位を除去</li> <li>・CRTLB.WGMODEビット領域用の表を1つの表に結合</li> <li>・文書とその構造の全般的な改善</li> </ul>                                                                                                                                |
| TCB     | <ul> <li>構成図更新</li> <li>タイマ/カウンタ クロック論理回路図追加</li> <li>図更新</li> <li>周期的割り込み動作</li> <li>制限時間検査動作</li> <li>事象での捕獲動作</li> <li>計数捕獲周波数測定動作</li> <li>計数捕獲周波数/パルス幅測定動作</li> <li>計数捕獲周波数/パルス幅測定動作</li> <li>単発動作</li> <li>8ビットPWM動作</li> <li>TCBでの事象生成部表追加</li> <li>TCBでの事象生成部表追加</li> <li>利用可能な割り込みへ、クタと供給元表の変位を除去</li> <li>ビット領域説明表に名称列を追加</li> <li>CTRLA.CLKSEL</li> <li>CTRLB.CNTMODE</li> </ul> |

| 前頁から続く |
|--------|
|--------|

| 前頁から続く<br><b>章</b> | 変更                                                     |
|--------------------|--------------------------------------------------------|
| <del>-</del>       | ・構成図更新                                                 |
|                    | ・TCDでの事象生成部表追加                                         |
|                    | ・利用可能な割り込みベクタと供給元表の変位を除去                               |
|                    | ・ビット領域説明表に名称列を追加                                       |
|                    | - CTRLA.CLKSEL                                         |
| TCD                | - CTRLA.CNTPRES                                        |
|                    | - CTRLA.SYNCPRES                                       |
|                    | - CTRLA.ENABLE                                         |
|                    | - DLYCTRL.DLYPRESC<br>- DLYCTRL.DLYTRIG                |
|                    | - DLYCTRL.DLYSEL                                       |
|                    | ・文書とその構造の全般的な改善                                        |
|                    | ・RTCでの事象生成部表追加                                         |
| RTC                | ・利用可能な割り込みべかりと供給元表の変位を除去                               |
|                    | ・文書とその構造の全般的な改善                                        |
|                    | ・USARTでの事象生成部表追加                                       |
|                    | ・USARTでの事象使用部表追加                                       |
| USART              | ・利用可能な割り込みへづ々と供給元表の変位を除去                               |
|                    | ・CTRLDレジスタ追加                                           |
|                    | ・文書とその構造の全般的な改善                                        |
|                    | ・構成図更新                                                 |
| OD!                | ・SPIでの事象生成部表追加                                         |
| SPI                | ・利用可能な割り込みベクタと供給元表の変位を除去 ・標準と緩衝の動作に対して割り込み要求フラグレジスタを分離 |
|                    | ・ 文書とその構造の全般的な改善                                       |
|                    | ・利用可能な割り込みへうなと供給元表の変位を除去                               |
|                    | ・ビット領域説明表に名称列を追加                                       |
|                    | - CTRLA.FMPEN                                          |
| TWI                | - MCTRLB.ACKACT                                        |
|                    | - MCTRLB.MCMD                                          |
|                    | ・文書とその構造の全般的な改善                                        |
| CRCSCAN            | ・利用可能な割り込みベクタと供給元表の変位を除去                               |
| CCL                | ・ INSELnt yh領域更新                                       |
| AC                 | ・内部入力としてDACREF除去                                       |
|                    | ・構成図更新                                                 |
| ADC                | ・WCOMPの誤植をWCMPに修正                                      |
| ADC                | ・利用可能な割り込みベクタと供給元表の変位を除去                               |
|                    | ・CRTLA.MUXPOSビット領域説明更新                                 |
| DAC                | ・繰り返される「DAC0だけが出力駆動部外部ピンを持つ」注を除去                       |
| PTC                | ・相互容量に対するRs値についての注を追加                                  |
|                    | <ul><li>・新しい外部文書へのリンクに更新</li><li>・図更新</li></ul>        |
|                    | - UPDIクロック領域                                           |
|                    | - UPDI命令一式概要                                           |
|                    | - LDS命令操作                                              |
|                    | - STS命令操作                                              |
|                    | - LD命令操作                                               |
| UPDI               | - ST命令操作                                               |
|                    | - LDCS命令操作                                             |
|                    | - STCS命令操作<br>- REPEAT命令操作                             |
|                    | - REPEAT 研究操作<br>- LDとRPTでのバ仆間遅延例                      |
|                    | ・項追加                                                   |
|                    | - 単線動作でのBREAK                                          |
|                    | - SYNCHと単線動作でのSYNCH                                    |
| 次頁へ続く              |                                                        |

| 前頁から続く |                                                                                                                                                                                                                                                                                                                                      |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 章      | 変更                                                                                                                                                                                                                                                                                                                                   |
| UPDI   | <ul> <li>・UPDI周辺機能許可に関連する文書を拡張して改善</li> <li>・UPDI周辺機能禁止に関連する文書を拡張して改善</li> <li>・"12V"を"高電圧"に改名</li> <li>・LD命令で使われるREPEAT操作図追加</li> <li>・チップ消去項を拡張して改善</li> <li>・UPDIでの事象生成部表追加</li> <li>・UPDI異常符号ピット領域に対するパス異常も文書追加</li> <li>・ASI制御Aレジスタに対するリセット値更新</li> <li>・最終使用者にとって有用でないと考察された実装特有詳細を除去</li> </ul>                               |
| 電気的特性  | <ul> <li>消費電力項に最大値追加</li> <li>周辺機能消費電力の表で数値を丸め</li> <li>TCD項追加</li> <li>TWI - タイシケルの要条件図更新</li> <li>TWI - タイシケルの要条件表でtoFに対する数値を更新</li> <li>SDA保持時間表追加</li> <li>ADCに対して50%デューティサイケル要件の注を追加</li> <li>TEMPSENSE項追加</li> <li>DACに対して精度特性表更新</li> <li>AC項で表更新</li> <li>周辺機能接触制御器特性 - 動作定格の表を更新</li> <li>UPDI最大ビット速度 対 VDDの表を追加</li> </ul> |
| 代表特性   | ・温度感知器誤差 対 温度±3σの図追加<br>・TWI SDA保持時間 対 温度の図追加                                                                                                                                                                                                                                                                                        |

**注1**: ATtiny1616/3216データシート(DS40001997C)と比べた時にだけ適用する変更 **注2**: ATtiny1617/3217データシート(DS40001999C)と比べた時にだけ適用する変更

## 41.2. 追補 - 廃止された改訂履歴

注: ピン数で編成された文書からの文書構造変更のため、参考として以下の文書履歴が提供されます。

- ・ATtiny1614データシート(DS40001995B)
- ・ATtiny1616/3216データシート (DS40001997C)
- ・ATtiny1617/3217データシート (DS40001999C)

#### 41.2.1. ATtiny1616/3216 - DS40001997

#### 廃止された公布DS40001997A - 2018年6月

| 章    | 変更   |
|------|------|
| 文書全般 | 初回公開 |

注: ATtiny1616ディイスは前にMicrochip文書40001893改訂C(ATtiny1617/1616/1614ディイス共通データシート)で記述されていました。 ATtiny3216とATtiny3217のディイスの導入で、40001893改訂Cは以下の3つの新しいデータシートによって置き換えられました。

- ATtiny1617 & ATtiny3217
- ・ATtiny1616とATtiny3216 (本文書、DS40001997)
- ATtiny1614

#### 廃止された公布DS40001997B - 2018年6月

| 章 | 変更                                                                                    |
|---|---------------------------------------------------------------------------------------|
|   | 以下のこれらの障害情報は実際にATtiny3216改訂Cから取り除かれました。 ・ADC: ADC禁止時に立往生する保留中の事象 ・CCL、RTC、USARTに対する全て |

#### 廃止された公布DS40001997C - 2019年7月

| 章            | 変更                                                                                                                  |
|--------------|---------------------------------------------------------------------------------------------------------------------|
| 文書           | ・編集上の更新                                                                                                             |
| デッバイス        | ・序説 - 車載データシートについての注を追加 - 全てのtinyAVR 0及び1系データシートと合わせるために文章を変更 ・保持力寿命値更新 ・データシート説明文書章追加 ・注文情報を移動 ・入出力多重化と考察を更新       |
| 構成設定と使用者ヒューズ | ・CRCAPPDISとCRCBOOTDISをCRCSRCで置換 ・TOUTDISビットで文章を明確化、16Kバイト デバイスに対する注を追加 ・RSTPINCFG:GPIOにヒューズ設定した時にシステム リセット後の時間制限を説明 |
| PORTMUX      | ・欠けていた情報で更新                                                                                                         |
| BOD - 低電圧検出器 | ・最小値と最大値で特性付けされない基準を削除<br>・電気的特性に代表値と参照基準に対する注を追加                                                                   |
| VREF - 基準電圧  | ・欠けていたCTRLCとCTRLDのレシブスタを追加                                                                                          |
| TCA          | ・代替WOnt°ンについての注を追加                                                                                                  |
| USART        | ・単線動作を明確化<br>・送信部禁止についての文章を明確化                                                                                      |
| SPI          | ・SPI SSピンについての機能を明確化                                                                                                |
| CRCSCAN      | ・欠けていたMODEビット領域を追加                                                                                                  |
| CCL          | ・割り込みへの言及を削除                                                                                                        |
| AC - アナログ比較器 | ・正と負の入力数を修正                                                                                                         |
| UPDI         | ・システムリセット後の期間に禁止されるGPIO機能をmsからクロック周期数に変更                                                                            |
| 電気的特性        | ・全般動作定格でチップ消去についての注を追加<br>・PTCチャネル数を修正                                                                              |
| 障害情報         | ・障害情報を独立した文書に移動                                                                                                     |
| 注文情報         | ・製品頁リンクと注文符号と共に更新                                                                                                   |
| 製品識別システム     | ・チューフ、とトレイ梱包媒体で更新                                                                                                   |
| 外囲器図         | ・外囲器図をMicrochip規格に更新                                                                                                |

## 41.2.2. ATtiny1617/3217 - DS40001999

## 廃止された公布DS40001999A - 2018年6月

| 章    | 変更   |
|------|------|
| 文書全般 | 初回公開 |

**注**: ATtiny1617デバイスは以前にMicrochip文書40001893改訂C(ATtiny1617/1616/1614デバイス用共通データシート)で記述されていました。

ATtiny3216とATtiny3217のデバイスの導入で、40001893改訂Cは以下の3つの新しいデータシートによって置き換えられました。

- ・ATtiny1617とATtiny3217 (本文書、DS40001999)
- ATtiny1616 & ATtiny3216
- ATtiny1614

## 廃止された公布DS40001999B - 2018年6月

| 章              | 変更                                                                                    |
|----------------|---------------------------------------------------------------------------------------|
| ATtiny3217障害情報 | 以下のこれらの障害情報は実際にATtiny3217改訂Cから取り除かれました。 ・ADC: ADC禁止時に立往生する保留中の事象 ・CCL、RTC、USARTに対する全て |

#### 廃止された公布DS40001999C - 2019年7月

| 章            | 変更                                                                                                                                                                                      |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 文書           | ・編集上の更新                                                                                                                                                                                 |
| デバイス         | <ul> <li>・序説</li> <li>- 車載データシートについての注を追加</li> <li>- 全てのtinyAVR 0及び1系データシートと合わせるために文章を変更</li> <li>・保持力寿命値更新</li> <li>・データシート説明文書章追加</li> <li>・注文情報を移動</li> <li>・入出力多重化と考察を更新</li> </ul> |
| 構成設定と使用者ヒューズ | ・CRCAPPDISとCRCBOOTDISをCRCSRCで置換<br>・TOUTDISビットで文章を明確化、16Kバイト デバイスに対する注を追加<br>・RSTPINCFG: GPIOにヒューズ設定した時にシステム リセット後の時間制限を説明                                                              |
| PORTMUX      | ・欠けていた情報で更新                                                                                                                                                                             |
| BOD - 低電圧検出器 | ・最小値と最大値で特性付けされない基準を削除<br>・電気的特性に代表値と参照基準に対する注を追加                                                                                                                                       |
| VREF - 基準電圧  | ・欠けていたCTRLCとCTRLDのレジスタを追加                                                                                                                                                               |
| TCA          | ・代替WOnt°ンについての注を追加                                                                                                                                                                      |
| USART        | <ul><li>・単線動作を明確化</li><li>・送信部禁止についての文章を明確化</li></ul>                                                                                                                                   |
| SPI          | ・SPI SSピンについての機能を明確化                                                                                                                                                                    |
| CRCSCAN      | ・支援されないBACKGROUNDとCONTINUOUSの走査機能を削除                                                                                                                                                    |
| CCL          | ・割り込みへの言及を削除                                                                                                                                                                            |
| AC - アナログ比較器 | ・正と負の入力数を修正                                                                                                                                                                             |
| UPDI         | ・システムリセット後の期間に禁止されるGPIO機能をmsからクロック周期数に変更                                                                                                                                                |
| 電気的特性        | ・全般動作定格でチップ消去についての注を追加                                                                                                                                                                  |
| 障害情報         | ・障害情報を独立した文書に移動                                                                                                                                                                         |
| 注文情報         | ・製品頁リンクと注文符号と共に更新                                                                                                                                                                       |
| 製品識別システム     | ・チューフ゛とトレイ梱包媒体で更新                                                                                                                                                                       |
| 外囲器図         | ・外囲器図をMicrochip規格に更新                                                                                                                                                                    |

## Microchipウェブ サイト

Microchipはhttp://www.microchip.com/で当社のウェブ サ小経由でのオンライン支援を提供します。このウェブ サ小はお客様がファイルや情報を容易に利用可能にするのに使われます。利用可能な情報のいくつかは以下を含みます。

- ・製品支援 データシートと障害情報、応用記述と試供プログラム、設計資源、使用者の手引きとハートヴェア支援資料、最新ソフトヴェア配布と保管されたソフトヴェア
- ・全般的な技術支援 良くある質問(FAQ)、技術支援要求、オンライン検討グループ、Microchip設計協力課程会員一覧
- ・Microchipの事業 製品選択器と注文の手引き、最新Microchip報道発表、セミナーとイベントの一覧、Microchip営業所の一覧、代理店と代表する工場

## 製品変更通知サービス

Microchipの製品変更通知サービスはMicrochip製品を最新に保つのに役立ちます。加入者は指定した製品系統や興味のある開発ツールに関連する変更、更新、改訂、障害情報がある場合に必ず電子メール通知を受け取ります。

登録するにはhttp://www.microchip.com/pcnへ行って登録指示に従ってください。

## お客様支援

Microchip製品の使用者は以下のいくつかのチャネルを通して支援を受け取ることができます。

- 代理店または販売会社
- ・ 最寄りの営業所
- ・組み込み解決技術者(ESE:Embedded Solutions Engineer)
- 技術支援

お客様は支援に関してこれらの代理店、販売会社、またはESEに連絡を取るべきです。最寄りの営業所もお客様の手助けに利用できます。営業所と位置の一覧はこの資料の後ろに含まれます。

技術支援はhttp://www.microchip.com/supportでのウェブ サ小を通して利用できます。

## 製品識別システム

注文する、または例えば、価格や納品の情報を得るには工場または一覧にされた販売代理店にお問い合わせください。



注: テープとリールの識別子は目録部品番号記述でだけ現れます。この識別子は注文目的に使われます。テープとリール選択で利用可能な外囲器についてはお客様のMicrochip販売代理店で調べてください。

# Microchipデバイス コード保護機能

Microchipデバイスでの以下のコード保護機能の詳細に注意してください。

- ・Microchip製品はそれら特定のMicrochipデータシートに含まれる仕様に合致します。
- ・Microchipは意図した方法と通常条件下で使われる時に、その製品系統が今日の市場でその種類の最も安全な系統の1つであると考えます。
- ・コート、保護機能を破るのに使われる不正でおそらく違法な方法があります。当社の知る限りこれらの方法の全てはMicrochipのデータ シートに含まれた動作仕様外の方法でMicrochip製品を使うことが必要です。おそらく、それを行う人は知的財産の窃盗に関与しています。
- ・Microchipはそれらのコードの完全性について心配されているお客様と共に働きたいと思います。
- ・Microchipや他のどの半導体製造業者もそれらのコードの安全を保証することはできません。コード保護は当社が製品を"破ることができない"として保証すると言うことを意味しません。

コート、保護は常に進化しています。Microchipは当社製品のコート、保護機能を継続的に改善することを約束します。Microchipのコート、保護機能を破る試みはデジタルシニアム著作権法に違反するかもしれません。そのような行為があなたのソフトウェアや他の著作物に不正なアクセスを許す場合、その法律下の救済のために訴権を持つかもしれません。

## 法的通知

デバイス応用などに関してこの刊行物に含まれる情報は皆さまの便宜のためにだけ提供され、更新によって取り換えられるかもしれません。皆さまの応用が皆さまの仕様に合致するのを保証するのは皆さまの責任です。Microchipはその条件、品質、性能、商品性、目的適合性を含め、明示的にも黙示的にもその情報に関連して書面または表記された書面または黙示の如何なる表明や保証もしません。Microchipはこの情報とそれの使用から生じる全責任を否認します。生命維持や安全応用でのMicrochipデバイスの使用は完全に購入者の危険性で、購入者はそのような使用に起因する全ての損害、請求、訴訟、費用からMicrochipを擁護し、補償し、免責にすることに同意します。他に言及されない限り、Microchipのどの知的財産権下でも暗黙的または違う方法で許認可は譲渡されません。

## 商標

Microchipの名前とロゴ、Mcicrochipロゴ、Adaptec、AnyRate、AVR、AVRロゴ、AVR Freaks、BesTime、BitCloud、chipKIT、chipKITロコ、CryptoMemory、CryptoRF、dsPIC、FlashFlex、flexPWR、HELDO、IGLOO、JukeBlox、KeeLoq、Kleer、LANCheck、LinkMD、maXStylus、maXTouch、MediaLB、megaAVR、Microsemi、Microsemiロゴ、MOST、MOSTロゴ、MPLAB、OptoLyzer、PackeTime、PIC、picoPower、PICSTART、PIC32ロゴ、PolarFire、Prochip Designer、QTouch、SAM-BA、SenGenuity、SpyNIC、SST、SSTロゴ、Super Flash、Symmetricom、SyncServer、Tachyon、TempTracker、TimeSource、tinyAVR、UNI/O、Vectron、XMEGAは米国と他の国に於けるMicrochip Technology Incor poratedの登録商標です。

Adjacent Key Suppression、AKS、Analog-for-the-Digital Age、Any Capacitor、AnyIn、AnyOut、BlueSky、BodyCom、CodeGuard、CryptoAuthentication、CryptoCompanion、CryptoController、dsPICDEM、dsPICDEM.net、Dynamic Average Matching、DAM、EC AN、EtherGREEN、In-Circuit Serial Programming、ICSP、INICnet、Inter-Chip Connectivity、JitterBlocker、KleerNetロゴ、memBrain、Mindi、MiWi、MPASM、MPF、MPLAB Certifiedロゴ、MPLAB、MPLINK、MultiTRAK、NetDetach、Omniscient Code Generation、PICDEM、PICDEM.net、PICkit、PICtail、PowerSmart、PureSilicon、QMatrix、REALICE、Ripple Blocker、SAM-ICE、Serial Quad I/O、SMART-I.S.、SQI、SuperSwitcher、SuperSwitcher II、Total Endurance、TSHARC、USBCheck、VariSense、View Sense、WiperLock、Wireless DNA、ZENAは米国と他の国に於けるMicrochip Technology Incorporatedの商標です。

SQTPは米国に於けるMicrochip Technology Incorporatedの役務標章です。

Adaptecロゴ、Frequency on Demand、Silicon Storage Technology、Symmcomは他の国に於けるMicrochip Technology Inc.の登録商標です。

GestICは他の国に於けるMicrochip Technology Inc.の子会社であるMicrochip Technology Germany II GmbH & Co. KGの登録商標です。

ここで言及した以外の全ての商標はそれら各々の会社の所有物です。

© 2020年、Microchip Technology Incorporated、米国印刷、不許複製

## 品質管理システム

Microchipの品質管理システムに関する情報についてはhttp://www.microchip.com/qualityを訪ねてください。

日本語© HERO 2024.

本データシートはMicrochipのATtiny3216/3217英語版データシート(DS40002205A-2020年5月)の翻訳日本語版です。日本語では不自然となる重複する形容表現は省略されている場合があります。日本語では難解となる表現は大幅に意訳されている部分もあります。必要に応じて一部加筆されています。頁割の変更により、原本より頁数が少なくなっています。

汎用入出力ポートの出力データレジスタとピン入力は、対応関係からの理解の容易さから出力レジスタと入力レジスタで統一表現されています。一部の用語がより適切と思われる名称に変更されています。必要と思われる部分には()内に英語表記や略称などを残す形で表記しています。

青字の部分はリンクとなっています。一般的に赤字の0,1は論理0,1を表します。その他の赤字は重要な部分を表します。

原書に対して若干構成が異なるため、一部の節/項番号が異なります。



# 世界的な販売とサービス

本計

2355 West Chandler Blvd. Chandler, AZ 85224-6199

Tel: 480-792-7200 Fax: 480-792-7277

技術支援:

http://www.microchip.com/ support

ウェブ アドレス:

http://www.microchip.com

アトランタ

Duluth, GA

Tel: 678-957-9614 Fax: 678-957-1455

オースチン TX

Tel: 512-257-3370

ボストン

Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088

シカゴ Itasca, IL

Tel: 630-285-0071 Fax: 630-285-0075

ダラス

Addison, TX Tel: 972-818-7423 Fax: 972-818-2924

デトロイト

Novi, MI

Tel: 248-848-4000

ヒューストン TX

Tel: 281-894-5983

インデアナポリス

Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453 Tel: 317-536-2380

ロサンセ・ルス

Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608 Tel: 951-273-7800

□−IJ− NC

Tel: 919-844-7510

ニュ**ーヨーク** NY

Tel: 631-435-6000

サンホセ CA

Tel: 408-735-9110 Tel: 408-436-4270 カナダ - トロント

Tel: 905-695-1980 Fax: 905-695-2078 オーストラリア - シト゛ニー

亜細亜/太平洋

Tel: 61-2-9868-6733

中国 - 北京

Tel: 86-10-8569-7000

中国 - 成都

Tel: 86-28-8665-5511

中国 - 重慶

Tel: 86-23-8980-9588

中国 - 東莞

Tel: 86-769-8702-9880

中国 - 広州

Tel: 86-20-8755-8029

中国 - 杭州

Tel: 86-571-8792-8115

中国 - 香港特別行政区

Tel: 852-2943-5100

中国 - 南京

Tel: 86-25-8473-2460

中国 - 青島

Tel: 86-532-8502-7355

中国 - 上海

Tel: 86-21-3326-8000

中国 - 瀋陽

Tel: 86-24-2334-2829

中国 - 深圳

Tel: 86-755-8864-2200

中国 - 蘇州

Tel: 86-186-6233-1526

中国 - 武漢

Tel: 86-27-5980-5300

中国 - 西安

Tel: 86-29-8833-7252

中国 - 廈門

Tel: 86-592-2388138

中国 - 珠海

Tel: 86-756-3210040

亜細亜/太平洋 イント - ハンガロール

Tel: 91-80-3090-4444

イント - ニューテリー

Tel: 91-11-4160-8631

イント - プネー

Tel: 91-20-4121-0141

日本 - 大阪

Tel: 81-6-6152-7160

日本 - 東京

Tel: 81-3-6880-3770

韓国 - 大邱 Tel: 82-53-744-4301

韓国 - ソウル

Tel: 82-2-554-7200

マレーシア - クアラルンプール

Tel: 60-3-7651-7906

マレーシア - ペナン

Tel: 60-4-227-8870

フィリピン - マニラ Tel: 63-2-634-9065

シンカ゛ホ゜ール

Tel: 65-6334-8870

台湾 - 新竹

Tel: 886-3-577-8366

台湾 - 高雄

Tel: 886-7-213-7830

台湾 - 台北

Tel: 886-2-2508-8600

タイ - バンコク

Tel: 66-2-694-1351

ベトナム - ホーチミン

Tel: 84-28-5448-2100

オーストリア - ヴェルス

Tel: 43-7242-2244-39

Fax: 43-7242-2244-393

欧州

デンマーク - コペンハーケ゛ン

Tel: 45-4485-5910

Fax: 45-4485-2829

フィンラント - エスホー

Tel: 358-9-4520-820

フランス - パリ

Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

ト・イツ - カ・ルヒング

Tel: 49-8931-9700

ドイツ - ハーン

Tel: 49-2129-3766400

ト・イツ - ハイルブロン

Tel: 49-7131-72400

ドイツ - カールスルーエ

Tel: 49-721-625370

ドイツ - ミュンヘン

Tel: 49-89-627-144-0

Fax: 49-89-627-144-44

ト・イツ - ローセ・ンハイム

Tel: 49-8031-354-560

イスラエル - ラーナナ Tel: 972-9-744-7705

イタリア – ミラノ

Tel: 39-0331-742611

Fax: 39-0331-466781

イタリア - パト゛ハ゛

Tel: 39-049-7625286

オランダ - デルーネン

Tel: 31-416-690399

Fax: 31-416-690340

ノルウェー - トロンハイム

Tel: 47-72884388

ホ<sup>°</sup>ーラント ー ワルシャワ

Tel: 48-22-3325737

ルーマニア - ブカレスト Tel: 40-21-407-87-50

スペペイン - マトブリートブ

Tel: 34-91-708-08-90 Fax: 34-91-708-08-91

スウェーテン - イェーテホリ

Tel: 46-31-704-60-40

スウェーテン – ストックホルム

Tel: 46-8-5090-4654

イキ・リス - ウォーキンカ・ム Tel: 44-118-921-5800 Fax: 44-118-921-5820