



# 暫定データシート

## 序説

AVR<sup>®</sup> EA系統のAVR64EA28/32/48マイクロコントローラは20MHzまでのクロック速度で動くハートウェア乗算器を持つAVR<sup>®</sup> CPUを使っています。これらは64Kパイトの7ラッシュメモリ、6KパイトのSRAM、512パイトのEEPROMを備えています。このマイクロコントローラは28、32、48ピン外囲器で利用可能です。AVR<sup>®</sup> EA系統は事象システム、正確なアナログ部分系、進化したデジタル周辺機能を含む柔軟で低電力な基本設計を持つMicrochipの最新技術を使います。

# 系統概要

下図はピン数変種とメモリ量で並べてAVR® EAデバイスを示します。

- ・これらのデバイスが完全なピンと機能の互換のため、垂直方向移植はコード変更なしで可能です。
- ・左への水平方向移植はピン数、従って利用可能な機能を減らします。



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

AVR® EA系のデバイスの名前は次のように復号されます。



(訳注)・本書はAVR64EA28/32/48シリコン障害とデータシート説明(DS80001048C)の内容を含みます。

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

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

# メモリ概要

下表は系統全体のメモリ概要を示しますが、この先の文書はAVR64EA28/32/48デバイスだけを記述します。

### 表1. メモリ概要

| パモリ形式                    | AVR16EA28/32/48 | AVR32EA28/32/48 | AVR64EA28/32/48 |
|--------------------------|-----------------|-----------------|-----------------|
| フラッシュ メモリ (書き中読み(RWW)領域) | 16Kバイト (12Kバイト) | 32Kバイト (28Kバイト) | 64Kバイト (56Kバイト) |
| SRAM                     | 2Kバイト           | 4Kバイト           | 6Kバイト           |
| EEPROM                   |                 | 512/ㆍイト         |                 |
| 使用者列                     |                 | 64시 イト          |                 |

# 周辺機能概要

下表はAVR® AE系統全体の周辺機能概要を示しますが、この先の文書はAVR64EA28/32/48デバイスだけを記述します。

| 表2. 周辺機能概要                   |               |                                      |                                     |                                                    |  |
|------------------------------|---------------|--------------------------------------|-------------------------------------|----------------------------------------------------|--|
| 機能項目                         | 型番            | AVR64EA28<br>AVR32EA28<br>AVR16EA28  | AVR64EA32<br>AVR32EA32<br>AVR16EA32 | AVR64EA48<br>AVR32EA48<br>AVR16EA48                |  |
| ピン数                          |               | 28                                   | 32                                  | 48                                                 |  |
| 最大動作周波数 (MHz)                |               | 20                                   |                                     |                                                    |  |
| 16ビット タイマ/カウンタA型 (TCA)       |               |                                      | 2                                   |                                                    |  |
| 16ビット タイマ/カウンタB型 (TCB)       |               |                                      | 4                                   |                                                    |  |
| 実時間計数器 (RTC)                 |               |                                      | 1                                   |                                                    |  |
| USART/SPI主装置                 |               |                                      | 3                                   |                                                    |  |
| SPI主装置/従装置                   |               | 1                                    |                                     |                                                    |  |
| TWI/I <sup>2</sup> C         | ( <b>注1</b> ) |                                      | 1                                   | -                                                  |  |
| 12ビット差動ADC (チャネル数)           |               | 1 (20)                               | 1 (24)                              | 1 (28)                                             |  |
| 10t*yhDAC                    |               |                                      | 1                                   |                                                    |  |
| アナログ比較器 (AC)                 |               | 2                                    |                                     |                                                    |  |
| 構成設定可能な注文論理回路 (CCL) (LUT数)   |               |                                      | 4                                   |                                                    |  |
| ウォッチドック゛ タイマ(WDT)            |               |                                      | 1                                   |                                                    |  |
| 事象システム チャネル数                 |               |                                      | 6                                   |                                                    |  |
| 汎用入出力 (GPIO) (入力数/出力数)       | ( <b>注2</b> ) | 24/23                                | 28/27                               | 42/41                                              |  |
| т°−ŀ                         |               | PA7~0<br>PC3~0<br>PD7~0<br>PF7,6,1,0 | PA7~0<br>PC3~0<br>PD7~0<br>PF7~0    | PA7~0<br>PB5~0<br>PC7~0<br>PD7~0<br>PE3~0<br>PF7~0 |  |
| 外部割り込み                       |               | 24                                   | 28                                  | 42                                                 |  |
| CRC走査 (CRCSCAN)              |               |                                      | 1                                   |                                                    |  |
| 統一プログラム/デバッグ インターフェース (UPDI) |               |                                      | 1                                   |                                                    |  |

注1: TWI/I<sup>2</sup>Cは異なるピンで主装置と従装置として同時に動かすことができます。

注2: PF6/RESETピンは入力専用です。

# 特徴

- $\bullet \ \mathrm{AVR}^{\mathbb{R}} \ \mathrm{CPU}$ 
  - 最大20MHzで走行
  - 単一周期I/Oレジスタ アクセス
  - 2段階の割り込み制御器
  - 2周期ハートウェア乗算器
  - 供給電圧範囲: 1.8~5.5V
- メモリ
  - 真の書き込み中の読み込み動作を持つ実装書き換え可能な64Kバイト(32K語)のフラッシュ メモリ
  - 6KバイトのSRAM
  - 512パイトのEEPROM
  - チップ消去間もデータを保持してデバイスが施錠中でも書くことができる不揮発性メモリ内の64バイトの使用者列
  - 書き込み/消去耐久性
    - ・フラッシュ:メモリ 10,000回
    - EEPROM: 100,000回
  - データ保持力:55℃で40年
- ・システム
  - 電源ONリセット(POR)回路
  - 使用者設定可能な基準を持つ低電圧検出器 (BOD)
  - BOD基準越えで設定可能な基準での割り込みを持ち使用者設定可能な基準を持つ電圧水準監視部 (VLM)
  - クロック障害検出(CFD)
  - クロック任意選択
    - ・20MHzまで選択可能な周波数を持つ高精度内部高周波数発振器(OSCHF)
       内部発振器精度を改善する自動調整
    - 内部超低電力32.768kHz発振器 (OSC32K)
    - ・外部32.768kHzクリスタル用発振器 (XOSC32K)
    - ・外部クロック入力
    - ・クロック障害検出を持つ外部高周波数クリスタル用発振器(XOSCHF)
  - 単一ピンの統一プログラム/デバッグ インターフェース (UPDI)
  - 3つの休止動作形態
    - ・即時起き上がりのために全ての周辺機能が走行しているアイドル
    - ・選んだ周辺機能の構成設定可能な動作を持つスタンバイ
    - ・完全なデータ保持力を持つパワーダウン
- ・周辺機能
  - PWMと波形生成用に3つの比較チャネルを持つ2つの16ビットタイマ/カウンタA型 (TCA)
  - 捕獲と信号測定用に捕獲入力を持つ4つの16ビットタイマ/カウンタB型 (TCB)
  - 外部クリスタルまたは内部発振器で走行することができる1つの16ビット実時間計数器 (RTC)
  - 分数ボーレート生成器、自動ボーレート、フレーム開始検出を持つ3つのUSART
  - -1つの主装置/従装置直列周辺インターフェース (SPI)
  - 2重アドレス一致を持つ1つの2線インターフェース (TWI)
  - ・ 独立した主装置と従装置の動作 (2元動作)
    - Philips I<sup>2</sup>C互換
    - ・標準動作 (Sm, 100kHz)
    - ・高速動作 (Fm, 400kHz)
    - ・高速動作プラス (Fm+, 1MHz)
  - CPUから独立して予測可能な周辺機能相互合図用の事象システム
  - 最大4つの設定可能な参照表(LUT)を持つ構成設定可能な注文論理回路(CCL)
  - 12ビット、375kspsの1つの差動A/D変換器 (ADC)
    - ・入力信号で1~16倍の利得の設定可能な利得増幅器(PGA)を内包
  - 1つの10ビットD/A変換器 (DAC)
  - 窓比較機能を持つ2つのアナログ比較器 (AC)
  - 多数の電圧参照基準
    - 1.024V
    - 2.048V
    - 2.500V
    - 4.096V
    - VREFAVDD
  - 自動化された巡回冗長検査(CRC)フラッシュ プログラム メモリ走査
  - 窓動作と独立したチップ上発振器を持つウォッチトック、タイマ (WDT)

- 全ての汎用ピンでの外部割り込み

#### ・I/Oと外囲器

- 24~42本の設定可能なI/Oピン
- 28ピンのSPDIP、28リードのSSOP、28パッドのVQFN 4×4mm
- 32パッドのVQFN 5×5mmと32リードのTQFP 7×7mm
- 48ハットのVQFN 6×6mmと48リートのTQFP 7×7mm
- ・温度範囲
  - 工業:周囲 -40~85℃
  - 拡張:周囲 -40~125℃

| 次 |
|---|
| 次 |

|     | 序説 ・・・・・                                                                                                             | 1           |
|-----|----------------------------------------------------------------------------------------------------------------------|-------------|
|     | 系統概要 •••••                                                                                                           | 1           |
|     | メモリ概要・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                            | 2           |
|     | 周辺機能概要 •••••                                                                                                         | 2           |
|     | 特徵                                                                                                                   | 3           |
| 1.  | 特徴 ····································                                                                              | 8           |
| 2.  | ピン配置 ・・・・・                                                                                                           | 9           |
| Ζ.  |                                                                                                                      | ~           |
|     | <ul> <li>2.1. 28L°ンSPDIP • 28IJ−ト SSOP • • • • • • • • • • • • • • • • • • •</li></ul>                               | 9           |
|     | 2.2.       28/ペッドVQFN         2.3.       32/ペッドVQFN・32IJ−ドTQFP                                                       | 9           |
|     | 2.4. 48/\°y\ <sup>*</sup> VQFN·48 <sup>y</sup> -1 <sup>*</sup> TQFP · · · · · · · · · · · · · · · · · · ·            | 10          |
| ~   |                                                                                                                      |             |
| 3.  | <b>入出力多重化と考察</b> ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                |             |
|     |                                                                                                                      | 11          |
| 4.  |                                                                                                                      | 2           |
|     |                                                                                                                      | 12          |
|     |                                                                                                                      | 12          |
|     | 4.3. RESET用接続 ····································                                                                   |             |
|     | <b>4.4.</b> UPDIプログラミング用接続 ・・・・・                                                                                     | 13          |
|     | <ul><li>4.5. 外部クリスタル発振子接続・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・</li></ul>                                              | 14          |
| _   | <b>4.6.</b> 外部基準電圧接続 · · · · · · · · · · · · · · · · · · ·                                                           | 15          |
| 5.  | <b>電力区域</b> ····································                                                                     | .6          |
|     | 5.1. 電源投入                                                                                                            | 16          |
| 6.  | <b>規定 ······</b> 1                                                                                                   |             |
|     | 6.1. 数字表記法 ······                                                                                                    |             |
|     | 6.2. メモリの大きさと形式 ・・・・・                                                                                                | 17          |
|     | 6.3. 周波数と時間 ・・・・・ ]                                                                                                  | 17          |
|     |                                                                                                                      | 18          |
|     | 6.5. ADCパラメータ定義・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                  | 19          |
| 7.  | AVR <sup>®</sup> CPU       2         7.1. 特徴・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                     | 20          |
|     | 7.1. 特徴                                                                                                              | 20          |
|     | 7.2. 概要                                                                                                              | 20          |
|     | 7.3. 基本構成                                                                                                            | 20          |
|     | <b>7.4. 機能的な説明</b> ····································                                                              | 21          |
|     | 7.5.     レジスタ要約     2       7.6.     レジスタ説明     2                                                                    | 24          |
|     |                                                                                                                      |             |
| 8.  | <u>/</u> モリ                                                                                                          | 27          |
|     | 8.1. 概要 ···································                                                                          | 27          |
|     | 8.2.                                                                                                                 | 27          |
|     | 8.3. 実装書き換え可能なフラッシュ プログラム メモリ・・・・・ 2                                                                                 | 27          |
|     | 8.4.         SRAMデータ メモリ         2           8.5.         EEPROMデータ メモリ         2                                    | 28          |
|     |                                                                                                                      | 28<br>20    |
|     | 8.6. USERROW - 使用者列 ······ 2<br>8.7. LOCK - メモリ領域アクセス保護 ····· 2                                                      | 20<br>20    |
|     | 8.8. FUSE - 構成設定と使用者のヒュース <sup>*</sup> ・・・・・・・*                                                                      | 20<br>20    |
|     | 8.0. FUSE - (構成設定と使用者のLI-A ····································                                                      | 30          |
|     | 8.9. SIGROW - 識票列<br>8.10. I/Oメモリ                                                                                    | 27          |
| 0   |                                                                                                                      | )<br>)<br>) |
| 9.  | GPR - 汎用レジスタ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                     | 00<br>20    |
|     | 9.1. レクスジ安市 (1) (1) (1) (1) (1) (1) (1) (1) (1) (1)                                                                  | 59<br>40    |
| 10  | 9.2. レッス>記明<br>周辺機能と基本構造 ····································                                                        | ±0          |
| 10. | 周辺機能と基本構造 444444444444444444444444444444444444                                                                       | 11          |
|     | 10.1.       周辺機能アドレス配置       4         10.2.       割り込みベクタ配置       4                                                 | 11<br>40    |
|     | 10.2. 割り込みへ 79配直 ************************************                                                                | 12<br>4 C   |
|     | 10.3. SYSCFG - システム構成設定 ····································                                                         | ¥3          |
| 11. | NVMCTRL - 不揮発性メモリ制御器 ······ 4                                                                                        | 4           |
|     | 11.1.       特徴       4         11.2.       概要       4         11.3.       機能的な説明・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ | 14          |
|     | 11.2. 概要                                                                                                             | 14          |
|     | 11.3. 機能的な説明・・・・・・・・・・・・・・・・・・・・・・・                                                                                  | 14          |

|       | 11.4.          | <b>レジスタ要約</b> ・・・・・・・・・・・・・・・・・51                                                                                                                       |
|-------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 11.5.          | <b>レジスタ説明</b> ····· 52                                                                                                                                  |
| 12.   | CI KC          | <b>TRL - クロック制御器 ・・・・・・・・・・</b> 56                                                                                                                      |
|       | 12.1.          | 特徴                                                                                                                                                      |
|       | 12.2.          | 概要                                                                                                                                                      |
|       | 12.2.          | 微安<br>機能的な説明 ······ 57                                                                                                                                  |
|       | 12.3.<br>12.4. | 後にりな説明<br>レジスタ要約・・・・・・・・・・・・・・・・・・・・・・・・・62                                                                                                             |
|       |                | レジスダ安約<br>レジスタ説明 ······63                                                                                                                               |
|       | 12.5.          |                                                                                                                                                         |
| 13.   |                | TRL - 休止制御器 ····· 70                                                                                                                                    |
|       | 13.1.          | 特徴                                                                                                                                                      |
|       | 13.2.          | 概要 ••••• 70                                                                                                                                             |
|       | 13.3.          | <b>機能的な説明</b> ······ 70                                                                                                                                 |
|       | 13.4.          | レジスタ要約 ····································                                                                                                             |
|       | 13.5.          | <b>レジスタ説明</b> ······ 74                                                                                                                                 |
| 14    | RSTC           | TRI - 비ヤット制御哭 ····· 75                                                                                                                                  |
|       | 14.1.          | 特徴 ····································                                                                                                                 |
|       | 14.2.          | 概要 •••••••                                                                                                                                              |
|       | 14.3.          | 機能的た道明                                                                                                                                                  |
|       | 14.4.          |                                                                                                                                                         |
|       | 14.5.          | 機能的な説明       75         レジスタ要約       78         レジス9説明       79                                                                                         |
|       |                |                                                                                                                                                         |
| 15.   |                | NT - CPU割り込み制御器 ······ 80                                                                                                                               |
|       | 15.1.          | 特徴 80<br>概要 80                                                                                                                                          |
|       | 15.2.          | 概要 80                                                                                                                                                   |
|       | 15.3.          | 機能的な説明 ************************************                                                                                                             |
|       | 15.4.          | 機能的な説明 ····· 80<br>レジスタ要約 ···· 84<br>レジスタ説明 ···· 85                                                                                                     |
|       | 15.5.          | <b>レジスタ説明</b> ····· 85                                                                                                                                  |
| 16.   | <b>EVSY</b>    | S - 事象システム ····· 87                                                                                                                                     |
|       | 16.1.          | 特徴                                                                                                                                                      |
|       | 16.2.          | 概要 ••••• 87                                                                                                                                             |
|       | 16.3.          | 機能的な説明 ······ 88                                                                                                                                        |
|       | 16.4.          | <b>レジスタ要約</b> ・・・・・・・・・・・・・・・・・・・・・・91                                                                                                                  |
|       | 16.5.          | <b>レジスタ説明</b> ・・・・・・・・・・・・・・・・・・・・・・・92                                                                                                                 |
| 17.   | PORT           | TMUX - ポート多重化器 ····· 95                                                                                                                                 |
| • • • | 17.1.          | 概要                                                                                                                                                      |
|       | 17.2.          | vy<br>レジスタ要約 ······· 96                                                                                                                                 |
|       | 17.3.          | <b>レジスタ説明</b> ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                      |
| 10    |                |                                                                                                                                                         |
| 18.   | PURI           | - I/Oピン構成設定 ····· 100<br>特徴 ···· 100<br>概要 ···· 100                                                                                                     |
|       | 18.1.          | 特徴・・・・・・・・・・・・・・・・・・・・・・・・100                                                                                                                           |
|       |                | 概要 100                                                                                                                                                  |
|       | 18.3.          | 機能的な説明 ······ 101                                                                                                                                       |
|       | 18.4.          | レジスタ要約 – PORTx ······ 104<br>レジスタ説明 – PORTx ····· 105                                                                                                   |
|       | 18.5.          | レジスタ説明 - PORTx ····· 105                                                                                                                                |
|       | 18.6.          | レジスタ要約 – VPORTx ······ 112<br>レジスタ説明 – VPORTx ····· 113                                                                                                 |
|       | 18.7.          | レジスタ説明 - VPORTx ······ 113                                                                                                                              |
| 19.   | BOD            | - 低電圧検出器 · · · · · · · · · · · · · · · · · · ·                                                                                                          |
|       | 19.1.          | <b>特徴 ······</b> 115                                                                                                                                    |
|       | 19.2.          | 概要 •••••••115                                                                                                                                           |
|       | 19.3.          | <b>機能的な説明</b> ・・・・・・・・・・・・・・・・・・・・115                                                                                                                   |
|       | 19.4.          | <b>レジスタ要約</b> ・・・・・・・・・・・・・・・・・・・・117                                                                                                                   |
|       | 20.5.          | <b>レジスタ説明</b> ・・・・・・・・・・・・・・・・118                                                                                                                       |
| 20    | VRFF           | 概要115機能的な説明115レジスタ要約117レジスタ説明118- 基準電圧121特徴121機121機121しジスタ要約121レジスタ要約122レジスタ説明123- ウオッチドック、タイマ124                                                       |
| 20.   | 20.1           | 生 ~ モニ 121                                                                                                                                              |
|       | 20.2           | 概要                                                                                                                                                      |
|       | 20.2.          | # 121                                                                                                                                                   |
|       | 20.0.          | レジェント J. Control 121<br>レジェンタ 要約 199                                                                                                                    |
|       | 20.4.          | レジスを説明 122                                                                                                                                              |
| 01    |                | μ <sub>120</sub> μ <sub>1</sub> <sup>*</sup> μ |
| ΖΙ.   | VVDT           | - 'JŢŸŢſŸŸ ¥1 < · · · · · · · · · · · · · · · · 124                                                                                                     |

|                   | 21.1.                                                                                                                                                                                                                                                    | <b>特徴 ·····</b> 124                                                                                                                                                                                                                                                                                             |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | 21.2.                                                                                                                                                                                                                                                    | 概要 ••••••124                                                                                                                                                                                                                                                                                                    |
|                   | 21.3.                                                                                                                                                                                                                                                    | <b>機能的な説明</b> ・・・・・・・・・・・・・・・・・・・・・・124                                                                                                                                                                                                                                                                         |
|                   | 21.4.                                                                                                                                                                                                                                                    | <b>レジスタ要約・・・・・・・・・・・・・・・・・</b> 127                                                                                                                                                                                                                                                                              |
|                   | 21.5.                                                                                                                                                                                                                                                    | <b>レジスタ説明</b> ・・・・・・・・・・・・・・・・・・・・128                                                                                                                                                                                                                                                                           |
| 22.               | TCA -                                                                                                                                                                                                                                                    | - <b>16ビット タイマ/カウンタA型 ・・・・・・・・</b> 129                                                                                                                                                                                                                                                                          |
|                   | 22.1.                                                                                                                                                                                                                                                    | 特徴                                                                                                                                                                                                                                                                                                              |
|                   | 22.2.                                                                                                                                                                                                                                                    | 概要 ••••••••••••••••                                                                                                                                                                                                                                                                                             |
|                   | 22.3.                                                                                                                                                                                                                                                    | 機能的な説明 ······ 131                                                                                                                                                                                                                                                                                               |
|                   | 22.4.                                                                                                                                                                                                                                                    | レジスタ要約 - 標準動作 ・・・・・・・・・・・・・・138                                                                                                                                                                                                                                                                                 |
|                   | 22.5.                                                                                                                                                                                                                                                    | レジスタ説明 - 標準動作 ······ 139                                                                                                                                                                                                                                                                                        |
|                   | 22.6.                                                                                                                                                                                                                                                    | レジスタ要約 - 分割動作 ・・・・・・・・・・・・・・・148                                                                                                                                                                                                                                                                                |
|                   | 22.7.                                                                                                                                                                                                                                                    | レジスタ説明 - 分割動作 ······ 149                                                                                                                                                                                                                                                                                        |
| 00                |                                                                                                                                                                                                                                                          | - 16ビット タイマ/カウンタB型 ····· 155                                                                                                                                                                                                                                                                                    |
| Ζ٥.               | 23.1.                                                                                                                                                                                                                                                    | - 100 97 91 97 97 99 20 133 155                                                                                                                                                                                                                                                                                 |
|                   | 23.1.                                                                                                                                                                                                                                                    | 概要                                                                                                                                                                                                                                                                                                              |
|                   | 23.2.<br>23.3.                                                                                                                                                                                                                                           | 概要<br>機能的な説明 ····· 156                                                                                                                                                                                                                                                                                          |
|                   |                                                                                                                                                                                                                                                          | (成化中)/よ記り 100                                                                                                                                                                                                                                                                                                   |
|                   | 23.4.                                                                                                                                                                                                                                                    | レジスタ要約 ······ 161<br>レジスタ説明 ····· 162                                                                                                                                                                                                                                                                           |
| ~ ~               | 23.5.                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                 |
| 24.               |                                                                                                                                                                                                                                                          | - <b>実時間計数器 ······</b> 167                                                                                                                                                                                                                                                                                      |
|                   | 24.1.                                                                                                                                                                                                                                                    | 特徴     167       概要     167                                                                                                                                                                                                                                                                                     |
|                   | 24.2.                                                                                                                                                                                                                                                    | 概要 •••••• 167                                                                                                                                                                                                                                                                                                   |
|                   | 24.3.                                                                                                                                                                                                                                                    | <b><sup>7</sup><sup>7</sup><sup>7</sup></b> <sup>7</sup> <b><sup>7</sup></b> <sup>7</sup>                                                                                                                                                                                                                       |
|                   | 24.4.                                                                                                                                                                                                                                                    | <b>RTCの機能的な説明</b> ······ 168                                                                                                                                                                                                                                                                                    |
|                   | 24.5.                                                                                                                                                                                                                                                    | <b>PITの機能的な説明</b> ······ 168                                                                                                                                                                                                                                                                                    |
|                   | 24.6.                                                                                                                                                                                                                                                    | クリスタル誤差修正       169         事象       169                                                                                                                                                                                                                                                                        |
|                   | 24.7.                                                                                                                                                                                                                                                    | 事象                                                                                                                                                                                                                                                                                                              |
|                   | 24.8.                                                                                                                                                                                                                                                    | 割り込み                                                                                                                                                                                                                                                                                                            |
|                   | 24.9.                                                                                                                                                                                                                                                    | <b>休止形態動作</b> •••••• 170<br>同期 ••••• 170                                                                                                                                                                                                                                                                        |
|                   | 24.10.                                                                                                                                                                                                                                                   | 同期 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                                                                                                                                                                                         |
|                   |                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                 |
|                   | 24.11.                                                                                                                                                                                                                                                   | デバッグ操作 ・・・・・170                                                                                                                                                                                                                                                                                                 |
|                   | 24.11.<br>24.12.                                                                                                                                                                                                                                         | デバッグ操作 ・・・・・170                                                                                                                                                                                                                                                                                                 |
|                   | 24.12.<br>24.13.                                                                                                                                                                                                                                         | <b>デバッグ操作</b> 170<br>レジスタ要約 171<br>レジスタ説明 172                                                                                                                                                                                                                                                                   |
| 25.               | 24.12.<br>24.13.<br>USAF                                                                                                                                                                                                                                 | デバッグ操作 170<br>レジスタ要約 171<br>レジスタ説明 172<br>RT - 万能同期非同期送受信器・・・・・ 179                                                                                                                                                                                                                                             |
| 25.               | 24.12.<br>24.13.<br>USAR<br>25.1.                                                                                                                                                                                                                        | デバッグ操作 170<br>レジスタ要約 171<br>レジスタ説明 172<br>RT - 万能同期非同期送受信器 179<br>特徴 179                                                                                                                                                                                                                                        |
| 25.               | 24.12.<br>24.13.<br>USAF                                                                                                                                                                                                                                 | デバッグ操作170レジスタ要約171レジスタ説明172RT - 万能同期非同期送受信器・・・・179特徴179概要179                                                                                                                                                                                                                                                    |
| 25.               | 24.12.<br>24.13.<br><b>USAF</b><br>25.1.<br>25.2.<br>25.3.                                                                                                                                                                                               | デバッグ操作       170         レジスタ要約       171         レジス9説明       172         RT - 万能同期非同期送受信器・・・・       179         特徴       179         概要       179         機能的な説明       180                                                                                                                                    |
| 25.               | 24.12.<br>24.13.<br><b>USAF</b><br>25.1.<br>25.2.<br>25.3.<br>25.4.                                                                                                                                                                                      | デバッグ操作       170         レジスタ要約       171         レジス9説明       172         RT - 万能同期非同期送受信器・・・・       179         特徴       179         概要       179         機能的な説明       180                                                                                                                                    |
|                   | 24.12.<br>24.13.<br><b>USAF</b><br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.                                                                                                                                                                             | デバッグ操作170レジスタ要約171レジスタ説明172RT - 万能同期非同期送受信器・179特徴179機能的な説明179機能的な説明180レジスタ要約189レジスタ説明190                                                                                                                                                                                                                        |
|                   | 24.12.<br>24.13.<br><b>USAF</b><br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.                                                                                                                                                                             | デバッグ操作170レジスタ要約171レジスタ説明172RT - 万能同期非同期送受信器179特徴179概要179機能的な説明180レジスタ要約189レジスタ説明190直列周辺インターフェース199                                                                                                                                                                                                              |
|                   | 24.12.<br>24.13.<br><b>USAF</b><br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.                                                                                                                                                                             | デバッグ操作170レジスタ要約171レジスタ説明172RT - 万能同期非同期送受信器179特徴179概要179機能的な説明180レジスタ要約189レジスタ説明190直列周辺インターフェース199                                                                                                                                                                                                              |
|                   | 24.12.<br>24.13.<br>USAR<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI –                                                                                                                                                                           | デバッグ操作170レジスタ要約171レジスタ説明172RT - 万能同期非同期送受信器・179特徴179概要179機能的な説明180レジスタ要約189レジスタ要約190直列周辺インターフェース199概要199                                                                                                                                                                                                        |
|                   | 24.12.<br>24.13.<br>USAR<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI -<br>26.1.<br>26.2.<br>26.3.                                                                                                                                                | デバッグ操作170レジスタ要約171レジスタ説明172RT - 万能同期非同期送受信器・179特徴179概要179機能的な説明180レジスタ要約189レジスタ要約190直列周辺インターフェース199特徴199機要199機能的な説明200                                                                                                                                                                                          |
|                   | 24.12.<br>24.13.<br>USAR<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI -<br>26.1.<br>26.2.<br>26.3.                                                                                                                                                | デバッグ操作170レジスタ要約171レジスタ説明172RT - 万能同期非同期送受信器・179特徴179概要179機能的な説明180レジスタ要約189レジスタ要約190直列周辺インターフェース199特徴199機要199機能的な説明200                                                                                                                                                                                          |
| 26.               | 24.12.<br>24.13.<br>USAF<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI -<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.5.                                                                                                                              | デバッグ操作170レジスタ要約171レジスタ要約172RT - 万能同期非同期送受信器179特徴179概要179機能的な説明180レジスタ要約189レジスタ説明190直列周辺インターフェース199機能的な説明200レジスタ要約200レジスタ要約200レジスタ要約206レジスタ説明207                                                                                                                                                                 |
| 26.               | 24.12.<br>24.13.<br>USAF<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI –<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.5.                                                                                                                              | デバッグ操作170レジスタ要約171レジスタ要約172RT - 万能同期非同期送受信器179特徴179概要179機能的な説明180レジスタ要約189レジスタ説明190直列周辺インターフェース199機能的な説明200レジスタ要約200レジスタ要約200レジスタ要約206レジスタ説明207248201ビジス9説明207248201                                                                                                                                            |
| 26.               | 24.12.<br>24.13.<br>USAF<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI –<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.5.                                                                                                                              | デバッグ操作170レジスタ要約171レジスタ要約172RT - 万能同期非同期送受信器179特徴179概要179機能的な説明180レジスタ要約189レジスタ説明190直列周辺インターフェース199機能的な説明200レジスタ要約200レジスタ要約200レジスタ要約206レジスタ説明207248201ビジス9説明207248201                                                                                                                                            |
| 26.               | 24.12.<br>24.13.<br>USAF<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI –<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.5.                                                                                                                              | デバッグ操作170レジスタ要約171レジスタ要約172RT - 万能同期非同期送受信器179特徴179概要179機能的な説明180レジスタ要約189レジスタ説明190直列周辺インターフェース199機能的な説明200レジスタ要約200レジスタ要約200レジスタ要約206レジスタ説明207248201ビジス9説明207248201                                                                                                                                            |
| 26.               | 24.12.<br>24.13.<br>USAF<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI –<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.5.                                                                                                                              | デバッグ操作170レジスタ要約171レジスタ要約172RT - 万能同期非同期送受信器179特徴179概要179機能的な説明180レジスタ要約189レジスタ説明190直列周辺インターフェース199機能的な説明200レジスタ要約200レジスタ要約200レジスタ要約206レジスタ説明207248201ビジス9説明207248201                                                                                                                                            |
| 26.               | 24.12.<br>24.13.<br>USAF<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI –<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.5.                                                                                                                              | デバッグ操作170レジスタ要約171レジスタ要約172RT - 万能同期非同期送受信器179特徴179概要179機能的な説明180レジスタ要約189レジスタ説明190直列周辺インターフェース199機能的な説明200レジスタ要約200レジスタ要約200レジスタ要約206レジスタ説明207248201ビジス9説明207248201                                                                                                                                            |
| 26.               | 24.12.<br>24.13.<br>USAF<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI –<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.5.                                                                                                                              | デバッグ操作170レジスタ要約171レジスタ要約172RT - 万能同期非同期送受信器179特徴179概要179機能的な説明180レジスタ要約189レジスタ説明190直列周辺インターフェース199機能的な説明200レジスタ要約200レジスタ要約200レジスタ要約206レジスタ説明207248201ビジス9説明207248201                                                                                                                                            |
| 26.<br>27.        | 24.12.<br>24.13.<br>USAF<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI -<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.5.<br>TWI -<br>27.1.<br>27.2.<br>27.3.<br>27.4.<br>27.5.                                                                        | デバッグ操作170レジスタ要約171レジスタ説明172RT - 万能同期非同期送受信器179特徴179概要179機能的な説明180レジスタ要約189レジスタ要約190直列周辺インターフェース199機能的な説明200レジスタ要約200レジスタ要約200レジスタ要約201ビジスタ要約201レジスタ要約202レジスタ要約201セジスタ説明201レジスタ要約202レジスタ要約202レジスタ要約202レジスタ要約202レジスタ要約202レジスタ要約202レジスタ要約220レジスタ説明221                                                              |
| 26.<br>27.        | 24.12.<br>24.13.<br>USAR<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI –<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.5.<br>TWI –<br>27.1.<br>27.2.<br>27.3.<br>27.4.<br>27.5.<br>CRCS                                                                | デバッグ操作170レジスタ要約171レジスタ説明172RT - 万能同期非同期送受信器179特徴179概要179機能的な説明180レジスタ要約189レジスタ要約190直列周辺インターフェース199機能的な説明190レジスタ要約199機要199機能的な説明200レジスタ要約206レジスタ要約2072線インターフェース211特徴211機能的な説明212レジスタ要約220レジスタ要約220レジスタ要約220レジスタ要約220レジスタ要約220レジスタ要約220レジスタ要約221松田の冗長検査メモリ走査231                                                   |
| 26.<br>27.        | 24.12.<br>24.13.<br>USAF<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI -<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.5.<br>TWI -<br>27.1.<br>27.2.<br>27.3.<br>27.4.<br>27.5.<br>CRCS<br>28.1.                                                       | デバッグ操作170レジスタ要約171レジスタ説明172RT - 万能同期非同期送受信器179特徴179概要179機能的な説明180レジスタ要約189レジスタ要約190直列周辺インターフェース199機能的な説明190レジスタ要約199機要199機能的な説明200レジスタ要約206レジスタ要約2072線インターフェース211特徴211機能的な説明212レジスタ要約220レジスタ要約220レジスタ要約220レジスタ要約220レジスタ要約220レジスタ要約220レジスタ要約221松田の冗長検査メモリ走査231                                                   |
| 26.<br>27.        | 24.12.<br>24.13.<br>USAR<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI -<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.5.<br>TWI -<br>27.1.<br>27.2.<br>27.3.<br>27.4.<br>27.5.<br>CRCS<br>28.1.<br>28.2.                                              | デバッグ操作170レジスタ要約171レジスタ要約172RT - 万能同期非同期送受信器179構要179概要179機能的な説明180レジスタ要約189レジスタ要約190直列周辺インターフェース199構要199機能的な説明200レジスタ要約200レジスタ要約200レジスタ要約200レジスタ要約200レジスタ要約201ビジスタ要約202レジスタ要約205レジスタ説明2072線インターフェース211構要212レジスタ要約220レジスタ要約220レジスタ要約220レジスタ説明212レジスタ説明221SCAN - 巡回冗長検査メモリ走査231構要231概要231                          |
| 26.<br>27.        | 24.12.<br>24.13.<br>USAF<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI -<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.5.<br>TWI -<br>27.1.<br>27.2.<br>27.3.<br>27.4.<br>27.5.<br>CRCS<br>28.1.<br>28.2.<br>28.3                                      | デバッグ操作170レジスタ要約171レジスタ要約172RT - 万能同期非同期送受信器179概要179概要179機能的な説明180レジスタ要約189レジスタ要約190直列周辺インターフェース199機能的な説明200レジスタ要約200レジスタ要約200レジスタ要約200レジスタ要約200レジスタ要約201ビジスタ要約202レジスタ要約201ジスタ要約202レジスタ要約201特徴211概要211機能的な説明212レジスタ要約220レジスタ要約221SCAN - 巡回冗長検査メモリ走査231機能的な説明231機能的な説明231機能的な説明231                                |
| 26.<br>27.        | 24.12.<br>24.13.<br>USAF<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI -<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.5.<br>TWI -<br>27.1.<br>27.2.<br>27.3.<br>27.4.<br>27.5.<br>CRCS<br>28.1.<br>28.2.<br>28.3                                      | デバッグ操作170レジスタ要約171レジスタ要約172RT - 万能同期非同期送受信器179概要179概要179機能的な説明180レジスタ要約189レジスタ要約190直列周辺インターフェース199機能的な説明200レジスタ要約200レジスタ要約200レジスタ要約200レジスタ要約200レジスタ要約201ビジスタ要約202レジスタ要約201ジスタ要約202レジスタ要約201特徴211概要211機能的な説明212レジスタ要約220レジスタ要約221SCAN - 巡回冗長検査メモリ走査231機能的な説明231機能的な説明231機能的な説明231                                |
| 26.<br>27.<br>28. | 24.12.<br>24.13.<br>USAF<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI -<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.3.<br>26.4.<br>26.5.<br>TWI -<br>27.1.<br>27.2.<br>27.3.<br>27.4.<br>27.5.<br>CRCS<br>28.1.<br>28.2.<br>28.3.<br>28.4.<br>28.5. | デバッグ操作170レジスタ要約171レジスタ説明172RT - 万能同期非同期送受信器179構要179機能的な説明180レジスタ要約189レジスタ要約190直列周辺インターフェース199機能的な説明190岐常数199機要199機能的な説明200レジスタ要約206レジスタ要約2072線インターフェース211特徴211機能的な説明212レジスタ要約220レジスタ要約220レジスタ要約221防な説明212レジスタ要約221防な説明221レジスタ要約221レジスタ要約221レジスタ要約221レジスタ要約221レジスタ要約221レジスタ要約231横能231機能的な説明231レジスタ要約234レジス9説明235 |
| 26.<br>27.<br>28. | 24.12.<br>24.13.<br>USAF<br>25.1.<br>25.2.<br>25.3.<br>25.4.<br>25.5.<br>SPI -<br>26.1.<br>26.2.<br>26.3.<br>26.4.<br>26.3.<br>26.4.<br>26.5.<br>TWI -<br>27.1.<br>27.2.<br>27.3.<br>27.4.<br>27.5.<br>CRCS<br>28.1.<br>28.2.<br>28.3.<br>28.4.<br>28.5. | デバッグ操作170レジスタ要約171レジスタ要約172RT - 万能同期非同期送受信器179概要179概要179機能的な説明180レジスタ要約189レジスタ要約190直列周辺インターフェース199機能的な説明200レジスタ要約200レジスタ要約200レジスタ要約200レジスタ要約200レジスタ要約201ビジスタ要約202レジスタ要約201ジスタ要約202レジスタ要約201特徴211概要211機能的な説明212レジスタ要約220レジスタ要約221SCAN - 巡回冗長検査メモリ走査231機能的な説明231機能的な説明231機能的な説明231                                |

|     | 29.2.          | 概要 •••••• 237                                                                                                                        |
|-----|----------------|--------------------------------------------------------------------------------------------------------------------------------------|
|     | 29.3.          | <b>機能的な説明</b> ····································                                                                                   |
|     | 29.4.          | <b>レジスタ要約</b> ······ 243                                                                                                             |
|     | 29.5.          | レジスタ説明 ····································                                                                                          |
| 30. | <b>AC</b> –    | <b>アナログ比較器 ・・・・・</b> 248                                                                                                             |
|     | 30.1.          | 特徴                                                                                                                                   |
|     | 30.2.          | 概要 •••••• 248                                                                                                                        |
|     | 30.3.          | <b>機能的な説明</b> ······ 249                                                                                                             |
|     | 30.4.          | レジスタ要約 ······251                                                                                                                     |
|     | 30.5.          | レジスタ説明                                                                                                                               |
| 31. |                | - A/D変換器 ····· 255                                                                                                                   |
|     | 31.1.          | 特徴 255                                                                                                                               |
|     | 31.2.          | 概要                                                                                                                                   |
|     | 31.3.          | 機能的な説明 ・・・・・・・・・・・・・・・・・ 256                                                                                                         |
|     | 31.4.          | レジスタ要約       266         レジスタ説明       267                                                                                            |
| ~~  | 31.5.          | レッス 外説明 207                                                                                                                          |
| 32. | DAC ·          | - D/A変換器 ····· 277<br>特徴 ····· 277                                                                                                   |
|     | 32.1.<br>32.2. | 特徴 277 概要 277                                                                                                                        |
|     | 32.2.<br>32.3. | (概要 21)<br>機能的た説明 977                                                                                                                |
|     | 32.3.<br>32.4  | <b>機能的な説明</b> ······277<br>レジスタ要約 ·····279                                                                                           |
|     | 32.5.          | レジスタ説明 ····································                                                                                          |
| 33. |                | - 統一プログラム/デバッグ インターフェース・281                                                                                                          |
| 00. | 33.1.          | 特徴                                                                                                                                   |
|     | 33.2.          | 概要 ······ 281                                                                                                                        |
|     | 33.3.          | <b>機能的な説明</b> ······ 283                                                                                                             |
|     | 33.4.          | <b>レジスタ要約</b> ・・・・・・・・・・・・・・・・・297                                                                                                   |
|     | 33.5.          | <b>レジスタ説明</b> ····································                                                                                   |
| 34. | 命令-            | <b>一式要約</b> · · · · · · · · · · · · · · · · · · ·                                                                                    |
| 35. | 電気的            | 内特性 •••••• 303                                                                                                                       |
|     | 35.1.          | お断り                                                                                                                                  |
|     | 35.2.          | 絶対最大定格 ······ 303                                                                                                                    |
|     | 35.3.          | 標準動作条件 •••••• 303                                                                                                                    |
|     | 35.4.          | 供給電圧 ····································                                                                                            |
|     | 35.5.          | 消費電力 ······ 305<br>周辺機能消費電力 ····· 306                                                                                                |
|     | 35.6.<br>35.7. | 周辺機能消貨電力 306<br>入出力ピン・・・・・・ 307                                                                                                      |
|     | 35.7.<br>25.0  | ス山 パレノ                                                                                                                               |
|     | 35.9           | 温度什样                                                                                                                                 |
|     | 35.10.         | メモリ プログラミング 仕様・・・・・・・308         温度仕様・・・・・・308         CLKCTRL・・・・・309                                                               |
|     | 35.11.         | RSTCTRL≽BOD       309         VREF       311         USART       312         SPI       312                                           |
|     | 35.12.         | <b>VREF</b>                                                                                                                          |
|     | 35.13.         | <b>USART</b>                                                                                                                         |
|     | 35.14.         | <b>SPI</b>                                                                                                                           |
|     | 35.15.         | TWI                                                                                                                                  |
|     | 35.16.         | DAC                                                                                                                                  |
|     | 35.17.         | ADC                                                                                                                                  |
|     | 35.18.         | ADC                                                                                                                                  |
| ~~  | 35.19.         |                                                                                                                                      |
| 36. | 特性國            | 図 · · · · · · · · · · · · · · · · · · ·                                                                                              |
| 37. | 汪又们            | 育報 319                                                                                                                               |
| 38. |                | 器図 ······ 320<br>オンライン外囲器図 ····· 320                                                                                                 |
|     | 38.1.          | <b>オンフ1ン外囲</b> 器図 ····································                                                                               |
|     | 38.2.          | ット囲 奋 衣 亦 恒 報 320                                                                                                                    |
|     | 38.3.<br>38.4. | 20L JOPDIE 322<br>2811-L'SSOD                                                                                                        |
|     | 38.5.          | オンパンパンパロな区       320         外囲器表示情報       320         28ビンSPDIP       322         28リート*SSOP       323         28ハット*VQFN       324 |
|     | 38.6.          | <b>28</b> パット VQFN 濡れ性側面 ······ 325                                                                                                  |
|     | 38.7.          | <b>32IJ-h</b> <sup>*</sup> <b>TQFP 32</b> 6                                                                                          |
|     |                |                                                                                                                                      |

| <ul> <li>38.8. 32パット、VQFN 濡れ性側面・・・・・・328</li> <li>38.9. 48リート、TQFP・・・・・329</li> <li>38.10. 48パット、VQFN 330</li> <li>38.11. 48パット、VQFN 濡れ性側面・・・・・・331</li> <li>39. 障害情報・・・・・332</li> </ul> | )<br> <br>2 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 38.10. 48パッドVQFN ・・・・・ 330<br>38.11. 48パッドVQFN 濡れ性側面 ・・・・・ 331                                                                                                                           | )<br>l<br>2 |
| <b>38.11. 48パッドVQFN 濡れ性側面・・・・・・・・・・・</b> 331                                                                                                                                             | l<br>2      |
|                                                                                                                                                                                          | 2           |
| 30                                                                                                                                                                                       | -           |
|                                                                                                                                                                                          | -           |
| <b>40</b> . データシート改訂履歴 ・・・・・・・・・・・・・・・ 335                                                                                                                                               | )           |
| <b>40.1. 改訂A - 2022年9月</b> ······ 335                                                                                                                                                    | 5           |
| Microchip情報 ····································                                                                                                                                         |             |
| <b>Microchipウェブ サイト</b> • • • • • • • • • • • • • • • • • • •                                                                                                                            | 5           |
| <b>製品変更通知サービス ・・・・・・・・・・・・・・・</b> 336                                                                                                                                                    | 5           |
| <b>お客様支援・・・・・・・・・・・・・・・・・・</b> 336                                                                                                                                                       | 3           |
| 製品識別システム ・・・・・・・・・・・・・・・・・・・・ 336                                                                                                                                                        | 5           |
| Microchipデバイス コート 保護機能 ・・・・・・・・ 336                                                                                                                                                      | 3           |
| <b>法的通知</b> · · · · · · · · · · · · · · · · · · ·                                                                                                                                        | 7           |
| 商標 •••••• 337                                                                                                                                                                            | 7           |
| 品質管理システム・・・・・・・・・・・・・・・・・・・・・・・337                                                                                                                                                       |             |
| 世界的な販売とサービス ・・・・・・・・・・・・・・・・・ 338                                                                                                                                                        |             |

# 1. 構成図



# 2. ピン配置

2.1. 28ピンSPDIP・28リート SSOP



# 2.2. 28パット VQFN



# 2.3. 32パッドVQFN・32リードTQFP



# 2.4. 48パット VQFN・48リート TQFP



© 2022 Microchip Technology Inc.とその子会社

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

# 3.1. 入出力多重化

# 表3-1. ポート機能多重化 (<u>注</u>2)

| 10                | 1.1               | P      | 1.176              | 北夕里                        |                      |                |                   |      |                |                |                |                                       |              |                |         |
|-------------------|-------------------|--------|--------------------|----------------------------|----------------------|----------------|-------------------|------|----------------|----------------|----------------|---------------------------------------|--------------|----------------|---------|
| VQFN48/<br>TQFP48 | VQFN32/<br>TQFP32 | VQFN28 | SPDIP28/<br>SSOP28 | ピン名<br>( <mark>注1</mark> ) | 特殊                   | ADC0           | ACn               | DAC0 | UARTn          | SPI0           | TWI0<br>(注3)   | TCAn                                  | TCBn         | CCL-<br>LUTn   | EVSYS   |
| 44                | 30                | 26     | 22                 | PA0                        | XTALHF1<br>EXTCLK    |                |                   |      | 0,TxD          | MOSI           | SDA(MS)        | 0,WO0                                 |              | 0,IN0          |         |
| 45                | 31                | 27     | 23                 | PA1                        | XTALHF2              |                |                   |      | 0,RxD          | MISO           | SCL(MS)        | 0,WO1                                 |              | 0,IN1          |         |
| 46                | 32                | 28     | 24                 | PA2                        |                      | AIN22          |                   |      | 0,XCK·0,TxD    |                | SDA(MS)        | 0,WO2                                 | 0,WO         | 0,IN2          | EVOUTA  |
| 47                | 1                 | 1      | 25                 | PA3                        |                      | AIN23          |                   |      | 0,XDIR•0,RxD   |                | SCL(MS)        | 0,WO3                                 | 1,WO         | 0,OUT          |         |
| 48                | 2                 | 2      | 26                 | PA4                        |                      | AIN24          |                   |      | 0,TxD          | MOSI           |                | 0,WO4·1,WO0                           |              |                |         |
| 1                 | 3                 | 3      | 27                 | PA5                        |                      | AIN25          |                   |      | 0,RxD          | MISO           |                | 0,WO5·1,WO1                           |              |                |         |
| 2                 | 4                 | 4      | 28                 | PA6                        |                      | AIN26          |                   |      | 0,XCK          | SCK            |                | 1.WO2                                 |              | 0,OUT          |         |
| 3                 | 5                 | 5      | 1                  | PA7                        | CLKOUT               | AIN27          | 0.OUT · 1.OUT     |      | 0.XDIR         | SS             |                |                                       |              | -,             | EVOUTA  |
| 4                 | _                 | -      | -                  | PB0                        | o <u>Dirio</u> o I   |                | 0,001 1,001       |      | 0,112111       | 00             |                | 0,WO0.1,WO0                           |              |                | 2.00111 |
| 5                 | -                 | -      | -                  | PB1                        |                      |                |                   |      |                |                |                | 0,WO1 · 1,WO1                         |              |                |         |
| 6                 | -                 | -      | -                  | PB2                        |                      |                |                   |      |                |                |                | 0,WO11,WO1<br>0,WO2·1,WO2             |              |                | EVOUTB  |
| 7                 | -                 | -      | -                  | PB3                        |                      |                |                   |      |                |                |                | 0,WO2 1,WO2                           |              |                | EVOOID  |
| 8                 | -                 |        | -                  | PB4                        |                      |                |                   |      |                |                |                | 0,WO3·1,WO3                           | 2.WO         |                |         |
| 9                 | -                 | -      | -                  | PB5                        |                      |                |                   |      |                |                |                | 0,W04·1,W04                           | 2,WO<br>3,WO |                |         |
|                   |                   | -      |                    | PB5<br>PC0                 |                      | AINIOO         |                   |      | 1 77 10        | COV MOSI       |                | 0,WO51,WO5                            |              | 1 100          |         |
| 10                | 6                 | 6      | 2                  |                            |                      | AIN28          |                   |      | 1,TxD          | SCK·MOSI       |                | · · · · · · · · · · · · · · · · · · · | 2,WO         | 1,IN0          |         |
| 11                | 7                 | 7      | 3                  | PC1                        |                      | AIN29          |                   |      | 1,RxD·0,TxD    | SS-MISO-MOSI   |                | 0,WO1                                 | 3,WO         | 1,IN1          | PLOUTO  |
| 12                | 8                 | 8      | 4                  | PC2                        |                      |                | 0,AINN3•1,AINN3   |      | 1,XCK•0,RxD    | SCK·MISO       | SDA(S)·SDA(MS) | 0,WO2                                 |              | 1,IN2          | EVOUTC  |
| 13                | 9                 | 9      | 5                  | PC3                        |                      | AIN31          | 0,AINP4 • 1,AINP4 |      | 1,XDIR•0,XCK   | <u>SS</u> •SCK | SCL(S)·SCL(MS) | 0,WO3                                 |              | 1,OUT          |         |
| 14                | -                 | -      | -                  | VDD                        |                      |                |                   |      |                |                |                |                                       |              |                |         |
| 15                | -                 | -      | -                  | GND                        |                      |                |                   |      |                |                |                |                                       |              |                |         |
| 16                | -                 | -      | -                  | PC4                        |                      |                |                   |      | 1,TxD          |                |                | 0,WO4·1,WO0                           |              |                |         |
| 17                | -                 | -      | -                  | PC5                        |                      |                |                   |      | 1,RxD          |                |                | 0,WO5·1,WO1                           |              |                |         |
| 18                | -                 | -      | -                  | PC6                        |                      |                | 0,OUT·1,OUT       |      | 1,XCK          |                | SDA(S)         | 1,WO2                                 |              | 1,OUT          |         |
| 19                | -                 | -      | -                  | PC7                        |                      |                |                   |      | 1,XDIR         |                | SCL(S)         |                                       |              |                | EVOUTC  |
| 20                | 10                | 10     | 6                  | PD0                        |                      | AIN0           | 0,AINN1 · 1,AINN1 |      |                |                |                | 0,WO0                                 |              | 2,IN0          |         |
| 21                | 11                | 11     | 7                  | PD1                        |                      | AIN1           |                   |      |                |                |                | 0,WO1                                 |              | 2,IN1          |         |
| 22                | 12                | 12     | 8                  | PD2                        |                      | AIN2           | 0,AINP0.1,AINP0   |      |                |                |                | 0,WO2                                 |              | 2,IN2          | EVOUTD  |
| 23                | 13                | 13     | 9                  | PD3                        |                      | AIN3           | 0,AINN0.1,AINP1   |      |                |                |                | 0,WO3                                 |              | 2,OUT          |         |
| 24                | 14                | 14     | 10                 | PD4                        |                      | AIN4           | 1,AINP2           |      | 0,TxD          | MOSI           |                | 0,WO4·1,WO0                           |              |                |         |
| 25                | 15                | 15     | 11                 | PD5                        |                      | AIN5           | 1,AINN0           |      | 0,RxD          | MISO           |                | 0,WO5•1,WO1                           |              |                |         |
| 26                | 16                | 16     | 12                 | PD6                        |                      | AIN6           | 0,AINP3 · 1,AINP3 | OUT  | 0,XCK·1,TxD    | SCK            |                | 1,WO2                                 |              | 2.OUT          |         |
| 27                | 17                | 17     | 13                 | PD7                        | VREFA                | AIN7           | 0,AINN2 · 1,AINN2 |      | 0.XDIR · 1.RxD | SS             |                |                                       |              |                | EVOUTD  |
| 28                | 18                | 18     | 14                 | VDD                        |                      |                | -,                |      |                |                |                |                                       |              |                |         |
| 29                | 19                | 19     | 15                 | GND                        |                      |                |                   |      |                |                |                |                                       |              |                |         |
| 30                | -                 | -      | -                  | PE0                        |                      | AIN8           | 0,AINP1           |      |                | MOSI           |                | 0,WO0                                 |              |                |         |
| 31                | -                 | -      | -                  | PE1                        |                      | AIN9           | 0,111.11.1        |      |                | MISO           |                | 0,WO1                                 |              |                |         |
| 32                | -                 | -      | -                  | PE2                        |                      | AIN10          | 0,AINP2           |      |                | SCK            |                | 0,WO1                                 |              |                | EVOUTE  |
| 33                | -                 | -      | -                  | PE3                        |                      | AIN10          | 0,111112          |      |                | SS             |                | 0,WO2                                 |              |                | D, OUIL |
| 34                | 20                | 20     | 16                 | PF0                        | XTAL32K1             | AIN11<br>AIN16 |                   |      | 2,TxD          | 00             |                | 0,WO3                                 |              | 3,IN0          |         |
| 35                | 20                | 20     | 17                 | PF1                        | XTAL32K1<br>XTAL32K2 | AIN10<br>AIN17 |                   |      | 2,1xD<br>2,RxD |                |                | 0,WO0                                 |              | 3,IN0<br>3,IN1 |         |
| 36                | 21                | -      | -                  | PF2                        | ATAL32K2             | AIN17<br>AIN18 |                   |      | 2,XCK          |                |                | 0,WO1                                 |              | 3,IN1<br>3,IN2 | EVOUTF  |
| 30                | 23                |        | -                  |                            |                      | AIN18<br>AIN19 |                   |      |                |                |                |                                       |              | 3,0UT          | EVOUIF  |
|                   |                   | -      |                    | PF3                        |                      |                |                   |      | 2,XDIR         |                |                | 0,WO3                                 | 0.WC         | 3,001          |         |
| 38                | 24                | -      | -                  | PF4                        |                      | AIN20          |                   |      | 2,TxD          |                |                | 0,WO4                                 | 0,WO         |                |         |
| 39                | 25                | -      | -                  | PF5                        | DEGET /I T           | AIN21          |                   |      | 2,RxD          |                |                | 0,WO5                                 | 1,WO         |                |         |
| 40                | 26                | 22     | 18                 | PF6                        | RESET/HV             |                |                   |      |                |                |                |                                       |              |                | DUOUTD  |
| 41                | 27                | 23     | 19                 | PF7                        | UPDI                 |                |                   |      |                | SS             |                |                                       |              |                | EVOUTF  |
| 42                | 28                | 24     | 20                 | VDD                        |                      |                |                   |      |                |                |                |                                       |              |                |         |
| 43                | 29                | 25     | 21                 | GND                        |                      |                |                   |      |                |                |                |                                       |              |                |         |

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

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

注3: 主装置または従装置として使えるTWIピンはMで記されます。従装置専用ピンはSで記されます。

# 4. ハート・ウェアの指針

本章はAVR 8ビットマイクロコントローラを使って電気的な回路図を設計して再検討するための指針を含みます。ここで提示される情報は 最も一般的な話題の簡単な概要です。より詳細な情報は本章の該当箇所で一覧にされる応用記述で見つけることができます。 本章は以下の話題を網羅します。

- ・一般的な指針
- ・電源用接続
- ・ RESET 用接続
- ・UPDI (統一プログラム/デバッグ インターフェース)用接続
- ・外部クリスタル発振子接続
- VREF(外部基準電圧)接続

# 4.1. 一般的な指針

未使用ピンはそれら各々に半田付けペッドに半田付けされなければなりません。半田付けペッドは回路に接続されてはなりません。 ポート ピンはリセット後にそれらの既定状態です。消費電力を減らすには「PORT - I/Oピン構成設定」章の推奨に従ってください。 全ての値は代表値で、回路設定に対する開始点としてだけ扱います。

更なる情報については以下の応用記述を参照してください。

- ・AVR040 電磁適合性(EMC)設計の考察
- AVR042 ハート・ウェア設計の考察

# 4.1.1. 中央パッド付き外囲器に対する特別な考慮

平板外囲器はしばしば裏に配置された露出パット'を備え、しばしば中央パット'または放熱パット'として参照されます。このパット'は電気的にチップの内部回路に接続されませんが、機械的に内部基材に接合されます。それは放熱材として扱うだけでなく、機械的な安定性の追加も提供します。このパット'は接地面が印刷回路基板(PCB)の最良の放熱基材(最大の銅箔領域)のため、GNDに接続されなければなりません。

# 4.2. 電源用接続

電源設計の基本と詳細はこれらの指針の範囲の向こう側にあります。この題目についてより多くの詳細な情報に関してはこの章の始めで言及した応用記述をご覧ください。

雑音分離(デカップ)コンデンサは各供給ビン対(VDDまたは他の電力供給ビンとそれに対応するGNDビン)に対してマイクロコントローラの近くに 配置されなければなりません。雑音分離コンデンサがマイクロコントローラから遠すぎる場所に配置される場合、雑音の増加と放射妨害波の 増加に帰着する高電流閉路を形成するかもしれません。

各供給ピン対(電力入力ピンと接地ピン)は独立した雑音分離コンデンサを持たなければなりません。

雑音分離コンデンサをマイクロコントローラと同じPCBの側に配置することが推奨されます。空間がそれを許さない場合、ビアを通して他の側に雑音分離コンデンサを配置することができますが、供給ピンとの距離が可能な限り短く保つことを確実にしてください。

基板が(数10MHz以上の)高周波数雑音を経験している場合、上で記述した雑音分離コンデンサと並列に第2のセラミック型コンデンサを追加 してください。この第2のコンデンサを主雑音分離コンデンサの傍らに配置してください。

電源回路からの基板配置で、最初に雑音分離コンデンサへの電力と戻りの布線を、その後にデバイスのピンへ走らせ、雑音分離コンデンサ が電力連鎖で最初になることを保証してください。同様にコンデンサと電力ピン間の布線長を最短に保ち、それによってPCB布線インダク タンスを減らすことが重要です。

本章の始めで言及したように、例で使われる全ての値は代表値です。実際の設計は他の値を必要とするかもしれません。

# 4.2.1. デジタル電源

より多ピン数の外囲器型についてはいくつかの VDDピンと対応するGNDピンがあります。マイクロコン トローラの全てのVDDピンは内部的に接続されてい ます。VDDピンの各々に同じ電圧が印加されなけ ればなりません。

右図はデベイスのVDDピンへの推奨電源接続を示します。



#### 代表値(推奨): C1:0.1uF(主雑音分離コンデンサ)

C2:1000pF $\sim$ 0.01µF(HF雑音分離コンデンサ) C3(\*):1µF(雑音分離コンデンサ – 任意選択)

重要:頻繁にVDDをON/OFFする、または高速なVDD過渡応答を経験する系については電源のスリューレート(上昇/下降速度) がスリューレート限度を超える場合、雑音分離コンデンサ(C3)の追加が推奨されます。電源のスリューレート限度については「電気 的特性」で供給電圧部分を参照してください。

GND

# 4.3. RESET用接続

デバイスのRESETピンは内部プルアップ抵抗付きLow活性で、ピンの外部 的なLow引き込みはデバイスのリセットになります。外部プルアップ抵抗は通 常必要とされません。

右図はデバイスへの外部リセット切替器接続の推奨を示します。

濾波コンデンサ短絡は系を害し得る尖頭雑音を発生するかもしれません。これを防ぐための切替器と直列の抵抗は濾波コンデンサを安全に放 電することができ、サージ(瞬間大)電流を防ぎます。

#### VDD R1 ● RESET 代表値(推奨):

GND

C1

SW1

図4-2. 推奨外部リセット回路の回路図

C1:0.1µF(濾波コンデンサ) R1:330Ω(切替器直列抵抗)

#### 高電圧指定変更でのUPDI許可

RESETピンに高電圧を印加することによって禁止されたUPDIを許可することが可能です。こような高電圧パルスが印加されるかもしれない場合、リセット回路設計とRESETピンに接続されるどの部品にも注意してください。

より多くの詳細については「UPDIプログラミング用接続」項と「UPDI」章をご覧ください。

# 4.4. UPDIプログラミング用接続

統一プログラム/デバッグ インターフェース(UPDI)接続は外部プログラミングとチップ上デバッグ(OCD)用の単線インターフェースを提供します。本項は 信号規約の詳細やUPDI周辺機能の機能ではなく、物理的な接続それ自身に関連します。これらの詳細は「UPDI」章で記述されま す。

推奨UPDI接続はその最初の紹介から変更されました。この理由のため、両接続が以降で記述され、UPDI接続v1と名付けられた初期のUPDI接続配置図と同時に新しいUPDI接続配置図はUPDI接続v2と名付けられます。2つの接続間の違いはv2用接続での RESET信号の内包です。

#### <mark>4.4.1</mark>. UPDI接続v1

これは(Atmel ICEのような)古いプログラミングツールによって使われるUPDI接続用の初期配置図でした。

UPDI接続v1は100mil(2.54mm)2×3の6ピン ヘッダです。例えプログラミングに3つのピンだけを使うとしても、このコネクタを使う殆どのツールが 100mil(2.54mm)2×3の6ピン コネクタで配給されるため、2×3ヘッダを使うことが推奨されます。

次図はUPDI接続v1を使うデバイスへのUPDI接続の推奨を示します。



VDDとGND間の雑音分離コンデンサは可能な限りピン対の近くに配置されなければなりません。例えUPDIコネクタが回路内に含められなくても、雑音分離コンデンサを含めてください。

#### 4.4.2. UPDI接続v2

この接続はどのAVRデバイスにも対応しますが、100mil(2.54mm)2×3ヘッダを持つAtmel-ICEやAtmel Powerデバッカのような古い書き込み器/デバッガを持つ使用者に関して調整ケーブルを必要とします。この接続プログラミング ツールのPICkit 4™インサーキット デバッガに直接対応します。

UPDI接続v2は100mil(2.54mm)1×4の4ピン ヘッダです。例え多くのAVRデバイスをプログラミングするのに3つのピンで充分でも、含まれる べきRESET信号を許す100mil 1列4ピン ヘッダを使うことが推奨されます。これはPICkit 4書き込み器にも対応します。 次図はデバイスへUPDIコネクタを接続するための推奨を示します。



VDDとGND間の雑音分離コンデンサは可能な限りピン対の近くに配置されなければなりません。例えUPDIコネクタが回路内に含められなくても、雑音分離コンデンサを含めてください。

#### \_\_\_\_\_\_ RESETを使うUPDI許可

設計や誤りにより、適切なヒューズを書くことによってUPDIを禁止することが有り得ます。UPDI禁止の詳細については「メモリ」章の「FUSE」項をご覧ください。一部のデバイスについて、UPDIを禁止することができないことに注意してください。

UPDIを許可するにはRESET ピンに高電圧ペルスが印加されなければなりません。RESET ピンへの高電圧ペルス印加法の詳細については「UPDI」章をご覧ください。

RESETビンが他の部品に接続されている場合、回路の設計で追加の注意をしてください。RESETビンに高電圧パルスが印加される場合、この線に接続された他の部品が損傷するかもしれません。この場合、設計は高電圧パルスが印加される前に回路からそれらの部品の切断を許さなければなりません。これの一例は取り外し可能なジャンパで有り得ます。

注: プログラム/デバッグインターフェース禁止(PDID)を特徴とするデバイスでは、PDID機能が有効にされた後にRESETピンを使ってUPDIを再 許可することはできません。

### 4.5. 外部クリスタル発振子接続

外部発振子の使用と発振器回路の設計はVDD、動作温度範囲、クリスタル型式と製造業者、負荷容量、回路配置とPCB材料のような 多くの変数があるため重要です。基本的な発振器回路設計を手助けするいくつかの代表的な指針が本項で提示されます。

- ・例え最良の性能の発振器回路と高品質のクリスタルでも、組立の間に使われる配置と材料が注意深く考慮されなければ、上手く行きません。
- クリスタル回路はデバイスと同じ基板の側に配置されなければなりません。クリスタル回路を可能な限り各々の発振器ピン近くに配置し、 長い布線を避けてください。これは寄生容量を減らして雑音と漏話に対する耐性を増します。負荷容量を基板の同じ側でクリスタルの隣に配置してください。ソケットを使わないでください。
- ・周辺回路から絶縁するためにクリスタル回路の周りに接地した銅箔領域を配置してください。回路基板が両面を持つなら、裏面層の 銅箔領域はクリスタル回路を網羅するベタ領域でなければなりません。表面層の銅箔領域はクリスタル回路周辺でビアの使用によって 裏面層に接続されなければなりません。
- ・接地した銅箔領域の内側にどんな信号布線や電力布線も走らせないでください。クリスタル線の近くでのデジタル線、特にクロック線の 配線を避けてください。
- ・両面PCBを使う場合、クリスタルの下のどの配線も避けてください。多層PCBについてはクリスタル線の下の信号配線を避けてください。
- ・塵や湿度は寄生容量を増やして信号絶縁を減らします。保護皮膜が推奨されます。
- ・望まれるような発振器性能を保証するため、成功する発振器設計は良い動作条件の仕様、初期試験での部品選択段階、実際の 動作条件での試験が必要とされます。

発振器と発振器回路設計についてより多くの詳細情報に関しては以下の応用記述をご覧ください。

- ・AN2648 AVR®マイクロコントローラ用32kHzクリスタルの選択と試験
- ・AN949 発振器を動かす

#### 4.5.1. XTAL32K(外部32.768kHzクリスタル発振子)接続

超低電力32.768kHz発振器は一般的に1µWを大幅に下回って消費し、従って回路を流れる電流は極端に小さいです。クリスタル周波 数は容量性負荷に大きく依存します。

発振器の過駆動を防ぐために直列抵抗(Rs)が必要とされるかもしれません。発振器駆動部での利得は低周波数発振子に対して時々高すぎるかもしれず、Rsでのインピーダンス追加で利得を下げることができます。過駆動は信号が飽和(切り取りまたは押し潰)されるため、発振器を正しくない振幅にさせます。クリスタルの過駆動は回路を高調波へ飛ばせることも有り得ます。



右図は外部32.768kHzクリスタル発振子を接続する方法を示します。

### 4.5.2. XTALHF(外部HFクリスタル発振子)接続

右図は外部高周波数クリスタル発振子を接続する方法を示します。

# 図4-6. 推奨外部高周波数発振子接続回路の回路図



# 4.6. 外部基準電圧接続

設計が外部基準電圧の使用を含む場合、一般的な推奨は参照基準と並列に接続される適切な コンデンサを使うことです。参照基準の本質と濾波されるのが必要な電気的雑音の形式がコンデンサ の値を与えます。

使われる外部参照基準電圧の形式に依存して追加の濾波部品が必要とされるかもしれません。



# 5. 電力区域



AVR® EA系統のデバイスは以下の電源ピンでいくつかの電力区域を持ちます。

VDD/VDDIO入出力線、OSCHF、OSC32K、XOSCHFに給電VDDANA入出力線、XOSC32K(外部32.768kHz/りスタル用発振器)、アナログ周辺機能に給電

全てのVDDピンに同じ電圧が印加されなければなりません。 接地(GND)ピンは同じ接地面に接続されなければなりません。 配置と雑音分離の推奨については「ハードウェアの指針」章を参照してください。

# 5.1. 電源投入

電源ONリセット(POR)と低電圧検出器(BOD)はVDDを監視し、電圧水準が各々の電圧閾値未満の場合に系をリセットに保ちます。更なる 情報については「RSTCTRL - リセット制御器」と「BOD - 低電圧検出器」の章を参照してください。 電圧閾値と供給電圧傾斜の更なる情報については「電気的特性」章を参照してください。

# <mark>6</mark>. 規定

# 6.1. 数字表記法

| 表6-1. 数字表記法   |                                                       |  |  |  |  |
|---------------|-------------------------------------------------------|--|--|--|--|
| シンホール         | 説明                                                    |  |  |  |  |
| 165           | 10進数値                                                 |  |  |  |  |
| 0b0101        | 2進数値( <mark>訳注</mark> :本書ではCコート、例内以外では不使用)            |  |  |  |  |
| <b>'0101'</b> | 明白な場合に接頭辞で与えられる2進数値( <mark>訳注</mark> :本書では基本的に赤文字で表現) |  |  |  |  |
| 0x3B24        | 16進数値(訳注:本書ではCコート、例内以外では不使用、代わりに\$接頭辞で「\$3B24」形式で表記)  |  |  |  |  |
| Х             | 未知またはどうでもよい値を表す。                                      |  |  |  |  |
| Z             | 信号またはバスのどちらかに対して高インピーダンス(浮き)状態を表す。(訳注:本書では「Hi-Z」と表記)  |  |  |  |  |

# 6.2. メモリの大きさと形式

# 表6-2. メモリの大きさとビット速度

| シンホール   | 説明                                                                          |
|---------|-----------------------------------------------------------------------------|
| Kバイト    | キロ ハイト (2 <sup>10</sup> =1024ハイト)                                           |
| Mバイト    | メカ <sup>*</sup> ハ <sup>*</sup> イト (2 <sup>20</sup> =1024Kハ <sup>*</sup> イト) |
| Gバイト    | ギガ バイト (2 <sup>30</sup> =1024Mバイト)                                          |
| b       | ビット(2進数値の'0'または'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> :本書では「語」と表記)                                         |

# 6.3. 周波数と時間

# 表6-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.00000001秒      |

# 6.4. レシ スタとビット

#### 表6-4. レジスタとビットの簡略記法

| シンホ゛ル       | 説明                                                                                                                                       |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| R/W         | 読み書きアクセス可能なレジスタビット。このビットに対して読み書きすることができます。                                                                                               |
| R           | 読み込み専用アクセス可能なレジスタビット。このビットを読むことだけできます。書き込みは無視されます。                                                                                       |
| W           | 書き込み専用アクセス可能なレジスタビット。このビットを書くことだけできます。このビットの読み込みは未定義の値を返します。                                                                             |
| ビット領域       | ビット名は大文字で支援されます(例:INTMODE)。                                                                                                              |
| ビット領域[n:m]  | ビットn~m(n>m)のビットの組。( <mark>訳注</mark> :本書では不使用、「FIELDn~m」形式で表記)<br>(例:PINA[3:0](不使用)=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'書き込みは両レジスタで対応するビットを反転します。                                                                                               |

# 6.4.1. ヘッダ ファイルからのレジスタ アクセス

供給されるCへッダ、ファイルでレジスタをアドレス指定するには以下の規則が適用されます。

1. レジスタはく周辺機能実体名>.<レジスタ名>、例えば、CPU.SREG、USART2.CTRLA、PORTB.DIRによって識別されます。

- 2. 周辺機能名は「周辺機能と基本構造」章の「周辺機能アトレス配置」で与えられます。
- 3. <周辺機能実体名>は周辺機能名の何れかのnまたはxを正しい実体識別子で置き換えることによって得られます。
- 4. 周辺機能レジスタに予め定義された値を割り当てる時に、その値は次のような規則に従って構築されます。 〈周辺機能名〉\_〈ビット領域名〉\_〈ビット領域値〉\_gc

<周辺機能名>は<周辺機能実体名>ですが、どの実体識別子も取り去られます。

くビット領域値>は周辺機能レジスタのビット領域を記述する「レジスタ説明」章内の表の「名称」列で見つけることができます。

#### 例6-1.レジスタ割り当て

// EVSYSチャネル0はTCB3のOVF事象によって駆動されます。 EVSYS. CHANNEL0 = EVSYS\_CHANNEL0\_TCB3\_0VF\_gc;

// USART0のRXMODEは2倍速伝送を使います。

USARTO. CTRLB = USART\_RXMODE\_CLK2X\_gc;

注: 違う動作形態に於いて異なるレジスター式を持つ周辺機能に対して、<周辺機能実体名>と<周辺機能名>は動作形態名が後続さ れなければならず、例えば以下です。

// 標準(SINGLE)動作のTCA0は周波数動作で波形生成器を使います。 TCA0. SINGLE. CTRL=TCA\_SINGLE\_WGMODE\_FRQ\_gc;

# 6.5. ADCパラーメータ定義

理想nt゙ット シングル エンドA/D変換はGNDとVREF間を2<sup>n</sup>段階(LSB)で電圧を直線的に変換します。最低値符号は'0'として読まれ、最 高値符号は2<sup>n</sup>-1として読まれます。いくつかの項目は理想的な動きからの偏差を記述します。

変位(オフセット)誤差

利得誤差

積分非直線性誤差 (INL)

微分非直線性誤差 (DNL)

理想遷移点(差0.5 LSB)と比べた最初の遷移(\$000から\$001)の偏差 です。 理想値:0LSB

変位(オフセット)誤差補正後、利得誤差は理想遷移(最大1.5 LSB以

下)と比べた最後の遷移(例えば、10ビットADCについては\$3FEから

変位(オフセット)誤差と利得誤差の補正後、INLは何れかの符号に対

\$3FF)の偏差として見出されます。理想値:0LSB

する理想遷移と比べた実際の遷移の最大偏差です。

隔)の最大偏差です。理想値:0LSB

理想值:0LSB





図6-3. 積分非直線性誤差 出力符号 入力電圧 VREF

理想符号幅(1 LSB)から実際の符号幅(隣接する2つの遷移間の間 図6-4. 微分非直線性誤差



量子化誤差

有限数の符号への入力電圧の量子化のため、入力電圧範囲(1 LSB幅)は同じ値に符号化します。常に  $\pm 0.5$  LSB

絶対精度

何れかの符号に対して理想遷移点と比べた(非補正の)実際の遷移の最大偏差です。これは全ての前 述の誤差の複合作用です。理想値:±0.5 LSB

# 7. AVR<sup>®</sup> CPU

# 7.1. 特徴

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

### 7.2. 概要

AVR CPUはメモリをアクセスし、計算を実行し、周辺機能を制御し、そしてプログラム メモリから命令を実行し割り込みを処理することができます。

# 7.3. 基本構成

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

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





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

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

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

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

#### 7.3.1.1. ハートウェア乗算器

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

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

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

## 7.4. 機能的な説明

#### 7.4.1. プログラムの流れ

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

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

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

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

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

 図7-2. 並列の命令取得と命令実行

 T1
 T2

 T3
 T4

 CLK\_CPU

 (命令1)
 (命令1)
 (命令1)
 (命令1)
 (命令2)
 (命令3)
 (命令3)

 (命令1)
 (命令1)
 (命令2)
 (命令3)
 (命令4)
 (命令4)
 ((市会3)
 ((市会3)</

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



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

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

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

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

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

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

| 表7-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メモリ書き込みまでのどちらか速い方で 自動的に割り込みを禁止します。

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

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

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

#### 図7-4. AVR® CPU 汎用作業レジスタ

| 즈/ 4.7 | WIN OF U MURTIFA |              |             |  |  |  |  |
|--------|------------------|--------------|-------------|--|--|--|--|
|        | 7 0              | アドレス         |             |  |  |  |  |
|        | R0               | \$00         |             |  |  |  |  |
|        | R1               | \$01         |             |  |  |  |  |
|        | R2               | \$02         |             |  |  |  |  |
|        | 2                |              |             |  |  |  |  |
|        | R13              | \$0D         |             |  |  |  |  |
|        | R14              | \$0E         |             |  |  |  |  |
| 汎用     | R15              | \$0F<br>\$10 |             |  |  |  |  |
| 作業     | R16              |              |             |  |  |  |  |
| レシスタ   | R17              | \$11         |             |  |  |  |  |
| ファイル   | 2                |              |             |  |  |  |  |
|        | R26              | \$1A         | Xレジスター下位バイト |  |  |  |  |
|        | R27              | \$1B         |             |  |  |  |  |
|        | R28              | \$1C         | Yレジスタ 下位バイト |  |  |  |  |
|        | R29              | \$1D         | 上位ハイト       |  |  |  |  |
|        | R30              | \$1E         | Zレジスター下位バイト |  |  |  |  |
|        | R31              | \$1F         | 上位バイト       |  |  |  |  |
|        |                  |              |             |  |  |  |  |

#### 7.4.5.1. X,Y,Z レシ スタ

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

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

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

#### 図7-5. X,Y,Zレジスタ

| ビット(個別)     | 7  | R27     | 0 | 7 | R26     | 0 |
|-------------|----|---------|---|---|---------|---|
| Χ レジスタ      |    | XH (上位) |   |   | XL (下位) |   |
| ビット(Xレシ`スタ) | 15 |         | 8 | 7 |         | 0 |
| ビット(個別)     | 7  | R29     | 0 | 7 | R28     | 0 |
| Υ レシ スタ     |    | YH (上位) |   |   | YL (下位) |   |
| ビット(Xレシ`スタ) | 15 |         | 8 | 7 |         | 0 |
| ビット(個別)     | 7  | R31     | 0 | 7 | R30     | 0 |
| Z レジ スタ     |    | ZH (上位) |   |   | ZL (下位) |   |
| ビット(Xレシ`スタ) | 15 |         | 8 | 7 |         | 0 |
|             |    |         |   |   |         |   |

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

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

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

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

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

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

- 1. ソフトウェアはCPU.CCPレジスタのCCPビット領域に保護されたI/Oレジスタの変更を許可する識票を書きます。
- 2.4命令内で、ソフトウェアは保護されたレジスタに適切なデータを書かなければなりません。
  - **注**: 殆どの保護されたレジスタは書き込み許可/変更許可/施錠のビットも含みます。このビットはデータが書かれるのと同じ操作内で1 を書かれなければなりません。

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

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

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

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

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

#### 

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

# 7.5. レジスタ要約

| 変位         | 略称    | ビット位置 | ビット7 | ビット6   | ビット5 | ビット4 | ビット3 | ビット2 | ビット1 | ビットロ |
|------------|-------|-------|------|--------|------|------|------|------|------|------|
| +\$00<br>~ | 予約    |       |      |        |      |      |      |      |      |      |
| +\$03      | 1^ ምህ |       |      |        |      |      |      |      |      |      |
| +\$04      | ССР   | 7~0   |      | CCP7~0 |      |      |      |      |      |      |
| +\$05<br>~ | 又约    |       |      |        |      |      |      |      |      |      |
| +\$0C      | 予約    |       |      |        |      |      |      |      |      |      |
| +\$0D      | CD    | 7~0   |      | 1      |      | SP   | 7~0  |      | 1    |      |
| +\$0E      | SP    | 15~8  |      |        |      | SP1  | 5~8  |      |      |      |
| +\$0F      | SREG  | 7~0   | Ι    | Т      | Н    | S    | V    | Ν    | Z    | С    |

### 7.6. レジスタ説明

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

| 図リ | る称 : CCP<br>を位 : +\$04<br>セット : \$00<br>持質 : - |        |     |     |     |     |     |     |     |
|----|------------------------------------------------|--------|-----|-----|-----|-----|-----|-----|-----|
|    | ビット                                            | 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'を読みます。

# 7.6.2. SP - スタック ホペインタ (Stack Pointer)

名称:SP(SPH,SPL)

**変位** : +\$0D

**リセット** : \$7FFF

特質:-

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

各デバイスに対して利用可能なSRAMをアドレス指定するのに必要とされるビット数だけが実装されます。未使用ビットはスタック ポインタが常にSRAMを指示するように設定されます。

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

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

| <b>ビット</b> | 15  | 14  | 13    | 12  | 11     | 10  | 9   | 8   |  |
|------------|-----|-----|-------|-----|--------|-----|-----|-----|--|
|            |     |     |       |     | SP14~8 |     |     |     |  |
| アクセス種別     | R   | R/W | R/W   | R/W | R/W    | R/W | R/W | R/W |  |
| リセット値      | 0   | 1   | 1     | 1   | 1      | 1   | 1   | 1   |  |
| ビット        | 7   | 6   | 5     | 4   | 3      | 2   | 1   | 0   |  |
|            |     |     | SP7~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ビットレジスタの下位バイトを保持します。

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

7.6.3. SREG - ステータス レジネタ (Status Register)

- 名称 : SREG
- **変位** : \$0F

リセット : \$00

特質 :-

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

| ビット    | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|
|        | Ι   | Т   | Н   | S   | V   | Ν   | Z   | С   |
| アクセス種別 | 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ビットを使います。

• E<sup>\*</sup>yト5 – H : ハーフキャリー フラク<sup>\*</sup> (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: 負7ラク (Negative Flag)

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

• ビット1 – Z : セロフラク (Zero Flag)

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

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

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

# <mark>8</mark>. メモリ

# 8.1. 概要

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

### 8.2. メモリ配置

下図はAVR® EA系統の最大メモリに対するメモリ配置を示します。更なる詳細については後続する項と周辺機能アドレス割り当て表を参照してください。

### 図8-1. メモリ配置: フラッシュ メモリ 64Kバイト、内部SRAM 6Kバイト、EEPROM 512バイト

|         | ⊐−ド空間     | データ空間                            |                                |              |               |
|---------|-----------|----------------------------------|--------------------------------|--------------|---------------|
| \$00000 |           |                                  | ¢0000 - ¢100E                  | 単一周期I/Oレシブスタ | \$0000~\$003F |
|         |           | I/Oメモリ                           | \$0000~\$103F                  | 拡張I/Oレジスタ    | \$0040~\$103F |
|         | フ゜ロク゛ラム用  | 施錠(LOCK)                         | \$1040~\$1043                  |              | -             |
|         | フラッシュ メモリ | ヒュース (FUSE)                      | \$1050~\$105F                  |              |               |
|         | 64Kハイト    | 使用者列(USERROW)<br>識票列(SIGROW)     | \$1080~\$10BF<br>\$1100~\$117F |              |               |
|         |           | 載宗列(SIGROW)<br>EEPROM<br>512ハイト  | $1100^{3117F}$                 |              |               |
| \$08000 |           | (予約)                             | $1600 \sim 67$ FF              |              |               |
|         |           | SRAM<br>6Kハイト                    | \$6800~\$7FFF                  |              |               |
| \$0FFFF |           | <br>割り当て<br>フラッシュ メモリ<br>32Kハベイト | \$8000~\$FFFF                  |              |               |

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

AVR64EA28/32/48はプログラム記憶用に実装書き換え可能なチップ上の64Kハイトのフラッシュメモリを含みます。全てのAVR命令が16または32のビット幅のため、このフラッシュメモリは16ビットデータ幅で構成されます。書き込み保護のため、フラッシュプログラムメモリ空間はブートコート領域、応用コート領域、応用データ領域の3つの領域に分けることができます。1つの領域に置かれたコートは別の領域のアトレスへの書き込みを制限されるかもしれません。より多くの詳細については「NVMCTRL - 不揮発性メモリ制御器」章をご覧ください。

プログラム カウンタ(PC)はプログラム メモリ全体をアドレス指定することができます。 フラッシュ メモリを書くための手順はNVMCTRL章で詳細に記 述されます。

フラッシュメモリの32Kハイトはデータ空間に割り当てられ、通常のLD/ST系命令でアクセス可能です。どのフラッシュメモリ部分がこのデータ空間 に割り当てられるかの詳細についてはNVMCTRL章をご覧ください。LD/ST系命令について、フラッシュメモリはアトレス\$8000から割り当 てられます。フラッシュメモリはLPM命令でも読むことができます。LPM命令について、フラッシュメモリ開始アトレスは\$0000です。

AVR64EA28/32/48はデータ バスでのCRC単位部主権者を持ちます。

右図は物理的と論理的なメモリ領域の割り当てを示します。

- ・NRWW = 書き込み中読み出し不可
- ・RWW = 書き込み中読み出し可

物理的と論理的なメモリ領域の違いとそれらの構成設定について のより多くの詳細に関してはNVMCTRL章をご覧ください。

| 表8-1. フラッシュ メモリの物理的な特性 |                 |  |  |  |  |
|------------------------|-----------------|--|--|--|--|
| 特性                     | AVR64EA28/32/48 |  |  |  |  |
| 量                      | 64Kバイト          |  |  |  |  |
| ページ容量                  | 128시 イト         |  |  |  |  |
| ページ数                   | 512             |  |  |  |  |
| データ空間での開始アドレス          | \$8000          |  |  |  |  |
| コート空間での開始アドレス          | \$0000          |  |  |  |  |

#### 図8-2. フラッシュ メモリ領域 物理領域 論理領域 FLASHSTART: \$0000 ブート NRWW ----BOOTEND: BOOTSIZE $\times 256-1$ 応用コード CODEEND: CODESIZE $\times 256-1$ 応用データ RWW FLASHEND: USERROW (訳補) BOOTSIZEtューズ×256が応用コート、領域先頭を、COD ESIZEヒューズ×256が応用データ領域先頭を示します。

## 8.4. SRAMデータ メモリ

SRAMメモリの主な仕事は応用データを格納することです。SRAMからコードを実行す ることは不可能です。

リセット後、プログラムスタックはSRAMの最後に置かれます。

| 表82. SF | RAMの物理的な特性 |
|---------|------------|
|---------|------------|

開始アドレス

| 特性     | AVR64EA28/32/48 |
|--------|-----------------|
| 量      | 6Kハ'イト          |
| 開始アドレス | \$6800          |
| 終了アドレス | \$7FFF          |

## 8.5. EEPROMデータメモリ

EEPROMメモリの主な仕事は不揮発性応用データを格納することです。EEPROMメモ リは単一と複数のバイト読み書きを支援します。EEPROMは不揮発性メモリ制御器 (NVMCTRL)によって制御されます。

| 表8-3. EEPRO        | 表8-3. EEPROMの物理的な特性 |  |  |  |  |  |
|--------------------|---------------------|--|--|--|--|--|
| 特性 AVR64EA28/32/48 |                     |  |  |  |  |  |
| 量                  | 512 가 イト            |  |  |  |  |  |
| ヘージ容量              | 8/차기ト               |  |  |  |  |  |
| ページ数               | 64                  |  |  |  |  |  |

\$1400

# 8.6. USERROW - 使用者列

AVR64EA28/32/48は使用者列(USERROW)と呼ばれる特別な64バイト メモリ領域を持ちます。USERROWは最終製品データ用に使うこ とができ、チップ消去によって影響を及ぼされません。例えデバイスが施錠されていても、統一プログラミング/デバッグ、インターフェース(UPDI)に よって書くことができ、これは他のどのメモリへのアクセスもなしに最終構成設定の記憶を許します。デバイスが施錠されると、UPDIはUSER ROWの内容を読むことが許されません。

CPUは通常のフラッシュメモリとしてこれを読み書きすることができます。更なる詳細については「システムメモリアドレス配置」表を参照してく ださい。

# 8.7. LOCK - メモリ領域アクセス保護

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

デバイスは施錠鍵(LOCK.KEY)レジスタに無効な鍵を書くことによって施錠されます。

| 表8-4. 解錠動作/施錠動作          | 表8−4. 解錠動作/施錠動作でのメモリアクセス (~/~は解錠時/施錠時、注1) |      |            |              |  |  |  |  |  |  |
|--------------------------|-------------------------------------------|------|------------|--------------|--|--|--|--|--|--|
|                          | CPU                                       | アクセス | UPDIアクセス   |              |  |  |  |  |  |  |
| メモリ領域                    | 読み                                        | 書き   | 読み         | 書き           |  |  |  |  |  |  |
| フラッシュ メモリ                | 0/0                                       | 0/0  | O/×        | $O/\times$   |  |  |  |  |  |  |
| SRAM                     | 0/0                                       | 0/0  | O/×        | O/X          |  |  |  |  |  |  |
| EEPROM                   | 0/0                                       | 0/0  | O/X        | O/X          |  |  |  |  |  |  |
| 使用者列 (USERROW)           | 0/0                                       | 0/0  | O/X        | 0/0 (注       |  |  |  |  |  |  |
| 識票列 (SIGROW)             | 0/0                                       | ×/×  | O/X        | ×/×          |  |  |  |  |  |  |
| ヒュース <sup>*</sup> (FUSE) | 0/0                                       | ×/×  | O/×        | O/X          |  |  |  |  |  |  |
| 施錠 (LOCK)                | 0/0                                       | ×/×  | O/×        | O/X          |  |  |  |  |  |  |
| レジスタ                     | 0/0                                       | 0/0  | O/X        | O/X          |  |  |  |  |  |  |
| きょ ナー いうちょう きっ           |                                           |      | 1° - 1 - 1 | 1+10+11 +/1- |  |  |  |  |  |  |

# 

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

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

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



重要: デベイスを解錠する唯一の方法はCHIPERASEです。応用データは保持されません。

**2**)

# 8.7.1. 施錠要約

| 変位    | 略称   | ビット位置       | ビット7 | ビット6 | ビット5 | ビット4  | ビット3  | ビット2 | ビット1 | ビットロ |
|-------|------|-------------|------|------|------|-------|-------|------|------|------|
| +\$00 |      | $7 \sim 0$  |      | 1    | 1    | , KEA | 7~0   | 1    | 1    |      |
| +\$01 | KEY  | $15 \sim 8$ |      | 1    | 1    | KEY   | 15~8  | 1    | 1    |      |
| +\$02 | NE I | 23~16       |      | 1    | 1    | KEY2  | 23~16 | 1    | 1    |      |
| +\$03 |      | 31~24       |      | 1    | 1    | KEY3  | 31~24 | 1    | 1    |      |

# 8.7.2. 施錠説明

8.7.2.1. KEY - 施錠鍵 (Lock Key)

**名称**:KEY

**変位**:+\$00

**リセット**:初期工場値=\$5CC5C55C

特質 :-

| ヒット    | 31 | 30                                           | 29 | 28   | 27   | 26 | 25 | 24 |
|--------|----|----------------------------------------------|----|------|------|----|----|----|
|        |    |                                              |    | KEY3 | 1~24 |    |    |    |
| アクセス種別 | R  | R                                            | R  | R    | R    | R  | R  | R  |
| リセット値  | Х  | Х                                            | Х  | Х    | Х    | Х  | Х  | Х  |
| ビット    | 23 | 22                                           | 21 | 20   | 19   | 18 | 17 | 16 |
|        |    | <u>.                                    </u> |    | KEY2 | 3~16 |    |    |    |
| アクセス種別 | R  | R                                            | R  | R    | R    | R  | R  | R  |
| リセット値  | Х  | Х                                            | Х  | Х    | х    | Х  | Х  | Х  |
| ビット    | 15 | 14                                           | 13 | 12   | 11   | 10 | 9  | 8  |
|        |    |                                              |    | KEY  | 15~8 |    |    |    |
| アクセス種別 | R  | R                                            | R  | R    | R    | R  | R  | R  |
| リセット値  | Х  | Х                                            | Х  | Х    | Х    | Х  | Х  | Х  |
| ビット    | 7  | 6                                            | 5  | 4    | 3    | 2  | 1  | 0  |
|        |    |                                              |    | KEY  | 7~0  |    |    |    |
| アクセス種別 | R  | R                                            | R  | R    | R    | R  | R  | R  |
| リセット値  | Х  | Х                                            | Х  | Х    | Х    | Х  | Х  | Х  |

### • ビット31~0 - KEY31~0 : 施錠鍵 (Lock Key)

このビット領域はデバイスが施錠されるかどうかを制御します。

| 值  | \$5CC5C55C     | その他            |
|----|----------------|----------------|
| 名称 | UNLOCKED       | LOCKED         |
| 説明 | デバイスは解錠されています。 | デバイスは施錠されています。 |

# 8.8. FUSE - 構成設定と使用者のヒュース

ヒュース、は不揮発性メモリの一部で、デバイス構成設定を保持します。ヒュース、はCPUとUPDIの両方によって読むことができますが、UPDI によってのみそれらを設定または解除することができます。ヒュース、に格納された構成設定値は始動手順の最後でそれら各々の目的 対象レジスタに書かれます。

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

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

#### 8.8.1. ヒューズ 要約

| 変位    | 略称       | ビット位置 | ビット7 | ビット6   | ビット5   | ビット4       | ビット3      | ビット2  | ビット1   | ビットロ   |
|-------|----------|-------|------|--------|--------|------------|-----------|-------|--------|--------|
| +\$00 | WDTCFG   | 7~0   |      | WINDO  | ₩3~0   | 1          |           | PERIC | DD3~0  |        |
| +\$01 | BODCFG   | 7~0   |      | LVL2~0 | 1      | SAMPFREQ   | ACTI      | VE1,0 | SLEI   | EP1,0  |
| +\$02 | OSCCFG   | 7~0   |      |        |        |            | OSCHFFRQ  |       |        |        |
| +\$03 | 予約       |       |      |        |        |            |           |       |        |        |
| +\$04 | 予約       |       |      |        |        |            |           |       |        |        |
| +\$05 | SYSCFG0  | 7~0   | CRCS | RC1,0  | CRCSEL | UPDIPINCFG | RSTPINCFG |       |        | EESAVE |
| +\$06 | SYSCFG1  | 7~0   |      |        |        |            |           |       | SUT2~0 |        |
| +\$07 | CODESIZE | 7~0   |      |        |        | CODES      | SIZE7~0   |       | 1      |        |
| +\$08 | BOOTSIZE | 7~0   |      |        | 1      | BOOTS      | SIZE7~0   | 1     | 1      |        |

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

#### 8.8.2.1. WDTCFG - ウォッチトック タイマ構成設定 (Watchdog Timer Configration)

名称:WDTCFG

**変位** : +\$00

既定 : \$00

#### 特質 :-

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

| ビット    | 7 | 6     | 5     | 4 | 3 | 2     | 1    | 0 |
|--------|---|-------|-------|---|---|-------|------|---|
| [      |   | WINDO | 0W3∼0 |   |   | PERIC | D3~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)

この値は電源ONまたはリセット後の始動手順の最後でウォッチドッグ制御A(WDT.CTRLA)レジスタの窓期間(WINDOW)ビット領域に設定されます。

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

この値は電源ONまたはリセット後の始動手順の最後でウォッチドッグ制御A(WDT.CTRLA)レジスタの制限期間(PERIOD)ビット領域に設定されます。

8.8.2.2. BODCFG - 低電圧検出器構成設定 (Brown-out Detector Configration)

名称:BODCFG

**変位** : +\$01

既定:\$00

特質 :-

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

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

| ビット    | 7 | 6      | 5 | 4        | 3    | 2    | 1    | 0     |
|--------|---|--------|---|----------|------|------|------|-------|
|        |   | LVL2~0 |   | SAMPFREQ | ACTI | VELO | SLEI | 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)ビット領域に設定されます。

注: 説明行の値は代表値です。 更なる詳細については「電気的特性」章を参照してください。

注: BODLEVEL0はチップ消去中にだけ許可されます。通常動作では、このビット領域への'000'書き込みはBOD禁止と同じです。

| 値  | 0 0 0                                         | 001       | 010       | 011       | その他  |
|----|-----------------------------------------------|-----------|-----------|-----------|------|
| 名称 | BODLEVEL0                                     | BODLEVEL1 | BODLEVEL2 | BODLEVEL3 | -    |
| 説明 | 1.75V (チップ消去中だけ許可されるBOD。<br>「電気的特性」章をご覧ください。) | 1.90V     | 2.60V     | 4.30V     | (予約) |

#### ● ビット4 - SAMPFREQ : BOD採取周波数 (BOD Sample Frequency)

この値はリセット中にBOD制御A(BOD.CTRLA)レジスタの採取周波数(SAMPFREQ)ビットに設定されます。 更なる詳細については「BOD - 低電圧検出器」章を参照してください。

| 値  | 0              | 1             |
|----|----------------|---------------|
| 名称 | 128HZ          | 32HZ          |
| 説明 | 採取周波数は128Hzです。 | 採取周波数は32Hzです。 |

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

この値はリセット中にBOD制御A(BOD.CTRLA)レジスタの活動/アイトル時動作(ACTIVE)ビット領域に設定されます。 更なる詳細については「BOD - 低電圧検出器」章を参照してください。

| 值  | 0 0     | 0 1        | 1 0        | 11                                         |
|----|---------|------------|------------|--------------------------------------------|
| 名称 | DISABLE | ENABLE     | SAMPLE     | ENABLEWAIT                                 |
| 説明 | BOD禁止   | 継続動作でBOD許可 | 採取動作でBOD許可 | 継続動作でBOD許可。実行は起き上がりで<br>BODの準備が整うまで停止されます。 |

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

この値はリセット中にBOD制御A(BOD.CTRLA)レジスタのスタンバイ/パワーダウン時動作(SLEEP)ビット領域に設定されます。更なる詳細については「BOD - 低電圧検出器」章を参照してください。

| 值  | 0 0     | 01         | 1 0        | 11   |
|----|---------|------------|------------|------|
| 名称 | DISABLE | ENABLE     | SAMPLE     | -    |
| 説明 | BOD禁止   | 継続動作でBOD許可 | 採取動作でBOD許可 | (予約) |

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

名称:OSCCFG

**変位** : +\$02

既定 : \$00

#### 特質 :-

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

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

#### ● ビット3~0 - OSCHFFRQ : 内部高周波数発振器周波数 (Internal High-frequency Oscillator Frequency)

このヒューズビットは内部高周波数発振器(OSCHF)の走行周波数を制御します。

| 値  | 0               | 1               |
|----|-----------------|-----------------|
| 説明 | 20MHzで走行するOSCHF | 16MHzで走行するOSCHF |

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

名称:SYSCFG0

**変位** : +\$05

**既定**:\$D0

特質 :-

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

| ビット    | 7    | 6     | 5      | 4          | 3         | 2 | 1 | 0      |
|--------|------|-------|--------|------------|-----------|---|---|--------|
| [      | CRCS | RC1,0 | CRCSEL | UPDIPINCFG | RSTPINCFG |   |   | EESAVE |
| アクセス種別 | R    | R     | R      | R          | R         | R | R | R      |
| 既定値    | 1    | 1     | 0      | 1          | 0         | 0 | 0 | 0      |

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

このビット領域はリセット初期化中にフラッシュメモリのどの領域がCRCSCAN周辺機能によって検査されるかを制御します。機能についてのより多くの情報に関しては「CRCSCAN - 巡回冗長検査メモリ走査」章をご覧ください。

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

#### ● ビット5 - CRCSEL : CRC多項式選択 (CRC Polynomial Selection)

このビットはCRCSCAN周辺機能によって実行されるCRCの形式を制御します。機能についてのより多くの情報に関しては「CRCSCA N - 巡回冗長検査メモリ走査」章をご覧ください。

| 値  | 0            | 1                   |
|----|--------------|---------------------|
| 名称 | CRC16        | CRC32               |
| 説明 | CRC-16-CCITT | CRC-32 (IEEE 802.3) |

#### • ビット4 - UPDIPINCFG : UPDIピン構成設定 (Configuration of UDPI Pin at Start-Up)

このビットは始動でのUPDIピン構成設定を選びます。

| 值  | 0           | 1                           |
|----|-------------|-----------------------------|
| 名称 | GPIO        | UPDI                        |
| 説明 | GPIOとして構成設定 | PF7で許可されるプルアップ付きUPDIとして構成設定 |

#### • ビット3 - RSTPINCFG : リセット ピン構成設定 (Configuration of Reset Pin at Start-Up)

このビットは始動でのリセットピンに対する構成設定を選びます。

| 値  | 0                | 1                      |
|----|------------------|------------------------|
| 名称 | INPUT            | RESET                  |
| 説明 | 外部入力ピンとしてPF6構成設定 | PF6で許可されるプルアップ付き外部リセット |

#### • ビット0 - EESAVE : チップ消去中EEPROM保存 (EEPROM Saved During Chip Erase)

このビットはチップ消去中にEEPROMが消去されるか保存されるかのどちらかを制御します。許可されたなら、チップ消去によってフラッシュ メモリだけが消去されます。

| 値  | 0                     | 1                                               |
|----|-----------------------|-------------------------------------------------|
| 名称 | DISABLE               | ENABLE                                          |
| 説明 | チップ消去中にEEPROMが消去されます。 | デバイスが施錠されているかどうかに関わらず、<br>チップ消去中にEEPROMは保存されます。 |

#### 8.8.2.5. 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)

このビット領域は電源ONとコード実行開始間の時間を意味する始動時間を制御します。

| 值  | 000 | 001 | 010 | 011 | 100 | 101  | 110  | 111  |
|----|-----|-----|-----|-----|-----|------|------|------|
| 名称 | 0MS | 1MS | 2MS | 4MS | 8MS | 16MS | 32MS | 64MS |
| 説明 | 0ms | 1ms | 2ms | 4ms | 8ms | 16ms | 32ms | 64ms |

#### 8.8.2.6. CODESIZE - コードの大きさ (Code Size)

- 名称: CODESIZE
- **変位** : +\$07
- 既定:\$00

#### 特質 :-

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

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

#### • ビット7~0 - CODESIZE7~0: コート 領域の大きさ (Code Section Size)

このビット領域は256パイトの塊でブートコート、領域と応用コート、領域を合わせた大きさを定義します。より多くの詳細については「NVMCTR L - 不揮発性メモリ制御器」章を参照してください。

注: FUSE.BOOTSIZEが\$00の場合、FUSE.CODESIZE値を使うことなく、フラッシュ メモリ全体がフート コート領域として設定されます。

#### 8.8.2.7. BOOTSIZE - ブートの大きさ (Boot Size)

名称:BOOTSIZE

**変位**:+\$08

既定:\$00

特質 :-

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

| ビット        | 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 - BOOTSIZE7~0: ブート領域の大きさ (Boot Section Size)

このビット領域は256ハイトの塊でブート領域の大きさを制御します。 \$00の値はブート コート 領域としてフラッシュ メモリ全体を制御します。より 多くの詳細については「NVMCTRL - 不揮発性メモリ制御器」章を参照してください。

### 8.9. SIGROW - 識票列

識票列(SIGROW)ヒュースでの内容は予め書かれていて変えることができません。SIGROWはデバイスID、通番、校正値を保持します。

全てのAVR64EA28/32/48デバイスはデバイスを識別する3パイトのデバイスIDを持ちます。 このデバイスIDは例えデバイスが施錠されている時でも、UPDIインターフェースを使って読む ことができます。この3パイトは識票列に属します。識票パイトは右表で与えられます。

| 表8-6. | デバイ | 、<br>スID |
|-------|-----|----------|
|       |     |          |

| デバイス名     | 識票バイト アドレス |        |        |  |  |
|-----------|------------|--------|--------|--|--|
| 7.1.1.4   | \$0000     | \$0001 | \$0002 |  |  |
| AVR64EA28 | \$1E       | \$96   | \$20   |  |  |
| AVR64EA32 | \$1E       | \$96   | \$1F   |  |  |
| AVR64EA48 | \$1E       | \$96   | \$1E   |  |  |

### 8.9.1. 識票列要約

| 変位     | 略称              | ビット位置       | ビット7 | <b>ビット6</b> | ビット5 | ビット4   | ヒット3    | <b>ビット2</b> | <b>ビット1</b> | ビットロ |  |  |
|--------|-----------------|-------------|------|-------------|------|--------|---------|-------------|-------------|------|--|--|
| +\$00  | DEVICEID0       | 7~0         |      | DEVICEID7~0 |      |        |         |             |             |      |  |  |
| +\$01  | DEVICEID1       | 7~0         |      | DEVICEID7~0 |      |        |         |             |             |      |  |  |
| +\$02  | DEVICEID2       | $7 \sim 0$  |      |             |      | DEVIC  | EID7~0  | 1           | 1           |      |  |  |
| +\$03  | 予約              |             |      |             |      |        |         |             |             |      |  |  |
| +\$04  | TEMPSENSE0      | $7 \sim 0$  |      |             |      | TEMPSE | ENSE7~0 | 1           | 1           |      |  |  |
| +\$05  | I ENT SENSED    | $15 \sim 8$ |      |             |      | TEMPSE | NSE15~8 | 1           | 1           |      |  |  |
| +\$06  | TEMPSENSE1      | $7 \sim 0$  |      |             |      | TEMPSE | ENSE7~0 | 1           | 1           |      |  |  |
| +\$07  | I EIVIP SEINSET | $15 \sim 8$ |      |             |      | TEMPSE | NSE15~8 | 1           | 1           |      |  |  |
| +\$08  | マが              |             |      |             |      |        |         |             |             |      |  |  |
| +\$0F  | 予約              |             |      |             |      |        |         |             |             |      |  |  |
| +\$10  | SERNUM0         | 7~0         |      |             |      | SERNU  | JM7~0   | 1           |             |      |  |  |
| $\sim$ |                 |             |      |             |      |        |         |             |             |      |  |  |
| +\$1F  | SERNUM15        | 7~0         |      |             |      | SERNU  | JM7~0   | 1           | 1           |      |  |  |

#### 8.9.2. 識票列説明

**8.9.2.1. DEVICEIDn - ว**ั*ก*ั**1XIDn** (Device ID n)

名称:DEVICEID0:DEVICEID1:DEICEVID2

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

リセット:[デバイスID]

特質:-

各デバイスはデバイスとメモリ量、ピン数、ダイ改訂を含むそれの特性を識別するデバイスIDを持ちます。デバイスと利用可能な機能を識別するのにこのIDを使ってください。デバイスIDはSIGROW.DEVICEID2~0の3バイトから成ります。

| ヒット    | 7 | 6 | 5 | 4     | 3      | 2 | 1 | 0 |
|--------|---|---|---|-------|--------|---|---|---|
|        |   |   |   | DEVIC | EID7~0 |   |   |   |
| アクセス種別 | R | R | R | R     | R      | R | R | R |
| リセット値  | х | Х | Х | Х     | х      | Х | х | Х |

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

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

名称:TEMPSENSE0L:TEMPSENSE0H:TEMPSENSE1L:TEMPSENSE1H

**変位**:+\$04 :+\$05 :+\$06 :+\$07

リセット: [温度感知器校正値]

特質:-

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

| ビット    | 15            | 14 | 13     | 12     | 11 | 10     | 9      | 8      |  |  |  |  |
|--------|---------------|----|--------|--------|----|--------|--------|--------|--|--|--|--|
|        | TEMPSENSE15~8 |    |        |        |    |        |        |        |  |  |  |  |
| アクセス種別 | R             | R  | R      | R      | R  | R      | R      | R      |  |  |  |  |
| リセット値  | Х             | Х  | Х      | Х      | Х  | Х      | Х      | Х      |  |  |  |  |
| ヒット    | 7             | 6  | 5      | 4      | 3  | 2      | 1      | 0      |  |  |  |  |
|        | TEMPSENSE7~0  |    |        |        |    |        |        |        |  |  |  |  |
| アクセス種別 | R             | R  | R      | R      | R  | R      | R      | R      |  |  |  |  |
| リセット値  | Х             | Х  | Х      | Х      | Х  | Х      | Х      | Х      |  |  |  |  |
|        |               |    | R<br>x | R<br>x |    | R<br>x | R<br>x | R<br>x |  |  |  |  |

●ビット15~0 - TEMPSENSE15~0:温度感知器校正 (Temperature Sensor Calibration)

これらのレジスタの使い方については「ADC - A/D変換器」章を参照してください。

8.9.2.3. SERNUMn - 通番バ仆n (Serial Number Byte n)

名称:SERNUM0 ~ SERNUM15 変位:+\$10 ~ +\$1F リセット:[デベイス通番のバイトn]

特質 :-

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

| ビット    | 7 | 6 | 5 | 4     | 3     | 2 | 1 | 0 |
|--------|---|---|---|-------|-------|---|---|---|
|        |   |   |   | SERNU | JM7~0 |   |   |   |
| アクセス種別 | R | R | R | R     | R     | R | R | R |
| リセット値  | Х | Х | Х | Х     | Х     | Х | Х | Х |

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

# 8.10. I/Oメモリ

AVR64EA28/32/48デベイスの全てのI/Oと周辺機能はI/Oメモリ空間に配置されます。更なる詳細については「周辺機能アドレス配置」 表を参照してください。

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

## 単一周期I/Oレジスタ

\$00~\$3Fに及ぶI/OメモリはINまたはOUTの命令を使って単一周期CPU命令によってアクセスすることができます。

単一周期I/Oレシブスタで利用可能な周辺機能は次のとおりです。

・ VPORTx (仮想ポート)

- 更なる詳細については「I/Oピン構成設定」章を参照してください。

- GPR (汎用レシ<sup>゙</sup>スタ)
- 更なる詳細については「汎用レジスタ」章を参照してください。
- CPU
- 更なる詳細については「AVR® CPU」章を参照してください。

\$00~\$1Fに及ぶ単一周期I/Oレジスタ(VPORTxとGPR)はSBIまたはCBIの命令を用いて直接ビットアクセスも可能です。これらの単一周 期I/Oレジスタでは、SBISまたはSBICの命令を用いることによって単一ビットを調べることができます。

更なる詳細については「命令一式要約」章を参照してください。

## 8.10.1. 16ビット レシ スタのアクセス

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

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

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

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

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

# 8.10.2. 24ビットと32ビットのレシズタのアクセス

24ビットと32ビットのレシ、スタについては、24ビットレシ、スタ用に2つの一時レシ、スタと32ビットレシ、スタ用に3つの一時レシ、スタがあることを除き、16 ビットレシ、スタに対して記述されたのと同じ方法で行われます。レシ、スタに書く時は最上位ハ、仆が最後に書かれなければならず、レシ、スタを 読む時は最下位ハ、仆が先に読まれなければなりません。





# 9. GPR - 汎用レジスタ

AVR64EA28/32/48デバイスは4つの汎用レジスタを提供します。これらのレジスタはどんな情報を格納するのにも使うことができ、それら は特に全域変数と割り込みフラグを格納するのに有用です。汎用レジスタのビットに暗黙的または明示的な意味は適用されません。ビット 値の意味はソフトウェアによって決められます。

アドレス範囲\$0C~\$1Fに属す汎用レジスタはSBI、CBI、SBIS、SBICの命令を用いて直接ビットアクセス可能です。

# 9.1. レジスタ要約

| 変位    | 略称   | ビット位置 | ビット7 | ビット6   | ビット5 | ビット4 | ビット3 | ビット2 | ビット1 | ビット0 |
|-------|------|-------|------|--------|------|------|------|------|------|------|
| +\$00 | GPR0 | 7~0   |      | GPR7~0 |      |      |      |      |      |      |
| +\$01 | GPR1 | 7~0   |      | GPR7~0 |      |      |      |      |      |      |
| +\$02 | GPR2 | 7~0   |      |        | 1    | GPF  | ₹7~0 |      | 1    |      |
| +\$03 | GPR3 | 7~0   |      |        | 1    | GPF  | 27~0 |      | 1    |      |

# 9.2. レジスタ説明

9.2.1. GPRn - 汎用レジスタn (General Purpose Register n)

| <b>名称</b> :GPR0   | : GPR1  | : GPR2  | : GPR3  |
|-------------------|---------|---------|---------|
| <b>変位</b> : +\$00 | : +\$01 | : +\$02 | : +\$03 |
| リセット : \$00       |         |         |         |

特質:-

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

| ビット    | 7      | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|--------|-----|-----|-----|-----|-----|-----|-----|--|--|
|        | GPR7~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 - GPR7~0:汎用レジスタn バイト (General Purpose Register Byte)

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

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

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

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

| 基準アドレス | 名称      | 説明            | 28ピン | 32ピン | 48ピン |
|--------|---------|---------------|------|------|------|
| \$0000 | VPORTA  | 仮想ポートA        | 0    | 0    | 0    |
| \$0004 | VPORTB  | 仮想ポートB        | ×    | ×    | 0    |
| \$0008 | VPORTC  | 仮想ポートC        | 0    | 0    | 0    |
| \$000C | VPORTD  | 仮想ポートD        | 0    | 0    | 0    |
| \$0010 | VPORTE  | 仮想ポートE        | ×    | ×    | 0    |
| \$0014 | VPORTF  | 仮想ポートF        | 0    | 0    | 0    |
| \$001C | GPR     | 汎用レジスタ        | 0    | 0    | 0    |
| \$0030 | CPU     | CPU           | 0    | 0    | 0    |
| \$0040 | RSTCTRL | リセット制御器       | 0    | 0    | 0    |
| \$0050 | SLPCTRL | 休止制御器         | 0    | 0    | 0    |
| \$0060 | CLKCTRL | クロック制御器       | 0    | 0    | 0    |
| \$00A0 | BOD     | 低電圧検出         | 0    | 0    | 0    |
| \$00B0 | VREF    | 基準電圧          | 0    | 0    | 0    |
| \$0100 | WDT     | ウォッチドッグタイマ    | 0    | 0    | 0    |
| \$0110 | CPUINT  | 割り込み制御器       | 0    | 0    | 0    |
| \$0120 | CRCSCAN | 巡回冗長検査メモリ走査   | 0    | 0    | 0    |
| \$0140 | RTC     | 実時間計数器        | 0    | 0    | 0    |
| \$01C0 | CCL     | 構成設定可能な注文論理回路 | 0    | 0    | 0    |
| \$0200 | EVSYS   | 事象システム        | 0    | 0    | 0    |
| \$0400 | PORTA   | ポートA構成設定      | 0    | 0    | 0    |
| \$0420 | PORTB   | ポートB構成設定      | ×    | ×    | 0    |
| \$0440 | PORTC   | ポートC構成設定      | 0    | 0    | 0    |
| \$0460 | PORTD   | ポートD構成設定      | 0    | 0    | 0    |
| \$0480 | PORTE   | ポートE構成設定      | ×    | ×    | 0    |
| \$04A0 | PORTF   | ポートF構成設定      | 0    | 0    | 0    |
| \$05E0 | PORTMUX | ポート多重器        | 0    | 0    | 0    |
| \$0600 | ADC0    | A/D変換器0       | 0    | 0    | 0    |
| \$0680 | AC0     | アナログ比較器0      | 0    | 0    | 0    |
| \$0688 | AC1     | アナログ比較器1      | 0    | 0    | 0    |
| \$06A0 | DAC0    | D/A変換器0       | 0    | 0    | 0    |
| \$0800 | USART0  | 万能同期非同期送受信器0  | 0    | 0    | 0    |
| \$0820 | USART1  | 万能同期非同期送受信器1  | 0    | 0    | 0    |
| \$0840 | USART2  | 万能同期非同期送受信器2  | 0    | 0    | 0    |
| \$0900 | TWI0    | 2線インターフェース0   | 0    | 0    | 0    |
| \$0940 | SPI0    | 直列周辺インターフェース0 | 0    | 0    | 0    |
| \$0A00 | TCA0    | タイマ/カウンタA型0   | 0    | 0    | 0    |
| \$0A40 | TCA1    | タイマ/カウンタA型1   | 0    | 0    | 0    |
| \$0B00 | TCB0    | タイマ/カウンタB型0   | 0    | 0    | 0    |
| \$0B10 | TCB1    | タイマ/カウンタB型1   | 0    | 0    | 0    |
| \$0B20 | TCB2    | タイマ/カウンタB型2   | 0    | 0    | 0    |
| \$0B30 | TCB3    | タイマ/カウンタB型3   | 0    | 0    | 0    |
| \$0F00 | SYSCFG  | システム構成設定      | 0    | 0    | 0    |
| \$0F80 | OCD     | チップ上デバッグ      | 0    | 0    | 0    |
| \$1000 | NVMCTRL | 不揮発性メモリ制御器    | 0    | 0    | 0    |

## 表10-2. システム メモリ アト・レス配置

| 基準アトレス | 名称      | 説明      | 28ピン | 32ピン | 48ピン |
|--------|---------|---------|------|------|------|
| \$1040 | LOCKBIT | 施錠ビット   | 0    | 0    | 0    |
| \$1050 | FUSE    | 使用者構成設定 | 0    | 0    | 0    |
| \$1080 | USERROW | 使用者列    | 0    | 0    | 0    |
| \$1100 | SIGROW  | 識票列     | 0    | 0    | 0    |

# 10.2. 割り込みべり外配置

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

割り込み条件が起こると、例え割り込みが許可されていなくても、周辺機能の割り込み要求フラグ(周辺機能名.INTFLAGS)レジスタで割り込み要求フラグが設定(1)されます。

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

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

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

| べかり<br>番号        | へ <sup>、</sup> クタ<br>アト <sup>・</sup> レス (語) | <b>周辺機能</b><br>(名称)     | 説明                                               | 28<br>ピン | 32<br>ピン   | 48<br>ピン               |
|------------------|---------------------------------------------|-------------------------|--------------------------------------------------|----------|------------|------------------------|
| 0                | \$0000                                      | RESET                   | リセット                                             | 0        | 0          | 0                      |
| 1                | \$0002                                      | NMI                     | 以下に対して利用可能な遮蔽不可割り込み: ・CRCSCAN<br>・CFD            | 0        | 0          | 0                      |
| 2                | \$0004                                      | BOD_VLM                 | 電圧水準監視器割り込み                                      | 0        | 0          | 0                      |
| 3                | \$0006                                      | CLKCTRL_CFD             | 外部クリスタル発振器/クロック元障害割り込み(CFD)                      | 0        | $\bigcirc$ | $\bigcirc$             |
| 4                | \$0008                                      | RTC_CNT                 | 実時間計数器の溢れまたは比較一致の割り込み                            | 0        | $\bigcirc$ | 0                      |
| 5                | \$000A                                      | RTC_PIT                 | 実時間計数器の周期割り込み (PIT)                              | 0        | $\bigcirc$ | $\bigcirc$             |
| 6                | \$000C                                      | CCL_CCL                 | 構成設定可能な注文論理回路割り込み                                | 0        | $\bigcirc$ | $\bigcirc$             |
| 7                | \$000E                                      | PORTA_PORT              | ポートA外部割り込み                                       | 0        | $\bigcirc$ | 0                      |
| 8                | \$0010                                      | TCA0_OVF<br>TCA0_LUNF   | 標準: タイマ/カウンタA型溢れ割り込み<br>分割: タイマ/カウンタA型下位下溢れ割り込み  | 0        | 0          | 0                      |
| 9                | \$0012                                      | TCA0_HUNF               | 標準:未使用<br>分割:タイマ/カウンタA型上位下溢れ割り込み                 | 0        | 0          | 0                      |
| 10               | \$0014                                      | TCA0_CMP0<br>TCA0_LCMP0 | 標準:タイマ/カウンタA型比較0割り込み<br>分割:タイマ/カウンタA型下位比較0割り込み   | 0        | 0          | 0                      |
| 11               | \$0016                                      | TCA0_CMP1<br>TCA0_LCMP1 | 標準: タイマ/カウンタA型比較1割り込み<br>分割: タイマ/カウンタA型下位比較1割り込み | 0        | 0          | 0                      |
| 12               | \$0018                                      | TCA0_CMP2<br>TCA0_LCMP2 | 標準:タイマ/カウンタA型比較2割り込み<br>分割:タイマ/カウンタA型下位比較2割り込み   | 0        | 0          | 0                      |
| 13               | \$001A                                      | TCB0_INT                | タイマ/カウンタB型捕獲/溢れ割り込み                              | 0        | $\bigcirc$ | 0                      |
| 14               | \$001C                                      | TCB1_INT                | タイマ/カウンタB型捕獲/溢れ割り込み                              | 0        | $\bigcirc$ | 0                      |
| 15               | \$001E                                      | TWI0_TWIS               | 2線インターフェース従装置割り込み                                | 0        | 0          | 0                      |
| 16               | \$0020                                      | TWI0_TWIM               | 2線インターフェース主装置割り込み                                | 0        | 0          | 0                      |
| 17               | \$0022                                      | SPI0_INT                | 直列周辺インターフェース割り込み                                 | 0        | 0          | $\bigcirc$             |
| 18               | \$0024                                      | USART0_RXC              | 万能同期非同期送受信器受信完了割り込み                              | 0        | 0          | 0                      |
| 19               | \$0026                                      | USART0_DRE              | 万能同期非同期送受信器データレジスタ空割り込み                          | 0        | 0          | 0                      |
| 20               | \$0028                                      | USART0_TXC              | 万能同期非同期送受信器送信完了割り込み                              | 0        | 0          | 0                      |
| 21               | \$002A                                      | PORTD_PORT              | ポートD外部割り込み                                       | 0        | 0          | 0                      |
| 22               | \$002C                                      | AC0_AC                  | アナログ比較器割り込み                                      | 0        | 0          | 0                      |
| 23               | \$002E                                      | ADC0_ERROR              | A/D変換器誤り割り込み                                     | 0        | 0          | 0                      |
| 24               | \$0030                                      | ADC0_RESRDY             | A/D変換器結果準備可割り込み                                  | 0        | 0          | 0                      |
| 25               | \$0032                                      | ADC0_SAMPRDY            | A/D変換器試料準備可割り込み                                  | 0        | 0          | 0                      |
| 26               | \$0034                                      | AC1_AC                  | アナログ比較器割り込み                                      | 0        | 0          | 0                      |
| 27               | \$0036                                      | PORTC_PORT              | ポートC外部割り込み                                       | 0        | 0          | $\left  \right\rangle$ |
| 28               | \$0038                                      | TCB2_INT                | タイマ/カウンタB型捕獲/溢れ割り込み                              | 0        | 0          | $\left  \right\rangle$ |
| 29               | \$003A                                      | USART1_RXC              | 万能同期非同期送受信器受信完了割り込み                              | 0        | 0          | $\left  \right\rangle$ |
| 30               | \$003C                                      | USART1_DRE              | 万能同期非同期送受信器データレジスタ空割り込み                          | 0        | 0          | 0                      |
| <u>31</u><br>次頁へ | \$003E                                      | USART1_TXC              | 万能同期非同期送受信器送信完了割り込み                              | 0        | 0          | 0                      |

#### 表10-3.割り込みベクタ配置

| 表10-3            | 8 (続き). 割              | り込みベクタ配置                |                                                      |            |            |            |
|------------------|------------------------|-------------------------|------------------------------------------------------|------------|------------|------------|
| <u>へ</u> が<br>番号 | <b>ベクタ</b><br>アドレス (語) | <b>周辺機能</b><br>(名称)     | 説明                                                   | 28<br>ピン   | 32<br>ピン   | 48<br>ピン   |
| 32               | \$0040                 | PORTF_PORT              | ポートF外部割り込み                                           | $\bigcirc$ | 0          | $\bigcirc$ |
| 33               | \$0042                 | EEREADY<br>FLREADY      | 不揮発性メモリ制御器EEPROM準備可割り込み<br>不揮発性メモリ制御器フラッシュメモリ準備可割り込み | 0          | 0          | 0          |
| 34               | \$0044                 | USART2_RXC              | 万能同期非同期送受信器受信完了割り込み                                  | $\bigcirc$ | 0          | $\bigcirc$ |
| 35               | \$0046                 | USART2_DRE              | 万能同期非同期送受信器データレジスタ空割り込み                              | $\bigcirc$ | 0          | $\bigcirc$ |
| 36               | \$0048                 | USART2_TXC              | 万能同期非同期送受信器送信完了割り込み                                  | $\bigcirc$ | 0          | $\bigcirc$ |
| 37               | \$004A                 | TCB3_INT                | タイマ/カウンタB型捕獲/溢れ割り込み                                  | 0          | $\bigcirc$ | $\bigcirc$ |
| 38               | \$004C                 | TCA1_OVF<br>TCA1_LUNF   | 標準:タイマ/カウンタA型溢れ割り込み<br>分割:タイマ/カウンタA型下位下溢れ割り込み        | 0          | 0          | 0          |
| 39               | \$004E                 | TCA1_HUNF               | 標準: 未使用<br>分割: タイマ/カウンタA型上位下溢れ割り込み                   | 0          | 0          | 0          |
| 40               | \$0050                 | TCA1_CMP0<br>TCA1_LCMP0 | 標準:タイマ/カウンタA型比較0割り込み<br>分割:タイマ/カウンタA型下位比較0割り込み       | 0          | 0          | 0          |
| 41               | \$0052                 | TCA1_CMP1<br>TCA1_LCMP1 | 標準:タイマ/カウンタA型比較1割り込み<br>分割:タイマ/カウンタA型下位比較1割り込み       | 0          | 0          | 0          |
| 42               | \$0054                 | TCA1_CMP2<br>TCA1_LCMP2 | 標準:タイマ/カウンタA型比較2割り込み<br>分割:タイマ/カウンタA型下位比較2割り込み       | 0          | 0          | 0          |
| 43               | \$0056                 | PORTE_PORT              | ポートE外部割り込み                                           | $\times$   | ×          | $\bigcirc$ |
| 44               | \$0058                 | PORTB_PORT              | ポートB外部割り込み                                           | ×          | $\times$   | 0          |

# 10.3. SYSCFG - システム構成設定

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

## 10.3.1. レジスタ要約

| 変位    | 略称    | ビット位置 | ビット7     | ビット6 | ビット5 | ビット4     | ビット3 | ビット2 | ビット1 | ビットロ |
|-------|-------|-------|----------|------|------|----------|------|------|------|------|
| +\$00 | 予約    |       |          |      |      |          |      |      |      |      |
| +\$01 | REVID | 7~0   | MAJOR3~0 |      |      | MINOR3~0 |      |      |      |      |

## 10.3.2. レジスタ説明

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

名称:REVID

**変位** : +\$01

**リセット** : [改訂ID]

特質:-

このレジスタは読み込み専用でデバイス改訂IDを示します。改訂=A0, A1,~B0, B1,~以下同様です。

| ヒット    | 7        | 6 | 5 | 4 | 3        | 2 | 1 | 0 |  |
|--------|----------|---|---|---|----------|---|---|---|--|
|        | MAJOR3~0 |   |   |   | MINOR3~0 |   |   |   |  |
| アクセス種別 | R        | R | R | R | R        | R | R | R |  |
| リセット値  | Х        | Х | Х | Х | Х        | Х | Х | Х |  |

## ● ビット7~4 - MAJOR3~0:主改訂 (Major Revision)

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

● ビット3~0 - MINOR3~0 : 副改訂 (Minor Revision)

このビット領域は\$0から始まる副デバイス改訂を含みます。

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

# 11.1. 特徴

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

## 11.2. 概要

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

## 11.2.1. 構成図



# 11.3. 機能的な説明

# 11.3.1. メモリ構成

## 11.3.1.1. フラッシュ メモリ

フラッシュメモリはページの組に分けられます。ページはフラッシュメモリを 消去する時にアドレス指定可能な最小単位です。それは一度にペー ジ全体を書くまたは消去することだけが可能です。1ページは128パ イトから成ります。

ページの大きさと無関係に、フラッシュメモリは領域で構成されます。フ ラッシュメモリはブートローダ応用に対する構造を最適化するために書 き込み中読み込み可(RWW:Read-While-Write)と書き込み中読み 込み不可(NRWW:Non Read-While-Write)の2つの物理的な領域 に分けられます。これら2つの領域をブートローダコート(BOOT)、応 用コート(APPCODE)、応用データ(APPDATA)の3つの論理的な領域 に分けることが可能です。

#### 図11-2. AVR EA系フラッシュ メモリ領域



#### 11.3.1.1.1. 物理的な領域

フラッシュ メモリは物理的に2つの固定された領域、書き込み中読み込み可(RWW:Read-While-Write)と書き込み中読み込み不可(NRW W:Non Read-While-Write)に分けられます。

2つの領域間の主な違いは次のとおりです。

・RWWフラッシュ メモリ内に位置するページの消去または書き込み時、NRWWフラッシュ メモリはその操作中に読むことができます。

・NRWWフラッシュ メモリ内に位置するページの消去または書き込み時、CPUはその操作全体の間停止されます。

「書き込み中読み込み可領域」の記法はプログラム(消去または書き込み)することで読めない領域を指します。RWWフラッシュ メモリが書かれ、または消去されつつある間にNRWWフラッシュ メモリ内に位置するコードだけがCPU命令を実行する、またはデータを読むのどちらかによってアクセスすることができます。

注: RWW領域に置かれた割り込みコート、はNRWW領域が消去または書き込みされる間に関連する割り込みが起動された場合にCPU を停止するかもしれません。これを避けるには割り込みを禁止するか、または割り込みコート、をブートコート、(BOOT)領域に置いてくだ さい。

下の図と表はこれら2つの物理的なフラッシュ メモリ領域を詳細に説明します。



| 表11-1. 書き込み中読み込みの筋書き |                 |     |  |  |  |  |
|----------------------|-----------------|-----|--|--|--|--|
| 7ラッシュ メモリ領域消去/書き込み   | フラッシュ メモリ領域アクセス | CPU |  |  |  |  |
| RWW領域                | NRWW領域          | 走行  |  |  |  |  |
| NRWW領域               | NRWW領域          | 停止  |  |  |  |  |
| RWW領域                | RWW領域           | 停止  |  |  |  |  |

- 注: 使用者列はRWWフラッシュ メモリに置かれます。使用者列内のページを消去または書き込む時はこの操作の間にNRWWフラッシュ メモリ を読むことができます。
- 注:物理的な領域の大きさはデバイス依存です。更なる詳細については「メモリ概要」項を参照してください。

## 11.3.1.1.2. 論理的な領域

フラッシュ メモリは各々が可変ページ数から成る3つの論理的な領域に分けることができます。これらの領域は次のとおりです。

- ・ブートコート (BOOT) BOOT領域から実行されるコート は他の全てのフラッシュ メモリ領域に対する完全な書き込みアクセスを持ちます。 ブート ロータ ソフトウェアが使われるなら、この領域に置かれなければなりません。
- ・応用コート、(APPCODE) APPCODE領域から実行されるコート、は他のフラッシュメモリ領域に対して限定された書き込みアクセスを持ちま す。実行可能な応用コート、は通常、この領域に置かれます。
- ・応用データ(APPDATA) 書き込みアクセスを持たないフラッシュメモリ領域。定数は通常、この領域に置かれます。

#### 領域容量

ブートの大きさ(FUSE.BOOTSIZE)ヒューズとコートでの大きさ(FUSE.CODESIZE)ヒューズはこれらの領域の大きさを設定します。ヒューズは256 パイトの塊単位で領域容量を選びます。BOOT領域はFLASHSTARTからBOOTENDに達し、APPCODE領域はBOOTEND直後から CODEENDまで広がります。残りの領域がAPPDATA領域です。

FUSE.BOOTSIZEが'0'を書かれた場合、フラッシュ メモリ全体がBOOT領域と見做されます。FUSE.CODESIZEが'0'を書かれ、FUSE.B OOTSEIZEが>0の場合、APPCODE領域はBOOTENDからフラッシュ メモリの最後までを走ります(APPDATA領域なし)。

FUSE.CODESIZE≦FUSE.BOOTSIZEだと、APPCODE領域は取り去られ、APPDATAがBOOTENDからフラッシュ メモリの最後までを走ります。

# 表11-2. フラッシュ メモリ領域の構成設定

| BOOTSIZE | CODESIZE | BOOT領域     | APPCODE領域        | APPDATA領域        |
|----------|----------|------------|------------------|------------------|
| 0        | 0        | 0~FLASHEND | _                | _                |
| >0       | 0        | 0~BOOTEND  | BOOTEND~FLASHEND | _                |
| >0       | ≦BOOTEND | 0~BOOTEND  | _                | BOOTEND~FLASHEND |
| >0       | >BOOTEND | 0~BOOTEND  | BOOTEND~CODEEND  | CODEEND~FLASHEND |

ブートローダ、ソフトウェアがない場合、応用コート、用にBOOT領域を使うことが推奨されます。

- 注: 1. リセット後、既定ヘ<sup>\*</sup>クタ表位置はAPPCODE領域の始めです。BOOT領域の始めに割り込みヘ<sup>\*</sup>クタ表を再配置することによってBO OT領域で走っているコートで周辺機能割り込みを使うことができます。それは制御A(CPUINT.CTRLA)レジ<sup>\*</sup>スタの割り込みヘ<sup>\*</sup>クタ 選択(IVSEL)ヒ<sup>\*</sup>ットを設定(1)することによって行われます。詳細については「CPUINT」章を参照してください。
  - 2. BOOTSIZE/CODESIZEのヒュース 設定によって決定されるBOOTEND/CODEENDがデバイスのFLASHENDを超える場合、対応 するヒュース 設定は無視され、既定値が使われます。既定値については「メモリ」章の「FUSE」項を参照してください。

#### 例11-1. フラッシュ メモリ領域の大きさの例

FUSE.BOOTSIZEが**\$0**4を書かれ、FUSE.CODESIZEが**\$0**8を書かれた場合、最初の4×256パイトがBOOTで、次の4×256パイトがAPPCODE、そして残りのフラッシュメモリがAPPDATAです。

## 11.3.1.1.3. フラッシュ メモリ アクセス保護

## 交差書き込み保護

安全性のため、コートが現在実行しているフラッシュ メモリの領域へ書くことは不可能です。APPCODE領域へ書くコートはBOOT領域から 実行されなければならず、APPDATAに書くコートはBOOT領域またはAPPDATA領域のどちらかから実行されなければなりません。

| 衣II-3. 日C/197529に対9る書ざ込み休護(/□27522/円) |      |         |         |        |         |  |  |  |  |
|---------------------------------------|------|---------|---------|--------|---------|--|--|--|--|
| <u>処</u> 理されつつある<br>プログラム実行領域         | воот | APPCODE | APPDATA | EEPROM | USERROW |  |  |  |  |
| BOOT                                  | ×    | 0       | 0       | 0      | 0       |  |  |  |  |
| APPCODE                               | ×    | ×       | 0       | 0      | 0       |  |  |  |  |
| APPDATA                               | X    | ×       | ×       | ×      | ×       |  |  |  |  |

表11-3. 自己プログラミングに対する書き込み保護(プログラミング可)

## フラッシュ メモリ保護

交差書き込み保護に加えて、NVMCTRLはフラッシュメモリ領域への望まれないアクセスを避けるための安全機構を提供します。例えCPU が決してBOOT領域に書くことできないにしても、制御B(NVMCTRL.CTRLB)レジスタのブート領域読み込み保護(BOOTRP)ビットはBOO T領域からのコートの読み込みと実行の防止を提供します。このビットはBOOT領域で実行されるコートからだけ設定(1)することができ、 BOOT領域を去る時にだけ有効になります。

制御B(NVMCTRL.CTRLB)レジスタの3つの書き込み保護ビット(EEPROM書き込み保護(EEWP)、応用データ領域書き込み保護 (APPDATAWP)と応用コート<sup>\*</sup>領域書き込み保護(APPCODEWP))は各々、EEPROM、APPDATA、APPCODEの領域に対して書き込み 保護を設定することができます。

## 11.3.1.2. EEPROM

EEPROMは1ページが多数のベイトからなるページの組に分けられる512ベイトの不揮発性メモリ領域です。EEPROMは消去/書き込みで ベイトの粒度を持ちます。各書き込み/消去はページ内で1つ以上のベイトを含むことができます。ページ緩衝部へのデータ書き込み時、 そのデータに対するアドレスが次の消去/書き込み実行時に更新されるように記されます。ページの残りのベイトは消去/書き込みされませ ん。1操作で1ベイトの消去と書き込みを実行することもできます。

## 11.3.1.3. 使用者列

使用者列は書き込み中読み込み可(RWW)フラッシュ メモリの64バイトです。校正/構成設定のデータや通番のような様々なデータを格納するのにこの領域を使ってください。この領域はチップ消去によって消去されません。

使用者列領域はCPUから読み書きすることができます。使用者列消去時、列全体が同時に消去されます。

この領域は解錠されたデバイスでUPDIを通して書くことができます。

## 11.3.1.4. ヒュース゛

ヒューズはデバイス構成設定値を含み、始動手順最後でそれらの目的対象レジスタに複写されます。

ヒューズはCPUまたはUPDIによって読むことができますが、UPDIによってだけ、書くまたは解除することができます。

## 11.3.1.5. 識票列

識票列は各マイクロコントローラテバイス型式と製造された各デバイスに対する通番を識別するデバイスIDを含みます。通番は製造ロット番号、ウェハ番号、デバイスのウェハ座標から成ります。 識票列はCPUまたはUPDIインターフェースによって読むことができますが、書き込みや消去ができません。

## 11.3.2. メモリ アクセス

フラッシュメモリは読み/書き操作に対してコート、空間またはCPUデータ空間のどちらかでアクセスすることができます。コート、空間使用時、フラッシュメモリはLPMとSPM系命令を通してアクセス可能です。

加えて、フラッシュ メモリはCPUデータ空間を通してバイト アクセス可能で、SRAM、EEPROM、I/Oレジスタと同じアドレス空間と命令を共用するこ とを意味し、アセンブリ言語でLD/ST系命令を使ってアクセス可能です。

## コート 空間でのフラッシュ メモリ アト・レス指定

コート、空間でのフラッシュメモリへの読み書きアクセスには、LPM/SPMアクセス用のZポインタを使ってください。



フラッシュメモリがページで構成され、語(ワード)でアクセスされるため、上図で示されるように、アドレスポインタは2つの領域を持つように扱うことができます。ページ内の語アドレス(FWORD)はアドレスポインタの下位側ビット(LSb)によって保持され、同時にアドレスポインタの上位側ビット(MSb)がフラッシュ ページ アドレス(FPAGE)を保持します。FPAGEとFWORDはフラッシュ メモリ内の語への絶対アドレスを保持します。 フラッシュ メモリ読み込み操作については1度に1パイトが読まれます。このため、語アドレス内の上位パイトと下位パイトを選ぶのにアドレスポインタの最下位ビット(ビット0)を使ってください。このビットが、0'ならば下位パイトが読まれ、このビットが、1'ならば上位パイトが読まれます。

一旦プログラミング操作を始めると、アドレスはラッチされ、アドレスポインタは更新して他の作業に使うことができます。

## CPUデータ空間でのフラッシュ メモリ アドレス指定

データ空間でのフラッシュメモリ領域は32Kバイトだけを持ちます。32Kバイトよりも大きなフラッシュメモリ量を持つデバイスについては、フラッシュメ モリが32Kバイトの塊に分割されます。これらの塊は制御B(NVMCTRL.CTRLB)レジスタのデータ空間に割り当てられるフラッシュメモリ領域 (FLMAP)ビット領域を使ってデータ空間に割り当てられます。

CPUデータ空間でのフラッシュメモリへの読み書きアクセスに対しては、1度に1バイトをアクセスするのにLD/ST系命令を使ってください。

## 11.3.2.1. 読み込み

フラッシュメモリ読み込みはメモリ割り当てに従ったアトレスを持つプログラムメモリ取得(LPM)系命令または取得型(LD\*)系命令を用いて行われます。EEPROMと識票列の読み込みはLD\*系命令を用いて行われます。書き込みまたは消去が進行中の間の読み込み操作実行は進行中の操作が完了するまで保留にされます。

## 11.3.2.2. ページ緩衝部設定

ページ緩衝部はメモリ割り当てで定義されるように直接メモリに書くことによって設定されます。EEPROMが独立したページ緩衝部を持つ 一方でフラッシュ メモリと使用者列は同じページ緩衝部を共用し、故に同時に1つの領域だけをプログラミングすることができます。ページ緩 衝部にデータを書く場所を選ぶのにアドレスの下位側ビットを使ってください。結果のデータはページ緩衝部の以前の内容と新規値間の2 進AND操作になります。ページ緩衝部は以下の後で自動的に消去(全ビット設定(1)に)されます。

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

注: ページ緩衝部でのどの操作も直前のNVMCTRL操作(指令)が完了されるまでCPUを停止します。

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

ページプログラミングについてはページ緩衝部を満たすのと、ページ緩衝部をフラッシュ メモリ、使用者列、EEPROMに書く、2つに分かれた 操作です。

へージ緩衝部内のデータでフラッシュメモリのヘージをプログラミングする前に、フラッシュメモリヘージの内容は消去(\$FF読み戻し)されなければなりません。未消去フラッシュメモリヘージのプログラミングはその内容を不正にします。

フラッシュ メモリのページ内容が正しくプログラミングされるのを確実にのに以下の2つの任意選択が利用可能です。

任意選択1: フラッシュ メモリは消去と書き込みの両方を処理する1つの指令を使ってプログラジングされます。

- 1. 状態(NVMCTRL.STATUS)レジスタのフラッシュメモリ多忙(FLBUSY)フラグを読むことによってフラッシュメモリの準備が整っているのを確実 にしてください。
- 2. ページ緩衝部を満たしてください。

3. フラッシュ メモリ ヘージ 消去/ヘージ 書き込み(FLPERW)指令でヘージ 緩衝部をフラッシュ メモリに書き込んでください。

任意選択2: フラッシュ メモリはページ消去とページ書き込み用の独立した指令を使ってプログラミングされます。

- 1. 状態(NVMCTRL.STATUS)レジスタのフラッシュ メモリ多忙(FLBUSY)フラグを読むことによってフラッシュ メモリの準備が整っているのを確実 にしてください。
- 2. アドレスを設定するためにページ上の位置に書いてください。
- 3. フラッシュ メモリ ページ消去(FLPER)指令を実行してください。
- 4. ページ緩衝部を満たしてください。
- 5. フラッシュ メモリ ページ 書き込み(FLPW)指令を実行してください。

NVM指令一式はフラッシュメモリとEEPROMの両方に対して単一の消去/書き込み (FLPERW/EEPERW)操作と分離したページ消去(FLPER/EEPER)指令とページ書 き込み(FLPW/EEPW)指令の両方を支援します。これらの分離した指令は書く 指令に対してより短いプログラミング時間を許し、消去操作は時間が重要でないプ ログラミング実行の間に行うことができます。

EEPROMプログラミングはフラッシュ メモリ プログラミングと似ていますが、ページ緩衝部で 更新されたバイトだけがEEPROMで書かれるか、または消去されます。

| 主11 | _1  | רח°⊓ | ブラミン  | ん * 业士 | 曲 |
|-----|-----|------|-------|--------|---|
| 衣口  | -4. | ノログ  | / フミノ | ソ私     | 凒 |

| <b>秋日</b> → → → → → → → → → → → → → → → → → → → |                  |                                    |  |  |  |  |  |  |  |
|-------------------------------------------------|------------------|------------------------------------|--|--|--|--|--|--|--|
| メモリ領域                                           | 消去粒度             | 書き込み粒度                             |  |  |  |  |  |  |  |
| フラッシュ メモリ配ろ                                     | 可へ。ージ            | ページ                                |  |  |  |  |  |  |  |
| EEPROM配列                                        | バイト              | パイト                                |  |  |  |  |  |  |  |
| 使用者列                                            | ページ ( <u>注</u> ) | ヘ <sup>°</sup> ージ <sup>*</sup> (注) |  |  |  |  |  |  |  |
|                                                 |                  |                                    |  |  |  |  |  |  |  |

<u>注</u>:使用者列ページは64バイトです。

### 11.3.2.4. 指令動作

メモリ配列の読み込みはLD/LPM系命令(注)を用いて処理されます。

EEPROM消去(EECHER)指令は制御A(NVMCTRL.CTRLA)レジスタに指令を書くことによって開始されます。他の書き込み/消去操作 は単にNVMCTRL.CTRLAレジスタに指令を書くことによって許可され、ST/SPM系命令(注)を用いてメモリ配列に書くことが後続されな ければなりません。

注: LPM/SPM系命令はEEPROMに使えません。

NVMCTRL.CTRLAレジスタに指令を書くには以下の手順の実行が必要です。

- 1. 状態(NVMCTRL.STATUS)レジスタの多忙(EEBUSYとFLBUSY)フラグを読むことによって直前のどの操作も完了されていることを確認してください。
- 2. NVM制御A(NVMCTRL.CTRLA)レジスタを解錠するために構成設定変更保護(CPU.CCP)レジスタに適切な鍵を書いてください。

3. 後続する4命令内で制御A(NVMCTRL.CTRLA)レジスタの指令(CMD)ビット領域に望む指令値を書いてください。

## 11.3.2.4.1. ページ書き込み指令

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

書き込みがフラッシ メモリへの場合、CPUは「11.3.1.1.1.物理的な領域」で説明されたようにコードを実行します。

書き込みがEEPROMへの場合、CPUはその操作が進行中の間にコートを実行します。書き込みを実行する前にページ/バイトを消去してください。

使ったページ緩衝部はその操作の終了後、自動的に消去されます。

## 11.3.2.4.2. ページ消去指令

ページ消去(FLPER/EEPER)指令は現在のページを消去します。ページ消去指令を実施するにはページ緩衝部に1バイトを書いてください。

フラッシュ メモリ消去については、初めに望むページ内の1つのアドレスへの偽装書き込みが必要とされ、その後に指令実行が続きます。そ してフラッシュ メモリのページ全体が消去されます。CPUはページ書き込み指令と同じ条件に基づいて停止または継続します。

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

使ったページ緩衝部はその操作の終了後、自動的に消去されます。

#### 11.3.2.4.3. フラッシュ複数ヘージ 消去動作

フラッシュ複数ヘージ消去(FLMPERn)動作は複数ヘージを消去するためのメモリ配列への各書き込みを許します。FLMPERn使用時、2、 4、8、16、32ヘージの消去から選ぶことが可能です。

どの複数フラッシュ ヘージが消去されるかを定義している時に、ヘージ アドレスの下位ビットが無視されます。例としてFLMPER4を使うと、 \$08~\$0B範囲内のどのヘージの消去も、範囲内の全てのヘージの消去を引き起こします。

| 表11-5. フラッシュ複 | 数ヘ ーシ 消去 |                                            |
|---------------|----------|--------------------------------------------|
| CMD           | 消去ページ数   | 説明                                         |
| FLMPER2       | 2        | FPAGEn~1に合致するページが消去されます。FPAGE0の値は無視されます。   |
| FLMPER4       | 4        | FPAGEn~2に合致するページが消去されます。FPAGE1~0の値は無視されます。 |
| FLMPER8       | 8        | FPAGEn~3に合致するページが消去されます。FPAGE2~0の値は無視されます。 |
| FLMPER16      | 16       | FPAGEn~4に合致するページが消去されます。FPAGE3~0の値は無視されます。 |
| FLMPER32      | 32       | FPAGEn~5に合致するページが消去されます。FPAGE4~0の値は無視されます。 |

**注**: FPAGEはフラッシュ メモリ消去を行う時のページ番号です。詳細については「11.3.2. メモリ アクセス」を参照してください。

#### 11.3.2.4.4. ページ 消去/書き込み操作

ページ消去/書き込み(FLPERW/EEPERW)指令はページ消去とページ書き込みの指令を組み合わせますが、ページ消去指令後のペー ジ緩衝部解除なしです。消去/書き込み操作は初めに選んだページを消去し、その後に同じページにページ緩衝部の内容を書きま す。

フラッシュ メモリで実行されると、CPUはページ書き込み指令と同じ条件に基づいて停止または継続します。EEPROMで行われると、CPU はコードの実行を続けます。

使ったページ緩衝部はその操作の終了後、自動的に消去されます。

### 11.3.2.4.5. ページ緩衝部消去指令

ヘージ緩衝部解消(FLBCLR/EEBCLR)指令は対応するヘージ緩衝部を消去します。ヘージ緩衝部の内容はこの操作後に全て'1'です。CPUはこの操作実行間、(7 CPU周期)停止されます。

#### 11.3.2.4.6. EEPROM消去指令

EEPROM消去(EECHER)指令はEEPROMを消去します。全てのEEPROMは操作後に\$FFを読み戻します。CPUはEEPROM消去の間、停止されます。

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

CPUとフラッシュメモリ/EEPROMの正しい動作に対して供給電圧が低すぎる場合、フラッシュメモリとEEPROMの書き込みや消去はメモリ化け を起こし得ます。これらの問題はフラッシュメモリ/EEPROMを使う基板上程の系と同じです。動作電圧が充分高いことを保証するために 内部または外部の低電圧検出器(BOD:Brown-Out Detector)が推奨されます。

電圧が低すぎると、次のような2つの状況がフラッシュ メモリ/EEPROM化けを引き起こすかもしれません。

1. フラッシュ メモリへの通常の書き込み手順は正しく動くための最低電圧を必要とします。

2. 供給電圧が低すぎると、CPU自身が命令を間違って実行し得ます。

チップ消去はヒューズを消しません。チップ消去指令を開始する前にBODがヒューズによって許可されている場合、チップ消去中、自動的に それが以前に構成設定されていた基準で許可されます。

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

注意:以下の対策を取ると、フラッシュ メモリ/EEPROM化けを避けるかもしれません。

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

## 11.3.4. 割り込み

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

| 名称      | ベクタ説明 | 条件                             |
|---------|-------|--------------------------------|
| EEREADY |       | 新規の書き込み/消去の操作に対してEEPROMが準備可    |
| FLREADY | NVM   | 新規の書き込み/消去の操作に対してフラッシュ メモリが準備可 |

割り込み条件が起こると、割り込み要求フラク(NVMCTRL.INTFLAGS)レジスタでフラッシュメモリ準備可(FLREADY)またはEEPROM準備可(EEREADY)の割り込み要求フラグが設定(1)されます。

割り込み元は割り込み許可(NVMCTRL.INTCTRL)レジスタでフラッシュメモリ準備可割り込み許可(FLREADY)またはEEPROM準備可割り 込み許可(EEREADY)のビットに書くことによって許可または禁止にされます。

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

## 11.3.5. 休止形態動作

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

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

EEPROM準備可とフラッシュメモリ準備可の割り込みはアイドル休止動作からだけデバイスを起き上がらせます。

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

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

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

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

表11-7. NVMCTRL - 構成設定変更保護下のレジスタ

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

# 11.4. レジスタ要約

| 変位          | 略称          | ビット位置       | ビット7      | ヒット6 | ビット5     | ビット4  | ビット3   | ビット2      | ビット1    | ビットロ      |
|-------------|-------------|-------------|-----------|------|----------|-------|--------|-----------|---------|-----------|
| +\$00       | CTRLA       | 7~0         |           |      |          |       | CMD6~0 | 1         |         |           |
| +\$01       | CTRLB       | 7~0         | FLMAPLOCK |      | FLM      | AP1,0 | EEWP   | APPDATAWP | BOOTRP  | APPCODEWP |
| +\$02       | <b>→</b> 44 |             |           |      |          |       |        |           |         |           |
| -~<br>+\$03 | 予約          |             |           |      |          |       |        |           |         |           |
| +\$04       | INTCTRL     | 7~0         |           |      |          |       |        |           | FLREADY | EEREADY   |
| +\$05       | INTFLAGS    | 7~0         |           |      |          |       |        |           | FLREADY | EEREADY   |
| +\$06       | STATUS      | 7~0         |           |      | ERROR2~0 |       |        |           | FLBUSY  | EEBUSY    |
| +\$07       | 予約          |             |           |      |          |       |        |           |         |           |
| +\$08       |             | 7~0         |           |      |          | DAT   | A7~0   | 1         | 1       |           |
| +\$09       | DATA        | $15 \sim 8$ | -         |      |          | DATA  | A15~8  | 1         | 1       |           |
| +\$0A       | 又约          |             |           |      |          |       |        |           |         |           |
| -~<br>+\$0₿ | 予約          |             |           |      |          |       |        |           |         |           |
| +\$0C       |             | 7~0         |           |      |          | ADD   | R7~0   | 1         |         |           |
| +\$0D       |             | 15~8        |           |      |          | ADDI  | R15~8  | 1         | 1       |           |
| +\$0E       | ADDR        | 23~16       |           |      |          | ADDR  | 23~16  | 1         |         |           |
| +\$0F       |             | 31~24       |           |      |          |       |        |           |         |           |

# 11.5. レジスタ説明

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

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

**特質**:構成設定変更保護

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

#### ビット6~0 - CMD6~0:指令 (Command)

指令を許可または発行するにはこのビット領域に書いてください。チップ消去とEEPROM消去の指令はこのビット領域にどちらかの指令 を書く時に開始します。他の指令は消去または書き込みの操作を許可します。これらの操作は消去または書き込みをされているフラッ シュ メモリのアドレスに格納を行う時に開始します。

(状態(NVMCTRL.STATUS)レジネタの異常符号(ERROR)ビット領域での)指令衝突異常を防ぐため、1つの指令から次へ行く時に無指令(NOCMD)または無操作(NOOP)の指令を含むことが推奨されます。

自己プログラミング(SPM)用の構成設定変更保護鍵がこれらのビットを保護します。

| 值               | 名称       | 説明                                             |
|-----------------|----------|------------------------------------------------|
| 000 0000 (\$00) | NOCMD    | 無指令                                            |
| 000 0001 (\$01) | NOOP     | 無操作                                            |
| 000 0100 (\$04) | FLPW     | フラッシュ メモリ ヘージ 書き込み許可                           |
| 000 0101 (\$05) | FLPERW   | フラッシュ メモリ ヘージ消去/ヘージ書き込み許可                      |
| 000 1000 (\$08) | FLPER    | フラッシュ メモリ ヘージ 消去許可                             |
| 000 1001 (\$09) | FLMPER2  | フラッシュ メモリ 2ページ消去許可                             |
| 000 1010 (\$0A) | FLMPER4  | フラッシュ メモリ 4ページ消去許可                             |
| 000 1011 (\$0B) | FLMPER8  | フラッシュ メモリ 8ヘ゜ージ消去許可                            |
| 000 1100 (\$0C) | FLMPER16 | フラッシュ メモリ 16ページ消去許可                            |
| 000 1101 (\$0D) | FLMPER32 | フラッシュ メモリ 32ページ消去許可                            |
| 000 1111 (\$0F) | FLPBCLR  | フラッシュ メモリ ヘ゜ージ緩衝部解消許可                          |
| 001 0100 (\$14) | EEPW     | EEPROMページ書き込み許可                                |
| 001 0101 (\$15) | EEPERW   | EEPROMページ消去/ページ書き込み許可                          |
| 001 0111 (\$17) | EEPER    | EEPROMページ消去許可                                  |
| 001 1111 (\$1F) | EEPBCLR  | EEPROMページ緩衝部解消許可                               |
| 010 0000 (\$20) | CHER     | フラッシュメモリとEEPROMを消去。                            |
|                 | UTEN     | EEPROMはEESAVEヒュースが設定(1)の場合に飛ばされます(UPDIアクセスのみ)。 |
| 011 0000 (\$30) | EECHER   | EEPROM消去                                       |
| その他             | -        | (予約)                                           |

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

- 名称 : CTRLB
- **変位** : +\$01
- **リセット** : \$30
- 特質:構成設定変更保護

| ビット    | 7         | 6 | 5        | 4   | 3    | 2         | 1      | 0         |
|--------|-----------|---|----------|-----|------|-----------|--------|-----------|
|        | FLMAPLOCK |   | FLMAP1,0 |     | EEWP | APPDATAWP | BOOTRP | APPCODEWP |
| アクセス種別 | R/W       | R | R/W      | R/W | R/W  | R/W       | R/W    | R/W       |
| リセット値  | 0         | 0 | 1        | 1   | 0    | 0         | 0      | 0         |

## • ビット7 - FLMAPLOCK : フラッシュ メモり割り当て施錠 (Flash Mapping Lock)

このビットへの'1'設定はデータ空間に割り当てるフラッシュメモリ領域(FLMAP1,0)の更なる更新を防ぎます。リセットだけがこのビットを解除(0) できます。

• ビット5,4 - FLMAP1,0 : データ空間に割り当てるフラッシュ メモリ領域 (Flash Section Mapped into Data Space)

フラッシュメモリの(32Kハイトの塊で)どの部分がCPUデータ空間の一部として割り当てられてLD/ST系命令を通してアクセス可能かを選びます。

| 值                         | 0 0      | 01           | 10         | 11       |
|---------------------------|----------|--------------|------------|----------|
| 名称                        | SECTION0 | SECTION1     | SECTION2   | SECTION3 |
| 割り当てられるフラッシュ メモリ部分 (64KB) | 0~32     | $32 \sim 64$ | $0\sim 32$ | 32~64    |

## • ビット3 - EEWP : EEPROM書き込み保護 (EEPROM Write Protection)

このビットへの'1'書き込みは更なる書き込みからEEPROMを守ります。このビットは'1'に書くことだけができます。リセットだけがこれを解除(0)します。

● ビット2 - APPDATAWP : 応用データ領域書き込み保護 (Application Data Section Write Protection)

このビットへの'1'書き込みは更なる書き込みから応用データ領域を守ります。このビットは'1'に書くことだけができます。リセットだけがこれを解除(0)します。

## ● ビット1 - BOOTRP : ブート領域読み込み保護 (Boot Section Read Protection)

このビットへの'1'書き込みは読み込みと命令取得からブート領域を守ります。応用領域から読み込みが発行された場合、'0'を返します。BOOT領域からの命令取得はNOP命令を返します。このビットはBOOT領域からだけ書くことができ、リセットだけがこれを解除(0)します。このビットはこのビットが(1を)書かれた後初めてBOOT領域を去る時にだけ有効です。

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

このビットへの'1'書き込みは更なる書き込みから応用コート'領域を守ります。このビットは'1'に書くことだけができます。リセットだけがこれを解除(0)します。

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

| 名称 : INTCTRL<br>変位 : +\$04<br>リセット : \$00<br>特質 : - |   |   |   |   |   |   |         |         |
|-----------------------------------------------------|---|---|---|---|---|---|---------|---------|
| ビット                                                 | 7 | 6 | 5 | 4 | 3 | 2 | 1       | 0       |
|                                                     |   |   |   |   |   |   | FLREADY | EEREADY |
| アクセス種別                                              | R | R | R | R | R | R | R/W     | R/W     |
| リセット値                                               | 0 | 0 | 0 | 0 | 0 | 0 | 0       | 0       |

## • ビット1 - FLREADY : フラッシュ メモリ準備可割り込み許可 (Flash Ready Interrupt Enable)

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

これは割り込み要求フラグ(INTFLAGS)レジスタのフラッシュメモリ準備可割り込み要求(FLREADY)フラグが'1'に設定されている時にだけ起動されるレベル割り込みです。従って、NVM指令が発行される前にFLREADYフラグが解除(0)されないため、この割り込みはNVM指令を起動する前に許可されてはなりません。この割り込みは割り込み処理部で禁止されなければなりません。

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

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

これは割り込み要求フラグ(INTFLAGS)レジスタのEEPROM準備可割り込み要求(EEREADY)フラグが、1、に設定されている時にだけ起動 されるレベル割り込みです。従って、NVM指令が発行される前にEEREADYフラグが解除(0)されないため、この割り込みはNVM指令を 起動する前に許可されてはなりません。この割り込みは割り込み処理部で禁止されなければなりません。

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

| 変(<br>リセ) | 称 : INTFLA<br>立 : +\$05<br>小 : \$00<br>質 : - | AGS |   |   |   |   |   |         |         |
|-----------|----------------------------------------------|-----|---|---|---|---|---|---------|---------|
|           | ビット                                          | 7   | 6 | 5 | 4 | 3 | 2 | 1       | 0       |
|           |                                              |     |   |   |   |   |   | FLREADY | EEREADY |
|           | アクセス種別                                       | R   | R | R | R | R | R | R/W     | R/W     |
|           | リセット値                                        | 0   | 0 | 0 | 0 | 0 | 0 | 0       | 0       |

• ビット1 - FLREADY : フラッシュ メモリ準備可割り込み要求フラク (Flash Ready Interrupt Flag)

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

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

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

# 11.5.5. STATUS - 状態 (Status)

- 名称 : STATUS 変位 : +\$06
- 夏世:1000 リセット:\$00

## 特質 :-

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

# ● ビット6~4 - ERROR2~0 : 異常符号 (Error Code)

このビット領域は最後に発生した異常を示します。この異常符号はこのビット領域に'0'を書くことによって解除することができます。

| 値  | 000  | 010                  | 0 1 1                             | 100                      | その他  |
|----|------|----------------------|-----------------------------------|--------------------------|------|
| 名称 | NONE | WRITEPROTECT         | CMDCOLLISION                      | WRONGSECTION             | -    |
| 説明 | 異常なし | 書き込み保護された<br>領域を書く試み | 既に書き込み指令が選ばれている<br>間に新しい書き込み指令を選択 | 使ったアドレスに対する<br>書き込み指令が不正 | (予約) |

# • ビット1 - FLBUSY : フラッシュ メモリ多忙 (Flash Busy)

このビットはフラッシュメモリプログラミング操作が進行中の時に'1'を読みます。

## • ビット0 - EEBUSY : EEPROM多忙 (EEPROM Busy)

このビットはEEPROMプログラミング操作が進行中の時に'1'を読みます。

# 11.5.6. DATA - データ (Data)

名称:DATA (DATAH, DATAL)

**変位** : +\$08

# リセット : \$0000

特質 :-

NVNCTRL.DATAHとNVMCTRL.DATALのレジスタ対は16ビット値のNVMCTRL.DATAを表します。

下位バイト[7~0](接尾辞L)は変位原点でアクセス可能です。

上位バイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

| ビット    | 15      | 14       | 13  | 12  | 11  | 10  | 9   | 8   |  |  |  |  |  |
|--------|---------|----------|-----|-----|-----|-----|-----|-----|--|--|--|--|--|
|        |         | DATA15~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   |  |  |  |  |  |
|        | 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   |  |  |  |  |  |

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

データレジスタはフラッシュメモリ、EEPROM、またはNVMCTRLからの最後の読み込み値を含みます。EEPROMアクセスにはDATA7~0だけが使われます。

# 11.5.7. ADDR - アドレス (Address)

名称: ADDR (ADDR2, ADDR1, ADDR0)

**変位**:+\$0C

**リセット** : \$000000

特質 :-

NVNCTRL.ADDR0、NVMCTRL.ADDR1、NVMCTRL.ADDR2、NVMCTRL.ADDR3は32ビット値のNVMCTRL.ADDRを表します。 下位ハイト[7~0](接尾辞0)は変位原点でアクセス可能です。

上位バイト[15~8](接尾辞1)は変位+1でアクセスすることができます。

拡張バイト[23~16](接尾辞2)は変位+2でアクセスすることができます。

バイト[31~24](接尾辞3)は変位+3でアクセスすることができますが、どんな値も決して含みません。

| ۲<br>۲ ۲     | 31  | 30        | 29  | 28   | 27    | 26  | 25  | 24  |  |  |  |  |  |
|--------------|-----|-----------|-----|------|-------|-----|-----|-----|--|--|--|--|--|
|              |     |           |     |      |       |     |     |     |  |  |  |  |  |
| アクセス種別       | -   | -         | -   | -    | -     | -   | -   | -   |  |  |  |  |  |
| リセット値        | -   | -         | -   | -    | -     | -   | -   | -   |  |  |  |  |  |
| <u>ل</u> ، ب | 23  | 22        | 21  | 20   | 19    | 18  | 17  | 16  |  |  |  |  |  |
|              |     | ADDR23~16 |     |      |       |     |     |     |  |  |  |  |  |
| アクセス種別       | 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>   | 15  | 14        | 13  | 12   | 11    | 10  | 9   | 8   |  |  |  |  |  |
|              |     |           |     | ADDI | ₹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   |  |  |  |  |  |
| <b>ビット</b>   | 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   |  |  |  |  |  |

ビット23~0 - ADDR23~0:アドレス値 (Address)

アドレス レジスタは最後にアクセスされたメモリ位置のアドレスを含みます。メモリをアクセスするのに必要とされるビット数だけが使われます。

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

# 12.1. 特徴

- ・周辺機能によって要求される時に自動的に許可される全てのクロックとクロック元
- 内部発振器
  - 20MHzまでの内部高周波数発振器(OSCHF)
- 32.768kHz超低電力発振器(OSC32K)
- ・内部発振器精度を改善するための自動調整
- ・外部クロック任意選択
  - 32.768kHzクリスタル用発振器(XOSC32K)
  - 高周波数クリスタル用発振器(XOSCHF)
  - 外部クロック
- ・主なクロック機能
  - 安全な走行時切り替え
  - -1~64の範囲の分周係数を持つ前置分周器
  - 内部供給元への自動クロック切り替えを持つクロック障害検出(CFD)

# 12.2. 概要

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

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

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

# 12.2.1. 構成図



クロック システムは主クロックと主クロックから派生したクロック、更にいくつかの非同期クロックから成ります。

- ・主クロック(CLK\_MAIN)は常に活動動作とアイドル休止動作で動きます。必要とされる場合はスタンバイ休止動作でも動きます。
- ・CLK\_MAINはクロック制御器によって前置分周されて分配されます。
  - CLK\_CPUはCPU、SRAM、不揮発性メモリ制御器(NVMCTRL)によって使われます。
  - CLK\_PERは非同期クロック下で一覧にされない全ての周辺機能によって使われ、CLKOUTピンに配線することもできます。
  - 全てのクロック元を主クロックとして使うことができます。

・主クロック領域に対して非同期に動くクロック

- CLK\_RTCは実時間計数器(RTC)と周期的割り込み計時器(PIT)に使われ、RTC/PITが許可される時に要求されます。 CLK\_RTC用のクロック元はこの周辺機能が禁止されている場合にだけ変更することができます。
- CLK\_WDTはウォッチドック゛タイマ(WDT)によって使われます。WDTが許可される時に要求されます。
- CLK\_BODは低電圧検出器(BOD)によって使われます。BODが採取動作で許可される時に要求されます。代替クロック元はヒューズによって制御されます。
- クロック障害検出器(CFD:Clock Failure Detector)は外部のクリスタルまたはクロック元での障害を検出する非同期機構です。

主クロック領域用のクロック元は主クロック制御A(CLKCTRL.MCLKCTRLA)レジスタのクロック選択(CLKSEL)ビット領域に書くことによって構成 設定されます。このレジスタは構成設定変更保護(CCP)を持ちます。CLKSELビット領域に書くのに先立って構成設定変更保護(CCP)レジスタに適切な鍵を書いてください。非同期クロック元は各々の周辺機能内のレジスタによって構成設定されます。

## 12.2.2. 信号説明

| 信号       | 形式     | 説明                                         |
|----------|--------|--------------------------------------------|
| CLKOUT   | デジタル出力 | CLK_PER出力                                  |
| XTALHF1  | アナログ入力 | 外部クロック元(EXTCLK)または高周波数クリスタルの1つのピン用の入力      |
| XTALHF2  | アナログ出力 | 高周波数クリスタルの1つのピン用の出力                        |
| XTAL32K1 | アナログ入力 | 外部クロック元(EXTCLK)または32.768kHzクリスタルの1つのピン用の入力 |
| XTAL32K2 | アナログ出力 | 32.768kHzクリスタルの1つのピン用の出力                   |

より多くの詳細については「入出力多重化」項を参照してください。

# 12.3. 機能的な説明

## 12.3.1. 初期化

クロック元を主クロックとして初期化するには以下のこれらの手順に従ってください。

- 1. 任意選択: 各々のクロック元のCTRLAレジスタのスタンハイ時走行(RUNSTDBY)ビットに'1'を書くことによって常に動くことをクロックに強制してください。
- 2. 対応するクロック元のCTRLAレジスタで必要とされるようにクロック元を構成設定し、当て嵌まるなら、許可ビットに'1'を書くことによってク ロック元を許可してください。
- 3. 任意選択: RUNSTDBYビットが'1'の場合、CLKCTRL.MCLKSTATUSで当該状態ビットをポーリングすることによってクロック元が安定 するのを待ってください。
- 4. 以下の補助手順は主クロック周波数が許された最大クロック周波数を決して超えないような順番で実行されることが必要です。
  - a. 必要とされるなら、主クロック制御B(CLKCTRL.MCLKCTRLB)レシ<sup>、</sup>スタで前置分周器分周値(PDIV)ビット領域に書いて前置分周 器許可(PEN)ビットに'1'を書くことによってクロック元周波数を構成設定してください。
  - b. 主クロック制御A(CLKCTRL.MCLKCTRLA)レジスタのクロック選択(CLKSEL)ビット領域で主クロックとして構成設定したクロック元を選ん でください。
- 5. 主クロック状態(CLKCTRL.MCLKSTATUS)レジスタの主クロック発振器変更(SOSC)ビットをホーリングすることによって主クロック変更を待ってください。
- 6. 任意選択: クロック元のCTRLAレジスタのRUNSTDBYビットを解除(0)してください。

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

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

構成設定変更保護機構は安全でないクロック切り替えを防ぎます。より多くの詳細については「構成設定変更保護」項を参照してください。

許可されると、クロック障害検出機構はクロック障害で内部クロック元へ安全に切り替えることを保証します。

外部クロック元選択時、選んだクロック元への切り替えはその外部クロックで充分な数の端(エッジ)が検出される場合だけに起こります。充分なクロック端数が検出されない場合、クロック元は無変化に留まり、リセットを実行することなく別のクロック元へ変更することは不可能です。

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

△注意

・ 外部クロック元がCLK\_MAIN供給元として使われている間に機能しなくなった場合、ウォッチドック゛タイマ(WDT)だけがシステム リセットを提供することができます。 CLK\_MAINはデバイスの周辺機能(CLK\_PER)に よって使われるのに先立って前置分周器へ供 給されます。前置分周器は1段だけを持ち、1~ 64の係数でCLK\_MAINを分周します。

#### 図12-2. 主クロックと前置分周器

OSCHF → OSC32K (32.768kHz) → XOSC32K (32.768kHz) → XOSCHF/外部クロック →



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

どのリセット後も、主クロック(CLK\_MAIN)は分周係数6の前置分周器での20MHz発振器(OSCHF)によって提供されます。

実際のOSCNF周波数は発振器構成設定(FUSE.OSCCFG)ヒュースの内部高周波数発振器周波数(OSCHFFRQ)選択ビットによって決められます。リセット後に可能な周波数の詳細についてはFUSE.OSCCFGヒューズの記述を参照してください。

## 12.3.4. クロック元

全ての内部クロック元はそれらが周辺機能によって要求される時に自動的に許可されます。外部クリスタルに基づくクルスタル用発振器はこれらがクロック元として扱うことができるのに先立って許可されなければなりません。

- ・XOSC32K発振器は32.768kHzクリスタル用発振器制御A(CLKCTRL.XOSC32KCTRLA)レシ<sup>\*</sup>スタの許可(ENABLE)ヒ<sup>\*</sup>ットに'1'を書くことによって許可されます。
- ・XOSCHF発振器は高周波数クリスタル用発振器制御A(CLKCTRL.XOSCHFCTRLA)レジ゙スタの許可(ENABLE)ビットに'1'を書くことに よって許可されます。

リセット後、デバイスは内部の高周波数発振器または32.768kHz発振器から走行を始めます。

主クロック状態(CLKCTRL.MCLKSTATUS)レジスタの各々の状態ビットはクロック元が走行していて安定かを示します。

#### 12.3.4.1. 内部発振器

内部発振器は走行するのにどんな外部部品も必要としません。精度と電気的特性については「電気的特性」章を参照してください。

#### 12.3.4.1.1. 内部高周波数発振器 (OSCHF)

OSCHFは20MHzまでの出力周波数を支援します。これは主クロック(CLK\_MAIN)と実時間計数器(CLK\_RTC)用クロック元として使うことができます。 できます。OSCHFの出力周波数は手動または外部発振器に対する自動のどちらかで調整することができます。 調整範囲と発振器仕様については「電気的特性」章を参照してください。

## 12.3.4.1.2. 32.768kHz発振器 (OSC32K)

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

この発振器は実時間計数器(RTC)、ウォッチトック、タイマ(WDT)、低電圧検出器(BOD)のために1.024kHzまたは32.768kHzのックロックを提供します。また、この発振器は主クロック(CLK\_MAIN)へ32.768kHzクロックを提供することができます。

この発振器の始動時間については「電気的特性」章を参照してください。

## 12.3.4.2. 外部クロック元

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

- ・XTALHF1とXTALHF2のピンは高周波数クリスタル用発振器(XOSCHF)を駆動するための専用にされます。
- ・クリスタル用発振器に代わりに、XTALHF1は外部クロック元を受け入れるように構成設定することができます。
- ・XTAL32K1とXTAL32K2のピンは32.768kHzクリスタル用発振器(XOSC32K)を駆動するための専用にされます。
- ・クリスタル用発振器の代わりに、XTAL32K1は外部クロック元を受け入れるように構成設定することができます。

## 12.3.4.2.1. 高周波数クリスタル用発振器 (XOSCHF)

この発振器は以下の2つの入力任意選択を支援します。

- ・ クリスタルはXTALHF1とXTALHF2のピンに接続されます。
- ・XTALHF1に接続された20MHzまでで走行する外部クロック

入力任意選択はXOSCHF制御A(CLKCTRL.XOSCHFCTRLA)レジスタの供給元選択(SELHF)ビットへの書き込みによって構成設定されなければなりません。

XOSCHFはXOSCHFCTRLAの許可(ENABLE)ビットに'1'を書くことによって許可されます。許可されると、XOSCHFによって使われる 汎用入出力(GPIO)ピンの構成設定はXTALHF1とXTALHF2のピンのため無効にされます。発振器は要求された時に走行を開始する ように許可されることが必要です。

与えられたクリスタル用発振器の始動時間はCLKCTRL.XOSCHFCTRLAのクリスタル始動時間(CSUTHF)ビット領域への書き込みによって 調節することができます。

XOSCHFがXTALHF1で外部クロックを使うように構成設定されると、始動時間は2周期に固定されます。

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

この発振器は以下の2つの入力任意選択を支援します。

・ クリスタルはXTAL32K1とXTAL32K2のピンに接続されます。

・XTAL32K1に接続された32.768kHzで走行する外部クロック

XOSC32K制御A(CLKCTRL.XOSC32KCTRLA)レジ゙スタの供給元選択(SEL)ビットを書くことによって入力任意選択を構成設定してください。

XOSC32KはCLKCTRL.XOSC32KCTRLAの許可(ENABLE)ビットに'1'を書くことによって許可されます。許可されると、XOSC32Kによって使われる汎用入出力(GPIO)ピンの構成設定はXTAL32K1とXTAL32K2のピンから無効にされます。発振器は要求された時に走行を開始するように許可されることが必要です。

与えられたクリスタル用発振器の始動時間はXOSC32KCTRLAのクリスタル始動時間(CSUT)ビット領域への書き込みによって調節することができます。

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

## 12.3.5. クロック障害検出 (CFD)

クロック障害検出(CFD:Clock Failure Detection)は外部のクリスタル発振子やクロック元が動かない場合に動作を続けることをデバイスに許します。CFDは主クロック制御C(CLKCTRL.MCLKCTRLC)レジスタのクロック障害検出許可(CFDEN)ビットに'1'を書くことによって許可されます。監視可能な発振器とクロック元についてはクロック障害検出(CFD)構成図をご覧ください。

#### 12.3.5.1. クロック障害検出(CFD)動作

クロック障害検出(CFD)機能は選んだ発振器/クロックで端を調べることによって動かない発振器やクロック元を検出します。特定時間内で端が検出されない場合、CF D状態が発行され、割り込みを起動するか、または安定な内部クロッ元への切り替えをデバイスに強制します。

CFD機能が許可されると、主クロック制御C(CLKCTRL.MCLKCTRLC)レジスタのク ロック障害検出元(CFDSRC)ビット領域で選ばれた供給元を監視します。休止での CFDは選んだ供給元が活性である場合にだけ許可されます。





CFD状態が起きた場合、主クロック割り込み要求フラグ(CLKCTRL.MCLKINTFLAGS)レジスタのCFD割り込み要求フラグが設定(1)されます。割り込みが許可される場合、割り込み要求が発行されます。主クロック割り込み制御(CLKCTRL.MCLKINTCTRL)レジスタの割り込み型(INTTYPE)ビットは標準割り込みまたは遮蔽不可割り込み(NMI)のどちらが発行されるかを決めます。

NMIが選ばれ、複数の割り込み元がNMIに設定される場合、どの供給元が割り込みを生成したかを知るためベクタを調べることが必要です。

監視されるクロック元が主クロックでそれが動かない場合、それで動く全てが停止します。これが起きた場合、CFD状態は始動クロック元を 選ぶように主クロック制御A(CLKCTRL.MCLKCTRLA)レジスタのクロック選択(CLKSEL)ビット領域を上書きし、これはそれのリセット周波数に 戻されます。

始動クロックは電源ONリセット(POR)後にシステムが走るクロックとして定義されます。この始動クロック元はヒューズによって定義されます。 CFD事象によってCLKSELが無効にされると、CLKOUT信号が禁止されます。



#### 12.3.5.2. 状態解消

CFD状態はリセット後に解消され、監視される供給元が再び交互切り替えを開始するか、または主クロック割り込み要求フラグ(CLKCTRL. MCLKINTFLAGS)レシ<sup>\*</sup>スタのクロック障害検出割り込み要求(CFD)フラグが設定(1)されます。障害状態に出会う限り、10 OSC32K周期毎に割り込みが起動します。それらの繰り返される割り込みが不要なら、主クロック割り込み制御(CLKCTRL.MCLKINTCTRL)レシ<sup>\*</sup>スタのクロック障害検出割り込み許可(CFD)ビットに<sup>\*</sup>0<sup>\*</sup>を書いてください。それが監視されている主クロックの場合、既定始動クロックに戻すことが再び主クロックに交互切り替えを開始させ、この状態を解消します。

#### 12.3.5.3. CFD試験

主クロック制御C(CLKCTRL.MCLKCTRLC)レジスタのクロック障害検出試験(CFDTST)と、ットはクロック障害検出器でクロック障害を起動するのに使うことができます。使用事例に応じて、クロック障害検出器を試験する2つの異なる動作形態があります。

### 12.3.5.3.1. 主クロックへの影響なしでのCFD試験

この動作形態は走行時の使用が意図されます。主クロックに影響しないよう、主クロック制御C(CLKCTRL.MCLKCTRLC)レジスタのクロック 障害検出試験(CFDTST)ビットが書かれる時にCLKCTRL.MCLKCTRLCのクロック障害検出供給元(CFDSRC)ビット領域は主クロックと違う クロック元に構成設定されなければなりません。CFDSRCは'00'以外でなければなりません。主クロック割り込み要求フラグ(CLKCTR L.MCLKINTFLAGS)レジスタのCFD割り込み要求(CFD)フラグが設定(1)されますが、主クロックは始動クロック元に変わりません。

クロック障害検出器が主クロックを監視し、クロック障害検出器の走行時検査が必要とされる場合、以下の手順を行うことが必要です。

- 1. CLKCTRL.MCLKCTRLCのクロック障害検出許可(CFDEN)ビットに'0'を書くことによってクロック障害検出器を禁止し、CFDSRCビット に'00'以外の数値を書くことによって供給元を直接的に発振器へ変更してください。
- 2. このフラグを解除するためにCLKCTRL.MCLKINTFLAGSのCFD割り込み要求フラグに'1'を書いてください。
- 3. CFDTSTビットに'1'を書き、CFDENビットに'1'を書くことによって再びクロック障害検出器を許可してください。
- 4. クロック障害作業を調べるためにCLKCTRL.MCLKINTFLAGSのCFDビットが設定(1)されるのを待ってください。
- 5. CFDビットに'0'を書くことによってクロック障害検出器を禁止し、CFDSRCビット領域に'00'を書くことによって再び供給元を主クロック に変更してください。
- 6. CFDTSTビットに'0'を書き、CFDENビットに'1'を書くことによってクロック障害検出器を再び許可してください。

#### 12.3.5.3.2. CFD試験と主クロックを始動クロック元へ変更

主クロック制御C(CLKCTRL.MCLKCTRLC)レジスタのクロック障害検出元(CFDSRC)ビット領域が'00'の値を持ち、主クロックが監視される場合、MCLKCTRLCのクロック障害検出試験(CFDTST)ビットへの'1'書き込みは主クロックを始動クロック元へ変更する障害を起動します。

#### 12.3.6. 時間基準

時間基準は1µs以上のタイング周期を生成するの使われ、ADC始動時間のような内部遅延のタイングに使われます。これは時間基準 (CLKCTRL.MCLKTIMEBASE)レジスタの時間基準(TIMEBASE)ビット領域を1µs以上になるCLK\_PER周期数に設定することによって行われます。この時間基準は最も近い整数に丸められなければなりません。

#### 12.3.7. 手動調整と自動調整

OSCHFの出力周波数は手動または外部発振器に対する自動のどちらかで調節することができます。

#### 手動調整

OSCHFの出力周波数は内部高周波数発振器調節(OSCHFTUNE)レジスタの使用者周波数調節(TUNE)ビット領域を書くことによって 上下に調節することができます。内部高周波数発振器制御A(OSCHFCTRLA)レジスタの自動調整許可(AUTOTUNE)ビットは'0'に留 まらなければなりません。

# 外部クリスタル発振器に対する自動調整

OSCHF出力周波数は外部クルスタル用発振器に対して自動的に調節することによって安定化することができます。OSCHFCTRLAレジ スタのAUTOTUNEビットで外部発振器(='1')を選ぶことによって自動調整を許可してください。これはOSCHFTUNEレジスタを施錠して

手動調整を阻止します。OSCHFTUNEレジスタは AUTOTUNEが禁止される時に最新のTUNE値 で更新されます。

詳細については「電気的特性」章も参照してくだ さい。



## 12.3.8. 休止形態動作

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

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

パワーダウン休止動作では全ての不揮発性メモリ(NVM)操作が完了された後に主クロックが停止します。休止動作形態のより多くの詳細に ついては「SLPCTRL - 休止制御器」章を参照してください。

休止でクロック障害検出(CFD)は選んだ供給元が活動の場合にだけ許可されます。リセット後、CFDは監視される発振器の始動時間(SUT)が経過されるのと等しい時間まで障害探索を始めません。

# 12.3.9. 構成設定変更保護

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

| 表12-1. CLKCTRL - 構成設定変更 | 保護下のレジスタ |
|-------------------------|----------|
| レジズタ                    | 鍵種別      |
| CLKCTRL.MCLKCTRLA       |          |
| CLKCTRL.MCLKCTRLB       |          |
| CLKCTRL.MCLKCTRLC       |          |
| CLKCTRL.MCLKINTCTRL     | IOREG    |
| CLKCTRL.OSCHFCTRLA      | IOREG    |
| CLKCTRL.OSC32KCTRLA     |          |
| CLKCTRL.XOSC32KCTRLA    |          |
| CLKCTRL.XOSCHFCTRLA     |          |

# 12.4. レジスタ要約

| 変位         | 略称           | ビット位置      | ビット7     | ビット6 | ビット5 | ビット4         | ビット3     | ビット2    | ビット1   | ビットロ     |
|------------|--------------|------------|----------|------|------|--------------|----------|---------|--------|----------|
| +\$00      | MCLKCTRLA    | $7 \sim 0$ | CLKOUT   |      |      | CLKSEL3~0    |          |         |        |          |
| +\$01      | MCLKCTRLB    | $7 \sim 0$ |          |      |      |              | PDIV3~0  |         |        |          |
| +\$02      | MCLKCTRLC    | $7 \sim 0$ |          |      |      |              | CFDS     | RC1,0   | CFDTST | CFDEN    |
| +\$03      | MCLKINTCTRL  | $7 \sim 0$ | INTTYPE  |      |      |              |          |         |        | CFD      |
| +\$04      | MCLKINTFLAGS | $7 \sim 0$ |          |      |      |              |          |         |        | CFD      |
| +\$05      | MCLKSTATUS   | $7 \sim 0$ |          |      |      | EXTS/XOSCHFS | XOSC32KS | OSC32KS | OSCHFS | SOSC     |
| +\$06      | MCLKTIMEBASE | $7 \sim 0$ |          |      |      |              |          |         |        |          |
| +\$07      | 予約           |            |          |      |      |              |          |         |        |          |
| +\$08      | OSCHFCTRLA   | $7 \sim 0$ | RUNSTDBY |      |      |              |          |         |        | AUTOTUNE |
| +\$09      | OSCHFTUNE    | $7 \sim 0$ |          |      |      | TUN          |          |         |        |          |
| +\$0A<br>∼ | 予約           |            |          |      |      |              |          |         |        |          |
| +\$17      |              |            |          |      |      |              |          |         |        |          |
| +\$18      | OSC32KCTRLA  | $7 \sim 0$ | RUNSTDBY |      |      |              |          |         |        |          |
| +\$19<br>~ | 予約           |            |          |      |      |              |          |         |        |          |
| +\$1B      | 3 71 3       |            |          |      |      |              |          |         |        |          |
| +\$1C      | XOSC32KCTRLA | $7 \sim 0$ | RUNSTDBY |      | CSU  | T1,0         |          | SEL     | LPMODE | ENABLE   |
| +\$1D<br>~ | 予約           |            |          |      |      |              |          |         |        |          |
| +\$1F      | 1.46.0       |            |          |      |      |              |          |         |        |          |
| +\$20      | XOSCHFCTRLA  | 7~0        | RUNSTDBY |      | CSUT | HF1,0        |          |         | SELHF  | ENABLE   |

# 12.5. レジスタ説明

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

- 名称:MCLKCTRLA
- **変位** : +\$00
- リセット : \$00

### 特質:構成設定変更保護

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

# • ビット7 - CLKOUT : 主クロック出力 (Main Clock Out)

このビットは主クロックが動いている時に主クロックが主クロック出力(CLKOUT)ピンで利用可能かどうかを制御します。 このビットはこれに'0'が書かれる時か、または供給元として主クロックでクロック障害検出(CFD)状態が起きた時に解除(0)されます。 このビットはこれに'1'が書かれる時に設定(1)されます。

| 值  | 0                      | 1                      |
|----|------------------------|------------------------|
| 説明 | 主クロックはCLKOUTピンで利用不能です。 | 主クロックはCLKOUTピンで利用可能です。 |

## • ビット3~0 - CLKSEL3~0 : クロック選択 (Clock Select)

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

| 值  | 0000          | 0001               | 0 0 1 0                                                               | 0 0 1 1                                                  | その他  |
|----|---------------|--------------------|-----------------------------------------------------------------------|----------------------------------------------------------|------|
| 名称 | OSCHF         | OSC32K             | XOSC32K                                                               | EXTCLK                                                   | -    |
| 説明 | 内部高周波数<br>発振器 | 32.768kHz<br>内部発振器 | XOSC32KCTRLAのSELビットに<br>応じて32.768kHz外部クロックまたは<br>32.768kHz外部クリスタル用発振器 | XOSCHFCTRLAのSELHFビット<br>に応じて外部クロックまたは<br>外部高周波数クリスタル用発振器 | (予約) |

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

名称:MCLKCTRLB

**変位** : +\$01

**リセット** : \$11

特質:構成設定変更保護

| ビット    | 7 | 6 | 5 | 4   | 3       | 2   | 1   | 0   |  |  |
|--------|---|---|---|-----|---------|-----|-----|-----|--|--|
|        |   |   |   |     | PDIV3~0 |     |     |     |  |  |
| アクセス種別 | 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\_MAIN)前置分周器の分周比を制御します。

| 値               | 0000 | 0001 | 0010 | 0011  | 0100  | 0101  | 1000 | 1001  | 1010  | 1011  | 1100  | その他  |
|-----------------|------|------|------|-------|-------|-------|------|-------|-------|-------|-------|------|
| 名称              | DIV2 | DIV4 | DIV8 | DIV16 | DIV32 | DIV64 | DIV6 | DIV10 | DIV12 | DIV24 | DIV48 | -    |
| 説明(CLK_MAIN分周数) | 2    | 4    | 8    | 16    | 32    | 64    | 6    | 10    | 12    | 24    | 48    | (予約) |

注:入力周波数(CLK\_MAIN)の構成設定と前置分周器設定は許された最大周波数の周辺機能クロック(CLK\_PER)やCPUクロック(CLK\_C PU)を超えてはなりません。更なる情報については「電気的特性」章を参照してください。

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

このビットは主クロック(CLK\_MAIN)前置分周器が許可されるかどうかを制御します。

| 値  | 0               | 1                                                      |
|----|-----------------|--------------------------------------------------------|
| 説明 | CLK_MAIN前置分周器禁止 | CLK_MAIN前置分周器許可、分周比は前置分周器<br>分周値(PDIV)ビット領域によって制御されます。 |

# 12.5.3. MCLKCTRLC - 主クロック制御C (Main Clock Control C)

名称:MCLKCTRLC

**変位** : +\$02

リセット : \$00

特質:構成設定変更保護

| ヒット    | 7 | 6 | 5 | 4 | 3    | 2     | 1      | 0     |
|--------|---|---|---|---|------|-------|--------|-------|
|        |   |   |   |   | CFDS | RC1,0 | CFDTST | CFDEN |
| アクセス種別 | R | R | R | R | R/W  | R/W   | R/W    | R/W   |
| リセット値  | 0 | 0 | 0 | 0 | 0    | 0     | 0      | 0     |

• ビット3,2 - CFDSRC1,0 : クロック障害検出元 (Clock Failure Detection Source)

このビット領域はクロック障害検出許可(CFDEN)ビットが'1'の時にどのクロック元が監視されるかを制御します。

| 值  | 0 0   | 01        | 10             | 11   |
|----|-------|-----------|----------------|------|
| 名称 | SYS   | XOSCHF    | XOSC32K        | -    |
| 説明 | 主クロック | 外部高周波数発振器 | 外部32.768kHz発振器 | (予約) |

注: このビット領域はCFDENビットが'1'で、主クロック割り込み制御(CLKCTRL.MCLKINTCTRL)レジスタのクロック障害検出割り込み許可 (CFD)ビットと割り込み型(INTTYPE)ビットの両方が'1'の時に読み込み専用です。このビットはシステムリセットが起こるまで読み込み専 用に留まります。

# ● ビット1 - CFDTST : クロック障害検出試験 (Clock Failure Detection Test)

このビットはCFD機能の試験を制御します。このビットへの'0'書き込みはこのビットを解除(0)して進行中のCFD試験障害状態を解消します。このビットへの'1'書き込みはこのビットを設定(1)してCFD障害状態を強制します。

| 値  | 0             | 1               |  |  |
|----|---------------|-----------------|--|--|
| 説明 | CFD機能の進行中試験なし | CFD障害状態が強制されます。 |  |  |

# • ビット0 - CFDEN : クロック障害検出許可 (Clock Failure Detection Enable)

このビットはCFDが許可されるか否かを制御します。

| 値  | 0      | 1      |
|----|--------|--------|
| 説明 | CFDは禁止 | CFDは許可 |

注: このビット領域はCFDENビットが'1'で、主クロック割り込み制御(CLKCTRL.MCLKINTCTRL)レシ、スタのクロック障害検出割り込み許可 (CFD)ビットと割り込み型(INTTYPE)ビットの両方が'1'の時に読み込み専用です。このビットはシステムリセットが起こるまで読み込み専 用に留まります。

# 12.5.4. MCLKINTCTRL - 主クロック割り込み制御 (Main Clock Interrupt Control)

名称:MCLKINTCTRL

**変位**:+\$03

リセット : \$00

**特質**:構成設定変更保護

| ビット    | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|--------|---------|---|---|---|---|---|---|-----|
|        | INTTYPE |   |   |   |   |   |   | CFD |
| アクセス種別 | R/W     | R | R | R | R | R | R | R/W |
| Jセット値  | 0       | 0 | 0 | 0 | 0 | 0 | 0 | 0   |

# • ビット7 - INTTYPE : 割り込み型 (Interrupt Type)

このビットはクロック障害検出(CFD)割り込みの型を制御します。

| 値  | 0      | 1        |
|----|--------|----------|
| 名称 | INT    | NMI      |
| 説明 | 通常割り込み | 遮蔽不可割り込み |

注: このビット領域は主クロック制御C(CLKCTRL.MCLKCTRLC)レシ、スタのクロック障害検出許可(CFDEN)ビットが'1'で、クロック障害検出割 り込み許可(CFD)ビットとこのビットの両方が'1'の時に読み込み専用です。このビットはシステムリセットが起こるまで読み込み専用に留 まります。

# • ビット0 - CFD : クロック障害検出割り込み許可 (Clock Failure Detection Interrupt Enable)

このビットはクロック障害検出(CFD)割り込みが許可されるか否かを制御します。

| 値  | 0          | 1          |
|----|------------|------------|
| 説明 | CFD割り込みは禁止 | CFD割り込みは許可 |

注: このビット領域は主クロック制御C(CLKCTRL.MCLKCTRLC)レジスタのクロック障害検出許可(CFDEN)ビットが'1'で、割り込み型(INTT YPE)ビットとこのビットの両方が'1'の時に読み込み専用です。このビットはシステムリセットが起こるまで読み込み専用に留まります。

## 12.5.5. MCLKINTFLAGS - 主クロック割り込み要求フラク (Main Clock Interrupt Flag)

名称:MCLKINTFLAGS

**変位**:+\$04

リセット : \$00

# 特質:-

|                                              | ビット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|----------------------------------------------|--------|---|---|---|---|---|---|---|-----|
|                                              |        |   |   |   |   |   |   |   | CFD |
| //TX性別 R R R R R R R R R R R R R R R R R R R | アクセス種別 | R | R | R | R | R | R | R | R/W |
| リセット値 0 0 0 0 0 0 0 0                        | リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0   |

## ● ビット7 - CFD : クロック障害検出割り込み要求フラグ(Clock Failure Detection Interrupt Flag)

このビットはこれに'1'を書くことによって解除(0)されます。このフラグはクロック障害が検出された時に設定(1)されます。このビットへの'0' 書き込みは無効です。このビットへの'1'書き込みはクロック障害検出割り込み要求(CFD)フラグを解除(0)します。

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

| 名称 | : MCLKSTATUS |
|----|--------------|
| 変位 | · +\$05      |

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

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

# ビット4 - EXTS/XOSCHFS:外部クリスタル/クロック状態(External Crystal/Clock Status)

| 值  | 0 | 1 |
|----|---|---|
| 説明 |   |   |

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

| 値  | 0                                                                                                                                             | 1 |
|----|-----------------------------------------------------------------------------------------------------------------------------------------------|---|
| 説明 | 外部32.768kHz発振器制御A(CLKCTRL.XOSC32KCTRLA)レシ、スタ<br>の供給元選択(SEL)ビットが'0'の時に外部32.768kHzクリスタルは安定<br>ではありません。<br>SELビットが'1'の時に外部32.768kHzクロックは動いていません。 |   |

# ● ビット2 - OSC32KS: 内部32kHz超低電力発振器状態 (32.768kHz Ultra Low-Power Internal Oscillator Status)

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

# ● ビット1 - OSCHFS : 内部高周波数発振器状態 (Internal High-Frequency Osillator Status)

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

0

R/W 0

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

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

# 12.5.7. MCLKTIMEBASE - 時間基準 (Timebase)

| 名ヨリ | 2.3.7. MCLK<br>3称 : MCLK<br>変位 : +\$06<br>セット : \$00<br>寺質 : - |   | □可旧至午( | T miebase) |     |     |             |     |   |
|-----|----------------------------------------------------------------|---|--------|------------|-----|-----|-------------|-----|---|
|     | ビット                                                            | 7 | 6      | 5          | 4   | 3   | 2           | 1   |   |
|     | [                                                              |   |        |            |     | r   | TIMEBASE4~0 | )   |   |
|     | アクセス種別                                                         | R | R      | R          | R/W | R/W | R/W         | R/W | F |
|     | リセット値                                                          | 0 | 0      | 0          | 0   | 0   | 0           | 0   |   |
|     |                                                                |   |        |            |     |     |             |     |   |

# ● ビット4~0 - TIMEBASE4~0 : 時間基準 (Timebase)

このビット領域は1µs以上になるCLK\_PER周期数を指定します。これはADC始動時間のような内部遅延のタイングに使われます。 この値は最も近い整数に丸められなければなりません。以下のコート断片はceil関数を使ってこれを行う方法を示します。

| #include <math.h></math.h>     |                             |
|--------------------------------|-----------------------------|
| #define CLK_PER 333333331      | // 20MHz/6 = 3.333333MHz    |
| #define TIMEBASE_VALUE ((uint8 | _t) ceil(CLK_PER*0.000001)) |

# 12.5.8. OSCHFCTRLA - 内部高周波数発振器制御A (Internal High-Frequency Oscillator Control A)

名称: OSCHFCTRLA

**変位**:+\$08

**リセット** : \$0C

**特質**:構成設定変更保護

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

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

このビットは内部高周波数発振器(OSCHF)が常に動くかどうかを制御します。

| 値  | 0                                                              | 1                                              |
|----|----------------------------------------------------------------|------------------------------------------------|
| 説明 | OSCHF発振器は周辺機能または主クロックによって<br>要求される時にだけ動きます。( <mark>注1</mark> ) | OSCHF発振器は常に活動動作及び<br>アイドルとスタンバイの休止動作で動きます。(注2) |
|    |                                                                |                                                |

注1:要求する周辺機能や主クロックは発振器始動時間を考慮しなければなりません。

注2: 発振器信号は要求された場合にだけ利用可能で、2 OSCHF周期後に利用可能です。

# • ビットO - AUTOTUNE : 自動調整許可 (Auto-Tune Enable)

このビットは内部高周波数発振器(OSCHF)の32.768kHzクリスタルでの自動調整機能が許可されるかどうかを制御します。

| 值  | 0                       | 1                       |
|----|-------------------------|-------------------------|
| 名称 | OFF                     | XOSC32K                 |
| 説明 | OSCHF発振器の自動調整機能が禁止されます。 | OSCHF発振器の自動調整機能が許可されます。 |

12.5.9. OSCHFTUNE - 内部高周波数発振器調節 (Internal High-Frequency Oscillator Tune)

| <b>夏</b><br>リ | 名称 : OSCHF<br>を位 : +\$09<br>セット : \$00<br>寺質 : - | ΓUNE |     |     |     |      |     |     |     |
|---------------|--------------------------------------------------|------|-----|-----|-----|------|-----|-----|-----|
|               | ビット                                              | 7    | 6   | 5   | 4   | 3    | 2   | 1   | 0   |
|               |                                                  |      |     |     | TUN | E7~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 - TUNE7~0 : 使用者周波数調節 (User Frequency Tuning)

このビット領域は内部高周波数発振器(OSCHF)の出力周波数の手動調節を制御します。周波数は発振器の目標周波数から32段階 下または31段階上へ調節することができます。従って、レジスタの受け入れ可能な入力値範囲は-32~+31です。

このビット領域の6ビット値が符号付き(2の補数)形式で表され、ビット5がビット6と7に反映されるため、ビット6と7への書き込みは無効です。

注: 内部高周波数発振器制御A(OSCHFCTRLA)レジスタの自動調整許可(AUTOTUNE)ビットが許可される場合、TUNE値は施錠され ます。AUTOTUNEが禁止されると、自動調整動作からの最新調整値がこのビット領域を更新するまでに最大0.75µsと3主クロック周 期かかります。

# 12.5.10. 内部OSC32KCTRLA - 32.768kHz発振器制御A (Internal 32.768kHz Oscillator Control A)

名称: OSC32KCTRLA

**変位** : +\$18

リセット : \$00

#### 特質:構成設定変更保護

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

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

このビットは内部32.768kHz発振器(OSC32K)が常に動くかどうかを制御します。

| 值  | 0                                                | 1                                                      |
|----|--------------------------------------------------|--------------------------------------------------------|
| 説明 | OSC32K発振器は周辺機能または主クロックによって<br>要求される時にだけ動きます。(注1) | OSC32K発振器は常に活動動作及びアイトル、<br>スタンバイ、パワーダウンの休止動作で動きます。(注2) |

注1: 要求する周辺機能や主クロックは発振器始動時間を考慮しなければなりません。

注2: 発振器信号は要求された場合にだけ利用可能で、4 OSC32K周期後に利用可能です。

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

- 名称:XOSC32KCTRLA
- **変位** : +\$1C

**リセット** : \$00

**特質**:構成設定変更保護

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

# ビット7 - RUNSTDBY: スタンハイ時走行 (Run Standby)

このビットは許可(ENABLE)ビットが'1'の時に32.768kHzクリスタル用発振器(XOSC32K)がどの動作で常に動くかどうかを制御します。

| 値  | 0                                                               | 1 |
|----|-----------------------------------------------------------------|---|
| 説明 | XOSC32K発振器は活動動作とアイドル休止動作で周辺機能<br>または主クロックによって要求される時にだけ動きます。(注1) |   |
|    |                                                                 |   |

注1: 要求する周辺機能や主クロックは発振器始動時間を考慮しなければなりません。

注2: 発振器信号は要求された場合にだけ利用可能で、初期クリスタル始動時間が既に終わった場合、最大3 XOSC32K周期後に 利用可能です。

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

このビット領域は供給元選択(SEL)ビットが'0'の時に32.768kHzクリスタル用発振器(XOSC32K)始動時間を制御します。

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

注: このビット領域は許可(ENABLE)ビットまたは主クロック状態(CLKCTRL.MCLKSTATUS)レシブスタのXOSC32K状態(XOSC32KS)ビットが '1'の時に読み込み専用です。

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

このビットは32.768kHzクリスタル用発振器(XOSC32K)の供給元を制御します。

| 値  | 0                                | 1                  |
|----|----------------------------------|--------------------|
| 説明 | XTAL32K1とXTAL32K2のピンに接続した外部クリスタル | XTAL32K1ピンでの外部クロック |

注: このビットは許可(ENABLE)ビットまたは主クロック状態(CLKCTRL.MCLKSTATUS)レシブスタのXOSC32K状態(XOSC32KS)ビットが'1'の 時に読み込み専用です。

## ● ビット1 - LPMODE : 低電力動作 (Low-Power Mode)

このビットは32.768kHzクリスタル用発振器(XOSC32K)が低電力動作かどうかを制御します。

注:低電力動作許可はクリスタルの始動時間を増し得ます。直列抵抗と全体容量を減らすためにクリスタル実装を変えるか、または低電力動作を禁止することによってこれを軽減してください。

| 値  | 0       | 1       |
|----|---------|---------|
| 説明 | 低電力動作禁止 | 低電力動作許可 |

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

このビットは32.768kHzクリスタル用発振器(XOSC32K)が許可されるかどうかを制御します。

| 値  | 0            | 1                                        |
|----|--------------|------------------------------------------|
| 説明 | XOSC32K発振器禁止 | XOSC32K発振器許可、各々の発振器ピンに対する通常のピン操作を無効にします。 |

## 12.5.12. XOSCHFCTRLA - 外部高周波数クリスタル用発振器制御A (External High-Frequency Oscillator Control A)

名称:XOSCHFCTRLA

**変位** : +\$20

リセット : \$00

**特質**:構成設定変更保護

| ビット    | 7        | 6 | 5    | 4     | 3 | 2 | 1     | 0      |
|--------|----------|---|------|-------|---|---|-------|--------|
|        | RUNSTDBY |   | CSUT | HF1,0 |   |   | SELHF | ENABLE |
| アクセス種別 | R/W      | R | R/W  | R/W   | R | R | R/W   | R/W    |
| リセット値  | 0        | 0 | 0    | 0     | 0 | 0 | 0     | 0      |

## ビット7 - RUNSTDBY: スタンハイ時走行 (Run Standby)

このビットは許可(ENABLE)ビットが'1'の時に外部高周波数発振器(XOSCHF)が常に動くかどうかを制御します。

| 值  | 0                                                | 1                                                |
|----|--------------------------------------------------|--------------------------------------------------|
| 説明 | XOSCHF発振器は周辺機能または主クロックによって<br>要求される時にだけ動きます。(注1) | XOSCHF発振器は常に活動動作及び<br>アイト・ルとスタンハイの休止動作で動きます。(注2) |

注1: 要求する周辺機能や主クロックは発振器始動時間を考慮しなければなりません。

注2: 発振器信号は要求された場合にだけ利用可能で、初期クリスタル始動時間が既に終わった場合、2 XOSCHF周期後に利用可能です。

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

このビット領域は供給元選択(SELHF)ビットが'0'の時に外部高周波数発振器(XOSCHF)の始動時間を制御します。

| 値  | 0 0          | 01          | 10          | 11   |  |
|----|--------------|-------------|-------------|------|--|
| 名称 | 256CYC       | 1KCYC       | 4KCYC       | _    |  |
| 説明 | 256 XOSCHF周期 | 1K XOSCHF周期 | 4K XOSCHF周期 | (予約) |  |

注: このビット領域は許可(ENABLE)ビットまたは主クロック状態(CLKCTRL.MCLKSTATUS)レシブスタのXOSCHF状態(XOSCHFS)ビットが '1'の時に読み込み専用です。

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

このビットは外部高周波数発振器(XOSCHF)の供給元を制御します。

| 值  | 0                              | 1                 |
|----|--------------------------------|-------------------|
| 名称 | CRYSTAL                        | EXTCLK            |
| 説明 | XTALHF1とXTALHF2のピンに接続した外部クリスタル | XTALHF1ピンでの外部クロック |

注: このビット領域は許可(ENABLE)ビットまたは主クロック状態(CLKCTRL.MCLKSTATUS)レシブスタのXOSCHF状態(XOSCHFS)ビットが '1'の時に読み込み専用です。

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

このビットは外部高周波数発振器(XOSCHF)が許可されるか否かを制御します。

| 値  | 0           | 1                                      |
|----|-------------|----------------------------------------|
| 説明 | XOSCHF発振器禁止 | XOSCHF発振器許可、各々の発振器ピンに対する標準ピン操作を無効にします。 |

# 13. SLPCTRL - 休止制御器

# 13.1. 特徴

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

# 13.2. 概要

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

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

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

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

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

# 13.2.1. 構成図



# 13.3. 機能的な説明

# 13.3.1. 初期化

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

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

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

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

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

## 13.3.2. 動作

## 13.3.2.1. 休止動作

消費電力を減らすために3つの異なる休止動作形態を許可することができます。

- **71ドル** CPUはコード実行を停止し、消費電力減少になります。 全ての周辺機能が動いて全ての割り込み元はデバイスを起こすことができます。
- スタンバイ スタンバイ休止動作で走行が許可されているどの周辺機能やクロックも除いて全ての高周波数クロックが停止されます。これは 対応するスタンバイ時走行(RUNSTDBY)ビットに'1'を書くことによって許可されます。消費電力は許可される機能に依存し ます。

一部の割り込み元がデバイスを起こすことができます(注)。

**パワーダウン** 全ての高周波数クロックが停止され、アイドル休止動作よりも低い消費電力になります。 一部の周辺機能が動いていて、一部の割り込み元がデバイスを起こすことができます(注)。

● 重要:予測不能な動きを避けるため、高温低漏れ許可が有効にされる時にTWI7ドレス一致とCCLの起き上がり元は禁止されなければなりません。

注: 更なる情報については以下の休止動作活動表を参照してください。

起き上がり時間が各種休止動作によってどう影響を及ぼされるかについては「起き上がり時間」項を参照してください。

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

| 周辺機能                             | 休止動作で活動 |                   |        |  |
|----------------------------------|---------|-------------------|--------|--|
|                                  | アイト゛ル   | スタンバイ             | パワーダウン |  |
| CPU                              | ×       | ×                 | ×      |  |
| RTC                              | 0       | 〇 ( <b>注1,2</b> ) | 〇 (注2) |  |
| WDT、BOD、EVSYS、NVM ( <b>注3</b> )  | 0       | 0                 | 0      |  |
| CCL, ACn, ADCn, DACn, TCAn, TCBn | 0       | 〇 (注1)            | ×      |  |
| 他の全ての周辺機能                        | 0       | ×                 | ×      |  |

注1:活動状態に入るには対応する周辺機能のスタンハイ時走行(RUNSTDBY)ビットが設定(1)されなければなりません。

注2: スタンハイ休止動作で活動状態に入るにはRTC機能だけ、RUNSTDBYビットの設定(1)が必要とされます。 パワーダウン休止動作ではPIT機能だけが利用可能です。

注3:進行中のプログラミングは完了され、その後にNVM周辺機能が禁止されます。

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

| クロック元             | 休止動作で活動 |                         |        |
|-------------------|---------|-------------------------|--------|
| ッロッシンL            | アイドル    | スタンバイ                   | パワーダウン |
| 主クロック元            | 0       | 〇 ( <mark>注</mark> 1)   | ×      |
| RTCクロック元          | 0       | 〇 ( <mark>注1,2</mark> ) | 〇 (注2) |
| WDT発振器、BOD発振器(注3) | 0       | 0                       | 0      |
| CCLクロック元          | 0       | 〇 (注1)                  | ×      |

注1:活動状態に入るには対応する周辺機能のスタンバイ時走行(RUNSTDBY)ビットが設定(1)されなければなりません。

注2: スタンハイ休止動作で活動状態に入るにはRTC機能だけ、RUNSTDBYビットの設定(1)が必要とされます。 ハプーダウン休止動作ではPIT機能だけが利用可能です。

注3: BOD発振器はBOD採取動作時のみ

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

| 起こし元                               | 休止動作で活動 |                   |          |
|------------------------------------|---------|-------------------|----------|
| 起こした                               | アイト゛ル   | スタンバイ             | パ゚ワータ゛ウン |
| PORTピン割り込み                         | 0       | 0                 | 〇 (注1)   |
| TWIアドレス一致割り込み、BOD VLM割り込み          | 0       | 0                 | 0        |
| CCL割り込み                            | 0       | 〇 (注2)            | 〇 (注3)   |
| RTC割り込み                            | 0       | 〇 ( <b>注2,4</b> ) | 〇 (注4)   |
| TCAn割り込み、TCBn割り込み、ADCn割り込み、ACn割り込み | 0       | 〇 (注2)            | ×        |
| USARTフレーム開始割り込み                    | ×       | 0                 | ×        |
| 他の全ての割り込み                          | 0       | ×                 | ×        |

注1:入出力ピンは「PORT」章の「非同期感知ピン特性」に従って構成設定されなければなりません。

注2:活動状態に入るには対応する周辺機能のスタンバイ時走行(RUNSTDBY)ビットが設定(1)されなければなりません。

**注3**: CCLはLUTnを通す経路が非同期(LUTn制御A(LUTnCTRLA)レジスタで濾波器選択(FILTSEL)='00'且つ端検出(EDGEDE T)='0')の場合にだけデバイスを起き上がらせることができます。

注4: スタンハイ休止動作で活動状態に入るにはRTC機能だけ、RUNSTDBYビットの設定(1)が必要とされます。 パワーダウン休止動作ではPIT機能だけが利用可能です。

## 13.3.2.2. 起き上がり時間

デバイスに対する標準起き上がり時間は6主クロック周期(CLK\_PER)と加えて主クロック元が開始するのにかかる時間、それと調整器が OFFに切り替えられていた場合、調整器が開始するのにかかる時間です。

- ・アイドル休止動作では追加の起き上がり時間をなくすために主クロック元が走行を維持します。
- ・スタンバイ休止動作では周辺機能の構成設定に依存して主クロックが走行するかもしれません。
- ・ パワーダウン休止動作では内部32.768kHz発振器と実時間計数器(RTC)クロック元だけが動くかもしれません。これらは低電圧検出器 (BOD)、ウオッチトックゲタイマ(WDT)、周期的割り込み計時器(PIT)によって使われます。他の全てのクロック元はOFFです。

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

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

| 表13-4. 休止動作と始動時間 |      |             |
|------------------|------|-------------|
| Г                | 休止動作 | <b>炒動時間</b> |

| 1个正到17月 | 始劉時间              |
|---------|-------------------|
| アイドル    | 6クロック周期           |
| スタンバイ   | 6クロック周期 + OSC始動時間 |
| パワータウン  | 6クロック周期 + OSC始動時間 |

# 13.3.3. デバッグ操作

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

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

# 13.4. レジスタ要約

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

# 13.5. レジスタ説明

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

| 名称 | : | CTRLA |
|----|---|-------|
| 赤凸 |   | 1002  |

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

# 特質:一

| ビット    | 7 | 6 | 5 | 4 | 3 | 2   | 1     | 0   |
|--------|---|---|---|---|---|-----|-------|-----|
|        |   |   |   |   |   | SMO | 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      | 001         | 010          | 011  |
|----|------------|-------------|--------------|------|
| 名称 | IDLE       | STANDBY     | PDOWN        | -    |
| 説明 | アイドル休止動作許可 | スタンバイ休止動作許可 | パワーダウン休止動作許可 | (予約) |

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

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

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

# 14.1. 特徴

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

## 14.2. 概要

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

## 14.2.1. 構成図



## 14.2.2. 信号説明

| 信号    | 形式      | 説明                     |
|-------|---------|------------------------|
| RESET | デジタル入力  | 外部リセット(Low活性)          |
| UPDI  | デジタル入出力 | 統一プログラム/ディバッグ インターフェース |

# 14.3. 機能的な説明

## 14.3.1. 初期化

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

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

## 14.3.2. 動作

## 14.3.2.1. リセット元

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

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

| • 電 | 源リセット元: |  |
|-----|---------|--|
|-----|---------|--|

- ・使用者リセット元:
- 外部リセット(RESET)
- 低電圧検出器 (BOD) リセット

- 電源ONリセット (POR)

- ウォッチト ゙ック゛ タイマ (WDT) リセット
- ソフトウェア リセット (SWRST)
- 統一プログラム/デバッグ インターフェース (UPDI) リセット

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

電源ONJセット(POR)は論理回路とメモリの安全な始動を保証 することが狙いです。チップ上の検出回路が常に許可され、 これを生成します。PORはVDDが上昇する時に活性にさ れ、VDDがPOR閾値電圧(VPOR+)未満である限り活性リセット を与えます。このリセットは始動してリセット初期化手順が終了さ れるまで持続されます。ヒュースが始動時間(SUT)を決めま す。VDDが検出基準(VPOR-)未満に落ちる時にリセットは遅延 もなしに再び活性にされます。

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

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





#### 14.3.2.1.3. 外部リセット (RESET)

外部リセットはヒューズによって許可されます。構成設定0(FUS E.SYSCFG0)ヒューズのリセット ピン構成設定(RSTPINCFG)ビット 領域をご覧ください。また、外部リセットが許可されると、リセット ピンの内部プルアップ抵抗が許可されます。

許可されると、外部リセットはRESETピンがLowである限り、リセットを要求します。デバイスはRESETが再びHighになるまでリセットに留まります。



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

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



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

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

リセット手順はビットが書かれた直後に始まります。



# 注: t<sub>SWR</sub>時間は概ね150nsです。

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

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

#### 14.3.2.1.7. 高電圧 (HV) リセット

高電圧がRESETピンに印加されるかまたは取り去られる場合にデバイスリセットが発行されます。UPDIを許可するのにHVパルスが使われると、それはデバイスリセットを引き起こします。HVパルスのより多くの情報については「UPDI – プログラム/デバッグ インターフェース」章を参照してください。

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

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

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

|                | DOD | DOD | ソフトウェア リヤット | 人立四よい  | WDTリセット |          | 古雨口(III)。シリス(汁)         |
|----------------|-----|-----|-------------|--------|---------|----------|-------------------------|
| リセット形式         | POR | BOD | フノトリエノ リセット | 外部リセット | WDIJE   | UPDIリセット | 高電圧(HV)パルス ( <b>注</b> ) |
| ヒュース、再設定       | 0   | 0   | 0           | 0      | 0       | 0        | 0                       |
| UPDIのリセット      | 0   | ×   | ×           | ×      | ×       | ×        | 0                       |
| 他の揮発性論理回路のリセット | 0   | 0   | 0           | 0      | 0       | 0        | 0                       |

注: HVパルスはリセットを発生することができますが、リセット元として意図的に使われるべきではありません。

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

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

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

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

## 14.3.3. 休止形態動作

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

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

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

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

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

| 表14-2. RSTCTRL - 構成設定変更保護下のレジスタ |       |  |  |  |
|---------------------------------|-------|--|--|--|
| レジスタ                            | 鍵種別   |  |  |  |
| RSTCTRL.SWRR                    | IOREG |  |  |  |

# 14.4. レジスタ要約

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

# 14.5. レジスタ説明

14.5.1. RSTFR - リセット フラク レジスタ (Reset Flag Register)

名称 : RSTFR

**変位**:+\$00

リセット : '00xx xxxx'

特質 :-

リセット フラグは各々のフラグに'1'を書くことによって解除(0)することができます。全てのフラグは電源ONリセット フラグ(PORF)と低電圧検出 リセット フラグ(BORF)を除き、電源ONリセット(POR)と低電圧検出リセット(BOR)によって解除(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 | Х      | Х    | Х    | Х     | Х    | Х    |

## • ビット5 - UPDIRF : UPDIリセット フラク (UPDI Reset Flag)

このビットはUPDIリセットが起きたか、またはHVハパルス発生によって起こったリセットのどちらかの場合に設定(1)されます。

• ビット4 - SWRF : ソフトウェア リセット フラク゛(Software Reset Flag)

このビットはソフトウェアリセットが起きた場合に設定(1)されます。

- ビット3 WDRF : ウォッチトック リセット フラク (Watchdog Reset Flag)
- このビットはウォッチドッグリセットが起きた場合に設定(1)されます。
- ビット2 EXTRF: 外部リセット 750<sup>\*</sup> (External Reset Flag)
   このビットは外部リセットが起きた場合に設定(1)されます。
- ビット1 BORF: 低電圧検出リセット 7ラク (Brownout Reset Flag)
- このビットは低電圧検出リセットが起きた場合に設定(1)されます。

# • ビットO - PORF : 電源ONリセット フラク (Power-On Reset Flag)

このビットは電源ONリセット(POR)が起きた場合に設定(1)されます。

POR後、PORフラグだけが設定(1)され、他の全てのフラグは解除(0)されます。POR後に完全なシステム ブートが走行する前に他のフラグが 設定(1)されることは有り得ません。

14.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'として読みます。

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

# 15.1. 特徴

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

# 15.2. 概要

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

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

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

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

## 15.2.1. 構成図

| 図15-1. CPUINT構成図 |                            |                      |                               |
|------------------|----------------------------|----------------------|-------------------------------|
| 周辺機能1 割り込み要求     | → 優先権                      | 割り込み制御器              | CPU "RETI"                    |
| )<br>)           | 復号器<br><sup>2</sup> STATUS | 4                    | CPU割り込み応答<br>CPU割り込み要求<br>CPU |
| 周辺機能2 割り込み要求     | → LVL1VEC                  | 全体割り込み許可<br>CPU.SREG | 起き上がり 休止 制御器                  |
|                  |                            | ]                    |                               |

# 15.3. 機能的な説明

## 15.3.1. 初期化

以下の順で割り込みを初期化してください。

- 1. 任意選択: 制御A(CPUINT.CTRLA)レジスタの割り込みベクタ選択(IVSEL)ビットを使って望む割り込みベクタの位置を構成設定してください。
- 2. 任意選択: CPUINT.CTRLAレジスタの簡潔ベクタ表(CVT)ビットに'1'を書くことによって簡潔ベクタ表を許可してください。
- 3. 任意選択: CPUINT.CTRLAレジスタのラウント<sup>゛</sup>ロヒン優先権許可(LVL0RR)ビットに'1'を書くことによってラウント<sup>゛</sup>ロヒンによるヘ<sup>゛</sup>クタの優先 順位付けを許可してください。
- 4. 任意選択: 段位1優先権保持割り込みベクタ(CPUINT.LVL1VEC)レジスタでの割り込みベクタに割り込みベクタ番号を書くことによって 優先段位1のベクタを選んでください。
- 5. 任意選択:割り込み優先段位0(LVL0PRI)レジスタを構成設定することによってLVL0割り込みの優先順位を変更してください。
- 6. 各周辺機能内で割り込み条件を構成設定し、周辺機能の割り込みを許可してください。
- 7. CPUステータス レジスタ(CPU.SREG)の全体割り込み許可(I)ビットに'1'を書くことによって全体的に割り込みを許可してください。

## 15.3.2. 動作

## 15.3.2.1. 許可、禁止とりセット

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

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

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

#### 15.3.2.2. 割り込みベクタ位置

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

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

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

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

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

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



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



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



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

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

## 15.3.2.4. 割り込み優先権

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

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

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

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

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

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

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

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

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

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

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

#### 15.3.2.4.3.1. 静的計画

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

## 図15-5. 既定静的計画



#### 15.3.2.4.3.2. 変更した静的計画

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

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

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

#### 図15-6. CPUINT.LVL0PRI≠0時静的計画



#### 15.3.2.4.3.3. ラウント・ロビン計画

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

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

#### 図15-7. ラウント・ロビン計画



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

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

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

1. ベクタ アドレス1の遮蔽不可割り込み(NMI)

2. ベクタ アドレス2の優先段位1(LVL1)割り込み

3. ベクタアドレス3の全ての優先段位0(LVL0)割り込み

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

#### 15.3.3. デバッグ操作

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

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

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

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

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

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

| 表15-3. CPUINT - 構成設定変更保護下のレジスタ |       |  |  |  |  |  |  |
|--------------------------------|-------|--|--|--|--|--|--|
| レジスタ                           | 鍵種別   |  |  |  |  |  |  |
| CPUINT.CTRLAのIVSELとCVT         | IOREG |  |  |  |  |  |  |

# 15.4. レジスタ要約

| 変位    | 略称      | ビット位置 | ビット7  | ビット6       | ビット5 | ビット4 | ビット3 | ビット2 | ビット1   | ビットロ   |
|-------|---------|-------|-------|------------|------|------|------|------|--------|--------|
| +\$00 | CTRLA   | 7~0   |       | IVSEL      | CVT  |      |      |      |        | LVL0RR |
| +\$01 | STATUS  | 7~0   | NMIEX |            |      |      |      |      | LVL1EX | LVL0EX |
| +\$02 | LVL0PRI | 7~0   |       | LVL0PRI7~0 |      |      |      |      |        |        |
| +\$03 | LVL1VEC | 7~0   |       | LVL1VEC7~0 |      |      |      |      |        |        |

# 15.5. レジスタ説明

# 15.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                     |  |  |  |  |  |  |  |
|---------------------------------------------------------|--------------------------|-----------------------|--|--|--|--|--|--|--|
| 説明                                                      | 望む割り込み~クタの位置はブート領域の直後(注) | 望む割り込みベクタの位置はブート領域の先頭 |  |  |  |  |  |  |  |
| 注: システム リセットはIVSELビット値に関わらず、プログラム カクンタを\$0000にリセットさせます。 |                          |                       |  |  |  |  |  |  |  |

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

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

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

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

| 値       | 0 | 1                                      |
|---------|---|----------------------------------------|
| = 11 HD |   | 優先段位0割り込み要求に対してラウンドロビン優先機<br>構が許可されます。 |

## 15.5.2. STATUS - 状態 (Status)

| 名称 | : STATUS | S |
|----|----------|---|
| 亦位 | + \$01   |   |

変位:+301 リセット:\$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)

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

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

| 名称 : LVL0Pf<br>変位 : +\$02<br>リセット : \$00<br>特質 : - | RI  |     |     |      |        |     |     |     |
|----------------------------------------------------|-----|-----|-----|------|--------|-----|-----|-----|
| ヒット                                                | 7   | 6   | 5   | 4    | 3      | 2   | 1   | 0   |
|                                                    |     |     |     | LVL0 | 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割り込みの優先権を変更するのに使われます。より多くの情報については「標準優先割り込み」項をご覧ください。

15.5.4. LVL1VEC - 優先段位1保持割り込みべりタ (Interrupt Vector with Priority Level 1)

| 変<br>归 | 称 : LVL1VE<br>位 : +\$03<br>zット : \$00<br>;質 : - | CC  |     |     |       |       |     |     |     |
|--------|-------------------------------------------------|-----|-----|-----|-------|-------|-----|-----|-----|
|        | ヒット                                             | 7   | 6   | 5   | 4     | 3     | 2   | 1   | 0   |
|        |                                                 |     |     |     | LVL1V | EC7~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割り込みは禁止されます。

# 16. EVSYS - 事象システム

# 16.1. 特徴

- ・周辺機能から周辺機能への直接的な合図のためのシステム
- ・周辺機能は周辺機能事象への直接的な生成、使用、反応が可能
- ・短くて予測可能な応答時間
- ・最大6つの平行事象チャネルを利用可能
- ・各チャネルは1つの事象生成部によって駆動され、複数の事象使用部を持つことが可能
- ・事象は殆どの周辺機能とソフトウェアによって送ることや受け取ることが可能
- ・事象システムは活動動作、アイドルとスタンバイの休止動作で動作

## 16.2. 概要

事象システム(EVSYS)は周辺機能から周辺機能への直接的な合図を許します。それはCPUを使うことなく、事象チャネルを通して或る周辺機能(事象生成部)での変化で別の周辺機能(事象使用部)での活動を起動することを許します。それは自律の周辺機能制御と相互作用、そして多数の周辺機能単位部での活動の同期タイシクがをも許す、周辺機能間の短くて予測可能な応答時間を提供するように設計されます。従って、EVSYS周辺機能はコアから独立した周辺機能(CIPs:Core Independent Peripherals)の実装を可能にします。 また、それはソフトウェアの複雑さ、大きさ、実行時間を減らすための強力な道具です。

事象生成部の状態の変化は事象として参照され、通常、周辺機能の割り込み条件の1つに対応します。事象は専用の事象経路網を 用いて他の周辺機能へ直接送ることができます。各チャネルの配線は事象生成と使用を含め、ソフトウェアで構成設定されます。

各チャネルでは1つの事象だけを配線することができます。複数の周辺機能が同じチャネルからの事象を使うことができます。

EVSYSはA/D変換器、アナログ比較器、入出力ポートピン、実時間計数器、タイマ/カウンタ、構成設定可能な注文論理回路のような周辺機能を直接的に接続することができます。事象はソフトウェアから生成することもできます。

## 16.2.1. 構成図



構成図は事象チャネルの動作を示します。入力でチャネルn生成部選択(EVSYS.CHANNELn)によって制御される多重器はどの事象元を 事象チャネルに配線するかを選びます。各事象チャネルは2つの副チャネル、1つの非同期副チャネルと1つの同期副チャネルを持ちます。同期使 用部は同期副チャネルを聴取し、非同期使用部は非同期副チャネルを聴取します。

非同期元からの事象信号は同期副チャネルに配線される前に事象システムによって同期化されます。同期使用部によって使われる非同期事象信号は同期部を通る伝搬を保証するために最低1周辺機能クロック周期間持続しなければなりません。同期部は事象発生時に依存してそのような事象を2~3クロック周期遅らせます。



#### 16.2.2. 信号説明

| 信号     | 形式     | 説明               |
|--------|--------|------------------|
| EVOUTx | デジタル出力 | 事象出力、入出力ポート毎に1出力 |

## 16.3. 機能的な説明

#### 16.3.1. 初期化

事象を使うには、事象システム、生成する周辺機能とその事象を使う周辺機能が適切に構成設定されなければなりません。

- 1. 生成する周辺機能を適切に構成設定してください。例えば、生成する周辺機能が計時器の場合、望む事象が生成されるように 前置分周、比較レジスタなどを設定してください。
- 2. 事象使用部周辺機能を適切に構成設定してください。例えば、ADCが事象使用部の場合、ADCの前置分周器、分解能、変換時間などを設定し、事象の受け取りで開始するようにADC変換を構成設定してください。
- 3. 事象システムを望む供給元に構成設定してください。この例では計時器比較一致を望む事象チャネルへです。これは例えば、チャネル0 生成部選択(EVSYS.CHANNEL0)レジスタへ書くことによって達成されるチャネル0かもしれません。
- 4. 対応する使用部nチャネル多重器(EVSYS.USERn)レジスタへ書くことによってこのチャネルを聴取するようにADCを構成設定してください。

#### 16.3.2. 動作

#### 16.3.2.1. 事象使用部多重器構成設定

各事象使用部はどの事象チャネルを聴取するかを選ぶ1つの専用事象使用部多重器を持ちます。応用は対応する使用部nチャネル入力 選択(EVSYS.USERn)レジスタを書くことによってこれらの多重器を構成設定します。

#### 16.3.2.2. 事象システム チャネル

ま16 1 H 出された 声色の 性 州

事象チャネルは事象生成部の1つに接続することができます。

各事象チャネルの供給元は各々のチャネルn生成部選択(EVSYS.CHANNELn)レジスタを書くことによって構成設定されます。

#### 16.3.2.3. 事象生成部

各事象チャネルは同時にどれか1つだけを選ぶことができるいくつかの可能な事象生成部を持ちます。チャネルに対する事象生成部は 各々のチャネルn生成部選択(EVSYS.CHANNELn)レジスタを書くことによって選ばれます。既定では、チャネルがどの事象生成部にも接続 されません。事象生成の詳細については対応する周辺機能の記述を参照してください。

生成される事象はデバイスの周辺機能クロック(CLK\_PER)に対して同期または非同期のどちらかです。非同期事象は周辺機能クロックの 標準端外で生成することができ、システムが選ばれたクロック周波数よりも速く応答することを示唆します。非同期事象はクロックが動いてい ない時のデバイスが休止動作の間に生成することもできます。

生成されたどの事象も、パルス事象またはレベル事象のどちらかとして分類されます。両方の場合で、事象は下表に従う特性で同期または非同期のどちらかにすることができます。

| 衣10-1.注 | 成されに争家の |                                                                     |
|---------|---------|---------------------------------------------------------------------|
| 事象型     | 同期/非同期  | 説明                                                                  |
| パルス     | 同期      | 1クロック周期持続するCLK_PERから生成された事象                                         |
|         | 非同期     | 1クロック周期持続するCLK_PER以外のクロックから生成された事象                                  |
|         | 同期      | 複数クロック周期持続するCLK_PERから生成された事象                                        |
| レヘル     | 非同期     | クロックなし(例えば、ピンまたは比較器)で生成された事象、または複数クロック周期持続するCLK_PER以外のクロックから生成された事象 |

信頼性があって予測可能な動作を保証するため、生成された事象と意図する事象使用部の両方の特性が考慮されなければなりません。

次表はこのデバイス系統に対して利用可能な事象生成部を示します。

| 表16-2.事 | 象生成部                |                                              |         |          |                                    |
|---------|---------------------|----------------------------------------------|---------|----------|------------------------------------|
|         | 成部名                 | 説明                                           | 事象型     | 生成クロック領域 | 事象長                                |
| 周辺機能    | 事象                  |                                              |         | 工成加力模域   |                                    |
| UPDI    | SYNCH               | 同期(SYNCH)文字                                  | 非同期、レベル | CLK_UPDI | CLK_UPDIに同期した<br>UPDI受信入力でのSYNCH文字 |
|         | OVF<br>CMP          | 計数器溢れ<br>比較一致                                | 非同期、パルス |          | 1 CLK_RTC周期                        |
| RTC     | EVGEN0              | 選択可能な前置分周した                                  |         | CLK_RTC  | 前置分周したRTC周期                        |
| CCL     | EVGEN1<br>LUTn      | RTC事象<br>LUT出力レベル                            | 非同期、レベル |          | CCL構成設定に依存                         |
| ACn     | OUT                 | 比較器出力レベル                                     |         | 非同期      | AC出力レベルで与えられる                      |
| ADCn    | RES<br>SAMP<br>WCMP | 結果準備可<br>採取(試料)準備可<br>窓比較一致                  | 同期、パルス  | CLK_PER  | 1 CLK_PER周期                        |
| PORTx   | EVGEN0<br>EVGEN1    | 芯に取一致<br>ピンレヘル                               | 非同期、レヘル | 非同期      | ピンレヘブルで与えられる                       |
| USARTn  | ХСК                 | SPI主装置動作と同期USART<br>動作でのクロック信号               | 同期、レベル  | TXCLK    | 最小2 CLK_PER周期                      |
| SPI0    | SCK                 | SPI主装置クロック                                   |         |          |                                    |
|         | OVF_LUNF            | 標準動作: 溢れ<br>分割動作: 下位バイ計時器<br>下溢れ             |         |          |                                    |
|         | HUNF                | 標準動作:利用不可<br>分割動作:上位バイ計時器<br>下溢れ             |         |          |                                    |
| TCAn    | CMP0_LCMP0          | 標準動作:比較チャネル0一致<br>分割動作:下位バイト計時器<br>比較チャネル0一致 | 同期、パルス  | CLK_PER  | 1 CLK_PER周期                        |
|         | CMP1_LCMP1          | 標準動作:比較チャネル1一致<br>分割動作:下位バイト計時器<br>比較チャネル1一致 |         |          |                                    |
|         | CMP2_LCMP2          | 標準動作:比較チャネル2一致<br>分割動作:下位バイト計時器<br>比較チャネル2一致 |         |          |                                    |
| TCBn    | CAPT                | CAPT7ラグ設定(1)                                 |         |          |                                    |
|         | OVF                 | 計数器溢れ                                        |         |          |                                    |

#### 16.3.2.4. 事象使用部

聴取する事象チャネルは事象使用部を構成設定することによって選ばれます。事象使用部は周辺機能クロックに対して同期または非同 期のどちらかの事象信号を必要とするかもしれません。非同期事象使用部はクロックが動いていない時の休止動作で事象に応答する ことができます。このような事象は周辺機能クロックの標準端外で応答することができ、事象使用部がクロック周波数よりも速く応答するこ とを示唆します。各周辺機能の必要条件の詳細については対応する周辺機能の記述を参照してください。

殆どの事象使用部はやって来る事象信号に基づいて対応する周辺機能で活動を起動するための端またはレベルの検出を実装しま す。両方の場合で、やって来る事象が周辺機能クロック(CLK\_PER)から生成されることを必要とする同期、またはそうでない非同期のど ちらかにすることができます。いくつかの非同期事象使用部は事象入力検出が適用されず、事象信号を直接使います。各種事象使 用部特性が次表で全般的に記述されます。

| 表16-3. 争家 | 家使用部の特性 |                                                   |  |  |  |  |  |  |
|-----------|---------|---------------------------------------------------|--|--|--|--|--|--|
| 入力検出      | 同期/非同期  | 説明                                                |  |  |  |  |  |  |
| 端         | 同期      | 事象使用部は事象端で起動され、やって来る事象がCLK_PERから生成されることを必要とします。   |  |  |  |  |  |  |
| 步而        | 非同期     | 事象使用部は事象端で起動され、非同期検出または内部同期部を持ちます。                |  |  |  |  |  |  |
| レヘッル      | 同期      | 事象使用部は事象レベルで起動され、やって来る事象がCLK_PERから生成されることを必要とします。 |  |  |  |  |  |  |
|           | 非同期     | 事象使用部は事象レベルで起動され、非同期検出または内部同期部を持ちます。              |  |  |  |  |  |  |
| 検出なし      | 非同期     | 事象使用部は事象信号を直接使います。                                |  |  |  |  |  |  |

下表はこのデバイス系統に対して利用可能な事象使用部を示します。

## 表16-4. 事象使用部

| 使用     | 部名     | 説明                             | 入力検出 | 同期/非同期  |
|--------|--------|--------------------------------|------|---------|
| 周辺機能   | 入力     | 1元19月                          | 入力検出 | 问册/ 护问册 |
| CCL    | LUTnx  | LUTn事象入力x                      | レヘッル |         |
| ADCn   | START  | 事象でのADC開始                      | 端    | 非同期     |
| EVSYS  | EVOUTx | EVSYSピン出力x                     | 検出なし |         |
| USARTn | IRDA   | USARTn IrDA事象入力                | レヘッル |         |
|        |        | 正事象端で計数                        | 端    |         |
|        | CNTA   | 両事象端で計数                        | 単面   |         |
|        | CNIA   | 事象信号がHighの間計数                  |      |         |
| TCA    |        | 事象レベルが計数方向を制御 (Low時上昇、High時下降) | レヘッル |         |
| TCAn   |        | 事象レベルが計数方向を制御 (Low時上昇、High時下降) |      |         |
|        | CNTB   | 正事象端で計数器再始動                    | 端    | 同期      |
|        | CNID   | 両事象端で計数器再始動                    | 山山   | 间旁      |
|        |        | 事象信号がHighの間再始動                 | レヘッル |         |
|        |        | 制限時間検査                         |      |         |
|        |        | 事象で計数捕獲                        |      |         |
|        | CAPT   | 計数捕獲周波数測定                      |      |         |
| TCBn   | CAPI   | 計数捕獲パルス幅測定                     | 端    |         |
|        |        | 計数捕獲周波数/パルス幅測定                 |      |         |
|        |        | 単発                             |      | 両方      |
|        | COUNT  | 事象で計数                          |      | 同期      |

#### 16.3.2.5. 同期化

事象は周辺機能クロックに対して同期または非同期のどちらかにすることができます。各事象システム チャネルは2つの副チャネル、1つの非同期副チャネルと1つの同期副チャネルを持ちます。

非同期副チャネルは生成部からの事象出力と同じです。事象生成部が周辺機能クロックに対して非同期な信号を生成する場合、非同期 副チャネル上の信号は非同期です。事象生成部が周辺機能クロックに対して同期する信号を生成する場合、非同期副チャネル上の信号も 同期になります。

事象生成部が周辺機能クロックに対して同期する信号を生成する場合、同期副チャネルは生成部からの事象出力と同じです。事象生成 部が周辺機能クロックに対して非同期な信号を生成する場合、この信号は同期副チャネルに配線される前に先立って同期化されます。 それが起きる時に依存して、同期化は2または3 クロック周期によって事象を遅らせます。事象システムは事象チャネルに対して非同期生成 部が選ばれる場合にこの同期化を自動的に実行します。

#### 16.3.2.6. ソフトウェア事象

応用はソフトウェア事象を生成することができます。チャネルn上のソフトウェア事象はソフトウェア事象(EVSYS.SWEVENTx)レシ、スタのソフトウェア事象 チャネル選択(SWEVENTxn)ビットに'1'を書くことによって発行されます。ソフトウェア事象は事象システムチャネルでパルスとして現れ、1クロック周 期間、現在の事象システム値を反転します。

事象使用部は事象を生成する周辺機能によって引き起こされるそれらと違わないものとしてソフトウェア事象を見ます。

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

構成設定されると、事象システムは全ての休止動作形態で動作します。それが周辺機能クロックを必要とするため、ソフトウェア事象は1つの 例外を示します。

非同期事象使用部はスタンバイ休止動作でそれらのクロック走行なしで事象に応答することができます。同期事象使用部は事象に応答 できるよう、動いているそれらのクロックを必要とします。このような使用部はアイバル休止動作と、適切なレシ、スタでスタンバイ時走行(RUNST DBY)ビットを設定(1)することによってスタンバイ動作で動くように構成設定された場合のスタンバイ休止動作でだけ動きます。

非同期事象生成部はそれらのクロック走行なし、即ち、スタンハイ休止動作で事象を生成することができます。同期事象生成部は事象を 生成できるよう、動いているそれらのクロックを必要とします。このような生成部はアイトル休止動作と、適切なレジスタでスタンハイ時走行(RU NSTDBY)ビットを設定(1)することによってスタンハイ動作で動くように構成設定された場合のスタンハイイホ止動作でだけ動きます。

#### 16.3.4. デバッグ動作

この周辺機能はデバッグ動作へ移行することによって影響を及ぼされません。

# 16.4. レジスタ要約

| 変位         | 略称       | ビット位置      | ビット7 | ビット6   | ビット5 | ビット4  | <b>ビット3</b> | <b>ビット2</b> | <b>ビット1</b> | ビットロ |
|------------|----------|------------|------|--------|------|-------|-------------|-------------|-------------|------|
| +\$00      | SWEVENTA | 7~0        |      |        |      | SWEVE | NTA7~0      | 1           | 1           |      |
| +\$01      | 予約       |            |      |        |      |       |             |             |             |      |
| +\$0F      | 1^ ምህ    |            |      |        |      |       |             |             |             |      |
| +\$10      | CHANNEL0 | 7~0        |      | ,<br>, |      | CHAN  | NEL7~0      | 1           | 1           |      |
| +\$11      | CHANNEL1 | $7 \sim 0$ |      | 1      | 1    | CHAN  | NEL7~0      | 1           | 1           |      |
| +\$12      | CHANNEL2 | $7 \sim 0$ |      | 1      | 1    | CHAN  | NEL7~0      | 1           | 1           |      |
| +\$13      | CHANNEL3 | $7 \sim 0$ |      | 1      | 1    | CHAN  | NEL7~0      | 1           |             |      |
| +\$14      | CHANNEL4 | $7 \sim 0$ |      | 1      | 1    | CHAN  | NEL7~0      | 1           | 1           |      |
| +\$15      | CHANNEL5 | 7~0        |      | 1      | 1    | CHAN  | NEL7~0      |             | 1           |      |
| +\$16<br>~ | 予約       |            |      |        |      |       |             |             |             |      |
| +\$1F      | ] ^      |            |      |        |      |       |             |             |             |      |
| +\$20      | USER0    | 7~0        |      | 1      | 1    | USEF  | 7~0         |             | 1           |      |
| $\sim$     | $\sim$   | $\sim$     |      | 1      | 1    | ~     | ~           |             | 1           |      |
| +\$3D      | USER29   | 7~0        |      | 1      |      | USEF  | ₹7~0        | 1           | 1           | 1    |

## 16.5. レジスタ説明

# 16.5.1. SWEVENTx - ソフトウェア事象 (Software Events)

**名称**:SWEVENTA

変位 : +\$00

リセット : \$00

特質 :-

対応する事象チャネルでソフトウェア事象を生成するにはこのレジスタのビットに'1'を書いてください。EVSYS.SWEVENTAレジスタのビット7~0 は事象チャネル7~0(訳補:本デバイスは5~0)に対応します。利用可能な事象チャネルの番号が8~15(訳補:本デバイスはなし)の場合、それ らはビットnが事象チャネル8+nであるEVSYS.SWEVENTBレジスタで利用可能です。

利用可能な事象システムチャネル数については「周辺機能概要」項を参照してください。

| ビット    | 7           | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|--------|-------------|---|---|---|---|---|---|---|--|--|
|        | SWEVENTx7~0 |   |   |   |   |   |   |   |  |  |
| アクセス種別 | W           | W | W | W | W | W | W | W |  |  |
| リセット値  | 0           | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |

#### • ビット7~0 - SWEVENTx7~0: ソフトウェア事象チャネル選択 (Software Event Channel Select)

このビット群のビットへの'1'書き込みは1周辺機能クロック周期間、事象チャネル上の信号を反転することによって対応する事象チャネルで単 一パルス事象を生成します。

## 16.5.2. CHANNELn - チャネルn生成部選択 (Channel n Generator Selection)

名称 : CHANNELn

**変位** : +\$10+n [n=0~5]

リセット : \$00

# 特質 :-

各チャネルは1つの事象生成部に接続することができます。全ての生成部が全てのチャネルに接続できる訳ではありません。どの生成部 供給元が各チャネルに配線することができ、この配線を達成するのにEVSYS.CHANNELnに書かれるべき生成部値を知るには下表を参 照してください。EVSYS.CHANNELnへの値\$00書き込みはそのチャネルをOFFにします。

利用可能な事象システムチャネル数については「周辺機能概要」項を参照してください。

| ビット    | 7          | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|------------|-----|-----|-----|-----|-----|-----|-----|--|--|
|        | CHANNEL7~0 |     |     |     |     |     |     |     |  |  |
|        |            |     |     |     |     |     |     |     |  |  |
| アクセス種別 | R/W        | R/W | R/W | R/W | R/W | R/W | R/W | R/W |  |  |

● ビット7~0 - CHANNEL7~0 : チャネル生成部選択 (Channel Generator Selection)

各ビット群構成設定に対応する指定生成部名は次表からの周辺機能と出力を「周辺機能」出力」のように結合することによって与えられます。

| 生成部          |                           |                  |            |                                                    |                          |
|--------------|---------------------------|------------------|------------|----------------------------------------------------|--------------------------|
| 値            | 名                         |                  | 同期/<br>非同期 | 説明                                                 | チャネル可用性                  |
|              | 周辺機能                      | 出力               | 261-1201   |                                                    |                          |
| \$01         | UPDI                      | SYNCH            |            | 同期(SYNCH)文字検出の上昇端                                  |                          |
| \$06         |                           | OVF              |            | 計数器溢れ                                              |                          |
| \$07         | RTC                       | CMP              |            | 比較一致                                               |                          |
| \$08         |                           | EVGEN0           |            | 選択可能な前置分周したRTC事象                                   |                          |
| \$09         |                           | EVGEN1           |            |                                                    |                          |
| \$10         |                           | LUT0             | 非同期        |                                                    | 全チャネル                    |
| \$11         | CCL                       | LUT1             |            | LUT出力レベル                                           |                          |
| \$12         |                           | LUT2             |            |                                                    |                          |
| \$13         | 1.00                      | LUT3             |            |                                                    | _                        |
| \$20         | AC0                       | OUT              |            | 比較器出力レベル                                           |                          |
| \$21         | AC1                       |                  |            |                                                    |                          |
| \$24         |                           | RES              | (III) +++n | 結果準備可 经 (1) (2) (2) (2) (2) (2) (2) (2) (2) (2) (2 | At the (2)               |
| \$25         | ADC0                      | SAMP             | 同期         | 採取(試料)準備可<br>突比較                                   | 全チャネル( <mark>注</mark> 1) |
| \$26         |                           | WCMP             |            | 窓比較一致                                              |                          |
| \$40         | PORTA                     | EVGEN0           |            |                                                    |                          |
| \$41         |                           | EVGEN1           |            |                                                    |                          |
| \$42<br>\$43 | PORTB ( <mark>注1</mark> ) | EVGEN0<br>EVGEN1 |            |                                                    |                          |
| \$43         |                           | EVGEN1<br>EVGEN0 |            |                                                    |                          |
| \$45         | PORTC                     | EVGEN0<br>EVGEN1 |            |                                                    |                          |
| \$46         |                           | EVGEN1<br>EVGEN0 | 非同期        | ピン レヘブル ( <b>注2</b> )                              |                          |
| \$47         | PORTD                     | EVGEN0           |            |                                                    |                          |
| \$48         |                           | EVGEN0           |            |                                                    |                          |
| \$49         | PORTE (注1)                | EVGEN1           |            |                                                    |                          |
| \$4A         |                           | EVGEN0           |            |                                                    |                          |
| \$4B         | PORTF                     | EVGEN1           |            |                                                    |                          |
| \$60         | USART0                    |                  |            |                                                    |                          |
| \$61         | USART1                    | ХСК              |            | SPI主装置動作と同期USART主装置動作でのクロック信号                      |                          |
| \$62         | USART2 (注1)               |                  |            |                                                    |                          |
| \$68         | SPI0                      | SCK              |            | SPI主装置クロック信号                                       |                          |
| \$80         |                           | OVF <u>L</u> UNF |            | 溢れ/下位バ小計時器下溢れ                                      | 人士,中国                    |
| \$81         |                           | HUNF             |            | 上位バイト計時器下溢れ                                        | 全チャネル                    |
| \$84         | TCA0                      | CMP0_LCMP0       |            | 比較チャネル0一致/下位バイト計時器比較チャネル0一致                        |                          |
| \$85         |                           | CMP1_LCMP1       |            | 比較チャネル1一致/下位バイト計時器比較チャネル1一致                        |                          |
| \$86         |                           | CMP2_LCMP2       |            | 比較チャネル2一致/下位バイト計時器比較チャネル2一致                        |                          |
| \$88         |                           | OVF_LUNF         |            | 溢れ/下位バイト計時器下溢れ                                     |                          |
| \$89         |                           | HUNF             | 同期         | 上位バイ計時器下溢れ                                         |                          |
| \$8C         | TCA1                      | CMP0_LCMP0       | 1.1541     | 比較チャネル0一致/下位バイ計時器比較チャネル0一致                         |                          |
| \$8D         |                           | CMP1_LCMP1       |            | 比較チャネル1一致/下位バイ計時器比較チャネル1一致                         |                          |
| \$8E         |                           | CMP2_LCMP2       |            | 比較チャネル2一致/下位バイ計時器比較チャネル2一致                         |                          |
| \$A0         | ТСВ0                      | CAPT             |            | CAPT割り込み要求フラグ設定(1)(注3)                             |                          |
| \$A1         |                           | OVF              |            | 計数器溢れ                                              |                          |
| \$A2         | TCB1                      | CAPT             |            | CAPT割り込み要求フラグ設定(1)(注3)                             |                          |
| \$A3         |                           | OVF              |            | 計数器溢れ                                              |                          |
| \$A4         | TCB2                      | CAPT             |            | CAPT割り込み要求7ラグ設定(1) (注3)                            |                          |
| \$A5         |                           | OVF              |            | 計数器溢れ                                              |                          |
| \$A6         | TCB3                      | CAPT             |            | CAPT割り込み要求7ラグ設定(1)(注3)                             |                          |
| \$A7         |                           | OVF              |            | 計数器溢れ                                              |                          |

注1: 全ての周辺機能の実体が全てのピン数で利用可能な訳ではありません。詳細については「周辺機能と基本構造」章を参照してください。 注2: ポート ピンからの事象は入力駆動部が禁止されている場合に'0'です。

注2. 小「トレンパロジー争家は八刀船動即か赤正さんししい」の場面にしてす。

注3: 計時器の動作形態がCAPTフラグを掲げる時を決めます。詳細については「TCB」章を参照してください。

16.5.3. USERn - 使用部nチャネル多重器 (User Channel Mux)

名称 : USERn 変位 : +\$20+n [n=0~29] リセット : \$00 特質 : -

各事象使用部は1つの事象チャネルに接続することができ、いくつかの使用部を同じチャネルに接続することができます。次表はそれらの 対応する使用部ID番号と名称と共に全ての事象システム使用部を一覧にします。使用部名称は次表からの周辺機能と入力と共に USERを「USER周辺機能入力」のように結合することによって与えられます。

| 使用部        | 使用                       | 部名称                        |        | = 1 = 2                          |
|------------|--------------------------|----------------------------|--------|----------------------------------|
| 番号         | 周辺機能                     | 入力                         | 同期/非同期 | 説明                               |
| 0 (\$0)    |                          | LUT0A                      |        | CCL LUT0事象入力A                    |
| 1 (\$1)    |                          | LUT0B                      |        | CCL LUT0事象入力B                    |
| 2 (\$2)    |                          | LUT1A                      |        | CCL LUT1事象入力A                    |
| 3 (\$3)    | CCL                      | LUT1B                      | 非同期    | CCL LUT1事象入力B                    |
| 4 (\$4)    | CCL                      | LUT2A                      | 外间旁    | CCL LUT2事象入力A                    |
| 5 (\$5)    |                          | LUT2B                      |        | CCL LUT2事象入力B                    |
| 6 (\$6)    |                          | LUT3A                      |        | CCL LUT3事象入力A                    |
| 7 (\$7)    |                          | LUT3B                      |        | CCL LUT3事象入力B                    |
| 8 (\$8)    | ADC0                     | START                      |        | 事象でADC開始                         |
| 9 (\$9)    |                          | EVOUTA                     |        | 事象出力(ピン出力)A                      |
| 10 (\$A)   |                          | EVOUTB ( <mark>注1</mark> ) |        | 事象出力(ピン出力)B                      |
| 11 (\$B)   | EVSYS                    | EVOUTC                     | _      | 事象出力(ピン出力)C                      |
| 12 (\$C)   | EVSIS                    | EVOUTD                     |        | 事象出力(ピン出力)D                      |
| 13 (\$D)   |                          | EVOUTE ( <mark>注1</mark> ) |        | 事象出力(ピン出力)E                      |
| 14 (\$E)   |                          | EVOUTF ( <mark>注1</mark> ) |        | 事象出力(ピン出力)F                      |
| 15 (\$F)   | USART0                   |                            |        | USARTO IrDA事象入力                  |
| 16 (\$10)  | USART1                   | IRDA                       |        | USART1 IrDA事象入力                  |
| 17 (\$11)  | USART2 (注1)              |                            |        | USART2 IrDA事象入力                  |
| 18 (\$12)  | TCA0                     | CNTA                       | 同期     | 事象の正端/両端/Highでの計数または事象レヘルが計数方向制御 |
| 19 (\$13)  | ICAU                     | CNTB                       |        | 事象の両端/Highでの再始動または事象レベルが計数方向制御   |
| 20 (\$14)  | TCA1 ( <mark>注1</mark> ) | CNTA                       |        | 事象の正端/両端/Highでの計数または事象レベルが計数方向制御 |
| 21 (\$15)  |                          | CNTB                       |        | 事象の両端/Highでの再始動または事象レベルが計数方向制御   |
| 22 (\$16)  |                          | CAPT                       | 両方     | 単発動作                             |
|            | TCB0                     | CAFI                       | 同期     | 単発動作以外の動作                        |
| 23 (\$17)  |                          | COUNT                      |        | 事象で計数                            |
| 24 (\$18)  |                          | CAPT                       | 両方     | 単発動作                             |
|            | TCB1                     |                            | 同期     | 単発動作以外の動作                        |
| 25 (\$19)  |                          | COUNT                      |        | 事象で計数                            |
| 26 (\$1A)  |                          | CAPT                       | 両方     | 単発動作                             |
|            | TCB2                     | UAF I                      | 同期     | 単発動作以外の動作                        |
| 27 (\$1B)  |                          | COUNT                      |        | 事象で計数                            |
| -28 (\$1C) |                          | CAPT                       | 両方     | 単発動作                             |
|            | TCB3 ( <mark>注1</mark> ) |                            | 同期     | 単発動作以外の動作                        |
| 29 (\$1D)  |                          | COUNT                      | 162191 | 事象で計数                            |

**注1**: 全ての周辺機能実体が全てのピン数に対して利用可能な訳ではありません。詳細については「周辺機能と基本構造」章を参照してください。

| ビット    | 7       | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|---------|-----|-----|-----|-----|-----|-----|-----|--|--|
|        | USER7~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 - CHANNEL7~0: 使用部チャネル選択 (User Channel Selection)

使用部がどの事象システムチャネルに接続するかを構成設定します。

| 値  | 0                        | 1∼6 (= n)             | その他  |
|----|--------------------------|-----------------------|------|
| 説明 | OFF、チャネルはこの事象システム使用部に未接続 | 事象使用部はチャネルn-1に接続されます。 | (予約) |

# 17. PORTMUX - ポート多重器

# 17.1. 概要

ポート多重器(PORTMUX)はピンの機能を許可または禁止、または既定と代替のピン位置の変更のどちらも行うことができます。利用可能な任意選択はPORTMUXレジスタ配置で詳細に記述され、実際のピンと特性に依存します。 利用可能なピンと機能については「入出力多重化と考察」章を参照してください。

# 17.2. レジスタ要約

| 変位    | 略称          | ビット位置      | ビット7 | ビット6 | ビット5   | ビット4    | ビット3   | ビット2    | ビット1      | ビットロ   |
|-------|-------------|------------|------|------|--------|---------|--------|---------|-----------|--------|
| +\$00 | EVSYSROUTEA | $7 \sim 0$ |      |      | EVOUTF | EVOUTE  | EVOUTD | EVOUTC  | EVOUTB    | EVOUTA |
| +\$01 | CCLROUTEA   | $7 \sim 0$ |      |      |        |         | LUT3   | LUT2    | LUT1      | LUT0   |
| +\$02 | USARTROUTEA | $7 \sim 0$ |      |      |        | USAR    | RT11,0 |         | USART02~0 |        |
| +\$03 | USARTROUTEB | $7 \sim 0$ |      |      |        |         |        |         | USART     |        |
| +\$04 | 予約          |            |      |      |        |         |        |         |           |        |
| +\$05 | SPIROUTEA   | $7 \sim 0$ |      |      |        |         |        |         | SPI02~0   |        |
| +\$06 | TWIROUTEA   | $7 \sim 0$ |      |      |        |         |        |         | TWI01,0   |        |
| +\$07 | TCAROUTEA   | $7 \sim 0$ |      |      |        | TCA12~0 | 1      | TCA02~0 |           |        |
| +\$08 | TCBROUTEA   | 7~0        |      |      |        |         | TCB3   | TCB2    | TCB1      | TCB0   |
| +\$09 | 予約          |            |      |      |        |         |        |         |           |        |
| +\$0A | ACROUTEA    | 7~0        |      |      |        |         |        |         | AC1       | AC0    |

17.3. レジスタ説明(訳注:本項の各表などは可能な限り各々の共通部分を纏めました。)

# 17.3.1. EVSYSROUTEA - 事象システム ピン位置 (Event System Pin Position)

名称: EVSYSROUTEA

**変位** : +\$00

# リセット : \$00

# 特質:-

| <u>ـــــــــــــــــــــــــــــــــــ</u> | 7 | 6 | 5      | 4      | 3      | 2      | 1      | 0      |
|--------------------------------------------|---|---|--------|--------|--------|--------|--------|--------|
|                                            |   |   | EVOUTF | EVOUTE | EVOUTD | EVOUTC | EVOUTB | EVOUTA |
| アクセス種別                                     | R | R | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |
| リセット値                                      | 0 | 0 | 0      | 0      | 0      | 0      | 0      | 0      |

#### ● ビット5,3,0 - EVOUTx : 事象出力x (Event Output x)

これらのビットは事象出力x用ピン位置を制御します。(訳補:事象出力xの既定はポートxの2番ピン、代替はポートxの7番ピン)

| 值  | 0                                        | 1                                      |  |  |  |  |
|----|------------------------------------------|----------------------------------------|--|--|--|--|
| 名称 | DEFAULT                                  | ALT1                                   |  |  |  |  |
| 説明 | F:PF2, E:PE2, D:PD2, C:PC2, B:PB2, A:PA2 | F:PF7, E:なし, D:PD7, C:PC7, B:なし, A:PA7 |  |  |  |  |

## 17.3.2. CCLROUTEA - CCL LUTnL<sup>°</sup>ン位置 (CCL LUTn Pin Position)

| 名称: | : | CCLROUTEA |
|-----|---|-----------|
|-----|---|-----------|

| 変位 : +\$ | 01 |
|----------|----|
|----------|----|

リセット : \$00

# 特質 :-

| ヒット    | 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|--------|---|---|---|---|------|------|------|------|
|        |   |   |   |   | LUT3 | LUT2 | LUT1 | LUT0 |
| アクセス種別 | R | R | R | R | R/W  | R/W  | R/W  | R/W  |
| リセット値  | 0 | 0 | 0 | 0 | 0    | 0    | 0    | 0    |

## ● ビット2~0 - LUTn : CCL LUTn信号 (CCL LUTn Signals) (訳補:LUT3~0はポートF,D,C,Aに対応)

これらのビットはCCL LUTn信号用ピン位置を制御します。

| 値    |     | 0                          | 1                         |  |  |  |
|------|-----|----------------------------|---------------------------|--|--|--|
| 名称   |     | DEFAULT                    | ALT1                      |  |  |  |
|      | IN2 | 3:PF2, 2:PD2, 1:PC2, 0:PA2 | 3:なし, 2:PD2, 1:PC2, 0:PA2 |  |  |  |
| 説明   | IN1 | 3:PF1, 2:PD1, 1:PC1, 0:PA1 | 3:なし、2:PD1、1:PC1、0:PA1    |  |  |  |
| 市市中日 | IN0 | 3:PF0, 2:PD0, 1:PC0, 0:PA0 | 3:なし, 2:PD0, 1:PC0, 0:PA0 |  |  |  |
|      | OUT | 3:PF3, 2:PD3, 1:PC3, 0:PA3 | 3:なし, 2:PD6, 1:PC6, 0:PA6 |  |  |  |

## 17.3.3. USARTROUTEx - USARTnピン位置 (USARTn Pin Position)

| 名称 : USARTRO<br>変位 : +\$02<br>リセット : \$00<br>特質 : - |   | USARTROUTI<br>+\$03 | ΞB |      |       |     |           |       |
|-----------------------------------------------------|---|---------------------|----|------|-------|-----|-----------|-------|
| <b>ビット</b>                                          | 7 | 6                   | 5  | 4    | 3     | 2   | 1         | 0     |
| USARTRUTEA                                          |   |                     |    | USAR | T11,0 |     | USART02~0 |       |
| アクセス種別                                              | R | R                   | R  | R/W  | R/W   | R/W | R/W       | R/W   |
| リセット値                                               | 0 | 0                   | 0  | 0    | 0     | 0   | 0         | 0     |
|                                                     |   |                     |    |      |       |     |           |       |
| נ <sup>י</sup> אַר                                  | 7 | 6                   | 5  | 4    | 3     | 2   | 1         | 0     |
| USARTRUTEB                                          |   |                     |    |      |       |     | USAR      | T21,0 |
| アクセス種別                                              | R | R                   | R  | R    | R     | R   | R/W       | R/W   |
| リセット値                                               | 0 | 0                   | 0  | 0    | 0     | 0   | 0         | 0     |
|                                                     |   |                     |    |      |       |     |           |       |

● ビット4,3,2~0 - USARTn1,0/2~0: USARTn信号 (USART n Signals) (訳補:USART2~0の基本はホートF,C,Aに対応) これらのビット領域はUSARTn信号用ピン位置を制御します。

|    | 値  |      | 00/000              | 01/001              | 10/010               | 11/011            | 100                               | その他      |
|----|----|------|---------------------|---------------------|----------------------|-------------------|-----------------------------------|----------|
| 名称 |    | 尓    | DEFAULT             | ALT1                | - / ALT2             | NONE / ALT3       | ALT4                              | NONE     |
|    |    | TxD  | 2:PF0, 1:PC0, 0:PA0 | 2:PF4, 1:PC4, 0:PA4 | 2:(予約), 1:PD6, 0:PA2 | 2:なし, 1:なし, 0:PD4 | 2:×, 1:×, 0:PC1                   | . °.     |
|    | 説明 | RxD  | 2:PF1, 1:PC1, 0:PA1 | 2:PF5, 1:PC5, 0:PA5 | 2:(予約), 1:PD7, 0:PA3 | 2:なし, 1:なし, 0:PD5 | $2:\times$ , $1:\times$ , $0:PC2$ | ピン<br>接続 |
|    |    | XCK  | 2:PF2, 1:PC2, 0:PA2 | 2:なし、1:PC6、0:PA6    | 2:(予約), 1:なし, 0:なし   | 2:なし, 1:なし, 0:PD6 | $2:\times$ , $1:\times$ , $0:PC3$ | なし       |
|    |    | XDIR | 2:PF3, 1:PC3, 0:PA3 | 2:なし、1:PC7、0:PA7    | 2:(予約), 1:なし, 0:なし   | 2:なし、1:なし、0:PD7   | 2:×, 1:×, 0:なし                    |          |

# 17.3.4. SPIROUTEA - SPInLン位置 (SPIn Pin Position)

名称:SPIROUTEA

**変位** : +\$05

リセット : \$00

特質 :-

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

## • ビット3~0 - SPI01,0 : SPI0信号 (SPI 0 Signals)

これらのビット領域はSPI0用ピン位置を制御します。

|    | 値  |      | 000     | 001  | 010     | 011  | 100  | 101  | 110  | 111    |
|----|----|------|---------|------|---------|------|------|------|------|--------|
| 名称 |    | Υ.   | DEFAULT | ALT1 | -       | ALT3 | ALT4 | ALT5 | ALT6 | NONE   |
|    |    | MOSI | PA4     | PE0  | (マ (4)) | PA0  | PD4  | PC0  | PC1  |        |
| =∺ |    | MISO | PA5     | PE1  |         | PA1  | PD5  | PC1  | PC2  |        |
| 市尤 | ,明 | SCK  | PA6     | PE2  | (予約)    | PC0  | PD6  | PC2  | PC3  | ピン接続なし |
|    |    | SS   | PA7     | PE3  |         | PC1  | PD7  | PC3  | PF7  |        |

# 17.3.5. TWIROUTEA - TWInビン位置 (TWIn Pin Position)

名称: TWIROUTEA

**変位** : +\$06

リセット : \$00

特質:-

| ヒット    | 7 | 6 | 5 | 4 | 3 | 2 | 1       | 0   |
|--------|---|---|---|---|---|---|---------|-----|
|        |   |   |   |   |   |   | TW[01,0 |     |
| アクセス種別 | R | R | R | R | R | R | R/W     | R/W |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0       | 0   |

# • ビット3~0 - TWI01,0 : TWI0信号 (TWI 0 Signals)

これらのビット領域はTWI0用ピン位置を制御します。

|  | 値  |     | 0 0     | 01                    | 10                    | 11      |
|--|----|-----|---------|-----------------------|-----------------------|---------|
|  | 名称 |     | DEFAULT | ALT1                  | ALT2                  | ALT3    |
|  | 説明 | SDA | PA2/PC2 | PA2/ <mark>PC6</mark> | PC2/ <mark>PC6</mark> | PA0/PC2 |
|  |    | SCL | PA3/PC3 | PA3/PC7               | PC3/PC7               | PA1/PC3 |

(訳注)各ピン名の記載は(標準動作の主/従装置または2元動作の主装置のピン)/(2元動作の従装置のピン)です。

# 17.3.6. TCAROUTEA - TCAnL°ン位置 (TCAn Pin Position)

| 変位 | : TCAROUTEA<br>: +\$07<br>: \$00<br>: - |  |
|----|-----------------------------------------|--|
|    | ビット 7                                   |  |
|    |                                         |  |

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

## • ビット5~3,2~0 - TCAn2~0 : TCAn信号 (TCAn Signals)

これらのビット領域はTCAn用ピン位置を制御します。

|    | TCA1 值         | 0 0 0                   | 001               | 100               | 101               | その他  |  |  |  |
|----|----------------|-------------------------|-------------------|-------------------|-------------------|------|--|--|--|
|    | 名称             | PORTB                   | PORTC             | PORTA             | PORTD             | _    |  |  |  |
|    | 説明             | PB0,PB1,PB2,PB3,PB4,PB5 | PC4,PC5,PC6,-,-,- | PA4,PA5,PA6,-,-,- | PD4,PD5,PD6,-,-,- | (予約) |  |  |  |
| (= | $(\mathbf{n})$ |                         |                   |                   |                   |      |  |  |  |

(訳注) 左からWO0,WO1,WO2,WO3,WO4,WO5の順で、PORTA,PORTC,PORTDのWO3,WO4,WO5は存在しません。

| TCA0 值                                                     | 0 0 0                                                        | 001   | 010   | 011   | 100   | 101   | その他 |  |  |
|------------------------------------------------------------|--------------------------------------------------------------|-------|-------|-------|-------|-------|-----|--|--|
| 名称                                                         | PORTA                                                        | PORTB | PORTC | PORTD | PORTE | PORTF | -   |  |  |
| 説明                                                         | 説明 PAn=WOn PBn=WOn PCn=WOn PDn=WOn PEn=WOn (訳注) PFn=WOn (予約) |       |       |       |       |       |     |  |  |
| (訳注) 基本的にPx0=WO0、Px1=WO1、以下同様に対応しますが、PORTEのWO4とWO5は存在しません。 |                                                              |       |       |       |       |       |     |  |  |

## 17.3.7. TCBROUTEA - TCBntン位置 (TCBn Pin Position)

| 名称 | : TCBROUTEA |
|----|-------------|
| 名称 | : TCBROUTEA |

**変位**:+\$08

リセット : \$00

特質 :-

| ビット    | 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|--------|---|---|---|---|------|------|------|------|
|        |   |   |   |   | TCB3 | TCB2 | TCB1 | TCB0 |
| アクセス種別 | R | R | R | R | R/W  | R/W  | R/W  | R/W  |
| リセット値  | 0 | 0 | 0 | 0 | 0    | 0    | 0    | 0    |

## • ビット4~0 - TCBn: TCBn出力 (TCBn Output)

これらのビットはTCBn出力用ピン位置を制御します。

| 值  | 0                          | 1                          |
|----|----------------------------|----------------------------|
| 名称 | DEFAULT                    | ALT1                       |
| 説明 | 3:PB5, 2:PC0, 1:PA3, 0:PA2 | 3:PC1, 2:PB4, 1:PF5, 0:PF4 |

## 17.3.8. ACROUTEA - ACnL<sup>°</sup>ン位置 (ACn Pin Position)

| 名称 | : ACROUTEA |
|----|------------|
|----|------------|

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

# 特質 :-

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

#### • ビット1,0 - ACn : ACn出力 (Analog Comparator n Output)

このビット領域はACn出力用ピン位置を制御します。

| 値  | 0            | 1            |
|----|--------------|--------------|
| 名称 | DEFAULT      | ALT1         |
| 説明 | 1:PA7, 0:PA7 | 1:PC6, 0:PC6 |

# 18. PORT - I/Oピン構成設定

# 18.1. 特徴

- ・個別構成設定を持つ汎用入出力ピン
  - プルアッフ゜
  - 反転I/O
- 入力電圧閾値
- ・割り込みと事象を持つ入力
  - 両端感知
  - 上昇端感知
  - 下降端感知
  - Lowレヘル感知
- ・ホート毎の任意選択スリューレート制御
- ・全休止動作形態からデバイスを起き上がらせることができる非同期ピン変化感知
- ・ポートピンへの効率的で安全なアクセス
  - 専用の切り換え、解除(0)、設定(1)用レジスタ通したハートウェア読み-変更-書き(RMW)
  - ビットアクセス可能なI/Oメモリ空間への度々使われるポートレジスタ割り当て(仮想ポート)

## 18.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ピン構成設定は他のデバイス機能の入力と出力の選択も制御します。

## 18.2.1. 構成図



## 18.2.2. 信号説明

| 信号  | 形式  | 説明           |  |
|-----|-----|--------------|--|
| Pxn | 入出力 | PORTxのn入出力ピン |  |

# 18.3. 機能的な説明

## 18.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ピンに対して個別ピン構成設定と割り込み制御を構成設定してください。

**重要:**最低消費電力のため、未使用ピンとアナログ入力または出力として使われるピンのデジタル入力緩衝部を禁止してください。 許可されたデジタル入力緩衝部を持つピンについては可能な限り素早いHighとLowの電圧閾値間遷移が推奨されます。

デバッガに接続するのに使われるそれらのような特定ピンは、それらの特殊機能によって必要とされるため、違う様に構成設定されるでしょう。

#### 18.3.2. 動作

**>** 

#### 18.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でそのビットを切り替え、対応するピンの方向を切り替えます。

## 18.3.2.2. ポート構成設定

ピンn制御(PORTx.PINnCTRL)レジスタは全てのPORTxピンに対するスリューレート制限を制御します。

スリューレート制限はPORTx.CTRLのスリューレート制限許可(SRL)ビットに'1'を書くことによって許可されます。更なる詳細については「電気的特性」章を参照してください。

#### 18.3.2.3. ピン構成設定

ピンの反転I/O、プルアップ、入力感知を構成設定するのにピンn制御(PORTx.PINnCTRL)レジスタを使ってください。ピンn用の制御レジスタ はハイトアトレスのPORTx+\$10+nです。

各々のn番ピンの全ての入力と出力はPORTx.PINnCTRLの反転I/O許可(INVEN)ビットに'1'を書くことによって反転することができます。INVENが'1'の時は、このピンに対してPORTx.IN/OUT/OUTSET/OUTCLRレジスタが反転操作になります。

INVENビットの交互切り替えは、このピンを使う全ての周辺機能によって検出することができるピンでの変化端(エッシゾ)を引き起こし、許可されていれば割り込みまたは事象によって見られます。

PORTx.PINnCTRLの入力基準選択(INLVL)ビットはピンnに対する入力電圧閾値を制御します。供給電圧から導き出したシュミットトリカ 閾値またはTTL基準の選択が利用可能です。

入力閾値はPORTx.INレジスタのビットnの値を決めるのと、機能が許可されていれば割り込み状態を起こす基準でも重要です。

ピンnの入力プルアップはPORTx.PINnCTRLのプルアップ許可(PULLUPEN)ビットに'1'を書くことによって許可されます。プルアップは例え PULLUPENビットが'1'でも、ピンが出力として構成設定されると、切断されます。

ピン割り込みはPORTx.PINnCTRLの入力/感知構成設定(ISC)ビット領域に書くことによってピンnに対して許可されます。更なる詳細については「18.3.3.割り込み」を参照してください。

ビンn用のデジタル入力緩衝部はISCビット領域にINPUT\_DISABLE設定を書くことによって禁止することができます。これは消費電力を 減らしてピンがアナログ入力として使われる場合に雑音を減らすでしょう。INPUT\_DISABLEに構成設定されている間、PORTx.INのビットn は入力同期部が禁止されるため変わりません。

#### 18.3.2.4. 複数ピン構成設定

複数ピン構成設定機能は1操作で複数のポートピンを構成設定できます。先に望むピンの構成設定が複数ピン構成設定(PORTx.PINC ONFIG)レジスタに書かれ、選んだ変更するピンでの複数ピン制御系(PORTx.PINCTRLUPD/SET/CLR)レジスタ書き込みが後続し、1度の書き込みで8つまでのピンに対する構成設定(PORTx.PINnCTRL)変更を許します。

助言: PORTx.PINCONFIGレジスタは全てのポートに反映され、複数ポートに渡る単一設定の使用を許します。PORTx.PINCTRL UPD/SET/CLR)ジスタは反映されず、構成設定は各ポートに対して書かれなければなりません。

複数ピン構成設定に対して、ポート ピンは以下のレジスタへの書き込みによって構成設定して変更することができます。

| <b>耒18-1</b> | 複数ピン構成設定レジスタ |  |
|--------------|--------------|--|
| 1210 1.      | 夜奴しノ曲ル収にレノヘノ |  |

| レジスタ             | 説明                                                             |
|------------------|----------------------------------------------------------------|
| PORTx.PINCONFIG  | 複数のPINCTRLレジスタへ同時構成設定準備のためPINnCTRL(ISC,PULLUPEN,INLVL,INVEN)設定 |
| PORTx.PINCTRLUPD | PINCTRLUPDレジスタビットへの'1'書き込みがPINCONFIGレジスタ内容をPINnCTRLレジスタに複写。    |
|                  | PINCTRLSETレジスタのビットへの'1'書き込みはPINCONFIGレジスタで'1'に設定されたビットに従ってPIN  |
| (注1)             | nCTRLレジスタの個別ビットを設定(1)します。                                      |
| PORTx.PINCTRLCLR | PINCTRLCLRレジスタのビットへの'1'書き込みはPINCONFIGレジスタで'1'に設定されたビットに従ってPIN  |
| ( <b>注2</b> )    | nCTRLレジスタの個別ビットを解除(0)します。                                      |

注1:0でないISCビット領域の構成設定にPINCTRLSETを使うと、PINCONFIGとPINnCTRLのレジスタでのビット単位論理和(OR)になります。これは予期せぬ設定を与えるかもしれません。

**注2**: 0でないISCビット領域の構成設定にPINCTRLCLRを使うと、PINCONFIGとPINnCTRLのレジスタでのビット単位反転論理積(AN D)になります。これは予期せぬ設定を与えるかもしれません。

以下のコートが断片は数個のポートの複数PINnCTRLレジスタ構成設定法を実演します。PINCONFIGレジスタが全てのポートに渡って反映されるため、この例ではポートAに1度書くだけで充分なことに注意してください。

PORTA. PINCONFIG = PORT\_ISC\_INPUT\_DISABLE\_gc; /\* PINnCTRLレジスタへ設定するための設定 \*/ PORTA. PINCTRLUPD = 0xff; PORTB. PINCTRLUPD = 0xff; PORTC. PINCTRLUPD = 0xff; PORTD. PINCTRLUPD = 0xff; PORTE. PINCTRLUPD = 0xff;

#### 18.3.2.5. 仮想ポート

仮想ポート レジスタは最も頻繁に使われる通常のポート レジスタを単一周期ビット アクセスを持つI/Oレジスタ空間に割り当てます。 仮想ポート レ ジスタへのアクセスは普通のレジスタへのアクセスと同じ結果を持ち、通常のポート ま18-2 仮想ポートルルレ当て

レジスタが属す拡張I/Oレジスタ空間で使うことができないビット操作命令のよう なメモリ特定命令を許します。右表はPORTとVPORTのレジスタ間の割り当て を示します。

注:通常のPORTレジスタのアクセス直後に単一周期I/O命令を使って割り当 てられたVPORTレジスタをアクセスするのを避けてください。これは単一周 期I/O命令アクセスが通常のPORTレジスタアクセスよりも速いためメモリ衝突 を起こすかもしれません。

| 表18-2. 仮想ボート割り当て |                  |  |  |  |
|------------------|------------------|--|--|--|
| 通常ポート レジスタ       | 割り当てられる仮想ポートレジスタ |  |  |  |
| PORTx.DIR        | VPORTx.DIR       |  |  |  |
| PORTx.OUT        | VPORTx.OUT       |  |  |  |
| PORTx.IN         | VPORTx.IN        |  |  |  |
| PORTx.INTFLAGS   | VPORTx.INTFLAGS  |  |  |  |

#### 18.3.2.6. 周辺機能優先

USART、ADC、計時器のような周辺機能は入出力ピンに接続されるでしょう。このような周辺機能は通常、ポート多重器(PORTMUX)またはその周辺機能内の多重器よって選択可能な基本と任意選択の1つ以上の代替入出力ピン接続を持ちます。このような周辺機能を構成設定して許可することにより、I/Oピン構成設定(PORT)によって制御される通常の汎用入出力ピンの動きは周辺機能に依存する方法で覆されます。いくつかの周辺機能はPORTレジスタの全てを覆さないかもしれず、入出力ピン操作のいくつかの面の制御をPORT単位部に残します。

周辺機能優先の情報については各周辺機能の記述を参照してください。周辺機能によって覆されないポートのどのピンも汎用入出力 ピンとしての動作を続けます。

#### 18.3.3. 割り込み

#### 表18-3.利用可能な割り込みべりタと供給元

| 名称    | ベクタ説明 | 条件                                                                         |
|-------|-------|----------------------------------------------------------------------------|
| PORTx |       | PORTx.INTFLAGSのINTnはPORTx.PINnCTRLの入力/感知構成設定(ISC)ビットによって構成設定されるとおりに掲げられます。 |

各PORTビンnは割り込み元として構成設定することができます。各割り込みはビンn制御(PORTx.PINnCTRL)レジスタの入力/感知構成 設定(ISC)へ書くことによって個別に許可または禁止することができます。 割り込み条件が起こると、周辺機能の割り込み要求フラク´(PORTx.INTFLAGS)レジスタで対応する割り込み要求(INTn)フラグが設定(1)されます。

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

割り込み設定の設定または変更時、次のこれらの点を考慮してください。

- ・入力/感知構成設定(ISC)が変更されるのと同じ周期で反転I/O許可(INVEN)ビットが切り替えられる場合、反転切り替えによって引き起こされる端は割り込み要求を引き起こさないかもしれません。
- ・ビンに対する入力基準選択(INLVL)の変更は関連する割り込みと周辺機能単位部が禁止されている間に実行されなければなりません。単位部が活動中の閾値変更はそのピンでの実際の電圧値と無関係に、入力での一時的な状態遷移を生成するかもしれません。
- ・割り込み同期中にISCへ書くことによって入力が禁止される場合、例えそれが違う割り込み設定で再許可されても、その特定割り 込みが再許可で要求されるかもしれません。
- ・割り込み同期中にISCへ書くことによって割り込み設定が変更される場合、その割り込みが要求されないかもしれません。

#### 18.3.3.1. 非同期感知ピン特性

全てのポート ピンは選択可能なピン変化条件に対する割り込みを持つ完全な非同期入力感知を支援します。完全な非同期ピン変化感知は割り込みを起動して、周辺機能/ロック(CLK\_PER)が停止される動作形態を含めて全ての休止動作からデバイスを起き上がらせることができます。割り込みを起動するのに必要とされるパルス幅はCLK\_PER周期未満です。

#### 18.3.4. 事象

PORTは以下の事象を生成することができます。

## 表18-4. PORTxの事象生成部

| 生     | 成部名       | 説明      | 事象型  | 生成する   | 事象の長さ            |  |
|-------|-----------|---------|------|--------|------------------|--|
| 周辺機能  | 事象        | 品元 9月   | 争豕空  | クロック領域 | 争家の安さ            |  |
| PORTx | EVGEN0SEL | ピン入力レベル | レヘッル | 非同期    | ピンレベルによって与えられます。 |  |
| FORIX | EVGEN1SEL |         |      | が同時期   | していたにようし子えられます。  |  |

全てのポート ピンは非同期事象システム生成部として構成設定することができます。各ポートに対して2つの事象生成部が利用可能です。 ポートからの事象システムへの出力はデジタル入力駆動部が許可される場合に対応するピンに存在する値です。ピン入力駆動部が禁止さ れる場合、事象システムの対応する出力は'0'です。

ポートは事象入力を持ちません。事象型と事象システム構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照し てください。

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

割り込みと入力の同期化の例外を除き、全てのピン構成設定は休止動作と無関係です。全てのピンはデバイスを休止から起き上がらせることができます。更なる詳細についてはポート割り込み部分をご覧ください。

ポートに接続された周辺機能は各々の周辺機能のデータシート部分で記述される休止動作によって影響を及ぼされ得ます。



## 18.3.6. デバッグ操作

ポートはデバッグ動作でのCPU停止時に通常動作を続けます。ポートが割り込みまたは同様のものを通してCPUによって定期的に処理 されるのを必要とするように構成設定する場合、デバッグ中に不正な動作やデータ損失が起こるかもしれません。

# 18.4. レジスタ要約 - PORTx

| 変位    | 略称         | ビット位置      | ビット7  | ビット6  | ビット5     | <b>ビット4</b> | ビット3     | <b>ビット2</b> | ビット1     | ビットロ |
|-------|------------|------------|-------|-------|----------|-------------|----------|-------------|----------|------|
| +\$00 | DIR        | 7~0        |       |       |          | DIR         | 7~0      |             | 1        |      |
| +\$01 | DIRSET     | 7~0        |       |       |          | DIRSE       | ET7~0    |             | 1        |      |
| +\$02 | DIRCLR     | $7 \sim 0$ |       |       |          | DIRCI       | LR7~0    |             | 1        |      |
| +\$03 | DIRTGL     | $7 \sim 0$ |       |       |          | DIRT        | GL7~0    |             | 1        |      |
| +\$04 | OUT        | $7 \sim 0$ |       |       |          | OUI         | Γ7~0     |             | 1        |      |
| +\$05 | OUTSET     | $7 \sim 0$ |       |       |          | OUTS        | ET7~0    |             | 1        |      |
| +\$06 | OUTCLR     | $7 \sim 0$ |       |       |          | OUTC        | LR7~0    |             | 1        |      |
| +\$07 | OUTTGL     | $7 \sim 0$ |       |       |          | OUTT        | GL7~0    |             | 1        |      |
| +\$08 | IN         | $7 \sim 0$ |       |       |          | IN7         | 7~0      |             | 1        |      |
| +\$09 | INTFLAGS   | 7~0        |       |       |          | INT         | 7~0      |             | 1        |      |
| +\$0A | PORTCTRL   | $7 \sim 0$ |       |       |          |             |          |             |          | SRL  |
| +\$0B | PINCONFIG  | $7 \sim 0$ | INVEN | INLVL |          |             | PULLUPEN |             | ISC2~0   |      |
| +\$0C | PINCTRLUPD | $7 \sim 0$ |       |       |          | PINCTRI     | LUPD7~0  |             | 1        |      |
| +\$0D | PINCTRLSET | 7~0        |       |       |          | PINCTR      | LSET7~0  |             | I        |      |
| +\$0E | PINCTRLCLR | 7~0        |       |       |          | PINCTRI     | LCLR7~0  |             | I        |      |
| +\$0F | 予約         |            |       |       |          |             |          |             |          |      |
| +\$10 | PIN0CTRL   | 7~0        | INVEN | INLVL |          |             | PULLUPEN |             | ISC2~0   |      |
| +\$11 | PIN1CTRL   | 7~0        | INVEN | INLVL |          |             | PULLUPEN |             | ISC2~0   |      |
| +\$12 | PIN2CTRL   | 7~0        | INVEN | INLVL |          |             | PULLUPEN |             | ISC2~0   |      |
| +\$13 | PIN3CTRL   | 7~0        | INVEN | INLVL |          |             | PULLUPEN |             | ISC2~0   |      |
| +\$14 | PIN4CTRL   | 7~0        | INVEN | INLVL |          |             | PULLUPEN |             | ISC2~0   |      |
| +\$15 | PIN5CTRL   | 7~0        | INVEN | INLVL |          |             | PULLUPEN |             | ISC2~0   |      |
| +\$16 | PIN6CTRL   | 7~0        | INVEN | INLVL |          |             | PULLUPEN |             | ISC2~0   |      |
| +\$17 | PIN7CTRL   | 7~0        | INVEN | INLVL |          |             | PULLUPEN |             | ISC2~0   |      |
| +\$18 | EVGENCTRLA | 7~0        |       | EV    | GEN1SEL2 | $\sim 0$    |          | EA          | GEN0SEL2 | ~0   |

# 18.5. レジスタ説明 - PORTx

# **18.5.1. DIR - データ方向** (Data Direction)

| 名称 | : | DIR   |
|----|---|-------|
| 変位 | : | +\$00 |

リセット : \$00

特質 :-

| ۲<br>۲ ۲ | 7      | 6   | 5   | 4   | 3   | 2   | 1   | 0      |
|----------|--------|-----|-----|-----|-----|-----|-----|--------|
|          |        |     |     | DIR | 7~0 |     |     |        |
| アクセス種別   | R/W    | D/W | D/W | D/W | DIN | DUU | D/W | D /III |
| ノノヒハ1里刀リ | Γ(/ VV | R/W    |

#### ビット7~0 - DIR7~0: データ方向 (Data Direction)

このビット領域は各PORTxピンに対する出力駆動部を制御します。

このビット領域はデジタル入力緩衝部を制御しません。ピンn(Pxn)用のデジタル入力緩衝部はピンn制御(PORTx.PINnCTRL)の割り込み/ 感知構成設定(ISC)ビット領域で構成設定することができます。

下表はこのビット領域で各ビットnに対して利用可能な構成設定を示します。

| 值  | 0                        | 1                      |
|----|--------------------------|------------------------|
| 説明 | Pxnは入力専用ピンとして構成、出力駆動部は禁止 | Pxnは出力ピンとして構成、出力駆動部は許可 |

## 18.5.2. DIRSET - データ方向設定 (Data Direction Set)

名称: DIRSET

**変位**:+\$01

リセット : \$00

特質 :-

| 1寸貝 | · |  |  |
|-----|---|--|--|
|     |   |  |  |

| ビット    | 7   | 6   | 5   | 4     | 3     | 2   | 1   | 0   |
|--------|-----|-----|-----|-------|-------|-----|-----|-----|
|        |     |     |     | DIRSI | 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 - DIRSET7~0 : データ方向設定 (Data Direction Set)

このビット領域は読み-変更-書き操作を使わず、各PORTxビンに対する出力駆動部を制御します。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みはデータ方向(PORTx.DIR)の対応するビットを設定(1)し、ピンn(Pxn)を出力ピンとして構成設定して出力駆動部を許可します。

このビット領域の読み込みはPORTx.DIRの値を返します。

## 18.5.3. DIRCLR - データ方向解除 (Data Direction Clear)

| 名称   | : DIRCLR |
|------|----------|
| 変位   | : +\$02  |
| リセット | : \$00   |

特質:-

| <b>ビット</b> | 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)の対応するビットを解除(0)し、ピンn(Pxn)を入力専用ピンとして構成設定して出力駆動部を禁止します。

このビット領域の読み込みはPORTx.DIRの値を返します。

18.5.4. DIRTGL - データ方向切り替え (Data Direction Toggle)

| 名称   | : DIRTGL |
|------|----------|
| 変位   | : +\$03  |
| リセット | : \$00   |

特質:-

| <b>ビット</b> | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|------------|-----|-----|-----|-----|-----|-----|-----|-----|--|--|
| DIRTGL7~0  |     |     |     |     |     |     |     |     |  |  |
| アクセス種別     | 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の値を返します。

## **18.5.5. OUT - 出力**值 (Output Value)

| 変位 : | +\$04 |
|------|-------|
|------|-------|

リセット : \$00

特質 :-

| <b>ビット</b> | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|------------|-----|-----|-----|-----|-----|-----|-----|-----|--|--|
| OUT7~0     |     |     |     |     |     |     |     |     |  |  |
| アクセス種別     | R/W |  |  |
| リセット値      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |  |  |

# • ビット7~0 - OUT7~0 : 出力値 (Output Value)

このビット領域は各PORTxピンに対する出力駆動部レベルを制御します。

この構成設定は対応するピンに対して駆動部(PORTx.DIR)が許可される時にだけ出力に影響を及ぼします。

下表はこのビット領域の各ビットnに対して利用可能な構成設定を示します。

| 値  | 0                      | 1                  |
|----|------------------------|--------------------|
| 説明 | ピンn(Pxn)出力はLowに駆動されます。 | Pxn出力はHighに駆動されます。 |

# 18.5.6. OUTSET - 出力值設定 (Output Value Set)

名称: OUTSET

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

# 特質:-

| <u> ビット</u> | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|-------------|-----|-----|-----|-----|-----|-----|-----|-----|--|--|
| OUTSET7~0   |     |     |     |     |     |     |     |     |  |  |
| アクセス種別      | 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の値を返します。

Δ

## 18.5.7. OUTCLR - 出力值解除(Output Value Clear)

| 名称   | : OUTCLR |  |
|------|----------|--|
| 変位   | : +\$06  |  |
| リカット | · \$00   |  |

特質:

| 侍頁:- |   |   |   |       |      |   |
|------|---|---|---|-------|------|---|
| ビット  | 7 | 6 | 5 | 4     | 3    | 2 |
|      |   |   |   | OUTCI | D7.0 |   |

| C /1   | 1         | 0   | 0   | 1   | 5   | 2   | 1   | 0   |  |  |  |
|--------|-----------|-----|-----|-----|-----|-----|-----|-----|--|--|--|
|        | OUTCLR7~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の値を返します。

## 18.5.8. OUTTGL - 出力値切り替え (Output Value Toggle)

名称:OUTTGL

**変位** : +\$07

リセット : \$00

特質 :-

| <u> ビット</u> | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|-------------|-----|-----|-----|-----|-----|-----|-----|-----|--|--|
| OUTTGL7~0   |     |     |     |     |     |     |     |     |  |  |
| アクセス種別      | R/W |  |  |
| リセット値       | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |  |  |

## • ビット7~0 - OUTTGL7~0 : 出力値切り替え (Output Value)

このビット領域は読み-変更-書き操作を使わず、各PORTxビンに対する出力駆動部レベルを制御します。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みは出力値(PORTx.OUT)の対応するビットを反転切り替えします。 このビット領域の読み込みはPORTx.OUTの値を返します。

## 18.5.9. IN - 入力值 (Input Value)

| 名称 | : | IN    |
|----|---|-------|
| 変位 | : | +\$08 |

リセット: \$00

特質:-

| <b>ビット</b> | 7   | 6   | 5   | 4   | 3           | 2   | 1   | 0   |
|------------|-----|-----|-----|-----|-------------|-----|-----|-----|
|            |     |     |     | IN  | <i>7</i> ∼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制御(P ORTx.PINnCTRL)レジスタの入力/感知構成設定(ISC)ビット領域で構成設定することができます。

下表はこのビット領域の各ビットnで利用可能な状態を示します。

| 値  | 0                | 1                 |
|----|------------------|-------------------|
| 説明 | Pxnでの電圧水準はLowです。 | Pxnでの電圧水準はHighです。 |

18.5.10. INTFLAGS - 割り込み要求フラク (Interrupt Flags)

| 変化 | 称 : INTFLAGS<br>立 : +\$09<br>小 : \$00<br>賃 : - | 5 |
|----|------------------------------------------------|---|
|    | P'uk                                           |   |

| ヒット    | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|
|        |     |     |     | INT | 7~0 |     |     |     |
| アクセス種別 | 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)します。

#### **18.5.11. PORTCTRL - ホート制御** (Port Control)

名称: PORTCTRL

**変位** : +\$0A

リセット : \$00

特質:-

このレジスタはこのポートに対するスリューレート制限許可ビットを含みます。

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

● ビット0 - SRL : スリューレート制限許可 (Slew Rate Limit Enable)

このビットはPORTxの全てのピンに対してスリューレート制限を制御します。

| 値  | 0                         | 1                         |
|----|---------------------------|---------------------------|
| 説明 | PORTxの全ピンに対してスリューレート制限が禁止 | PORTxの全ピンに対してスリューレート制限が許可 |

## 18.5.12. PINCONFIG - 複数ピン構成設定 (Multi-Pin Configuration)

名称: PINCONFIG

**変位**:+\$0B

**リセット** : \$00

特質 :-

ポート単位部のより速い構成設定のため、複数構成設定書き込みは単一周期でポートのいくつかのピンの構成設定を許します。特に多ピン数のデバイスで、この機能はPORTピン構成設定操作をかなり速めることができます。

このレジスタへの書き込みはPORTxに対するピンn制御(PORTx.PINnCTRL)レジスタを更新するため、複数ピン制御系(PORTx.PINCTRL)UPD/SET/CLR)レジスタのどれかへの書き込みが後続されるでしょう。

このレジスタは全てのPORTx単位部に渡って反映されます。

| ヒット    | 7     | 6     | 5 | 4 | 3        | 2   | 1      | 0   |
|--------|-------|-------|---|---|----------|-----|--------|-----|
|        | INVEN | INLVL |   |   | PULLUPEN |     | ISC2~0 |     |
| アクセス種別 | R/W   | R/W   | R | R | R/W      | R/W | R/W    | R/W |
| リセット値  | 0     | 0     | 0 | 0 | 0        | 0   | 0      | 0   |

## ● ビット7 - INVEN : 反転I/O許可 (Inverted I/O Enable)

このビットはピンnに対する入力と出力が反転されるか否かを制御します。

| 值  | 0             | 1            |
|----|---------------|--------------|
| 説明 | 入出力値は反転されません。 | 入出力値は反転されます。 |

# ● ビット6 - INLVL : 入力基準選択 (Input Level Select)

このビットはポート入力読み込みと割り込み条件に使われるピンnに対する入力電圧閾値を制御します。

| 值  | 0                    | 1     |
|----|----------------------|-------|
| 名称 | ST                   | TTL   |
| 説明 | 供給水準から導き出されたシュミットトリガ | TTL基準 |

#### • ビット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 | _             | (予約)                                                 |
|     | していたいても何      | (****)<br>後年如杉林山やわる担合 1 力値(DODT-IN)以バフタのビットのは再新されませ) |

注1: ピンnのデジタル入力緩衝部が禁止される場合、入力値(PORTx.IN)レジスタのビットnは更新されません。

注2: LEVEL割り込みはピンがLowに留まる限り継続的に起動し続けます。

#### 18.5.13. PINCTRLUPD - 複数ピン制御更新許可 (Multi-Pin Control Update Mask)

名称: PINCTRLUPD

**変位**:+\$0C

**リセット** : \$00

特質 :-

ポート単位部のより速い構成設定のため、複数構成設定書き込みは単一周期でいくつかのポートピンの構成設定を許します。特に多ピン数のデバイスで、この機能はPORTピン構成設定操作をかなり速めることができます。

| ビット    | 7             | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|---------------|-----|-----|-----|-----|-----|-----|-----|
| [      | PINCTRLUPD7~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 - PINCTRLUPD7~0: 複数ピン制御更新許可 (Multi-Pin Control Update Mask)

このビット領域は各レジスタに対する個別書き込みを使わず、個別ピンn制御(PORTx.PINnCTRL)レジスタに複数ピン構成設定(PORTx.PI NCONFIG)レジスタ内容の複写を制御します。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みはPORTx.PINCONFIGレジスタ内容を対応するPORTx.PINnCTRLレジスタに複写します。 このビット領域の読み込みは常に0を返します。

# 18.5.14. PINCTRLSET - 複数ピン制御設定許可 (Multi-Pin Control Set Mask)

名称: PINCTRLSET

**変位** : +\$0D

リセット : \$00

#### 特質 :-

ポート単位部のより速い構成設定のため、複数構成設定書き込みは単一周期でいくつかのポートピンの構成設定を許します。特に多ピン数のデバイスで、この機能はPORTピン構成設定操作をかなり速めることができます。

| Ľ'ット   | 7             | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |
|--------|---------------|-----|-----|-----|-----|-----|-----|-----|--|
|        | PINCTRLSET7~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 - PINCTRLSET7~0: 複数ピン制御設定許可 (Multi-Pin Control Set Mask)

このビット領域は各レジスタに対する個別読みー変更ー書きし操作を使わず、個別ピンn制御(PORTx.PINnCTRL)レジスタでの複数ビット設 定を制御します。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みは複数ピン構成設定(PORTx.PINCONFIG)レジスタで'1'に設定されているビットに従ってPORT x.PINnCTRLレジスタの個別ビットを設定します。

このビット領域の読み込みは常に0を返します。

#### 18.5.15. PINCTRLCLR - 複数ピン制御解除許可 (Multi-Pin Control Clear Mask)

名称: PINCTRLCLR

**変位**:+\$0E

リセット : \$00

リセット値

特質 :-

ポート単位部のより速い構成設定のため、複数構成設定書き込みは単一周期でいくつかのポートピンの構成設定を許します。特に多ピ ン数のデバイスで、この機能はPORTピン構成設定操作をかなり速めることができます。

| ビット    | 7             | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |
|--------|---------------|-----|-----|-----|-----|-----|-----|-----|--|
|        | PINCTRLCLR7~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 - PINCTRLCLR7~0 : 複数ピン制御解除許可 (Multi-Pin Control Clear Mask)

このビット領域は各レジスタに対する個別読みー変更ー書きし操作を使わず、個別ピンn制御(PORTx.PINnCTRL)レジスタでの複数ビット解 除を制御します。

このビット領域のビットnへの'0'書き込みは無効です。

このビット領域のビットnへの'1'書き込みは複数ピン構成設定(PORTx.PINCONFIG)レジスタで'1'に設定されているビットに従ってPORT x.PINnCTRLレジスタの個別ビットを解除します。

このビット領域の読み込みは常に0を返します。

0

#### 17.5.16. PINnCTRL - ビンn制御 (Pin n Control)

| 変リ | 4称 : PIN0CTF<br>5位 : +\$10<br>セット : \$00<br>持質 : - | L : PIN1CTRL<br>:+\$11 |       | : PIN3CTRL<br>: +\$13 | : PIN4CTI<br>: +\$14 | RL : PIN5CTRL<br>: +\$15 | : PIN6CTRL<br>: +\$16 | : PIN7CTRL<br>: +\$17 |     |
|----|----------------------------------------------------|------------------------|-------|-----------------------|----------------------|--------------------------|-----------------------|-----------------------|-----|
|    | ヒット                                                | 7                      | 6     | 5                     | 4                    | 3                        | 2                     | 1                     | 0   |
|    |                                                    | INVEN                  | INLVL |                       | F                    | PULLUPEN                 | IS                    | SC2~0                 |     |
|    | アクセス種別                                             | R/W                    | R/W   | R                     | R                    | R/W                      | R/W                   | R/W                   | R/W |

0

#### ● ビット7 - INVEN:反転I/O許可 (Inverted I/O Enable)

このビットはピンnに対する入力と出力が反転されるか否かを制御します。

0

| 値  | 0             | 1            |
|----|---------------|--------------|
| 説明 | 入出力値は反転されません。 | 入出力値は反転されます。 |

0

0

0

0

### ● ビット6 - INLVL:入力基準選択 (Input Level Select)

このビットはポート入力読み込みと割り込み条件に使われるピンnに対する入力電圧閾値を制御します。

0

| 值  | 0                    | 1     |  |  |  |
|----|----------------------|-------|--|--|--|
| 名称 | ST                   | TTL   |  |  |  |
| 説明 | 供給水準から導き出されたシュミットトリガ | TTL基準 |  |  |  |

# • ビット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             | -             | (予約)                                           |
| 2 <b>1</b> 1 12 | いのこうかりましん     | 。<br>(金切が林山やわて相久、1.力広(DODT-IN)しいでれのビュレけ再転やわたけ) |

注1: ピンnのデジタル入力緩衝部が禁止される場合、入力値(PORTx.IN)レジスタのビットnは更新されません。

注2: LEVEL割り込みはピンがLowに留まる限り継続的に起動し続けます。

# 18.5.17. EVGENCTRLA - 事象生成部制御A (Event Generator Control A)

名称: EVGENCTRLA

**変位** : +\$18

**リセット** : \$00

特質:-

| Ľ"ット   | 7 | 6   | 5          | 4   | 3 | 2            | 1   | 0   |
|--------|---|-----|------------|-----|---|--------------|-----|-----|
|        |   | E   | VGEN1SEL2~ | ~0  |   | EVGEN0SEL2~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,2~0 - EVGENnSEL2~0:事象生成部n選択 (Enect Generator n Select)

このビット領域はどのピンが事象生成部nに接続されるかを制御します。

| 值  | 000  | 001  | 010  | 011  | 100  | 101  | 110  | 111  |
|----|------|------|------|------|------|------|------|------|
| 名称 | PIN0 | PIN1 | PIN2 | PIN3 | PIN4 | PIN5 | PIN6 | PIN7 |
| 説明 | Px0  | Px1  | Px2  | Px3  | Px4  | Px5  | Px6  | Px7  |

# 18.6. レジスタ要約 - VPORTx

| 変位    | 略称       | ビット位置      | ビット7 | ビット6   | ビット5   | ビット4 | ビット3 | ビット2 | ビット1 | ビット0 |
|-------|----------|------------|------|--------|--------|------|------|------|------|------|
| +\$00 | DIR      | $7 \sim 0$ |      | DIR7~0 |        |      |      |      |      |      |
| +\$01 | OUT      | 7~0        |      |        | OUT7~0 |      |      |      |      |      |
| +\$02 | IN       | $7 \sim 0$ |      |        | 1      | IN7  | Z∼0  | 1    | 1    |      |
| +\$03 | INTFLAGS | $7 \sim 0$ |      | INT7~0 |        |      |      |      |      |      |

# 18.7. レシズタ説明 - VPORTx

# 18.7.1. DIR - データ方向 (Data Direction)

名称 : DIR

**変位**:+\$00

リセット : \$00

特質 :-

仮想ポートレジスタへのアクセスは普通のレジスタへのアクセスと同じ結果を持ち、通常のポートレジスタが属す拡張I/Oレジスタ空間で使うことができないビット操作命令のようなメモリ特定命令を許します。

| ビット    | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|--|--|
| DIR7~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は出力ピンとして構成、出力駆動部は許可 |

#### **18.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   | 0   | 0   | 0   |

#### • ビット7~0 - OUT7~0 : 出力値 (Output Value)

このビット領域は各PORTxピンに対する出力駆動部レベルを制御します。

この構成設定は対応するピンに対して駆動部(PORTx.DIR)が許可される時にだけ出力に影響を及ぼします。

下表はこのビット領域の各ビットnに対して利用可能な構成設定を示します。

| 值  | 0                      | 1                  |
|----|------------------------|--------------------|
| 説明 | ピンn(Pxn)出力はLowに駆動されます。 | Pxn出力はHighに駆動されます。 |

# 18.7.3. IN - 入力值 (Input Value)

名称 : IN

**変位**:+\$02

リセット : \$00

特質 :-

仮想ポート レジスタへのアクセスは普通のレジスタへのアクセスと同じ結果を持ち、通常のポート レジスタが属す拡張I/Oレジスタ空間で使うことが できないビット操作命令のようなメモリ特定命令を許します。

| ヒット    | 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制御(P ORTx.PINnCTRL)レジスタの入力/感知構成設定(ISC)ビット領域で構成設定することができます。

下表はこのビット領域の各ビットnに対して利用可能な構成設定を示します。

| 值  | 0                | 1                 |
|----|------------------|-------------------|
| 説明 | Pxnでの電圧水準はLowです。 | Pxnでの電圧水準はHighです。 |

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

名称 : INTFLAGS

**変位** : +\$03

**リセット** : \$00

# 特質 :-

仮想ポートレジ゙スタへのアクセスは普通のレジ゙スタへのアクセスと同じ結果を持ち、通常のポートレジ゙スタが属す拡張I/Oレジスタ空間で使うことが できないビット操作命令のようなメモリ特定命令を許します。

| ビット _  | 7      | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|--------|--------|-----|-----|-----|-----|-----|-----|-----|--|--|
|        | INT7~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)します。

# 19. BOD - 低電圧検出器 (BOD:Brownout Detector)

# 19.1. 特徴

- ・低電圧検出は設定可能な基準未満での動作を避けるために電源を監視します。
- ・利用可能な3つの動作形態
  - 継続動作で許可
  - 採取動作で許可
  - 禁止
- ・活動動作と休止動作に対して独立した動作形態を選択
- ・割り込みを持つ電圧水準監視部(VLM)
- ・BOD基準に比例した設定可能なVLM基準

# 19.2. 概要

低電圧検出器(BOD)は電源を監視して供給電圧を設定可能な低電圧閾値基準と比べます。低電圧閾値基準はシステム リセットを生成 する時を定義します。電圧水準監視部(VLM)も電源を監視してそれをBOD閾値よりも高い閾値と比べます。そしてVLMは供給電圧 がBOD閾値に近づいている時に"早期警告"として割り込み要求を生成することができます。VLM閾値基準はBOD閾値基準の%超え として表現されます。

BODは主にヒューズによって制御され、使用者によって許可されなければなりません。スタンハイ休止動作とパワーダウン休止動作で使われる動作形態は標準プログラム実行で変えることができます。VLMは更にI/Oレジスタによっても制御されます。

有効にされると、BODはBODが継続的に活動する許可動作形態で、またはBODが供給電圧水準を検査するのに与えられた周期で 一時的に活動にされる採取動作形態で動作することができます。

#### 19.2.1. 構成図



# 19.3. 機能的な説明

# 19.3.1. 初期化

BOD設定はリセットの間にヒューズから設定されます。活動動作とアイドル休止動作でのBOD基準と動作形態はヒューズによって設定され、 ソフトウェアによって変更することができません。スタンバイ休止動作とパワーダウン休止動作での動作形態はヒューズによって設定され、ソフトウェ アによって変更することができます。

電圧水準監視部機能は割り込み制御(BOD.INTCTRL)レジスタのVLM割り込み許可(VLMIE)ビットに'1'を書くことによって許可することができます。VLM割り込みはBOD.INTCTRLレジスタのVLM構成設定(VLMCFG)ビットを書くことによって構成設定されます。割り込みは供給電圧が上または下のどちらかからVLM閾値を横切る時に要求されます。

VLM機能はBOD動作に従います。BODが禁止された場合、VLMは例えVLMIEが'1'でも許可されません。BODが採取動作を使う 場合、VLMも採取にされます。VLM割り込み許可時、割り込み要求フラク'はVLMCFGが\$2と等しい場合に常に設定(1)され、VLMCF Gが\$0または\$1に構成設定される場合に設定(1)されるかもしれません。

VLM閾値はVLM制御A(BOD.VLMCTRLA)レジズタのVLM基準(VLMLVL)ビットを書くことによって定義されます。

#### 19.3.2. 割り込み

| 表19-1.利用可能な割り込みベクタと供給元 |         |                                                                          |  |  |  |  |  |  |  |
|------------------------|---------|--------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 名称                     | ベクタ説明   | 条件                                                                       |  |  |  |  |  |  |  |
| VLM                    | 電圧水準監視部 | 割り込み制御(BOD.INTCTRL)レシブスタのVLM構成設定(VLMCFG)ビットによって構成されるよう<br>に供給電圧がVLM閾値を横断 |  |  |  |  |  |  |  |

VLM割り込みはCPUがデバッグ動作で停止されている場合に実行されません。

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

### 19.3.3. 休止形態動作

各種休止動作でのBOD構成設定はヒュース、によって定義されます。活動動作とアイドル休止動作で使われる動作形態はBOD構成設定 (FUSE.BODCFG)の活動とアイドルでのBOD動作形態(ACTIVE)ヒュース、によって定義され、これは制御A(BOD.CTRLA)レジスタの活動/ アイドル時動作(ACTIVE)ヒット領域に設定されます。スタンハイ休止動作とハ<sup>の</sup>ワーダウン休止動作で使われる動作形態はFUSE.BODCFGの 休止でのBOD動作形態(SLEEP)ヒュース、によって定義され、これは制御A(BOD.CTRLA)レジスタのスタンハイ/ハ<sup>の</sup>ワーダウン時動作(SLEEP) ビット領域に設定されます。

活動動作とアイドル休止動作(即ち、BOD.CTRLAのACTIVE)での動作形態はソフトウェアによって変えることができません。スタンバイ休止 動作とパワーダウン休止動作での動作形態は制御A(BOD.CTRLA)レジスタの休止(SLEEP)ビット領域への書き込みによって変えることが できます。

デバイスがスタンハイ休止動作またはハ<sup>®</sup>ワーダウン休止動作へ行く時に、BODはBOD.CTRLAのSLEEPによって定義されるように動作形態 を変更します。デバイスがスタンハイまたはハ<sup>®</sup>ワーダウンの休止動作から起き上がる時に、BODは制御A(BOD.CTRLA)レシ、スタのACTIVEビッ ト領域によって定義される動作形態で動きます。

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

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

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

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

#### 表19-2. BOD - 構成設定変更保護下のレジスタ

| レジスタ               | 鍵種別   |
|--------------------|-------|
| BOD.CTRLAのSLEEPビット | IOREG |

# 19.4. レジスタ要約

| 変位         | 略称          | ビット位置      | ビット7 | ビット6 | ビット5 | ビット4     | ビット3 | ビット2  | ビット1   | ビットロ  |
|------------|-------------|------------|------|------|------|----------|------|-------|--------|-------|
| +\$00      | CTRLA       | $7 \sim 0$ |      |      |      | SAMPFREQ | ACTI | VE1,0 | SLEI   | EP1,0 |
| +\$01      | CTRLB       | $7 \sim 0$ |      |      |      |          |      |       | LVL2~0 |       |
| +\$02<br>~ | <b>→</b> 44 |            |      |      |      |          |      |       |        |       |
| +\$07      | 予約          |            |      |      |      |          |      |       |        |       |
| +\$08      | VLMCTRLA    | 7~0        |      |      |      |          |      |       | VLML   | VL1,0 |
| +\$09      | INTCTRL     | $7 \sim 0$ |      |      |      |          |      | VLMC  | FG1,0  | VLMIE |
| +\$0A      | INTFLAGS    | $7 \sim 0$ |      |      |      |          |      |       |        | VLMIF |
| +\$0B      | STATUS      | 7~0        |      |      |      |          |      |       |        | VLMS  |

# 19.5. レジスタ説明

# 19.5.1. CTRLA - 制御A (Control A)

名称 : CTRLA

**変位** : +\$00

リセット: FUSE.BODCFGヒューズから設定

特質:構成設定変更保護(SLEEPビットのみ)

| ヒ <sup>*</sup> ット | 7 | 6 | 5 | 4        | 3         | 2 | 1        | 0   |
|-------------------|---|---|---|----------|-----------|---|----------|-----|
|                   |   |   |   | SAMPFREQ | ACTIVE1,0 |   | SLEEP1,0 |     |
| アクセス種別            | R | R | R | R        | R         | R | R/W      | R/W |
| リセット値             | 0 | 0 | 0 | Х        | Х         | Х | Х        | Х   |

### ● ビット4 - SAMPFREQ : 採取周波数 (Sample Frequency)

このビットはBOD採取周波数を制御します。

リセット値はFUSE.BODCFGのBOD採取周波数(SAMPFREQ)ビットから取得/設定されます。

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

#### ビット3,2 - ACTIVE1,0:活動/アイトル時動作(Active)

これらのビットはデバイスが活動動作とアイドル休止動作の時のBOD動作形態を選びます。

リセット値はFUSE.BODCFGの活動とアイドルでのBOD動作形態(ACTIVE)ビットから取得/設定されます。

| 値  | 00 01   |         | 10      | 11                          |  |  |
|----|---------|---------|---------|-----------------------------|--|--|
| 名称 | DISABLE | ENABLED | SAMPLE  | ENABLEWAIT                  |  |  |
| 説明 | 禁止      | 継続動作で許可 | 採取動作で許可 | 継続動作で許可。実行は起き上がりでBODが動くまで停止 |  |  |

# ビット1,0 - SLEEP1,0 : スタンハ・イ/パワーダ・ウン時動作 (Sleep)

これらのビットはデバイスがスタンバイとパワーダウンの休止動作の時のBOD動作形態を選びます。

リセット値はFUSE.BODCFGの休止でのBOD動作形態(SLEEP)ビットから取得/設定されます。

このビットは構成設定変更保護(CCP)下です。

| 值  | 0 0     | 01      | 10      | 11   |
|----|---------|---------|---------|------|
| 名称 | DISABLE | ENABLED | SAMPLED | -    |
| 説明 | 禁止      | 継続動作で許可 | 採取動作で許可 | (予約) |

# 19.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 | Х | Х      | Х |

### ビット2~0 - LVL2~0 : BOD基準 (BOD Level)

このビット領域はBOD閾値基準を制御します。

リセット値はBOD構成設定(FUSE.BODCFG)ヒュースのBOD基準(LVL)ビットから取得/設定されます。

| 値   | 0 0 0     | 001       | 010       | 011       | その他  |
|-----|-----------|-----------|-----------|-----------|------|
| 名称  | BODLEVEL0 | BODLEVEL1 | BODLEVEL2 | BODLEVEL3 | -    |
| 代表値 | 1.75V     | 1.90V     | 2.60V     | 4.30V     | (予約) |

注: ・BODLEVEL0はチップ消去中だけ許可されます。通常動作中のこのビット領域への'0'書き込みはBOD禁止と同じです。 ・BOD基準特性と更なる詳細については表35-14.を参照してください。

© 2022 Microchip Technology Inc.とその子会社

# 19.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              |  |
|----|------------|----------------|-----------------|-----------------|--|
| 名称 | OFF 5ABOVE |                | 15ABOVE         | 25ABOVE         |  |
| 説明 | VLM禁止      | BOD閾値+5%がVLM閾値 | BOD閾値+15%がVLM閾値 | BOD閾値+25%がVLM閾値 |  |

# 19.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            | 01             | 10            | 11   |
|----|----------------|----------------|---------------|------|
| 名称 | FALLING        | RISING         | BOTH          | -    |
| 説明 | VDDがVLM閾値未満へ下降 | VDDがVLM閾値越えへ上昇 | VDDがVLM閾値を横切る | (予約) |

# • ビット0 - VLMIE : VLM割り込み許可 (VLM Interrupt Enable)

このビットへの'1'書き込みは電圧水準監視部(VLM)割り込みを許可します。

# 19.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が許可されている時にだけ更新されます。

# 19.5.6. STATUS - VLM状態 (VLM Status)

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

| <b>ビット</b> | 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               |
|----|---|-----------------|-----------------|
| 名称 | 7 | ABOVE           | BELOW           |
| 説明 | ] | 電圧はVLM閾値基準越えです。 | 電圧はVLM閾値基準未満です。 |

# 20. VREF - 基準電圧

# 20.1. 特徴

- ・設定可能な基準電圧源
- D/A変換器0(DAC0)用に1つの参照基準
   全てのアナログ比較器(AC0)間で共用される1つの参照基準
- ・各参照基準元は以下の電圧を支援
  - 1.024V
  - 2.048V
  - 4.096V
  - 2.500V
  - VDD (VDDANA)
  - VREFA

# 20.2. 概要

基準電圧(VREF)周辺機能はいくつかの周辺機能によって使われる基準電圧源用の制御レジスタを提供します。VREF周辺機能の適切なレジスタを書くことによってDAC0とAC0に対する基準電圧を選ぶことができます。

基準電圧源は周辺機能によって要求される時に自動的に許可されます。使用者は基準電圧源を許可することができ、従って、DAC 0参照基準(VREF.DAC0REF)、アナログ比較器参照基準(VREF.ACREF)で各々の参照基準常時ON(ALWAYSON)ビットに'1'を書くことによって未使用供給元の自動禁止を無効にすることができます。これは増される消費電力を犠牲にして始動時間を減らします。

# 20.2.1. 構成図



# 20.3. 機能的な説明

# 20.3.1. 初期化

既定構成設定はDAC0またはAC0が基準電圧を要求する時に各々の供給元を許可します。既定の基準電圧は1.024Vですが、DAC 0参照基準(DAC0REF)またはアナログ比較器参照基準(ACREF)のレジスタで各々の参照基準選択(REFSEL)ビット領域を書くことによって 構成設定することができます。 20.4. レジスタ要約

| 変位         | 略称      | L <sup>ット</sup> 位置 | ビット7     | ビット6 | ビット5 | ビット4 | ビット3 | ビット2 | ビット1      | ビットロ |
|------------|---------|--------------------|----------|------|------|------|------|------|-----------|------|
| +\$00<br>~ | 予約      |                    |          |      |      |      |      |      |           |      |
| +\$01      | ገ       |                    |          |      |      |      |      |      |           |      |
| +\$02      | DAC0REF | $7 \sim 0$         | ALWAYSON |      |      |      |      |      | REFSEL2~0 |      |
| +\$03      | 予約      |                    |          |      |      |      |      |      |           |      |
| +\$04      | ACREF   | 7~0                | ALWAYSON |      |      |      |      |      | REFSEL2~0 |      |

# 20.5. レジスタ説明

#### 20.5.1. DACOREF - DACO参照基準 (DAC0 Reference)

| 名称 | : DACOREF |
|----|-----------|
|----|-----------|

**変位** : +\$02

### **リセット** : \$00

# 特質 :-

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

● ビット7 - ALWAYSON : 参照基準常時ON (Reference Always ON)

このビットはDAC0の参照基準が常時ONか否かを制御します。

| 値  | 0                        | 1            |
|----|--------------------------|--------------|
| 説明 | 参照基準は必要とされる時に自動的に許可されます。 | 参照基準は常にONです。 |

# ● ビット2~0 - REFSEL2~0:参照基準選択 (Reference Select)

このビット領域はD/A変換器0(DAC0)用の基準電圧水準を制御します。

| 値  | 000                                | $0 \ 0 \ 1$                        | 010                                | 011                                | $1 \ 0 \ 0$ | $1 \ 0 \ 1$    | 110                                | 111  |
|----|------------------------------------|------------------------------------|------------------------------------|------------------------------------|-------------|----------------|------------------------------------|------|
| 名称 | 1V024                              | 2V048                              | 4V096                              | 2V500                              | -           | VDD            | VREFA                              | _    |
| 説明 | 内部1.024V<br>参照基準( <mark>注</mark> ) | 内部2.048V<br>参照基準( <mark>注</mark> ) | 内部4.096V<br>参照基準( <mark>注</mark> ) | 内部2.500V<br>参照基準( <mark>注</mark> ) | (予約)        | 参照基準<br>としてVDD | VREFAt <sup>®</sup> ンからの<br>外部参照基準 | (予約) |

注: 内部参照基準に対して与えられる値は代表値なだけです。更なる詳細については「電気的特性」章を参照してください。

# 20.5.2. ACREF - アナログ比較器参照基準 (Anolog Comparator Reference)

- 名称:ACREF
- **変位** : +\$04
- **リセット** : \$00

# 特質:-

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

#### ● ビット7 - ALWAYSON : 参照基準常時ON (Reference Always ON)

このビットはACnの参照基準が常時ONか否かを制御します。

| 値  | 0                        | 1            |
|----|--------------------------|--------------|
| 説明 | 参照基準は必要とされる時に自動的に許可されます。 | 参照基準は常にONです。 |

# ● ビット2~0 - REFSEL2~0 : 参照基準選択 (Reference Select)

このビット領域はアナログ比較器(ACn)用の基準電圧水準を制御します。

| 値  | 000                                | 001                                | 010                                | 011                                | 100  | 101            | 110                                | 111  |
|----|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------|----------------|------------------------------------|------|
| 名称 | 1V024                              | 2V048                              | 4V096                              | 2V500                              | _    | VDD            | VREFA                              | -    |
| 説明 | 内部1.024V<br>参照基準( <mark>注</mark> ) | 内部2.048V<br>参照基準( <mark>注</mark> ) | 内部4.096V<br>参照基準( <mark>注</mark> ) | 内部2.500V<br>参照基準( <mark>注</mark> ) | (予約) | 参照基準<br>としてVDD | VREFAt <sup>®</sup> ンからの<br>外部参照基準 | (予約) |

注: 内部参照基準に対して与えられる値は代表値なだけです。 更なる詳細については「電気的特性」章を参照してください。

# **21**. WDT – ウォッチト・ック タイマ

# 21.1. 特徴

- ・時間超過前にウォッチトッグタイマが解消されない場合にシステムリセットを発行
- ・独立した発振器を用いる周辺機能クロックからの非同期動作
- ・32.768kHz超低電力発振器(OSC32K)の1.024kHz出力を使用
- ・8msから8sまで11種の選択可能な時限期間
- ・2つの動作形態
  - 標準動作
  - 窓動作
- ・望まれない変更を防ぐための構成設定施錠

# 21.2. 概要

ウォッチトック「タイマ(WDT)は正しいプログラム動作を監視するためのシステム機能です。許可されると、WDTは構成設定可能な時限期間で 継続的に計時器を動かします。WDTが制限期間内にリセットされなければ、システム リセットを発行し、これは暴走や停滞されたコートのよう な状況からの回復をシステムに許します。WDTはソフトウェアからWDR(Watchdog Timer Reset)命令を実行することによってリセットされま す。

上で記述されたような標準動作に加えて、WDTは窓動作を持ちます。窓動作はWDTがリセットされなければならない間の制限時間内 側の時間幅または"窓"を定義します。WDTが速すぎまたは遅すぎでこの窓の外側でリセットされた場合、システムリセットが発行されま す。標準動作に比べ、窓動作はコート、異常が一定のWDR実行を引き起こす状況を捕らえることができます。

許可されると、WDTは活動動作と全ての休止動作で動きます。これが非同期の(CPUから独立したクロック元から動く)ため、例え主クロッ クが動かなくても、動作を継続してシステムリセットを発行することができます。

WDTは構成設定変更保護(CCP)機構と施錠機能を持ち、WDT設定が事故によって変更され得ないことを保証します。

# 21.2.1. 構成図



# 21.3. 機能的な説明

# 21.3.1. 初期化

1. WDTは制御A(WDT.CTRLA)レジスタの制限期間(PERIOD)ビット領域に0以外の値が書かれる時に許可されます。

2. 任意選択: 窓形態動作を許可するにはWDT.CTRLAレジスタの窓(WINDOW)ビット領域に0以外の値を書いてください。

制御A(WDT.CTRLA)レジスタの全ビットと状態(WDT.STATUS)レジスタの施錠(LOCK)ビットは構成設定変更保護機構によって書き込み 保護されます。

ウォッチトック構成設定(FUSE.WDTCFG)ヒュースはWDT.CTRLAレジスタのリセット値を定義します。FUSE.WDTCFGのウォッチトック制限時間 周期(PERIOD)ビット領域が0以外なら、起動時にWDTが許可されてWDT.STATUSレジスタのLOCKビットが設定(1)されます。

# **21.3.2**. クロック

1.024kHzクロック(CLK\_WDT)は内部超低電力発振器(OSC32K)から供給されます。超低電力設計のため、この発振器はデバイスで特徴 とされる他の発振器よりもかなり不正確で、従って正確な時限期間はデバイス毎に変わるかもしれません。全てのデバイスに対して使われる時限期間が有効なことを保証するため、WDTを使うソフトウェア設計時にこの変化が考慮されなければなりません。

WDTクロック(CLK\_WDT)は周辺機能クロックに対して非同期です。この非同期性のため、WDT制御A(WDT.CTRLA)レジスタへの書き込みはクロック領域間の同期が必要とされます。更なる詳細については「21.3.6.同期」を参照してください。

# 21.3.3. 動作

# 21.3.3.1. 標準動作

標準動作操作では、WDTに単一制限期間が設定されます。WDTが定義された時限期間中にWDR命令を用いてソフトウェアからリセットされない場合、WDTはシステム リセッ トを発行します。

WDTがWDR命令を用いてソフトウェアによってリセットされる時毎に新しいWDT時限期 間が開始されます。

制御A(WDT.CTRLA)レジスタの制限期間(PERIOD)ビット領域に書くことによって8ms から8sまで選択可能な11個の可能なWDT時限期間(TOWDT)があります。

右図は標準動作でのWDT操作に対する代表的なタイミング体系を示します。 標準動作は制御A(WDT.CTRLA)レジスタの窓期間(WINDOW)ビット領域が'0000'で ある限り許可されます。

# 21.3.3.2. 窓動作

窓動作操作では、WDTが次のような2つの異なる制限期間、閉鎖窓制限期間(TOWDTW)と開放窓制限期間(TOWDT)を使います。

- ・TOWDTWはWDTをリセットされるべきではない8msから8sまでの持続期間 を定義します。この期間の間にWDTがリセットされた場合、WDTはシステムリ セットを発行します。
- ・TOWDTも8msから8sで、WDTをリセットすることができる(すべき)間の開放 持続期間を定義します。開放期間は常に閉鎖期間に続き、故に時限期 間の総持続期間は閉鎖窓と開放窓の時限期間の合計です。

窓動作許可時、またはデバッグ動作の外に出る時に、窓は最初のWDR命令後に活性(有効)にされます。

右図は窓動作でのWDT操作に対する代表的なタイミング体系を示します。 窓動作は制御A(WDT.CTRLA)レジ<sup>\*</sup>スタの窓期間(WINDOW)ビット領域に0以 外の値を書くことで許可され、<sup>\*0000</sup> を書くことで禁止されます。



# 21.3.3.3. 意図しない変更の防止

WDTはWDT設定に対して意図しない変更を避けるために次のような2つの安全機構を提供します。

- ・WDT制御レジスタ変更のために時限書き込み手順を使う構成設定変更保護(CCP)機構。更なる詳細については「21.3.7.構成設 定変更保護」を参照してください。
- ・状態(WDT.STATUS)レジスタの施錠(LOCK)ビットに'1'を書くことによる構成設定の施錠。このビットが'1'の時に制御A(WDT.CTRL A)レジスタは変更することができません。LOCKビットはソフトウェアで'1'を書くことだけができるのに対し、デバイスがそれに'0'を書くこと ができるにはデバックが動作が必要です。結果としてWDTはソフトウェアから禁止することができません。
- **注**: WDT構成設定はリセット後にヒューズから設定されます。制限期間(PERIOD)ビット領域が0以外に設定される場合、WDT.STATUSレシ゛ スタで自動的にLOCKビットが設定(1)されます。

# 21.3.4. 休止形態動作

WDTは供給元クロックが活性であるどの休止動作形態でも動作を続けます。

# 21.3.5. デバッグ操作

走行時のデベッグ時、この周辺機能は標準動作を続けます。デベッグ動作形態でのCPU停止はこの周辺機能の標準動作を停止します。

デバッグ動作形態でのCPU停止時、WDT計数器はリセットされます。

WDTが窓動作で動いていてCPUを開始すると、最初の閉鎖窓制限時間は禁止され、標準動作制限時間が実行されます。

図21-2. 標準動作操作



# 21.3.6. 同期

WDTクロック領域と周辺機能クロック領域間が非同期なため、制御A(WDT.CTRLA)レジスタは書かれた時に同期されます。状態(WDT.ST ATUS)レジスタの同期化多忙(SYNCBUSY)フラグは進行中の同期化があるかを示します。

SYNCBUSY=1の間のWDT.CTRLAレジスタ書き込みは許されません。

以下のビット領域は書かれた時に同期化されます。

- ・制御A(WDT.CTRLA)レジスタの制限期間(PERIOD)ビット
- ・WDT.CTRLAレシ<sup>゙</sup>スタの窓期間(WINDOW)ヒ<sup>゙</sup>ット

WDR命令は同期するのに2~3周期のWDTクロックが必要です。

# 21.3.7. 構成設定変更保護

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

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

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

CCPによって保護されるビット/レジスタの一覧は以下です。

- ・制御A(WDT.CTRLA)レジスタの制限期間(PERIOD)ビット
- ・制御A(WDT.CTRLA)レジスタの窓期間(WINDOW)ビット
- ・状態(WDT.STATUS)レシブスタの施錠(LOCK)ビット

| 表21-1. WDT - | 構成設定変更保護 | 下のレジスタ |
|--------------|----------|--------|
|              |          |        |

| レジスタ               | 鍵種別   |
|--------------------|-------|
| WDT.CTRLA          | IOREG |
| WDT.STATUSのLOCKビット | IOREG |

# 21.4. レジスタ要約

| 変位    | 略称     | ビット位置 | ビット7 | ビット6      | ビット5 | ビット4 | ビット3 | ビット2      | ビット1 | ビットロ     |  |  |
|-------|--------|-------|------|-----------|------|------|------|-----------|------|----------|--|--|
| +\$00 | CTRLA  | 7~0   |      | WINDOW3~0 |      |      |      | PERIOD3~0 |      |          |  |  |
| +\$01 | STATUS | 7~0   | LOCK |           |      |      |      |           |      | SYNCBUSY |  |  |

# 21.5. レジスタ説明

# 21.5.1. CTRLA - 制御A (Control A)

名称 : CTRLA

**変位** : +\$00

# **リセット**: FUSE.WDTCFGからの値

#### **特質**:構成設定変更保護

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

# ● ビット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     | -    |
| 説明            |      | 7.8125ms | 15.625ms | 31.25ms | 62.5ms | 0.125s | 0.250s | 0.500s | 1.0s  | 2.0s  | 4.0s  | 8.0s      | (予約) |
| 注: 32.768kHz超 | 氏電力  | 発振器((    | OSC32K   | )精度に    | 関する特   | 定情報に   | こついては  | 「電気的物  | 寺性」章  | を参照し  | てくださ  | <i>``</i> |      |

• ビット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 | -    |
| 説明            | -                                                            | 7.8125ms | 15.625ms | 31.25ms | 62.5ms | 0.125s | 0.250s | 0.500s | 1.0s  | 2.0s  | 4.0s  | 8.0s  | (予約) |
| 注: 32.768kHz超 | 注: 32.768kHz超低電力発振器(OSC32K)精度に関する特定情報については「電気的特性」章を参照してください。 |          |          |         |        |        |        |        |       |       |       | N°    |      |

#### 21.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)下ではありません。

# 22. TCA - 16ビット タイマ/カウンタA型

# 22.1. 特徴

- 16ビットタイマ/カウンタ
- ・3つの比較チャネル
- ・2重緩衝されたタイマ定期間設定
- ・2重緩衝された比較チャネル
- ・波形生成:
- 周波数生成
- 単一傾斜PWM(パルス幅変調)
- 2傾斜PWM
- 事象での計数
- ・計時器溢れ割り込み/事象
- ・比較チャネル当たり1つの比較一致
- ・分割動作での2つの8ビットタイマ/カウンタ

# 22.2. 概要

柔軟な16ビットタイマ/カウンタA型(TCA)は正確なプログラム実行タイミング、周波数と波形の生成、指令実行を提供します。

TCAは基本計数器と比較チャネルの組から成ります。基本計数器はクロック周期または事象を計数するのに使うことができ、またクロック周期をどう計数するかを事象に制御させます。それは方向制御を持ち、タイミングに周期設定を使うことができます。比較チャネルは基本計数器と共に、比較一致制御、周波数生成、パルス幅波形変調を実行するのに使うことができます。

動作形態に依存して、計数器は各タイマ/カウンタ クロックまたは事象入力で解消、再設定、増加、減少されます。

タイマ/カウンタは任意選択の前置分周を持つ周辺機能クロックから、または事象システムからクロック駆動と計時をすることができます。事象シス テムは方向制御または動作の同期にも使うことができます。

既定で、TCAは16ビットタイマ/カウンタです。このタイマ/カウンタは各々3つの比較チャネルを持つ2つの8ビットタイマ/カウンタに分割する分割動作 機能を持ちます。使う動作形態に応じて、レジスタのアドレス付けや、ビット遮蔽と群構成設定の使用は以降のように、レジスタに対してTC An.SINGLE.REGISTERまたはTCAn.SPLIT.REGISTER、ビット遮蔽と群構成設定の例としてTCA\_SINGLE\_CLKSEL\_DIV1\_gcまたはTC A\_SPLIT\_CLKSEL\_DIV1\_gcのどちらかとして行われます。

本章でレジスタはTCAn.REGISTERとしてアドレス付けされます。

下図は密接に関連する(青枠の(訳注:原書は灰色の))周辺機能単位部を伴う16ビットタイマ/カウンタの構成図を示します。



# 22.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は前置分周された周辺機能クロックか、または事象システムからの事象のどちらかです。



# 22.2.2. 信号説明

| 信号  | 形式     | 説明   |
|-----|--------|------|
| WOn | デジタル出力 | 波形出力 |

# 22.3. 機能的な説明

# 22.3.1. 定義

以下の定義は文書全体を通して使われます。

| 表22-1. タイマ | /カウンタ定義                                                                                                                     |
|------------|-----------------------------------------------------------------------------------------------------------------------------|
| 名称         | 説明                                                                                                                          |
| BOTTOM     | 計数器が底(BOTTOM)に到達し、それが\$0000になる時                                                                                             |
| MAX        | 計数器が最大(MAXimum)に到達し、それが全て1になる時                                                                                              |
| TOP        | 計数器が頂上(TOP)に到達し、それが計数の流れで最高値と等しくなる時                                                                                         |
| UPDATE     | 更新条件一致、波形生成動作に依存してタイマ/カウンタがBOTTOMまたはTOPに到達する時。有効な緩衝値を持つ<br>緩衝されるレジスタは制御E(TCAn.CTRLE)レジスタの更新施錠(LUPD)ビットが設定(1)されていない限り更新されます。 |
| CNT        | 計数器レジスタ値                                                                                                                    |
| CMP        | 比較レジスタ値                                                                                                                     |
| PER        | 定期(周期)レジスタ値                                                                                                                 |

一般的に用語の計時器はタイマ/カウンタが周期的クロック刻みを計数する時に使われます。用語の計数器は入力信号が散発的または不規則なクロック刻みを持つ時に使われます。後者は事象計数時の場合に有り得ます。

#### 22.3.2. 初期化

基本動作でタイマ/カウンタの使用を開始するには以下のようにこれらの手順に従ってください。

- 1. 定期(TCAn.PER)レジスタにTOP値を書いてください。
- 2. 制御A(TCAn.CTRLA)レシ<sup>、</sup>スタの許可(ENABLE)ビットに'1'を書くことによって周辺機能を許可してください。計数器はTCAn.CTRL Aレシ<sup>、</sup>スタのクロック選択(CLKSEL)ビット領域で設定した前置分周器に従ったクロック刻みの計数を開始します。
- 3. 任意選択: 事象制御(TCAn.EVCTRL)レジスタの事象入力での計数器事象入力A許可(CNTAEI)ビットに'1'を書くことにより、クロック 刻みに代わって事象が計数されます。
- 4. 計数値は計数(TCAn.CNT)レジスタの計数(CNT)ビット領域から読むことができます。

#### 22.3.3. 動作

#### 22.3.3.1. 標準動作

標準動作では計数器がTOPまたはBOTTOMに達するまで、制御E(TCAn.CTRLE)レジスタの方向(DIR)ビットによって選ばれる方向でクロック刻みを計数します。制御A(TCAn.CTRLA)レジスタのクロック選択(CLKSEL)ビット領域に従って前置分周した周辺機能クロック(CLK\_PER)がクロック刻みを与えます。

計数器が上昇計数中にTOPに達すると、計数器は次のクロック刻みで'0'に丸められます。下降計数時、計数器はBOTTOMに達した時に定期(TCAn.PER)レジスタ値で再設定されます。

計数器が走行している時に計数(TCAn.CNT)レジスタの計数 値を変更することが可能です。TCAn.CNTレジスタへの書き 込みアクセスは計数、解消、再設定よりも高い優先権を持ち、 直ちに行われます。計数器の方向はTCAn.CTRLEレジスタ のDIRビットに書くことによって標準動作の間でも変更するこ とができます。



#### 22.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重緩衝機能を許します。



(PERBUF値でPER更新)

-- <u>TOP</u> -- BOTTOM

#### 22.3.3.3. 周期変更

- 計数器の周期は新しいTOP値を定期(TCAn.PER)レシ<sup>、</sup>スタ へ書くことによって変更されます。
- 緩衝なし:2重緩衝を使わない場合、どんな周期変更も 直ちに行われます。

計数(TCAn.CNT)と定期(TCAn.PER)のレジスタが継続的に

比較されるため、計数器丸めは緩衝なしでの上昇計数時

のどの動作形態でも起こり得ます。現在のTCAn.CNTより

も低い新しいTOP値をTCAn.PERに書く場合、計数器は

比較一致が起こるのに先立って先に丸めを行うでしょう。

図22-6. 緩衝なし周期変更 現CNTより高い新TOP値PER書き込み 計数器丸め MAX ○″更新″ CNT BOTTOM 現CNTより低い新TOP値PER書き込み 図22-7. 緩衝なし2傾斜動作 現CNTより高い新TOP値PER書き込み 計数器丸め MAX ○″更新″ CNT TOP -- воттом 現CNTより低い新TOP値PER書き込み 図22-8. 緩衝使用周期変更 現CNTより高い新TOP値PER書き込み ○″更新″

現CNTより低い新TOP値PER書き込み

- **緩衝有り**:2重緩衝を使うと、緩衝部は何時でも書けて、 未だ正しい動作を維持します。右図の2傾斜 動作に対して示されるように、定期(TCAn.P ER)レジスタは常に"更新"(UPDATE)条件で更 新されます。これは丸めと奇数波形の生成を 防ぎます。
- 注:他に指定されない場合、TCA動作を示す図では緩衝 が使われます。

### 22.3.3.4. 比較チャネル

各比較nチャネルは計数器(TCAn.CNT)値を比較n(TCAn.CMPn)レジスタと継続的に比較します。TCAn.CNTとTCAn.CMPnが等しい場合、比較器は一致を合図します。この一致は次の計時器クロック周期で比較チャネルの割り込み要求フラグ(INTFLAGS.CMPn)を設定(1)し、任意選択の割り込みが生成されます。

CNT

比較n緩衝(TCAn.CMPnBUF)レジスタは定期緩衝(TCAn.PERBUF)レジスタのものと等価な能力を持つ2重緩衝を提供します。2重緩衝はUPDATE条件に従って、計数の流れのTOPまたはBOTTOMのどちらかに対して緩衝値でのTCAn.CMPnレジスタの更新を同期化します。同期化は不具合なしの出力のために奇数長の発生、非対称ハパルスを防ぎます。

CMPnBUFの値はUPATE条件でCMPnに移動され、次の計数から計数器(TCAn.CNT)値と比較されます。

#### 22.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を使うには分割動作が許可されなければなりません。

#### 22.3.3.4.2. 周波数(FRQ)波形生成

周波数生成に関して、周期(T)は定期(TCAn.PER)レジス 図22-9. 周波数波形生成 タに代わって比較0(TCAn.CMP0)レジスタによって制御さ 方向変更 CNT書き込み れます。対応する波形生成(WG)出力はTCAn.CNTとTC ○ "更新" An.CMPnのレジスタ間の各比較一致で交互切り替えされ ←周期(T)→ TOP ます。 CNT 次式は波形周波数(fFRQ)を定義します。 BOTTOM  $f_{CLK\_PER}$  $f_{\rm FRQ} =$ WG出力  $\frac{1}{2N(CMPn+1)}$ 

ここでNは使われる前置分周数(制御A(TCAn.CTRLA)レシ、スタのクロック選択(CLKSEL)ビット領域参照)を表し、fcLK\_PERは周辺機能クロック 周波数です。

生成される波形の最大周波数はTCAn.CMP0レジスタが0(\$0000)を書かれて前置分周が全く使われない(TCAn.CTRLAのCLKSEL= 0、N=1の)時に周辺機能クロック周波数(fcLK\_PER)の半分です。

追加の波形出力WOnを得るにはTCAn.CMP1とTCAn.CMP2のレジスタを使ってください。波形WOnは同一またはWO0に対する変位のどちらかで有り得ます。この変位はTCAn.CMPn、TCAn.CNT、計数方向によって動かすことができます。秒での変位(tOffset)は下表の式を使って計算することができます。この式はCMPn<CMP0の時にだけ有効です。

| 表22-2. 変位式概要                                                                                                         |      |                                              |             |  |
|----------------------------------------------------------------------------------------------------------------------|------|----------------------------------------------|-------------|--|
| 式                                                                                                                    | 計数方向 | CMPn対CNTの状態                                  | 変位          |  |
|                                                                                                                      | 上昇   | CMPn≧CNT                                     | WO0に先行するWOn |  |
| $t_{\text{Offset}} = \left(\frac{\text{CMP0} - \text{CMPn}}{\text{CMP0} + 1}\right) \left(\frac{\text{T}}{2}\right)$ | 下降   | CMP0≦CNT                                     | WO0に後行するWOn |  |
| · · · · · · · · · · · · · · · · · · ·                                                                                |      | CMP0>CNTでCMPn>CNT                            | WO0に後行するWOn |  |
| $t_{om} = (CMPn+1)(T)$                                                                                               | 上昇   | CMP0 <cnt< th=""><th>WO0に後行するWOn</th></cnt<> | WO0に後行するWOn |  |
| $t_{\text{Offset}} = \left(\frac{1}{\text{CMP0}+1}\right) \left(\frac{1}{2}\right)$                                  | 下降   | CMP0≦CNT                                     | WO0に先行するWOn |  |

右図は両式を使うことができるWOn用の先行と後 行の変位を示します。正しい式は計数方向と計 時器が許可される、またはCMPnが変更される時 のCMPn対CNTの状態によって決められます。

#### 図22-10. 上昇計数時の変位



# 図22-11. 波形出力反転



右図は走行時中のCMPn変更が波形をどう反転 し得るかを示します。

#### 22.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=\$0003)で、最大分解能は 16ビット(TCAn.PER=MAX)です。

次式は単一傾斜PWMに対するビットでの正確な分解能 (RPWM\_SS)を計算します。

 $R_{\text{PWM}_SS} = \frac{\log(\text{PER}+1)}{\log(2)}$ 

単一傾斜PWM周波数(fPWM\_SS)は周期設定(TCAn.PE R)、周辺機能クロック周波数(fCLK\_PER)、TCA前置分周器 (TCAn.CTRLAレシ、スタのCLKSELL'ット領域)に依存しま す。それは使う前置分周数をNが表す右式によって計算 されます。



#### 22.3.3.4.4. 2傾斜PWM生成

2傾斜PWM生成に関して、定期(TCAn.PER)レシ<sup>、</sup>スタが周期(T)を制御する一方で、比較n(TCAn.CMPn)レシ<sup>、</sup>スタ値は波形生成(WG)出 力のデューティサイクルを制御します。

下図は2傾斜PWMに対して計数器がBOTTOMからTOPへそしてその後にTOPからBOTTOMへどう繰り返し計数するかを示します。 波形生成器出力はBOTTOMで設定(1)され、上昇計数時の比較一致で解除(0)され、下降計数時の比較一致で設定(1)されます。

CMPn=BOTTOMはWOnで静的なLow信号を生じ、一方でCMPn=TOPはWOnで静的なHigh信号を生じます。

定期(TCAn.PER)レジスタはPWM分解能を定義します。最 小分解能は2ビット(TCAn.PER=\$0003)で、最大分解能は 16ビット(TCAn.PER=MAX)です。

次式は2傾斜PWMに対する正確な分解能(RPWM\_DS)を 計算します。

PWM周波数(fpwm Ds)はTCAn.PERレジスタでの周期設

$$R_{\text{PWM}_{DS}} = \frac{\log(\text{PER}+1)}{\log(2)}$$



定、周辺機能 $p_{Py}/B$ 波数( $f_{CLK\_PER}$ )、TCAn.CTRLA $\nu i$ スタのCLKSELE'ット領域で選ばれる前置 分周器に依存します。それは右式によって計算することができます。  $f_{PWM\_DS} = \frac{f_{CLK\_PER}}{2N \times PER}$ 

ここでNは使う前置分周数を表します。

2傾斜PWMの使用は単一傾斜PWM動作と比較して周期毎に倍の計時器増加数のため、概ね半分の最大動作周波数になります。

#### 22.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出力を反転します。



#### 22.3.3.5. タイマ/カウンタ指令

周辺機能の状態を直ちに変更するために、ソフトウェアによって1組の指令を発行することができます。これらの指令は更新、再始動、リ セットの信号の直接制御を与えます。指令は制御E設定(TCAn.CTRLESET)レジスタの指令(CMD)ビット領域に各々の値を書くことによっ て発行されます。

更新(UPDATE)指令はUPDATE指令が制御E(TCAn.CTRLESET/CLR)レジスタの更新施錠(LUPD)ビットの状態によって影響を及ぼされないことを除き、更新条件が起こる時と同じ効果を持ちます。

ソフトウェアは再始動(RESTART)指令を発行することによって現在の波形周期の再始動を強制することができます。この場合は計数器と 全ての波形出力が'0'に設定されます。

リセット(RESET)指令は全てのタイマ/カウンタレジスタをそれらの初期値に設定します。RESET指令はタイマ/カウンタが走行していない(TCAn. CTRLAレジスタの許可(ENABLE)=0の)時にだけ発行することができます。

#### 22.3.3.6. 分割動作 - 2つの8ビット タイマ/カウンタ

#### 分割動作概要

分割動作はTCAで計時器とPWMチャネルの数を倍にするために提供されます。この分割動作では、各々がPWM生成用に3つの比較 チャネルを持つ2つの独立した8ビット計時器として働きます。分割動作は単一傾斜下降計数でだけ動きます。事象で制御される操作は 分割動作で支援されません。

右図は分割動作での単一傾斜PWM生成を示します。波形生成部出力はBOTTOMで解除(0)され、計数器値(TCAn.xCNT)と比較n(TCAn.xCMPn)のレジスタ間の比較一致で設定(1)です。

CMPn=BOTTOMやCMPn>TOPはWOnでの固定Low信 号を生じます。

分割動作の有効化はいくつかのレジスタとレジスタビットの 機能を変更します。この変更は独立したレジスタ割り当て で記述されます(「22.6. レジスタ要約 - 分割動作」をご覧 ください)。



# 標準動作と比べた分割動作の違い

- ・計数
  - 下降計数専用
  - 下位バイトタイマ/カウンタ(TCAn.LCNT)レジスタと上位バイトタイマ/カウンタ(TCAn.HCNT)レジスタは独立です。
- ・波形生成

- 単一傾斜PWM専用(TCAn.CTRLBレジスタのWGMODE=SINGLESLOPE)

- ・割り込み
  - 下位バイト タイマ/カウンタ(TCAn.LCNT)レジスタに対する変更なし
  - 上位バイトタイマ/カウンタ(TCAn.HCNT)レジスタに対する下溢れ割り込み
  - 比較n上位バイト(TCAn.HCMPn)レジスタに対する比較割り込みと割り込み要求フラグなし
- •事象活動:不適合
- ・緩衝レジ゙スタと緩衝有効フラグ: 不使用
- ・レシブスタ アクセス:全てのレジブタに対してバイト アクセス

#### 構成図



# 分割動作初期化

標準動作と分割動作の間を移る時に、いくつのレジスタとビットの機能が変わりますが、それらの値は変わりません。この理由のため、予期せぬ動きを避けるため、動作を変更する時に周辺機能を禁止(TCAn.CTRLAレジスタのENABLE=0)して、ハートリセット(制御E設定(T CAn.CTRLESET)レジスタの指令(CMD)=RESET)を行うことが推奨されます。

ハードリセット後に基本的な分割動作でタイマ/カウンタの使用を開始するには、以下のこれらの手順に従ってください。

- 1. 制御D(TCAn.CTRLD)レジスタの分割動作許可(SPLITM)ビットに'1'を書くことによって分割動作を許可してください。
- 2. 定期(TCAn.H/LPER)レジスタにTOP値を書いてください。
- 3. 制御A(TCAn.CTRLA)レシ<sup>、</sup>スタの許可(ENABLE)ビットに'1'を書くことによって周辺機能を許可してください。計数器はTCAn.CTRL Aレシ<sup>、</sup>スタのクロック選択(CLKSEL)ビット領域に従ってクロック刻みを計数します。
- 4. 計数器値は計数(TCAn.H/LCNT)レジスタの計数(H/LCNT)ヒット領域から読むことができます。

分割動作の有効化はいくつかのレジスタとレジスタビットの機能の変更に帰着します。この変更は分離したレジスタ配置で記述されます。

#### 22.3.4. 事象

TCAは下表で記述される事象を生成することができます。TCAn\_HUNFを除く全ての生成部は標準動作と分割動作の操作間で共有 されます。生成部名は生成部が各動作で次のように表す特定信号を示します。標準動作での溢れと分割動作での下位パイト下溢れ に対応するOVF\_LUNF。同じことがCMPn\_LCMPnに適用されます。

#### 表22-3. TCAでの事象生成部

| 生    | 成部名        | 説明                                       | 市名刊 | ᄷᇥᄵᇞᄵᅒᆧ  | 事象長         |
|------|------------|------------------------------------------|-----|----------|-------------|
| 周辺機能 | 事象         | 市元リケ                                     | 事象型 | 生成クロック領域 | 争豕艾         |
|      | OVF_LUNF   | 標準動作: 溢れ<br>分割動作: 下位バ仆計時器下溢れ             |     |          |             |
|      | HUNF       | 標準動作:利用不可<br>分割動作:上位バ仆計時器下溢れ             |     |          |             |
| TCAn | CMP0_LCMP0 | 標準動作:比較チャネル0一致<br>分割動作:下位バイト計時器比較チャネル0一致 | パルス | CLK_PER  | 1 CLK_PER周期 |
|      | CMP1_LCMP1 | 標準動作:比較チャネル1一致<br>分割動作:下位バイト計時器比較チャネル1一致 |     |          |             |
|      | CMP2_LCMP2 | 標準動作:比較チャネル2一致<br>分割動作:下位バイト計時器比較チャネル2一致 |     |          |             |

注: 事象生成の条件は標準動作と分割動作の両方に対して割り込み要求フラク(TCAn.INTFLAGS)レジスタで対応する割り込み要求フ ラグを掲げるそれらと同じです。

TCAは入力事象での検出と活動のために2つの事象使用部を持ちます。下表は事象使用部とそれらの関連機能を記述します。

| 表22-4. TC | 表22-4. TCAでの事象使用部 |                                  |      |        |  |  |  |  |  |
|-----------|-------------------|----------------------------------|------|--------|--|--|--|--|--|
| 使用        | 部名                | 説明                               | 入力検出 | 同期/非同期 |  |  |  |  |  |
| 周辺機能      | 入力                | נקיזמ                            |      |        |  |  |  |  |  |
|           |                   | 正事象端で計数                          | 端    |        |  |  |  |  |  |
|           | CNTA              | 両事象端で計数                          | 山山   |        |  |  |  |  |  |
|           | CNIA              | 事象信号がHighの間計数                    |      |        |  |  |  |  |  |
| TCAn      |                   | 事象レベルが計数方向を制御、Lowの時に上昇、Highの時に下降 | レヘッル | 同期     |  |  |  |  |  |
| TCAII     |                   | 事象レベルが計数方向を制御、Lowの時に上昇、Highの時に下降 |      | 问为     |  |  |  |  |  |
|           | CNTB              | 正事象端で計数器再始動                      | 端    |        |  |  |  |  |  |
|           | CNID              | 両事象端で計数器再始動                      | 凹面   |        |  |  |  |  |  |
|           |                   | 事象信号がHighの間再始動                   | レヘッル |        |  |  |  |  |  |

上表で記述される特定の活動は事象制御(TCAn.EVCTRL)レジスタの事象活動(EVACTA、EVACTB)ビットに書くことによって選ばれます。入力事象はTCAn.EVCTRLの事象入力での計数許可(CNTAEI、CNTBEI)ビットに'1'を書くことによって許可されます。

EVACTAとEVACTBの両方が計数方向を制御するように構成設定される場合、事象信号は計数方向を決めるために論理和(OR)されます。そのため上向きに計数するには計数器に対して両事象入力がLow('0')でなければなりません。

注: 1. 事象入力は分割動作で使われません。

2. レベル入力検出での事象活動は事象周波数が計時器の周波数未満の場合にだけ確実に動きます。

事象型と事象システム構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照してください。

#### 22.3.5. 割り込み

#### 表22-5.標準動作で利用可能な割り込みべうタと供給元

| 名称   | ベクタ説明       | 条件                  |
|------|-------------|---------------------|
| OVF  | 溢れ割り込み      | 計数器がTOPまたはBOTTOMに到達 |
| CMP0 | 比較チャネル0割り込み | 計数器値と比較0レジスタ間の一致    |
| CMP1 | 比較チャネル1割り込み | 計数器値と比較1レジスタ間の一致    |
| CMP2 | 比較チャネル2割り込み | 計数器値と比較2レジスタ間の一致    |

#### 表22-6. 分割動作で利用可能な割り込みベクタと供給元

| 名称    | ベクタ説明        | 条件                    |  |  |  |  |  |  |
|-------|--------------|-----------------------|--|--|--|--|--|--|
| LUNF  | 下位バイト下溢れ割り込み | 下位バイ計時器がBOTTOMに到達     |  |  |  |  |  |  |
| HUNF  | 上位バイト下溢れ割り込み | 上位バイ計時器がBOTTOMに到達     |  |  |  |  |  |  |
| LCMP0 | 比較チャネル0割り込み  | 計数器値と下位バイト比較0レジスタ間の一致 |  |  |  |  |  |  |
| LCMP1 | 比較チャネル1割り込み  | 計数器値と下位バイト比較1レジスタ間の一致 |  |  |  |  |  |  |
| LCMP2 | 比較チャネル2割り込み  | 計数器値と下位バイト比較2レジスタ間の一致 |  |  |  |  |  |  |

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

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

TCAは既定でスタンハイ休止動作に於いて禁止されます。休止動作に入ると直ぐに停止されます。この単位部は制御A(TCAn.CTRL A)レジスタのスタンハイ時走行(RUNSTDBY)ビットが'1'を書かれる場合にスタンハイ休止動作で完全な動作に留まることができます。 全ての動作はハ<sup>®</sup>ワーダウン休止動作で停止します。

# 22.4. レジスタ要約 - 標準動作

| 変位         | 略称               | ビット位置       | ビット7     | ビット6      | ビット5   | ビット4   | ビット3   | <b>ビット2</b> | ビット1         | ビットロ   |
|------------|------------------|-------------|----------|-----------|--------|--------|--------|-------------|--------------|--------|
| +\$00      | CTRLA            | 7~0         | RUNSTDBY |           |        |        |        | 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 \sim 0$  | I        | EVACTB2~( | )      | CNTBEI |        | EVACTA2~(   | þ            | CNTAEI |
| +\$0A      | INTCTRL          | 7~0         |          | CMP2      | CMP1   | CMP0   |        |             |              | OVF    |
| +\$0B      | INTFLAGS         | 7~0         |          | CMP2      | CMP1   | CMP0   |        |             |              | OVF    |
| +\$0C      | 子、约              |             |          |           |        |        |        |             |              |        |
| +\$0D      | 予約               |             |          |           |        |        |        |             |              |        |
| +\$0E      | DBGCTRL          | 7~0         |          |           |        |        |        |             |              | DBGRUN |
| +\$0F      | TEMP             | 7~0         |          |           |        | TEM    | P7~0   |             |              |        |
| +\$10      | 7 44             |             |          |           |        |        |        |             |              |        |
| +\$1F      | 予約               |             |          |           |        |        |        |             |              |        |
| +\$20      |                  | 7~0         |          |           |        | CNT    | 7~0    |             |              |        |
| +\$21      | CNT              | 15~8        |          |           |        |        | 15~8   |             |              |        |
| +\$22      |                  |             |          |           |        |        |        |             |              |        |
| →<br>+\$25 | 予約               |             |          |           |        |        |        |             |              |        |
| +\$26      |                  | 7~0         |          |           |        | PER    |        |             |              |        |
| +\$27      | PER              | $15 \sim 8$ |          |           |        |        | 15~8   | +           | <del> </del> |        |
| +\$28      |                  | 7~0         |          |           |        |        | P7~0   | +           | +            |        |
| +\$29      | CMP0             | 15~8        |          |           |        |        |        | ł           | ł            |        |
| +\$2A      |                  | 7~0         |          |           |        |        | 27~0   | 1           | 1            |        |
| +\$2B      | CMP1             | 15~8        |          |           |        |        | 15~8   |             |              |        |
| +\$2C      |                  | 7~0         |          |           |        |        |        |             |              |        |
| +\$2D      | CMP2             | 15~8        |          |           |        | CMP    | 215~8  |             |              |        |
| +\$2E      | $\rightarrow 44$ |             |          |           |        |        |        |             |              |        |
| +\$35      | 予約               |             |          |           |        |        |        |             |              |        |
| +\$36      |                  | 7~0         |          |           |        | PERB   | UF7~0  |             |              |        |
| +\$37      | PERBUF           | $15 \sim 8$ |          |           |        |        | JF15~8 |             |              |        |
| +\$38      |                  | <u>7~0</u>  |          |           |        |        | UF7~0  |             |              |        |
| +\$39      | CMP0BUF          | $15 \sim 8$ |          |           |        |        | JF15~8 |             |              |        |
| +\$3A      |                  | 7~0         |          |           |        |        | UF7~0  |             |              |        |
| +\$3B      | CMP1BUF          | $15 \sim 8$ |          |           |        |        | JF15~8 |             |              |        |
| +\$3C      |                  | 7~0         |          |           |        |        | UF7~0  |             |              |        |
| +\$3D      | CMP2BUF          | 15~8        |          |           |        |        | JF15~8 |             |              |        |
|            |                  | 10 0        |          |           | 1      |        |        | 1           | 1            |        |

# 22.5. レジスタ説明 - 標準動作

### 22.5.1. CTRLA - 制御A (Control A) - 標準/分割動作共通

#### 名称 : CTRLA

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

### 特質 :-

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

# ビット7 - RUNSTDBY: スタンハイ時走行 (Run Standby)

このビットへの'1'書き込みはこの周辺機能にスタンバイ休止動作での走行を許します。

#### ● ビット3~1 - CLKSEL2~0: クロック選択 (Clock Select)

これらのビットはタイマ/カウンタに対するクロック周波数を選びます。

| 值                                      | 000              | 001        | 010        | 011        | 100         | 101         | 110          | 111                   |
|----------------------------------------|------------------|------------|------------|------------|-------------|-------------|--------------|-----------------------|
| 名称                                     | DIV1             | DIV2       | DIV4       | DIV8       | DIV16       | DIV64       | DIV256       | DIV1024               |
| <b>説明</b> ( <i>f</i> <sub>TCA</sub> =) | <i>f</i> clk_per | fclk_per/2 | fclk_per/4 | fclk_per/8 | fclk_per/16 | fclk_per/64 | fclk_per/256 | <i>f</i> clk_per/1024 |

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

| 値  | 0            | 1            |
|----|--------------|--------------|
| 説明 | 周辺機能は禁止されます。 | 周辺機能は許可されます。 |

# 22.5.2. CTRLB - 制御B (Control B) - 標準動作

| 名称   | • | CTRLB |
|------|---|-------|
| 1111 | • | UINLD |

#### **変位**:+\$01

リセット : \$00

#### 特質:-

| <u> ビット</u> | 7 | 6      | 5      | 4      | 3     | 2   | 1         | 0      |
|-------------|---|--------|--------|--------|-------|-----|-----------|--------|
|             |   | CMP2EN | CMP1EN | CMP0EN | ALUPD |     | WGMODE2~0 | )<br>) |
| アクセス種別      | 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レシ <sup>゛</sup> スタのLUPDビットは<br>自動的に設定 <mark>(1</mark> )/解除(0)されます。 |

#### ● ビット2~0 - WGMODE2~0:波形生成動作(Waveform Generation Mode)

このビット領域は波形生成動作を選び、計数器の計数進行、TOP値、UPDATE条件、割り込み条件、生成される波形の形式を制御します。

標準形態の動作では波形生成が全く実行されません。他の全ての動作形態に対して対応する比較n許可(CMPnEN)ビットを設定(1) する場合、波形生成部出力がポートピンに直結されるだけです。ポートピンの方向は出力として設定されなければなりません。

| 1    | 直   | 000                   | 001                   | 010  | 011         | 100  | 101    | 1 1 0      | 111      |
|------|-----|-----------------------|-----------------------|------|-------------|------|--------|------------|----------|
| 名    | 称   | NORMAL                | FRQ                   | _    | SINGLESLOPE | _    | DSTOP  | DSBOTH     | DSBOTTOM |
|      | 動作  | 標準                    | 周波数                   | (予約) | 1傾斜PWM      | (予約) | 2傾斜PWM | 2傾斜PWM     | 2傾斜PWM   |
| 説明   | TOP | PER                   | CMP0                  | -    | PER         | -    | PER    | PER        | PER      |
| 市元中日 | 更新  | TOP( <mark>注</mark> ) | TOP( <mark>注</mark> ) | -    | BOTTOM      | -    | BOTTOM | BOTTOM     | BOTTOM   |
|      | OVF | TOP( <mark>注</mark> ) | TOP( <mark>注</mark> ) | -    | BOTTOM      | -    | TOP    | ТОРとВОТТОМ | BOTTOM   |

**注**: 上昇計数時

#### 22.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ビットは迂回されます。

22.5.4. CTRLD - 制御D (Control D) - 標準/分割動作共通

| 名称 : CTRLD<br>変位 : +\$03<br>リセット : \$00<br>特質 : - |     |        |
|---------------------------------------------------|-----|--------|
| ניֿאַל <u>7</u> 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ビット動作と比べてレシ、スタ割り当てが変わります。

# 22.5.5. CTRLECLR - 制御E解除 (Control Register E Clear) - 標準動作

名称:CTRLECLR

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

特質 :-

そのビット位置に'1'を書くことによって個別ビットを解除(0)するため、このレジスタを読み-変更-書き(RMW)の代わりに使ってください。

| ヒット    | 7 | 6 | 5 | 4 | 3   | 2    | 1    | 0   |
|--------|---|---|---|---|-----|------|------|-----|
|        |   |   |   |   | CMI | D1,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'として読みます。

| 1 | 値  | 0 0  | 01     | 1 0     | 11                        |
|---|----|------|--------|---------|---------------------------|
| 名 | S称 | NONE | UPDATE | RESTART | RESET                     |
| 訪 | 兑明 | 指令なし | 強制更新   | 強制再始動   | 強制ハート リセット (TCAが許可の場合は無効) |

#### ● ビット1 - LUPD : 更新施錠 (Lock Update)

更新施錠は更新を実行するのに先立って全ての緩衝部が有効であることを保証するのに使うことができます。

| 值 | 0 | 1                                                                   |
|---|---|---------------------------------------------------------------------|
|   |   | 例えUPDATE条件が起きても、緩衝されるレジスタの更新は実行されません。この設定は指令ビット領域によって発行される更新を妨げません。 |

#### ● ビット0 - DIR : 計数方向 (Counter Direction)

通常、このビットは波形生成動作または事象活動によってハートウェアで制御されますが、ソフトウェアからも変更することができます。

| 值  | 0            | 1            |
|----|--------------|--------------|
| 説明 | 計数器は上昇計数(増加) | 計数器は下降計数(減少) |

# 22.5.6. CTRLESET - 制御E設定 (Control Register E Set) - 標準動作

名称: CTRLESET

**変位** : +\$05

**リセット** : \$00

特質 :-

そのビット位置に'1'を書くことによって個別ビットを設定(1)するため、このレジスタを読み-変更-書き(RMW)の代わりに使ってください。

| ビット    | 7 | 6 | 5 | 4 | 3   | 2    | 1    | 0   |
|--------|---|---|---|---|-----|------|------|-----|
|        |   |   |   |   | CMI | D1,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    | 10      | 11                        |
|----|------|--------|---------|---------------------------|
| 名称 | NONE | UPDATE | RESTART | RESET                     |
| 説明 | 指令なし | 強制更新   | 強制再始動   | 強制ハート リセット (TCAが許可の場合は無効) |

# ● ビット1 - LUPD : 更新施錠 (Lock Update)

更新を施錠することは更新を実行するのに先立って全ての緩衝部が有効であることを保証します。

| 値 | 0 | 1                                                                   |
|---|---|---------------------------------------------------------------------|
|   |   | 例えUPDATE条件が起きても、緩衝されるレジスタの更新は実行されません。この設定は指令ビット領域によって発行される更新を妨げません。 |

#### ● ビット0 - DIR : 計数方向 (Counter Direction)

通常、このビットは波形生成動作または事象活動によってハートウェアで制御されますが、ソフトウェアからも変更することができます。

| 値  | 0            | 1            |  |  |
|----|--------------|--------------|--|--|
| 説明 | 計数器は上昇計数(増加) | 計数器は下降計数(減少) |  |  |

# 22.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)します。

# 22.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)

CMPnBVビットは新しい値が対応する比較n緩衝(TCAn.CMPnBUF)レジスタに書かれた時に設定(1)されます。これらのビットはUPDATE 条件で自動的に解除(0)します。

# ● ビット0 - PERBV : 定期緩衝有効 (Period Buffer Valid)

このビットは新しい値が定期緩衝(TCAn.PERBUF)レジスタに書かれた時に設定(1)されます。このビットはUPDATE条件で自動的に解除(0)します。

# 22.5.9. EVCTRL - 事象制御 (Event Control) - 標準動作専用

| 名称 | : EVCTRL |
|----|----------|
|    |          |

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

| ビット    | 7         | 6   | 5   | 4      | 3            | 2   | 1   | 0      |
|--------|-----------|-----|-----|--------|--------------|-----|-----|--------|
|        | EVACTB2~0 |     |     | CNTBEI | EI EVACTA2~0 |     |     | CNTAEI |
| アクセス種別 | 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 - EVACTB2~0 : 事象活動B (Event Action B)

これらのビットは或る事象条件で計数器が取る活動を定義します。

| 値     | 名称              | 説明                                                                                      |
|-------|-----------------|-----------------------------------------------------------------------------------------|
| 000   | NONE            | 活動なし                                                                                    |
| 011   | UPDOWN          | 前置分周したクロック周期か、事象入力A用設定に従って一致する事象を計数。事象信号は計数方向を制御し、Lowの時に上昇、Highの時に下降。方向は計数器計数時にラッチされます。 |
| 100   | RESTART_POSEDGE | 正事象端で計数器再始動                                                                             |
| 101   | RESTART_ANYEDGE | 両事象端で計数器再始動                                                                             |
| 1 1 0 | RESTART_HIGHLVL | 事象信号がHighの間、計数器再始動                                                                      |
| その他   | -               | (予約)                                                                                    |

#### ● ビット4 - CNTBEI : 計数器事象入力B許可 (Enable Counter Event Input B)

| 値  |   | 0           | 1                          |  |  |
|----|---|-------------|----------------------------|--|--|
| 説明 | 月 | 計数器事象入力Bは禁止 | 計数器事象入力BはEVACTBビット領域に従って許可 |  |  |

#### ● ビット3~1 - EVACTA2~0:事象活動A (Event Action A)

これらのビットは或る事象条件で計数器が取る活動を定義します。

| 値   | 名称          | 説明                                                                   |
|-----|-------------|----------------------------------------------------------------------|
| 000 | CNT_POSEDGE | 正事象端で計数                                                              |
| 001 | CNT_ANYEDGE | 両事象端で計数                                                              |
| 010 | CNT_HIGHLVL | 事象信号がHighの間、前置分周されたクロック周期を計数                                         |
| 011 | UPDOWN      | 前置分周されたクロック周期を計数。事象信号は計数方向を制御し、Lowの時に上昇、Highの時に下降。方向は計数器計数時にラッチされます。 |
| その他 | _           | (予約)                                                                 |

# ● ビット0 - CNTAEI : 計数器事象入力A許可 (Enable Counter Event Input A)

| 値  | 0           | 1                          |  |  |
|----|-------------|----------------------------|--|--|
| 説明 | 計数器事象入力Aは禁止 | 計数器事象入力AはEVACTAビット領域に従って許可 |  |  |

# 22.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)
 OVFビットへの'1'書き込みは上下溢れ割り込みを許可します。

22.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フラグは計数(TCAn.CNT)レジスタと対応する比較(TCAn.CMPn)レジスタ間で比較一致が起こる時に設定(1)されます。CMPnフラグは自動的に解除(0)されません。そのビット位置に'1'を書くことによってだけ解除(0)されます。

#### ● ビット0 - OVF : 上下溢れ割り込み要求フラグ(Timer Overflow/Underflow Interrupt Flag)

このフラグは波形生成動作(WGMODE)設定に依存して、TOP(上溢れ)またはBOTTOM(下溢れ)のどちらかで設定(1)されます。OVF7 ラグは自動的に解除(0)さません。このビット位置に'1'を書くことによってだけ解除(0)されます。

22.5.12. DBGCTRL - デバッグ制御 (Debug Control) - 標準/分割動作共通

**変位** : +\$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停止中のデバッグ動作中断で走行継続 |

# 22.5.13. TEMP - 一時レジスタ (Temporary bits for 16-bit Access) - 標準動作専用

名称:TEMP

**変位**:+\$0F

リセット : \$00

特質 :-

一時レジスタはこの周辺機能の16ビットレジスタへの16ビット単一周期アクセスのためにCPUによって使われます。このレジスタはこの周辺機能の全ての16ビットレジスタに対して共通でソフトウェアによって読み書きすることができます。16ビットレジスタの読み書きのより多くの詳細については「メモリ」章の「16ビットレジスタのアクセス」を参照してください。



• ビット7~0 - TEMP7~0:一時値 (Temporary Bits for 16-bit Access)

## 22.5.14. CNT - 計数 (Counter Register) - 標準動作

名称: CNT (CNTH, CNTL)

変位 : +\$20 リセット : \$0000

#### 507 . ↓00 特質:-

特頁:-

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

| <u>ـــــــــــــــــــــــــــــــــــ</u> | 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   | 0   | 0   |

• ビット15~8 - CNT15~8 : 計数値上位バイ (Counter high byte)

このビット領域は16ビット計数レジスタの上位バイトを保持します。

• ビット7~0 - CNT7~0 : 計数値下位バ仆 (Counter low byte)

このビット領域は16ビット計数レジスタの下位バイトを保持します。

#### 22.5.15. PER - 定期 (Period Register) - 標準動作

名称: PER (PERH, PERL)

**変位** : +\$26

# **リセット**: \$FFFF

特質:-

TCAn.PERレジスタは周波数波形生成(FRQ)を除く全ての動作形態でタイマ/カウンタの16ビットTOP値を含みます。

TCAn.PERHとTCAn.PERLのレシ<sup>\*</sup>スタ対は16ビット値のTCAn.PERを表します。下位ハ<sup>\*</sup>イト[7~0](接尾辞L)は変位原点でアクセスできます。 上位ハ<sup>\*</sup>イト[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   | 3    | 2   | 1   | 0   |
|        |     |     |     | PEF | 27~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 - PER15~8: 定期値上位バイ (Periodic high byte) このビット領域は16ビット定期レジスタの上位バイトを保持します。

ビット7~0 - PER7~0: 定期値下位バイト (Periodic low byte)
 このビット領域は16ビット定期レジスタの下位バイトを保持します。

## 22.5.16. CMPn - 比較n (Compare n Register) - 標準動作

名称: CMP0 (CMP0H, CMP0L): CMP1 (CMP1H, CMP1L): CMP2 (CMP2H, CMP2L)

リセット : \$0000

特質 :-

このレジスタは継続的に計数器値と比較します。通常、比較器からの出力は波形を生成するのに使われます。

TCAn.CMPnレジスタはUPDATE条件発生時に対応する比較緩衝(TCAn.CMPnBUF)レジスタからの緩衝値で更新されます。

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

| <b>ビ</b> ット | 15  | 14  | 13  | 12  | 11    | 10  | 9   | 8   |
|-------------|-----|-----|-----|-----|-------|-----|-----|-----|
|             |     |     |     | CMP | 215~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   |
|             |     |     |     | CMI | 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ビット比較レジスタの下位ハイトを保持します。

#### 22.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   |
|--------|-----|-----|-----|-------|--------|-----|-----|-----|
|        |     |     |     | PERBL | 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   |
|        |     |     |     | PERBU | 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ビット定期緩衝レジスタの下位バイトを保持します。

### 22.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   | 6   | 5   | 4     | 3      | 2   | 1   | 0   |
|        |     |     |     | CMPB  | UF7~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 - CMPBUF15~8:比較緩衝値上位バイト (Compare Buffer high byte) これらのビットは16ビット比較緩衝レジスタの上位バイトを保持します。

● ビット7~0 - CMPBUF7~0 : 比較緩衝値下位バイト (Compare Buffer low byte)

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

#### 変位 略称 ビット位置 ビット6 ビット5 ビット4 ビット3 ビット2 ビット1 ビットロ ビット7 RUNSTDBY CLKSEL2~0 ENABLE +\$00 **CTRLA** $7 \sim 0$ +\$01 LCMP0EN CTRLB $7 \sim 0$ HCMP2EN HCMP1EN HCMP0EN LCMP2EN LCMP1EN +\$02 HCMP2OV HCMP1OV HCMP0OV LCMP2OV LCMP1OV LCMP0OV CTRLC $7 \sim 0$ +\$03 CTRLD $7 \sim 0$ SPLITM +\$04CTRLECLR $7 \sim 0$ CMD1,0 CMDEN1,0 CMD1,0 CMDEN1,0 +\$05 CTRLESET $7 \sim 0$ +\$06 予約 +\$09 INTCTRL +\$0A $7 \sim 0$ LCMP2 LCMP1 LCMP0 HUNF LUNF +\$0B INTFLAGS LCMP1 HUNF LUNF $7 \sim 0$ LCMP2 LCMP0 +\$0C 予約 +\$0D +\$0E $7 \sim 0$ DBGRUN DBGCTRL +\$0F 予約 +\$1F +\$20 LCNT7~0 LCNT $7\sim 0$ +\$21 HCNT HCNT7~0 $7 \sim 0$ +\$22 予約 +\$25 +\$26 LPER $7 \sim 0$ LPER7~0 +\$27 HPER $7 \sim 0$ HPER7~0 +\$28 LCMP7~0 LCMP0 $7 \sim 0$ +\$29 HCMP0 $7 \sim 0$ HCMP7~0 +\$2A LCMP1 $7 \sim 0$ LCMP7~0 +\$2B HCMP1 $7 \sim 0$ HCMP7~0 $7 \sim 0$ +\$2C LCMP2 LCMP7~0 +\$2D HCMP2 $7 \sim 0$ HCMP7~0

# 22.6. レジスタ要約 - 分割動作

# 22.7. レジスタ説明 - 分割動作

#### 22.7.1. CTRLA - 制御A (Control A) - 標準/分割動作共通

#### 名称:CTRLA

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

#### 特質 :-

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

#### ビット7 - RUNSTDBY: スタンハイ時走行 (Run Standby)

このビットへの'1'書き込みはこの周辺機能にスタンバイ休止動作での走行を許します。

#### • ビット3~1 - CLKSEL2~0: クロック選択 (Clock Select)

これらのビットはタイマ/カウンタに対するクロック周波数を選びます。

| 値                       | 000              | 001        | 010        | 011        | 100         | 101         | 110          | 111                   |
|-------------------------|------------------|------------|------------|------------|-------------|-------------|--------------|-----------------------|
| 名称                      | DIV1             | DIV2       | DIV4       | DIV8       | DIV16       | DIV64       | DIV256       | DIV1024               |
| 説明 (f <sub>TCA</sub> =) | <i>f</i> clk_per | fclk_per/2 | fclk_per/4 | fclk_per/8 | fclk_per/16 | fclk_per/64 | fclk_per/256 | <i>f</i> clk_per/1024 |

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

| 値  | 0                 | 1                 |
|----|-------------------|-------------------|
| 兑明 | 周辺機能(TCA)は禁止されます。 | 周辺機能(TCA)は許可されます。 |

### 22.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+3ピンに対するポート出力(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波形生成動作形態でのLCMPnENビット設定(1)は対応するWOnビンに対するポート出力(PORTx.OUT)レジスタを無効 にします。 22.7.3. CTRLC - 制御C (Control C) - 分割動作

名称:CTRLC

**変位**:+\$02

リセット : \$00

特質 :-

| ビット    | 7 | 6       | 5       | 4       | 3 | 2       | 1       | 0       |
|--------|---|---------|---------|---------|---|---------|---------|---------|
|        |   | HCMP2OV | HCMP1OV | HCMP0OV |   | LCMP2OV | LCMP10V | 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 - HCMP0OV : 上位バイト比較0出力値 (High-byte Compare 0 Output Value)

HCMPnOVビットはタイマ/カウンタが許可されない時に波形生成部の出力値への直接アクセスを許します。これはタイマ/カウンタが走行していない時にWOn+3出力値を設定(1)または解除(0)するのに使われます。

• ビット2 - LCMP2OV: 下位バイル比較2出力値 (Low-byte Compare 2 Output Value) LCMP0OVをご覧ください。

● ビット1 - LCMP10V:下位バイト比較1出力値 (Low-byte Compare 1 Output Value) LCMP0OVをご覧ください。

# • ビット0 - LCMP0OV : 下位バイ比較0出力値 (Low-byte Compare 0 Output Value)

LCMPnOVビットはタイマ/カウンタが許可されない時に波形生成部の出力値への直接アクセスを許します。これはタイマ/カウンタが走行していない時にWOn出力値を設定(1)または解除(0)するのに使われます。

注: この出力がパットに接続される時に、制御B(TCAn.CTRLB)レジスタの上位/下位パイト比較n許可(xCMPnEN)ビットが設定(1)されな い限り、これらのビットの上書きは動きません。この出力がCCLに接続される場合、TCAn.CTRLBレジスタのxCMPnENビットは迂回さ れます。

### 22.7.4. CTRLD - 制御D (Control D) - 標準/分割動作共通

|--|

- **変位** : +\$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      |

• ビットO - SPLITM : 分割動作許可 (Enalbe Split Mode)

このビットはタイマ/カウンタを分割動作形態に設定し、2つの8ビットタイマ/カウンタとして動きます。標準16ビット動作と比べてレシ、スタ割り当てが変わります。

22.7.5. CTRLECLR - 制御E解除 (Control Register E Clear) - 分割動作

名称:CTRLECLR

**変位**:+\$04

リセット : \$00

特質 :-

そのビット位置に'1'を書くことによって個別ビットを解除(0)するため、このレジスタを読み-変更-書き(RMW)の代わりに使ってください。

| ヒ <sup>*</sup> ット | 7 | 6 | 5 | 4 | 3      | 2   | 1        | 0   |
|-------------------|---|---|---|---|--------|-----|----------|-----|
|                   |   |   |   |   | CMD1,0 |     | CMDEN1,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  | 01   | 1 0     | 11                        |
|----|------|------|---------|---------------------------|
| 名称 | NONE | -    | RESTART | RESET                     |
| 説明 | 指令なし | (予約) | 強制再始動   | 強制ハート リセット (TCAが許可の場合は無効) |

#### • ビット1,0 - CMDEN1,0: 指令許可 (Command enable)

このビット領域はCMDビットによって与えられた指令がどのタイマ/カウンタに適用するかを構成設定します。

| 値  | 0 0  | 01   | 1 0  | 11                           |  |
|----|------|------|------|------------------------------|--|
| 名称 | NONE | -    | -    | BOTH                         |  |
| 説明 | なし   | (予約) | (予約) | 指令は上下バイトの両<br>タイマ/カウンタに対して適用 |  |

#### 22.7.6. CTRLESET - 制御E設定 (Control Register E Set) - 分割動作

名称: CTRLESET

**変位** : +\$05

リセット : \$00

特質 :-

そのビット位置に'1'を書くことによって個別ビットを設定(1)するため、このレジスタを読み-変更-書き(RMW)の代わりに使ってください。

| ヒット    | 7 | 6 | 5 | 4 | 3      | 2   | 1        | 0   |
|--------|---|---|---|---|--------|-----|----------|-----|
|        |   |   |   |   | CMD1,0 |     | CMDEN1,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  | 01   | 10      | 11                        |
|----|------|------|---------|---------------------------|
| 名称 | NONE | -    | RESTART | RESET                     |
| 説明 | 指令なし | (予約) | 強制再始動   | 強制ハート リセット (TCAが許可の場合は無効) |

#### ● ビット1,0 - CMDEN1,0 : 指令許可 (Command enable)

このビット領域はCMDビットによって与えられた指令がどのタイマ/カウンタに適用するかを構成設定します。

| 値  | 0 0  | 0 1  | 1 0  | 11                           |
|----|------|------|------|------------------------------|
| 名称 | NONE | _    | -    | BOTH                         |
| 説明 | なし   | (予約) | (予約) | 指令は上下バイトの両<br>タイマ/カウンタに対して適用 |

22.7.7. INTCTRL - 割り込み制御 (Interrupt Control) - 分割動作

名称: INTCTRL

**変位** : +\$0A

リセット : \$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 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'書き込みは下位バイト下溢れ割り込みを許可します。

22.7.8. INTFLAGS - 割り込み要求フラク (Interrupt Flag Register) - 分割動作

名称 : INTFLAGS 変位 : +\$0B リセット : \$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割り込み要求7ラグ (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'書き込みがこれを行います。

### 22.7.9. DBGCTRL - デバッグ制御 (Debug Control) - 標準/分割動作共通

| 変<br>リ | i称:DBGCT<br>E位:+\$0E<br>セット:\$00<br>F質:- | `RL |   |   |   |   |   |   |        |
|--------|------------------------------------------|-----|---|---|---|---|---|---|--------|
|        | ビット                                      | 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停止中のデバッグ動作中断で走行継続 |

22.7.10. LCNT - 下位バ (Low-byte Timer Counter Register) - 分割動作

名称 : LCNT

**変位**:+\$20

リセット : \$00

特質 :-

TCAn.LCNTレジスタは下位ハイト計時器用計数値を含みます。CPUとUPDIの書き込みアクセスはこの計数器の計数、解消、再設定を超える優先権を持ちます。

| <b>ビット</b> | 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)

このビット領域は下位バイト計時器の計数器値を定義します。

22.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)

このビット領域は上位ハイト計時器の計数器値を定義します。

### 22.7.12. LPER - 下位バイト定期 (Low-byte Timer Period Register) - 分割動作

名称:LPER

**変位**:+\$26

**リセット** : \$FF

# 特質 :-

TCAn.LPERレシズタは下位バイ計時器用TOP値を含みます。

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

● ビット7~0 - LPER7~0 : 下位バイ計時器用定期値 (Period value low-byte timer)

このビット領域は下位バイト計時器用TOP値を保持します。

22.7.13. HPER - 上位バイ定期 (High-byte Timer Period Register) - 分割動作

名称 : HPER

**変位** : +\$27

**リセット** : \$FF

特質 :-

TCAn.HPERレジスタは上位ハイト計時器用TOP値を含みます。

| <b>ビット</b> | 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値を保持します。

22.7.14. LCMPn - 下位バイト比較n (Low-byte Compare Register n) - 分割動作

名称 : LCMP0 : LCMP1 : LCMP2 変位 : +\$28 : +\$2A : +\$2C リセット : \$00 特質 : -

TCAn.LCMPnレシ<sup>、</sup>スタは下位ハ<sup>・</sup>仆用比較チャネルnの比較値を表します。このレシ<sup>、</sup>スタは下位ハ<sup>・</sup>仆計時器(TCAn.LCNT)の計数器値と継続的に比較されます。通常、比較器からの出力はその後に波形を生成するのに使われます。

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

• ビット7~0 - LCMP7~0:下位バイ比較n値 (Compare value of channel n)

このビット領域はTCAn.LCNTと比較されるチャネルnの下位バイル比較値を保持します。

22.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   |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|
|        |     |     |     | HCM |     |     |     |     |
| アクセス種別 | R/W |
| リセット値  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

● ビット7~0 - HCMP7~0 : 上位バイ比較n値 (Compare value of channel n)

このビット領域はTCAn.HCNTと比較されるチャネルnの上位バイト比較値を保持します。

# 23. TCB - 16ビット タイマ/カウンタB型

# 23.1. 特徴

- ・16ビット計数器動作形態
  - 周期的割り込み
  - 制限時間検査
  - 計数捕獲
    - ・事象での捕獲
    - ・周波数測定
    - ・パルス幅測定
    - ・周波数とパルス幅の測定
    - 32ビット捕獲
  - 単発
- 8ビット パルス幅変調(PWM)
- ・事象入力での雑音消去器
- ・TCA0との同期動作

# 23.2. 概要

16ビット タイマ/カウンタB型(TCB)の能力は周波数と波形の生成、デジタル信号の時間と周波数の測定を持つ事象での計数捕獲を含みます。TCBは基本計数器と各動作形態が独特な機能を提供する8つの異なる動作形態の1つに設定することができる制御論理回路から成ります。基本計数器は任意選択の前置分周を持つ周辺機能クロックによってクロック駆動されます。

# 23.2.1. 構成図



このタイマ/カウンタは周辺機能クロック(CLK\_PER)、16ビットタイマ/カウンタA型(CLK\_TCAn)、事象システム(EVSYS)からクロック駆動することができます。

制御A(TCBn.CTRLA)レシ<sup>、</sup>スタのクロック選択(CLKSEL)ヒット領域はクロック入力(CLK\_TCB)として前置分周器出力の1つを直接、または事象チャネルを選びます。

TCAnからのクロックを使うタイマ/カウンタ設定はそのTCAnと同期して動くことをタイマ/カウンタに許します。

EVSYSを使って、何れかの入出力ピンでの外部クロック信号のようなどの外部事象供給元も計数器クロック入力または制御論理回路入力として使うことができます。事象活動で制御される動作使用時、クロック選択は計数器入力として事象チャネルを使うように設定してください。



### 23.2.2. 信号説明

| 信号 | 形式        | 説明   |
|----|-----------|------|
| WO | デジタル非同期出力 | 波形出力 |

# 23.3. 機能的な説明

#### 23.3.1. 定義

右の定義は文書全体を通して使われます。

注: 一般的に用語の'計時器'はタイマ/カウンタが周 期的クロック刻みを計数する時に使われます。 用語の'計数器'は入力信号が散発的または 不規則なクロック刻みを持つ時に使われます。

#### 表23-1. タイマ/カウンタ定義

| 名称     | 説明                             |
|--------|--------------------------------|
| BOTTOM | 計数器は\$0000になる時にBOTTOMに到達します。   |
| MAX    | 計数器は\$FFFFになる時に最大に到達します。       |
| TOP    | 計数器が計数の流れで最高値と等しくなる時にTOPに達します。 |
| CNT    | 計数器(TCBn.CNT)レジスタ値             |
| CCMP   | 捕獲/比較(TCBn.CCMP)レジスタ値          |

#### 23.3.2. 初期化

既定でTCBは周期的割り込み動作です。これの使用を開始するには以下のようにこれらの手順に従ってください。

- 1. 比較/捕獲(TCBn.CCMP)レジスタにTOP値を書いてください。
- 2. 任意選択: 制御B(TCBn.CTRLB)レジスタの比較/捕獲出力許可(CCMPEN)ビットに'1'を書いてください。これは対応するPORT出 カレジスタの値を無効にして対応するピンでの波形出力を利用可能にします。
- 3. 制御A(TCBn.CTRLA)レシ<sup>\*</sup>スタの許可(ENABLE)ビットに'1'を書くことによって計数器を許可してください。計数器はTCBn.CTRLAレ ジ<sup>\*</sup>スタのクロック選択(CLKSEL)ビット領域で設定した前置分周器に従ったクロック刻みの計数を開始します。
- 4. 計数値は計数(TCBn.CNT)レジスタから読むことができます。周辺機能はCNT値がTOPに達する時に捕獲(CAPT)割り込みと事象 を生成します。

a. 比較/捕獲レジスタが現在のCNTよりも低い値に変更される場合、周辺機能はMAXまで計数して丸めを行います。

b. MAXで溢れ(OVF)割り込みと事象が生成されます。

#### 23.3.3.動作

#### 23.3.3.1. 動作形態

計時器は以降の部分で記述される8つの異なる動作形態の1つで動くように構成設定することができます。端検出を保証するために 事象パルスは1システム クロック周期より長いことが必要です。

#### 23.3.3.1.1. 周期的割り込み動作

周期的割り込み動作では計数器が捕獲(TOP)値ま で計数してBOTTOMから再開します。CAPT割り込 みと事象はCNTがTOPと等しい時に生成されます。 TOPがCNTよりも低い値に更新された場合、MAX 到達でOVFの割り込みと事象が生成され、計数器 はBOTTOMから再開します。



#### 23.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)ビット 書き込みは無効です。



#### 23.3.3.1.3. 事象での捕獲動作

事象での捕獲動作では計数器がBOTTOMからMAXへ計数します。事象検出時、計数(TCBn.CNT)レジスタ値は比較/捕獲(TCBn.C CMP)レジスタに転送され、CAPT割り込みと事象が生成されます。事象端検出部は上昇端または下降端のどちらかで捕獲を起動する ように構成設定することができます。

この動作は事象使用部として構成設定されたTCBを必要とし、事象部分で説明されます。

右図は事象入力信号の下降端で計数捕獲するように 構成設定した捕獲部を示します。CAPT割り込み要求7 ラグは比較/捕獲(TCBn.CCMP)レジスタの下位バイ読み 込み後、自動的に解除(0)されます。CNTがMAXの時に OVF割り込みと事象が生成されます。

**重要:**他のどれかの動作からこの動作へ移行す る時に計数器(TCBn.CNT)レジスタに\$0000 を書くことが推奨されます。



#### 23.3.3.1.4. 計数捕獲周波数測定動作

計数捕獲周波数動作ではTCBが事象入力信号の正端 または負端のどちらかで計数器値を捕獲して再始動し ます。

この動作は事象使用部として構成設定されたTCBを必要とし、事象部分で説明されます。

CAPT割り込み要求フラグは比較/捕獲(TCBn.CCMP)レジスタの下位バイト読み込み後、自動的に解除(0)されます。CNTがMAXの時にOVF割り込みと事象が生成され

す。これがMAAの時にしいで割り込みと事家が主成され ます。 右図は上昇端で働くように構成設定された時のこの動

石図は上昇端で働くように構成設定された時のこの動 作を図解します。

#### 23.3.3.1.5. 計数捕獲パルス幅測定動作

計数捕獲パルス幅測定動作では計数捕獲パルス幅測定 が正端で計数器を再始動し、割り込み要求が生成され るのに先立って次の下降端で捕獲します。CAPT割り込 み要求7ラグは比較/捕獲(TCBn.CCMP)レジスタの下位 パ化読み込み後、自動的に解除(0)されます。CNTが MAXの時にOVF割り込みと事象が生成されます。計時 器は自動的に上昇端と下降端の方向を切り替えます が、正しい動きのために20ロック周期の最小端間分離が 必要とされます。

この動作は事象使用部として構成設定されたTCBを必要とし、事象部分で説明されます。





### 23.3.3.1.6. 計数捕獲周波数/パルス幅測定動作

計数捕獲周波数/パルス幅測定動作では事象入力信号で正端が検出された時に計時器が計数を開始します。後続する下降端で計

数値が捕獲されます。計数器は事象入力信号の2つ目 の上昇端が検出された時に停止してCAPT割り込み要 求フラクを設定(1)します。

この動作は事象使用部として構成設定されたTCBを必要とし、事象部分で説明されます。

比較/捕獲(TCBn.CCMP)レジスタの下位ハイト読み込み後、CAPT割り込み要求フラグが自動的に解除(0)され、新しい捕獲手順の準備が整います。従って、計数(TCB n.CNT)レジスタは事象入力信号の次の正端でBOTTOM にリセットされるため、比較/捕獲レジスタの前に読んでください。CNTがMAXの時にOVF割り込みと事象が生成されます。



#### 23.3.3.1.7. 単発動作

接続された事象チャネルで上昇端または下降端が観測される毎に比較/捕獲(TCBn.CCMP)レジスタによって定義される持続時間を持つ パルスを生成するのに単発動作を使ってください。

この動作は事象使用部として構成設定されたTCBを必要とし、事象部分で説明されます。

計数器が止まると、出力ピンがLowに設定されます。接続した事象チャネルで事象が検出された場合、計時器はリセットしてBOTTOMから TOPまでの計数を開始し、同時にその出力をHighに駆動します。計数器が計数しているかを見るのに状態(TCBn.STATUS)レジスタの 走行(Run)ビットを読んでください。一旦CNTの値がCCMPレジスタに達すると、計数器は計数を止めます。同時に出力ピンが最小1計数 器クロック(CLK\_TCB)周期間Low状態に移ります。この期間中に起きる新しいどの事象も無視されます。これに続き、新しい事象を受け てから出力がHighに設定されるまでに2周辺機能クロック(CLK\_PER)周期の遅延があります。事象制御(TCBn.EVCTRL)レジスタの事象 端(EDGE)ビットが、1、を書かれると、どの端も計数器の開始を起動できます。EDGEビットが、0、なら、正端だけが開始を起動します。

計数器は例え事象による起動がなくてもこの周辺機能が許可されると、またこの周辺機能が許可されている間に事象制御(TCBn.EV CTRL)レジスタ内の事象端(EDGE)ビットが変更された場 図22 0 単発動体

合、直ぐに計数を開始し、これは計数(TCBn.CNT)レジス タにTOP値を書くことによって防がれます。同様の動き はTCBn.EVCTRLレジスタ内のEDGEL'ットが '1'と同時に この単位部が許可される場合にも見られます。計数レジ スタへのTOP値書き込みはこれも防ぎます。

制御B(TCBn.CTRLB)レジスタの非同期許可(ASYNC)ビットが'1'を書かれた場合、計時器は到着事象に対して非同期に反応します。事象端は出力信号を直ちに設定(1)させます。計数器は未だ事象が受け取られた後の完全な2クロック周期で計数を開始し、結果として2~3クロック周期の遅延が観測されます。

# 23.3.3.1.8. 8ビットPWM動作

TCBは各16ビット比較/捕獲(TCBn.CCMPHとTCBn.CC MPL)レジスタ対が個別の比較レジスタとして使われる8ビット PWM動作で動くように構成設定することができます。 CCMPLは周期(T)を制御し、同時にCCMPHは波形の デューティサイクルを制御します。計数器はBOTTOMから CCMPLまで継続的に計数し、出力はBOTTOMで設定 (1)され、計数器がCCMPHに達する時に解除(0)されま す。

CCMPHは出力がHighに駆動される間のクロック数です。 CCMPL+1が出力パルス周期で、この+1の結果として1ク ロック周期の遅延が観測されます。





#### 23.3.3.2. 出力

計時器同期と出力論理レヘルは選んだ制御B(TCBn.CTRLB)レシ、スタの計時器動作(CNTMODE)と、ット領域に依存します。単発動作で は信号生成が到着事象に対して非同期に起こるようにタイマ/カウンタを構成設定(TCBn.CTRLBの非同期許可(ASYNC)と、ット=1に)するこ とができます。

その後、出力信号はTCB/ロックに同期化される代わりに到着事象で直ちに設定(1)されます。計数器の同期遅延のため、波形出力は TOP値によって定義されたよりも3~4 CLK\_TCB周期長くHighに設定されます。

TCBn.CTRLBの比較/捕獲出力許可(CCMPEN)ビットの'1'書き込みが波形出力を許可します。これは対応するポート出力レシブスタでの 値を無効にして対応するピンで波形出力を利用可能にします。

下表は各種構成設定と出力でのそれらの影響を一覧にします。

| 表23-2. 出 | 力構成設定     |       |                                                    |
|----------|-----------|-------|----------------------------------------------------|
| CCMPEN   | CNTMODE   | ASYNC | 出力                                                 |
|          | 単発動作      | 0     | 出力は計数器開始時にHigh、計数器停止時にLowです。                       |
| 1        | 中光期作      | 1     | 出力は事象到着時にHigh、計数器停止時にLowです。                        |
| 1        | 8ビットPWM動作 | 非適用   | 8ビットPWM動作                                          |
|          | その他の動作    | 非適用   | TCBn.CTRLBレジスタの比較/捕獲ピン初期値(CCMPINIT)ビットが初期出力レヘ゛ルを選択 |
| 0        | 非適用       | 非適用   | 出力なし                                               |

周辺機能が許可されている間の動作変更は予期せぬ出力を生成し得るため推奨されません。計時器構成設定中に割り込み要求フラグが設定(1)される可能性があります。周辺機能構成設定後にタイマ/カウンタ割り込み要求フラグ(TCBn.INTFLAGS)レジスタを解除(=0)することが推奨されます。

#### 23.3.3.3. 32ビット計数捕獲

真の32ビット計数捕獲として動くように2つの16ビットタイマ/カウンタB型(TCBn)を結合することができます。

1つのTCBは下位2<sup>1</sup>/1<sup>\*</sup>/1<sup>\*</sup>を計数します。一旦この計数器がMAXに達すると、溢れ(OVF)事象が生成され、計数器は丸められます。2 つ目のTCBはこれらのOVF事象を計数するように構成設定され、従って上位2<sup>-1</sup>/1<sup>\*</sup>を提供します。32<sup>±</sup>/1<sup>\*</sup>計数器値は2つの計数器値 から連結されます。

32ビット計数器として機能するには、以下の項で記述されるように2つのTCBとシステムを設定してください。

#### システム構成設定

- ・応用の必要条件に従って下位側TCB用計数入力のために供給元(TCA、事象、CLK\_PER)を構成設定してください。
- ・下位側TCB(事象生成部)からのOVF事象を上位側TCB(事象使用部)に配線するように事象システムを構成設定してください。
- ・同じ捕獲事象(CAPT)生成部を両TCBに配線するように事象システムを構成設定してください。

### 下位側計数器の構成設定

- ・制御A(CTRLA)レジスタのクロック選択(CLKSEL)ビット領域に書くことによって構成設定した計数入力を選んでください。
- ・計数捕獲動作の1つを選ぶように制御B(CTRLB)レジスタの計時器動作(CNTMODE)ビット領域を書いてください。
- ・CTRLAの2つのタイマ/カウンタ連結(CASCADE)ビットは'0'でなければなりません。

#### 上位側計数器の構成設定

- ・CTRLAの2つのタイマ/カウンタ連結(CASCADE)ビットに'1'を書くことによって32ビット動作を許可してください。
- ・CTRLAレジスタのクロック選択(CLKSEL)ビット領域を書くことによってクロック入力として事象を選んでください。
- ・下位側TCBと同じ計数捕獲動作を選ぶように制御B(CTRLB)レジスタの計時器動作(CNTMODE)ビット領域を書いてください。

#### 32ビット計数器値捕獲

32ビット計数器値を取得するには両TCBにCAPT事象を送ってください。両TCBは同じ捕獲動作で動いており、故に各々が各々の比較/捕獲(CCMP)レジスタで現在の計数器値(CNT)を捕獲します。32ビット捕獲値は2つのCCMPレジスタの連結によって形成されます。

#### 例23-1. 下位側計数器としてTCB0、上位側計数器としてTCB1の使い方

TCB0は計数入力を数え、TCB1はTCB0からのOVF事象を数えます。両TCBは事象での計数捕獲動作です。

CAPT事象が生成され、それらの現在のCNT値をそれら各々のCCMPレジスタに複写させます。2つの異なるCASCADEビット値が 正しいCAPT事象タイングを許します。

捕獲した32ビット値はTCB1.CCMP(上位側)とTCB0.CCMP(下位側)で連結されます。

|                    | 捕獲要求   |                    |                                    |
|--------------------|--------|--------------------|------------------------------------|
| TCB0 - 下位側計数器      |        | → TCB1 - 上位側計数器    |                                    |
| CTRLA.CASCADE=0    |        | CTRLA.CLKSEL=EVENT |                                    |
| CTRLB.CNTMODE=CAPT | 事象システム | CTRLA.CASCADE=1    | 32ビット捕獲値                           |
| CNT                |        | CTRLB.CNTMODE=CAPT | TCB1.CCMP TCB0.CCMP                |
| =MAX               | OVF >  |                    | ハイト3 ハイト2 ハイト1 ハイト0<br>(MSB) (LSB) |

#### 23.3.3.4. 雑音消去器

雑音消去器は簡単なデジタル濾波器の仕組みを用いることによって雑音耐性を改善します。事象制御(TCBn.EVCTRL)レジスタの雑音 濾波器(FILTER)ビットが許可されると、周辺機能は事象チャネルを監視して最後の4つの観測試料の記録を維持します。4つの連続する 試料が等しければ、その入力は安定と見做され、その信号は端検出器に供給されます。

許可されると、雑音消去器は入力に印加された変化と入力比較レジスタの更新の間に4システム クロック周期の付加遅延をもたらします。 雑音消去器は周辺機能クロックを使い、従って、前置分周器によって影響を及ぼされません。

#### 23.3.3.5. タイマ/カウンタA型との同期

TCBは制御A(TCBn.CTRLA)レシ<sup>、</sup>スタのクロック選択(CLKSEL)ビット領域に'10'を書くことによってタイマ/カウンタA型(TCAn)のクロック(CLK\_T CA)を使うように構成設定することができます。この設定でTCBはTCAnで選んだ同じクロック元で計数します。

制御A(TCBn.CTRLA)レジスタの同期更新(SYNCUPD)ビットが'1'を書かれると、TCB計数器はTCAn計数器が再始動する時に再始動します。

#### 23.3.3.6. ポート無効化

制御B(TCBn.CTRLB)レシ<sup>\*</sup>スタの比較/捕獲出力許可(CCMPEN)ビットに'1'を書くことが波形出力を許可し、対応するPORT出力レシ<sup>\*</sup>スタ での値を無効にして対応するピンで波形出力を利用可能にします。

#### 23.3.4. 事象

TCBは以下の表で記述される事象を生成することができます。

| 表23-3. TC | 表23-3. TCBでの事象生成部 |              |        |          |             |  |  |  |  |  |
|-----------|-------------------|--------------|--------|----------|-------------|--|--|--|--|--|
| 生         | <b>戓部名</b>        | =26 四日       | 事象型    | 生成クロック領域 | 市色目         |  |  |  |  |  |
| 周辺機能      | 事象                |              |        | 主成フロッフ頃域 | 事象長         |  |  |  |  |  |
| TCBn      | CAPT              | CAPTフラグ設定(1) | パルス    |          | 1 CLK_PER周期 |  |  |  |  |  |
| TCDI      | OVF               | OVFフラグ設定(1)  | ~ // ∧ | CLK_PER  | I CLK_FEK问势 |  |  |  |  |  |

CAPTとOVFの事象を生成するための条件はタイマ/カウンタ割り込み要求フラグ(TCBn.INTFLAGS)レジスタで対応する割り込み要求フラグ を掲げるそれらと同じです。事象使用部と事象システム構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照し てください。

TCBは下表で記述される事象を受け取ることができます。

#### 表23-4. TCBでの事象使用部と利用可能な事象活動

| 使    | 用部名   | 説明             | 入力検出 | 同期/非同期  |
|------|-------|----------------|------|---------|
| 周辺機能 | 入力    | 記が明            | 入力検出 | 回朔/ 非回朔 |
|      |       | 制限時間検査         |      |         |
|      |       | 事象で計数捕獲        |      |         |
|      | CAPT  | 計数捕獲周波数測定      |      | 同期      |
| TCBn | CAPT  | 計数捕獲パルス幅測定     | 端    |         |
|      |       | 計数捕獲周波数/パルス幅測定 |      |         |
|      |       | 単発             |      | 両方      |
|      | COUNT | 事象で計数          |      | 同期      |

CAPTとCOUNTは入力事象で検出して働くTCB事象使用部です。

COUNT事象使用部は制御A(TCBn.CTRLA)レジ<sup>\*</sup>スタのクロック選択(CLKSEL)ヒ<sup>\*</sup>ット領域をEVENTに変更することによってこの周辺機能 で許可され、それによって事象システムを設定します。

事象制御(TCBn.EVCTRL)レジスタの捕獲事象入力許可(CAPTEI)ビットが'1'を書かれた場合、やって来る事象は制御B(TCBn.CTRL B)レジスタの計時器動作(CNTMODE)ビット領域とTCBn.EVCTRLレジスタの事象端選択(EDGE)ビットによって定義されたような事象活動になります。事象は認知されるために最低1 CLK\_PER周期間留まらなければなりません。

単発動作に対して非同期動作が許可された場合、事象は端起動され、1周辺機能クロック周期よりも短い事象入力で変更を捕獲します。

#### 23.3.5. 割り込み

| 表23-5. 利用可能な割り込みべりタと供給元 |         |                                           |  |  |  |  |  |  |
|-------------------------|---------|-------------------------------------------|--|--|--|--|--|--|
| 名称                      | ベクタ説明   | 条件                                        |  |  |  |  |  |  |
| CAPT                    | TCB割り込み | 動作形態に依存。TCBn.INTFLAGSレジスタのCAPTの記述をご覧ください。 |  |  |  |  |  |  |
| OVF                     | ICB割り込み | タイマ/カウンタがMAXからBOTTOMへ溢れ。                  |  |  |  |  |  |  |

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

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

TCBは既定でスタンバイ休止動作に於いて禁止されます。休止動作へ移行すると直ぐに停止されます。

制御A(TCBn.CTRLA)レジスタのスタンバイ時走行(RUNSTDBY)ビットが'1'を書かれた場合、この単位部は完全な動作をすることができます。

全ての動作はパワーダウン休止動作で停止されます。

# 23.4. レジスタ要約

| 変位                                            | 略称       | Lット位置       | ビット7 | ビット6     | ビット5     | ビット4    | ビット3  | <b>ビット2</b> | ビット1     | ビットロ   |
|-----------------------------------------------|----------|-------------|------|----------|----------|---------|-------|-------------|----------|--------|
| +\$00                                         | CTRLA    | 7~0         |      | RUNSTDBY | CASCADE  | SYNCUPD |       | CLKSEL2~0   | )        | ENABLE |
| +\$01                                         | CTRLB    | $7 \sim 0$  |      | ASYNC    | CCMPINIT | CCMPEN  |       | C           | NTMODE2~ | -0     |
| +\$02<br>~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | 予約       |             |      |          |          |         |       |             |          |        |
| +\$04                                         | EVCTRL   | 7~0         |      | FILTER   |          | EDGE    |       |             |          | CAPTEI |
| +\$05                                         | INTCTRL  | 7~0         |      |          |          |         |       |             | OVF      | CAPT   |
| +\$06                                         | INTFLAGS | $7 \sim 0$  |      |          |          |         |       |             | OVF      | CAPT   |
| +\$07                                         | STATUS   | $7 \sim 0$  |      |          |          |         |       |             |          | RUN    |
| +\$08                                         | DBGCTRL  | $7 \sim 0$  |      |          |          |         |       |             |          | DBGRUN |
| +\$09                                         | TEMP     | $7 \sim 0$  |      | 1        | 1        | TEM     | P7~0  | 1           | 1        |        |
| +\$0A                                         | CNT      | $7 \sim 0$  |      | 1        | 1        | CNT     | 7~0   | 1           | 1        |        |
| +\$0B                                         | UNI      | $15 \sim 8$ |      |          | ı<br>I   | CNT     | 15~8  |             | 1        |        |
| +\$0C                                         | ССМР     | 7~0         |      |          |          | ССМ     | IP7~0 |             |          |        |
| +\$0D                                         | CCIVIF   | $15 \sim 8$ |      |          |          | CCM     | P15~8 | ı           | ı        |        |

### 23.5. レジスタ説明

# 23.5.1. CTRLA - 制御A (Control A)

名称:CTRLA

**変位**:+\$00 リヤット ・ \$00

| ノセット  | : | \$00 |
|-------|---|------|
| 1+ 66 |   |      |

# 特質 :-

| ビット    | 7 | 6        | 5       | 4       | 3   | 2         | 1   | 0      |
|--------|---|----------|---------|---------|-----|-----------|-----|--------|
|        |   | RUNSTDBY | CASCADE | SYNCUPD |     | CLKSEL2~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 - RUNSTDBY: スタンハイ時走行 (Run Standby)

このビットへの'1'書き込みはこの周辺機能にスタンバイ休止動作での走行を許します。

#### • ビット5 - CASCADE: 2つのタイマ/カウンタ連結 (Cascade Two Timer/Counters)

このビットに'1'を書くと、事象システムを使う32ビット動作用に2つの16ビットタイマ/カウンタB型(TCBn)の連結を許可します。このビットは上位2 ハイト(MSB)に使われるタイマ/カウンタに対して'1'でなければなりません。このビットが'1'の時は捕獲(CAPT)用に選ばれた事象元が1周 辺機能クロック周期遅らされ、事象システム経由で2つの計数器を連結する時の繰り上げ伝搬遅延を補償します。

### ● ビット4 - SYNCUPD:同期更新 (Synchronize Update)

このビットが'1'を書かれると、TCBはTCAnが再始動または溢れる時に必ず再始動し、これはPWM周期での捕獲を同期化できます。 クロック元としてTCAnが選ばれた場合、TCBはそのTCAnが再始動した時に再始動します。他のクロック選択に対してはTCA0と共に再 始動します。

### ビット3~1 - CLKSEL2~0: クロック選択 (Clock Select)

これらビットの書き込みはこの周辺機能用のクロック元を選びます。

| 值  | 000     | 001       | 010                | 011                | 100  | 101  | 110  | 111         |
|----|---------|-----------|--------------------|--------------------|------|------|------|-------------|
| 名称 | DIV1    | DIV2      | TCA0               | TCA1               | _    | _    | _    | EVENT       |
| 説明 | CLK_PER | CLK_PER/2 | TCA0からの<br>CLK_TCA | TCA1からの<br>CLK_TCA | (予約) | (予約) | (予約) | 事象入力の<br>正端 |

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

このビットに'1'を書くことがタイマ/カウンタB型周辺機能を許可します。

## **23.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出力レジスタの値を無効にします。

| 値  | 0                  | 1                     |
|----|--------------------|-----------------------|
| 説明 | 対応ピンで波形出力は許可されません。 | 波形出力は対応ピンの出力値を上書きします。 |

#### ● ビット2~0 - CNTMODE2~0 : 計時器動作 (Timer Mode)

このビット領域への書き込みは計時器動作を選びます。

| 値  | 0 0 0      | 001      |          | 010              |   | 011         |           |
|----|------------|----------|----------|------------------|---|-------------|-----------|
| 名称 | INT        | TIMEOUT  |          | CAPT             |   |             | FRQ       |
| 説明 | 周期的割り込み動作  | 制限時間検査動作 |          | 事象での計数捕獲動作       |   | 計数捕獲周波数測定動作 |           |
| 値  | 100        |          | 101      |                  | 1 | 10          | 111       |
| 名称 | PW         | PW       |          | FRQPW            |   | IGLE        | PWM8      |
| 説明 | 計数捕獲パルス幅測定 | 動作       | 計数捕獲周波数/ | 計数捕獲周波数/パルス幅測定動作 |   | ě動作         | 8ビットPWM動作 |

#### 23.5.3. EVCTRL - 事象制御 (Event Control)

| 名称 | : | EVCTRI |
|----|---|--------|
|----|---|--------|

**変位** : +\$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    | 計数開始                | 計数停止                |
| 前欧时间恢道到旧                    | 1    | 計数停止                | 計数開始                |
| 車角での計粉構羅動化                  | 0    | 計数値を捕獲、割り込み         | -                   |
| 事象での計数捕獲動作                  | 1    | -                   | 計数値を捕獲、割り込み         |
| 計数捕獲周波数測定動作                 | 0    | 計数値を捕獲/解消/再開、割り込み   | _                   |
| 可数相爱问权效例是到旧                 | 1    | -                   | 計数値を捕獲/解消/再開、割り込み   |
| 計数捕獲パルス幅測定動作                | 0    | 計数値を解消/再開           | 計数値を捕獲、割り込み         |
| 司 叙信授 / // 小阳 (四) 上 到 [ 上   | 1    | 計数値を捕獲、割り込み         | 計数値を解消/再開           |
| 計数捕獲周波数/パルス幅測定動作            | 0    | 第1正端で計数値を解消/再開、後続する | る負端で捕獲、第2正端で停止と割り込み |
| 可数11100问仪数/ / / / / / 阳侧足到下 | 1    | 第1負端で計数値を解消/再開、後続する | る正端で捕獲、第2負端で停止と割り込み |
| 単発動作                        | 0    | 計数開始                |                     |
| 中元 期1F                      | 1    | 計数開始                | 計数開始                |
| 8ビットPWM動作                   | 0    |                     |                     |
| OU YFFW MBJ/F               | 1    |                     |                     |

• ビットO - CAPTEI : 捕獲事象入力許可 (Capture Event Input Enable)

このビットに'1'を書くことがTCBに対する事象入力捕獲を許可します。

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

| 名称 | : | INTCTRL |
|----|---|---------|
| ᆂᄮ |   | L C C   |

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

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

• ビット1 - OVF: 溢れ割り込み許可 (Overflow Interrupt Enable)

このビットに'1'を書くことが溢れでの割り込みを許可します。

ビット0 - CAPT: 捕獲割り込み許可 (Capture Interrupt Enable)
 このビットに'1'を書くことが捕獲での割り込みを許可します。

#### 23.5.5. INTFLAGS - 割り込み要求7ラク (Interrupt Flags)

|      | : INTFLAGS<br>: +\$06 |
|------|-----------------------|
| リセット |                       |

特質 :-

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

### • ビット1 - OVF : 溢れ割り込み要求フラグ (Overflow Interrupt Flag)

このビットは溢れ割り込み発生時に設定(1)されます。このフラグはタイマ/カウンタがMAXからBOTTOMに丸められる時に必ず設定(1)されます。

このビットはこのビット位置に'1'を書くことによって解除(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)、フラグは捕獲読み込 |       |                  |
| パルス幅測定動作  | み時に解除( <u>0</u> )               |       |                  |
| 8ビットPWM動作 | 計数器がCCMPLに達した時に設定(1)            | CCMPL | CNT=CCMPL        |

# 23.5.6. STATUS - 状態 (Status)

| 名称 : STATUS<br>変位 : +\$07 |   | (20000) |   |   |   |   |   |     |
|---------------------------|---|---------|---|---|---|---|---|-----|
| リセット:\$00<br>特質:-         |   |         |   |   |   |   |   |     |
| ビット                       | 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によって設定することはできません。

# 23.5.7. DBGCTRL - デバッグ制御 (Debug Control)

| 名称 : DBGCTF<br>変位 : +\$08<br>リセット : \$00<br>特質 : - | RL |   |   |   |   |   |   |        |
|----------------------------------------------------|----|---|---|---|---|---|---|--------|
| ビット                                                | 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停止時に走行継続 |

### 23.5.8. TEMP - 一時レジスタ (Temporary Value)

名称:TEMP

**変位**:+\$09

**リセット** : \$00

## 特質 :-

ー時レジスタはこの周辺機能の16ビットレジスタへの16ビット単一周期アクセスのためにCPUによって使われます。このレジスタはこの周辺機能の全ての16ビットレジスタに対して共通で、ソフトウェアによって読み書きすることができます。16ビットレジスタ読み書きのより多くの詳細については「メモリ」章の「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 Value)

# **23.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   | C   | _   | 4     | 0             | 0   | 1   | 0   |
|        | (   | 6   | 5   | 4<br> |               | . Ž | I   | . 0 |
|        |     |     | 1   | , UNI | ļ <i>1∼</i> 0 |     | i   |     |
| アクセス種別 | 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~8 - CNT15~8 : 計数値上位バイト (Count Value high)

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

● ビット7~0 - CNT7~0 : 計数値下位バ仆 (Count Value low)

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

23.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がデューティサイクルを制御します。

| 13 12      | 11 10                              | 9 8                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CO         | CMP15~8                            |                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| R/W R/W    | R/W R/W                            | R/W R/W                                                                                                                                                                                        | N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0 0        | 0 0                                | 0 0                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| <b>F</b> 4 |                                    | 1 0                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|            | $\frac{3}{CMD7}$                   | 1 0                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| <u> </u>   |                                    |                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| R/W R/W    | R/W R/W                            | R/W R/V                                                                                                                                                                                        | N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0 0        | 0 0                                | 0 0                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|            | CC<br>V R/W R/W<br>0 0<br>5 4<br>C | CCMP15~8           V         R/W         R/W         R/W           0         0         0         0           5         4         3         2           CCMP7~0         CCMP7~0         CCMP7~0 | CCMP15~8         R/W         R/ |

● ビット15~8 - CCMP15~8:比較/捕獲値上位バイト(Compare/Capture Value high byte) これらのビットは16ビットの比較/捕獲/TOP値の上位バイを保持します。

これののアビッドは10ビッドの元報/抽波/10F直の工位ハイドを体行しより。

● ビット7~0 - CCMP7~0 : 比較/捕獲値下位バイト (Compare/Capture Value low byte)

これらのビットは16ビットの比較/捕獲/TOP値の下位バイトを保持します。

# 24. RTC - 実時間計数器

# 24.1. 特徴

- ・16ビット分解能
- ・選択可能なクロック元
- ・設定可能な15ビット クロック前置分周
- 1つの比較レジスタ
- ・1つの定期レジスタ
- ・定期上昇溢れでの計数器解消
- ・任意選択の上昇溢れと比較一致での割り込み/事象
- ・周期的な割り込みと事象
- ・クリスタル誤差修正

# 24.2. 概要

RTC周辺機能は実時間計数器(RTC:Real-Time Couter)と周期的割り込み計時器(PIT:Priodic Interrupt Timer)の2つのタイシング機能を提供します。

PIT機能はRTC機能から独立して許可することができます。

### RTC - 実時間計数器

RTCは計数レジスタで(前置分周された)クロック周期を計数し、計数レジスタの内容を定期レジスタ及び比較レジスタと比較します。

RTCは比較一致または溢れで割り込みと事象の両方を生成することができます。計数器値が比較レジスタ値と等しい後の最初の計数で比較割り込みや事象を、計数器値が定期レジスタ値と等しい後の最初の計数で溢れ割り込みや事象を生成します。溢れは計数器値を0にリセットします。

RTC周辺機能は時間の経緯を保つよう、一般的に低電力休止動作形態を含み継続して動きます。これは規則的な間隔で休止動作 形態からデバイスを起き上がらせたり、デバイスに割り込むことができます。

基準クロックは代表的に外部クリスタルからの32.768kHz出力です。RTCは外部クロック信号、32.768kHz内部超低電力発振器(OSC32K)、または32分周されたOSC32Kからもクロック駆動することができます。

RTC周辺機能は計数器へ至る前に基準クロックを下げることができる設定可能な15ビットの前置分周器を含みます。RTCに対して広範囲の分解能と時間限度を構成設定することができます。32.768kHzのクロック元とで、最大分解能は30.5µsで、時間限度期間は2sまでにすることができます。1sの分解能とで、最大時間限度期間は18時間よりも多くなります(65536s)。

RTCは外部クリスタル選択を用いる動作時のクリスタル誤差修正を支援します。修正のために外部的に校正された値が使われます。RTC はソフトウェアによって±1ppmで調整することができ、最大調整は±127ppmです。RTC修正動作はクリスタル誤差を考慮するために前置分 周器を(計数を飛ばすことによる)加速または(余分な計数を追加することによる)減速のどちらかを行います。

### PIT - 周期的割り込み計時器

PITはRTC機能と同じクロック元を使い、毎回の第nクロック周期で割り込み要求やレベル事象を生成することができます。nは割り込みに対して4,8,16,~32768、事象に対して64,128,256,~8192から選ぶことができます。

### 24.2.1. 構成図



# **24.3**. クロック

周辺機能クロック(CLK\_PER)は前置分周器設定と無関係に計数器値を読むためにRTCクロック(CLK\_RTC)よりも最低4倍速いことが必要とされます。

32.768kHzクリスタルは必要とされる何れかの負荷容量と共にXTAL32K1とXTAL32K2のピンに接続することができます。代わりに、外部 デジタル クロックをXTAL32K1ピンに接続することができます。

# 24.4. RTCの機能的な説明

RTC周辺機能は実時間計数器(RTC)と周期的割り込み計時器(PIT)の2つのタイング機能を提供します。

#### 24.4.1. 初期化

RTC周辺機能と望む活動(割り込み要求、出力事象)を許可する前に、RTCを動かすためにRTC計数器用の供給元クロックが構成設定されなければなりません。

## 24.4.1.1. CLK\_RTCクロック構成設定

CLK\_RTCを構成設定するには以下のこれらの手順に従ってください。

1. クロック制御器(CLKCTRL)周辺機能で望む発振器を必要とされる動作に構成設定してください。

2. それに応じてクロック選択(RTC.CLKSEL)レジスタのクロック選択(CLKSEL)ビット領域を書いてください。

CLK\_RTCクロック構成設定はRTCとPITの両機能によって使われます。

#### 24.4.1.2. RTC構成設定

RTCを動かすには以下のこれらの手順に従ってください。

- 1. 比較(RTC.CMP)レジスタに比較値、定期(RTC.PER)レジスタに溢れ値を設定してください。
- 2. 割り込み制御(RTC.INTCTRL)レジスタで各々の割り込み許可(CMP,OVF)ビットに'1'を書くことによって望む割り込みを許可してください。
- 3. 制御A(RTC.CTRLA)レシ<sup>\*</sup>スタで前置分周器(PRESCALER)ビット領域に望む値を書くことによってRTC内部前置分周器を構成設定 してください。
- 4. RTC.CTRLAレジスタでRTC周辺機能許可(RTCEN)ビットに'1'を書くことによってRTCを許可してください。

### 24.4.2. 操作 - RTC

#### 24.4.2.1. 許可と禁止

RTCは制御Aレシ<sup>\*</sup>スタ(RTC.CTRLA)レシ<sup>\*</sup>スタのRTC周辺機能許可(RTCEN)ヒ<sup>\*</sup>ットに'1'を書くことによって許可されます。RTCはRTC.CT RLAのRTCENL<sup>\*</sup>ットに'0'を書くことによって禁止されます。

# 24.5. PITの機能的な説明

RTC周辺機能は実時間計数器(RTC)と周期割り込み計時器(PIT)の2つのタイング機能を提供します。

# 24.5.1. 初期化

PITを動かすには以下のこれらの手順に従ってください。

- 1. 「24.4.1.1. CLK\_RTC/puy/構成設定」項で記述されるようにRTC/puy/(CLK\_RTC)を構成設定してください。
- 2. 周期割り込み計時器割り込み制御(RTC.PITINTCTRL)レジスタの周期割り込み許可(PI)ビットに'1'を書くことによって割り込みを許可してください。
- 3. 周期割り込み計時器制御A(RTC.PITCTRLA)レジスタで周期(PERIOD)ビット領域に望む値と周期割り込み計時器許可(PITEN)ビット に'1'を書くことによって割り込み周期を選んでPITを許可してください。

### 24.5.2. 操作 - PIT

#### 24.5.2.1. 許可と禁止

PITは周期割り込み計時器制御A(RTC.PITCTRLA)レジスタの周期割り込み計時器許可(PITEN)ビットに'1'を書くことによって許可されます。PITはRTC.PITCTRLAのPITENビットに'0'を書くことによって禁止されます。

#### 24.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周期毎の交互切り替えを続けます。

#### 例24-1. PERIOD=CYC16に対するPITタイミング図

RTC.PITCTRLAでのPERIOD=CYC16に対して、PITは事実上前置分周器計数器ビット3の状態に従い、故に結果の割り込み出力は16 CLK\_RTC周回の周期を持ちます。

初回PIT割り込みとPITENへの'1'書き込み間の時間は実質的に0と(n CLK\_RTC周期の)PIT周期間で変わり得ます。PIT許可と それの初回出力間の正確な遅延は前置分周器の計数段階に依存し、下で示される初回割り込みは先行する時間窓内側の何 処かでPITENへ'1'を書くことによってもたらされます。



# 24.6. クリスタル誤差修正

RTCとPIT用の前置分周器は制御A(RTC.CTRLA)レジスタの周波数修正許可(CORREN)ビットが'1'の時にクリスタル周波数校正(CALIB) レジスタからのppm誤差値を使うことによってクリスタル クロックの内部周波数修正を行うことができます。

CALIBレジスタは周波数誤差についての情報に基づき、使用者によって書かれなければなりません。100万周期間隔を通して分散してRTC.CALIBレジスタ内の誤差修正値(ERROR)ビット領域で与えられる値に等しいいくつかの周期を追加または削除することによって修正操作を実行してください。

計数(RTC.CNT)レジスタを通して利用可能なRTC計数値またはPIT間隔はこのクロック修正を反映します。

修正機能を禁止した場合、進行中の修正周回はこの機能が禁止されるのに先立って完了されます。

注: 負の修正でこの機能を使う場合、最小前置分周構成設定は2分周(DIV2)です。

# 24.7. 事象

RTCは次表で記述される事象を生成することができます。

#### 表24-1. RTC事象生成部

| 生    | 成部名       | =兴 □2         | │<br>│事象型│生成クロック領┘ |          | 事象長                                          |  |
|------|-----------|---------------|--------------------|----------|----------------------------------------------|--|
| 周辺機能 | 事象        | 説明            | 争豕空                | 生成クロック領域 | <b>一</b> 一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一 |  |
|      | OVF       | 溢れ            | パルス                |          | 1 CLK_RTC周期                                  |  |
| RTC  | CMP       | 比較一致          | ~ // // /          | CLK_RTC  | I CLK_KIC向列                                  |  |
| RIC  | EVGEN0SEL | 前置分周したCLK_RTC | レヘッル               | _        | 選んだ前置分周器事象によって定義                             |  |
|      | EVGEN1SEL | 前直方向したULK_KIU |                    |          | 速んに則直力向命事家にようて足我                             |  |

OVFとCMPの事象を生成するための条件は割り込み要求フラク(RTC.INTFLAGS)レジスタで対応する割り込み要求フラグを掲げるそれらと同じです。

事象使用部と事象システム構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照してください。

#### 24.8. 割り込み

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

| 名称  | へ クタ説明                | 条件                                                                                                                                        |
|-----|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| RTC | 実時間計数器溢れと<br>比較一致割り込み | <ul> <li>・溢れ(OVF) : 計数器が定期(RTC.PER)レジネタからの値に達して0に丸められる</li> <li>・比較一致(CMP) : 計数器(RTC.CNT)レジネタからの値と比較(RTC.CMP)レジネタからの<br/>値間で一致</li> </ul> |
| 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レジスタを持ちます。

# 24.9. 休止形態動作

RTCはアイトル休止動作で動作を続けます。制御Aレシ、スタ(RTC.CTRLA)のスタンハイ時走行(RUNSTDBY)ビットが設定(1)なら、スタンハイ休止動作で走行します。

PITはどの休止動作形態でも動作を続けます。

# 24.10. 同期

RTCとPITは共に非同期で、周辺機能クロック(CLK\_PER)から独立した違うクロック元(CLK\_RTC)で動きます。制御と計数レジスタ更新に関して、更新されたレジスタ値がレジスタで利用可能になる前、または構成設定変更が各々RTCやPITに影響を及ぼすまで、RTCクロックや周辺機能クロックで多少の周期数がかかります。この同期時間はレジスタ説明項で各レジスタに対して記述されます。

いくつかのRTCレジスタに関して、状態(RTC.STATUS)レジスタで同期多忙(CMPBUSY, PERBUSY, CNTBUSY, CTRLABUSY)フラグが 利用可能です。

周期割り込み計時器制御A(RTC.PITCTRLA)レジスタについては、周期割り込み計時器状態(RTC.PITSTATUS)レジスタでPIT制御A同期多忙(CTRLBUSY)フラグが利用可能です。

言及したレジスタへ書く前にこれらのフラグを調べてください。

# 24.11. デバッグ操作

デバッグ制御(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を再開します。

# 24.12. レジスタ要約

| 変位         | 略称            | ビット位置       | ビット7     | ヒット6   | <b>ビット</b> 5 | ビット4   | ビット3     | ビット2    | ビット1    | ビットロ      |
|------------|---------------|-------------|----------|--------|--------------|--------|----------|---------|---------|-----------|
| +\$00      | CTRLA         | 7~0         | RUNSTDBY |        | PRESCA       | LER3~0 | i        | CORREN  |         | RTCEN     |
| +\$01      | STATUS        | 7~0         |          |        |              |        | CMPBUSY  | PERBUSY | CNTBUSY | CTRLABUSY |
| +\$02      | INTCTRL       | 7~0         |          |        |              |        |          |         | CMP     | OVF       |
| +\$03      | INTFLAGS      | 7~0         |          |        |              |        |          |         | CMP     | OVF       |
| +\$04      | TEMP          | $7 \sim 0$  | -        |        |              | TEM    | P7~0     |         | 1       |           |
| +\$05      | DBGCTRL       | 7~0         |          |        |              |        |          |         |         | DBGRUN    |
| +\$06      | CALIB         | $7 \sim 0$  | SIGN     |        |              |        | ERROR6~0 |         | 1       | 1         |
| +\$07      | CLKSEL        | $7 \sim 0$  |          |        |              |        |          |         | CLKS    | EL1,0     |
| +\$08      | CNT           | $7 \sim 0$  |          |        |              | CNT    | ſ7∼0     |         |         |           |
| +\$09      | CIVI          | $15 \sim 8$ | 1        |        |              | CNT    | 15~8     |         |         | 1         |
| +\$0A      | PER           | $7 \sim 0$  |          |        |              | PEF    | R7∼0     |         |         | 1         |
| +\$0B      | I LIX         | $15 \sim 8$ |          |        |              | PER    | 15~8     |         | 1       | 1         |
| +\$0C      | CMP           | 7~0         |          |        |              | CMI    | P7∼0     |         |         |           |
| +\$0D      | CIVII         | $15 \sim 8$ |          |        |              | CMF    | 215~8    |         |         |           |
| +\$0E<br>∼ | 予約            |             |          |        |              |        |          |         |         |           |
| +\$0F      | 1、氷り          |             |          |        |              |        |          |         |         |           |
| +\$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    |
| +\$16      | PITEVGENCTRLA | 7~0         |          | EVGENI | SEL3~0       |        |          | EVGEN   | OSEL3~0 |           |

# 24.13. レジスタ説明

# 24.13.1. CTRLA - 制御A (Control A)

名称:CTRLA

変位:+\$00

リセット : \$00

特質:-

| ビット      | 7   | 6   | 5      | 4      | 3   | 2      | 1 | 0     |
|----------|-----|-----|--------|--------|-----|--------|---|-------|
| RUNSTDBY |     |     | PRESCA | LER3~0 |     | CORREN |   | RTCEN |
| アクセス種別   | R/W | R/W | R/W    | R/W    | R/W | R/W    | 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        | 0010         | 0011         | 0100         | 0101         | 0110          | 0111          |
|----|-----------------|-------------|--------------|--------------|--------------|--------------|---------------|---------------|
| 名称 | 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   |
| 値  | $1 \ 0 \ 0 \ 0$ | 1001        | 1010         | 1011         | 1100         | 1101         | 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 |

● ビット2 - CORREN : 周波数修正許可 (Frequency Correction Enablee)

| 值  | 0       | 1       |  |  |  |  |
|----|---------|---------|--|--|--|--|
| 説明 | 周波数修正禁止 | 周波数修正許可 |  |  |  |  |

#### • ビット0 - RTCEN : RTC周辺機能許可 (RTC Peripheral Enable)

| 値  | 0         | 1         |  |  |  |  |
|----|-----------|-----------|--|--|--|--|
| 説明 | RTC周辺機能禁止 | RTC周辺機能許可 |  |  |  |  |

重要: RTCクロックと主クロック領域間同期のため、レジスタ更新からそれが効果を持つまでに2 RTCクロック周期の遅れがあります。 応用ソフトウェアはこのレジスタを書く前に状態(RTC.STATUS)レジスタの制御A同期多忙(CTRLABUSY)フラグが解除(0)されて いるのを確認しなければなりません。

### 24.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 OVF R/W 0

#### • ビット0 - CTRLABUSY : 制御A同期多忙 (Control A Synchronization Busy)

このビットはRTCがRTCクロック領域で制御A(RTC.CTRLA)レジスタを同期中多忙の時に'1'です。

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

| 3<br>リ | 名称 : INTCTR<br>変位 : +\$02<br>セット : \$00<br>寺質 : - | L |   |   |   |   |   |     |
|--------|---------------------------------------------------|---|---|---|---|---|---|-----|
|        | ヒット                                               | 7 | 6 | 5 | 4 | 3 | 2 | 1   |
|        |                                                   |   |   |   |   |   |   | CMP |
|        | アクセス種別                                            | R | R | R | R | R | R | R/W |
|        | リセット値                                             | 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              |
|----|----------------|----------------|
| 説明 | 溢れ割り込みは禁止されます。 | 溢れ割り込みは許可されます。 |

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

| 変位<br>リセッ | ⊼ : INTFLA<br>Z : +\$03<br>ŀ : \$00<br>Į : - | AGS |   |   |   |   |   |     |     |
|-----------|----------------------------------------------|-----|---|---|---|---|---|-----|-----|
|           | ビット                                          | 7   | 6 | 5 | 4 | 3 | 2 | 1   | 0   |
|           |                                              |     |   |   |   |   |   | CMP | OVF |
| 7         | Ppセス種別                                       | 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)します。

### **24.13.5. TEMP - 一時レジスタ**(Temporary)

名称:TEMP

**変位** : +\$04

**リセット** : \$00

特質:-

一時レジスタはこの周辺機能の16ビットレジスタへの16ビット単一周期アクセスのためにCPUによって使われます。このレジスタはこの周辺機能の全ての16ビットレジスタに対して共通でソフトウェアによって読み書きすることができます。「メモリ」章の「16ビットレジスタのアクセス」を参照してください。

| ۲<br>۲<br>۳ | 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ビットレジスタでの読み書き操作用一時レジスタ

# **24.13.6. DBGCTRL - デバッグ制御** (Debug Control)

| 名称 : DBGC<br>変位 : +\$05<br>リセット : \$00<br>特質 : - |   |   |   |   |   |   |   |        |
|--------------------------------------------------|---|---|---|---|---|---|---|--------|
| ビット                                              | 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停止中のデベッグ動作中断で走行継続 |

# 24.13.7. CALIB - クリスタル周波数校正 (Crystal Frequency Calibration)

名称:CALIB

**変位** : +\$06

リセット : \$00

特質 :-

このレジスタは行う修正形式と誤差値を格納します。このレジスタは外部校正や温度校正に基づく誤差値でソフトウェアによって書かれます。

| ビット    | 7    | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|------|-----|-----|-----|-----|-----|-----|-----|
|        | SIGN |     |     |     |     |     |     |     |
| アクセス種別 | 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 - SIGN : 誤差修正符号ビット (Error Correction Sign Bit)

このビットは修正の方向を示すのに使われます。

| 値  | 0                  | 1                                                  |
|----|--------------------|----------------------------------------------------|
| 説明 | 前置分周器により遅く計数させる正修正 | 前置分周器により速く計数させる負修正。<br>これは最小前置分周器構成設定がDIV2であることが必要 |

• ビット6~0 - ERROR6~0: 誤差修正値 (Error Correction Value)

各100万RTCクロック周期間隔に対する修正クロック数(ppm)

### 24.13.8. CLKSEL - クロック選択 (Clock Selection)

名称:CLKSEL

**変位** : +\$07

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

侍賀 :-

| ビット    | 7 | 6 | 5 | 4 | 3 | 2 | 1         | 0   |
|--------|---|---|---|---|---|---|-----------|-----|
| [      |   |   |   |   |   |   | CLKSEL1,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                    | 01                    | 1 0                                           | 11                    |
|---|---|------------------------|-----------------------|-----------------------------------------------|-----------------------|
| 名 | 称 | OSC32K                 | OSC1K                 | XTAL32K                                       | EXTCLK                |
| 説 | 明 | OSC32Kからの<br>32.768kHz | OSC32Kからの<br>1.024kHz | XOSC32Kからの32.768kHzまたは<br>XTAL32K1ピンからの外部クロック | EXTCLKピンからの<br>外部クロック |

# **24.13.9. 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   |  |  |  |  |
|         | CNT7~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)されてい るのを確認しなければなりません。

#### 24.13.10. PER - 定期 (Period)

名称: PER (PERH, PERL)

- **変位** : +\$0A
- **リセット** : \$FFFF

#### 特質 :-

RTC.PERHとRTC.PERLのレシブスタ対は16ビット値のRTC.PERを表します。下位ハイト[7~0](接尾辞L)は変位原点でアクセスできます。上位ハイト[15~8](接尾辞H)は変位+1でアクセスすることができます。

| <b>ビット</b> | 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   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |  |
|            |         |     |     | PEF | 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   |  |  |  |  |

● ビット15~8 - PER15~8: 定期値上位バ仆 (Periodic high byte)

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

• ビット7~0 - PER7~0: 定期値下位バ仆 (Periodic low byte)

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



重要: RTCクロックと主クロック領域間同期のため、レジスタ更新からそれが効果を持つまでに2 RTCクロック周期の遅れがあります。 応用ソフトウェアはこのレジスタを書く前に状態(RTC.STATUS)レジスタの定期同期多忙(PERBUSY)フラグが解除(0)されている のを確認しなければなりません。

# 24.13.11. 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   |  |  |  |  |
|        |         |     |     | CMI | 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)されている のを確認しなければなりません。

# 24.13.12. PITCTRLA - 周期割り込み計時器制御A (Peiodic Interrupt Timer Control A)

名称:;PITCTRLA

**変位**:+\$10

# **リセット** : \$00

|        | • - | - |
|--------|-----|---|
| 119.52 | •   |   |
|        |     |   |
|        |     |   |

| ビット    | 7 | 6   | 5         | 4   | 3   | 2 | 1 | 0     |
|--------|---|-----|-----------|-----|-----|---|---|-------|
|        |   |     | PERIOD3~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クロック周期数を選びます。

| 値  | 0000   | 0001    | 0010    | 0011    | 0100    | 0101     | 0110     | 0111   |
|----|--------|---------|---------|---------|---------|----------|----------|--------|
| 名称 | OFF    | CYC4    | CYC8    | CYC16   | CYC32   | CYC64    | CYC128   | CYC256 |
| 説明 | 割り込みなし | 4周期     | 8周期     | 16周期    | 32周期    | 64周期     | 128周期    | 256周期  |
| 値  | 1000   | 1001    | 1010    | 1011    | 1100    | 1101     | 1110     | 1111   |
| 名称 | CYC512 | CYC1024 | CYC2048 | DIV4096 | CYC8192 | CYC16384 | CYC32768 | -      |
| 説明 | 512周期  | 1024周期  | 2048周期  | 4096周期  | 8192周期  | 16384周期  | 32768周期  | (予約)   |

● ビット0 - PITEN : 周期割り込み計時器許可 (Periodic Interrupt Timer Enable)

このビットへの'1'書き込みがPITを許可します。

|   | 値  | 0           | 1           |
|---|----|-------------|-------------|
| i | 説明 | 周期割り込み計時器禁止 | 周期割り込み計時器許可 |

重要: RTCクロックと主クロック領域間同期のため、レジスタ更新からそれが効果を持つまでに2 RTCクロック周期の遅れがあります。 応用ソフトウェアはこのレジスタを書く前にPIT状態(RTC.PITSTATUS)レジスタのPIT制御A同期多忙(CTRLBUSY)フラグが解除 (0)されているのを確認しなければなりません。 24.13.13. PITSTATUS - 周期割り込み計時器状態 (Periodic Interrupt Timer Status)

| 変(<br>リセ) | 弥 : PITSTA<br>立 : +\$11<br>小 : \$00<br>覧 : - | ATUS |   |   |   |   |   |   |          |
|-----------|----------------------------------------------|------|---|---|---|---|---|---|----------|
|           | ビット                                          | 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'です。

24.13.14. PITINTCTRL - PIT割り込み制御 (PIT Interrupt Control)

名称 : PITINTCTRL 変位 : +\$12 リセット : \$00 特質 : -ビット 7

| ビット    | 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        |
|----|----------|----------|
| 説明 | 周期割り込み禁止 | 周期割り込み許可 |

# 24.13.15. 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)します。

### 24.13.16. 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.13.17. PITEVGENCTRLA - 周期計時器事象生成制御A (Periodic Timer Event Generation Control A)

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

| ビット    | 7   | 6      | 5      | 4   | 3   | 2     | 1       | 0   |
|--------|-----|--------|--------|-----|-----|-------|---------|-----|
|        |     | EVGEN1 | SEL3~0 |     |     | EVGEN | DSEL3~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,3~0 - EVGENnSEL3~0 : 事象生成n選択 (Event Generation n Select)

| Γ | 値  | 0000            | 0001            | 0010         | 0011            | 0100         | 0101            | 0110          | 0111        |
|---|----|-----------------|-----------------|--------------|-----------------|--------------|-----------------|---------------|-------------|
|   | 名称 | OFF             | DIV4            | DIV8         | DIV16           | DIV32        | DIV64           | DIV128        | DIV256      |
|   | 説明 | 事象生成なし          | CLK_RTC/4       | CLK_RTC/8    | CLK_RTC/16      | CLK_RTC/32   | CLK_RTC/64      | CLK_RTC/128   | CLK_RTC/256 |
|   | 値  | $1 \ 0 \ 0 \ 0$ | $1 \ 0 \ 0 \ 1$ | 1010         | $1 \ 0 \ 1 \ 1$ | 1100         | $1 \ 1 \ 0 \ 1$ | 1110          | 1111        |
| Γ | 名称 | DIV512          | DIV1024         | DIV2048      | DIV4096         | DIV8192      | DIV16384        | DIV32768      | -           |
|   | 説明 | CLK_RTC/512     | CLK_RTC/1024    | CLK_RTC/2048 | CLK_RTC/4096    | CLK_RTC/8192 | CLK_RTC/16384   | CLK_RTC/32768 | (予約)        |

# 25. USART - 万能同期/非同期送受信器

### 25.1. 特徴

- ・全二重操作
- ・半二重操作
- 単線動作
- RS-485動作
- ・非同期と同期の操作
- ・5,6,7,8,9のデータビットと1または2の停止ビットを持つ直列フレーム支援
- ・分数ボーレート発生器
  - どの周辺機能クロック周波数からも望むボーレートを生成可
- 外部発振器不要
- ・組み込みの誤り検出と修正の仕組み
  - 奇数/偶数パリティ生成器とパリティ検査
  - 緩衝部オーハランとフレーム異常検出
- 不正開始ビット検出とデジタル低域通過濾波器を含む雑音濾波
- ・以下の独立した割り込み
  - 送信完了
  - 送信データレジスタ空
  - 受信完了
- ・主装置SPI動作
- ・複数プロセッサ通信動作
- ・フレーム開始検出
- ・IrDA®適合パルス変調/復調用赤外線通信(IRCOM)単位部
- ・LIN従装置支援

# 25.2. 概要

万能同期/非同期直列送受信器(USART:Universal Synchronous and Asynchronuos serial Receiver and Transmitter)は高速で柔軟 な直列通信周辺機能です。USARTは複数の形式の応用と通信装置に対応することができるいくつかの異なる動作形態を支援しま す。例えば、単線半二重動作は少ピン数応用が望まれる時に有用です。通信はフレームに基づき、フレーム形式は広範囲の規格を支援 するように直すことができます。

USARTは両方向で緩衝され、フレーム間でのどんな遅延もなしに継続するデータ転送を許します。受信と送信の完了に対する独立した割り込みは完全な割り込み駆動通信を許します。

送信部は2段の書き込み緩衝部、移動レジスタ、それと各種フレーム形式用の制御論理回路から成ります。受信部は2段の受信緩衝部と 移動レジスタから成ります。受信したデータの状態情報は異常検査に対して利用可能です。データとクロックの再生部は非同期データ受信中 の頑強な同期と雑音濾波を保証します。

### 25.2.1. 構成図



#### 25.2.2. 信号説明

| 信号   | 形式  | 説明              |  |  |  |  |
|------|-----|-----------------|--|--|--|--|
| ХСК  | 入出力 | 同期動作用クロック       |  |  |  |  |
| XDIR | 出力  | RS485用送信許可      |  |  |  |  |
| TxD  | 入出力 | 送信線(と単線動作での受信線) |  |  |  |  |
| RxD  | 入力  | 受信線             |  |  |  |  |

# 25.3. 機能的な説明

### 25.3.1. 初期化

## 全二重動作:

- 1. ボーレート(USARTn.BAUD)を設定してください。
- 2. フレーム構成と動作形態(USARTn.CTRLC)を設定してください。
- 3. TxDピンを出力として構成設定してください。
- 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操作について、初期化の間は全体割り込みが禁止されなければなりません。
  - ・ボーレートまたはフレーム構成の変更を伴う再初期化を行う前に、そのレジスタが変更される間に進行中の送信がないことを確実にしてください。

#### 25.3.2. 動作

#### 25.3.2.1. フレーム形式

USARTデータ転送はフレームに基づきます。フレームは開始ビットで始まり、データビットの1文字が後続します。許可されたなら、データビット後で最初の停止ビットの前にハッリティビットが挿入されます。フレームの停止ビット後、直ちに次のフレームを後続するか、または通信線をアイドル (High)状態に戻すかのどちらかにすることができます。USARTは有効なフレーム形式として以下の組み合わせ全てを受け入れます。

- ・1つの開始ビット
- 5, 6, 7, 8, 9 ビット データ
- ・奇数または偶数パリティビット、またはなし
- ・1つまたは2つの停止ビット

下図は可能なフレーム形式の組み合わせを図解します。[]付きビットは任意選択です。

| 図25-2. フレーム構成                                                                          |                                                                        |
|----------------------------------------------------------------------------------------|------------------------------------------------------------------------|
| (IDLE) St D0 X D1 X D2 X D3 X D4 X [D5] X [D6] X [D7] X [D8] X [P] Sp1 [Sp2] (St/IDLE) |                                                                        |
| •                                                                                      | - 1 7V-L                                                               |
| St :開始ビット(常にLow)<br>Dn : データ ビット(0~8)<br>P : パリティ ビット(偶数または奇数)                         | Spn : 停止ビット(常に <mark>High</mark> )<br>IDLE: RxDまたはTxDの通信線で転送なし(常にHigh) |

### 25.3.2.2. クロック生成

データビットの移動と採取に使われるクロックは内部的な分数ボーレート発生器または外部的な転送クロック(XCK)ピンから生成されます。



### 25.3.2.2.1. 分数ボーレート発生器

USARTがクロック元としてXCK入力を使わない動作ではクロックを生成するのに分数ボーレート生成器が使われます。ボーレートは秒毎のビット 数(bps)の言葉で与えられ、ボーレート(USARTn.BAUD)レジスタを書くことによって構成設定されます。ボーレート(*f*BAUD)は周辺機能クロック (*f*CLK PER)をBAUDレジスタによって決められる分割係数で分割することによって生成されます。

分数ボーレート発生器はfBAUDで割り切れない場合に対応するハードウェアが特徴です。通常、この状況は丸め誤差をもたらします。分数ボーレート発生器は表25-1.の式で実行されるように、6ビット左移動した望む分割係数を含むBAUDレジスタを期待します。そして下位6ビットは望む除数の小数部を保持します。望むボーレートにより近い近似を達成するため動的にfBAUDを調節するのにBAUDレジスタの小数部を使ってください。

ボーレートをfcLK\_PERよりも高くすることができないため、BAUDレジスタの整数部は最低1であることが必要です。結果は6ビット左移動されるため、対応するBAUDレジスタの最小値は64です。有効な範囲は64~65535です。

同期動作では、BAUDレジスタの10ビット整数部(BAUD15~6)だけがボーレートを決め、従って、小数部(BAUD5~0)は0を書かれなければなりません。

下表はボーレートをBAUDレジスタ用の入力値に変換するための式を一覧にします。式は分数解釈を考慮し、故にこれらの式で計算されたBAUD値はどんな追加の尺度調整もなしに直接USARTn.BAUDに書くことができます。

### 表25-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}}_{\text{PER}}}{S \times BAUD}$ | $BAUD = \frac{64 \times f_{\text{CLK}}_{\text{PER}}}{S \times f_{\text{BAUD}}}$ |  |
| 同期主装置 | $f_{\text{BAUD}} < \frac{f_{\text{CLK},\text{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

### 25.3.2.3. データ送信

USART送信部は周期的に送信線をLowに駆動することによってデータを送ります。データ送信は送るデータを送信データ(USARTn.TXD ATALとUSARTn.TXDATAH)レジスタに設定することによって始められます。送信データレジスタのデータは送信緩衝部が一旦空になると それに移され、移動レジスタが一旦空になるとそれに進み、新しいフレームを送る準備が整います。移動レジスタがデータを設定された後、 データフレームが送信されます。

移動レジスタのフレーム全体が移動出力されてしまい、送信データや送信緩衝部に存在する新しいデータがないと、状態(USARTn.STATU S)レジスタの送信完了割り込み要求フラグ(TXCIF)ビットが設定(1)され、それが許可されていれば割り込みが生成されます。

送信データレジスタはそれらが空で新しいデータの準備が整っていることを示すUSARTn.STATUSレジスタのデータレジスタ空割り込み要求 フラグ(DREIF)ビットが設定(1)される時にだけ書くことができます。

8ビットよりも少ないフレームの使用時、送信データレジスタに書かれる上位側ビットは無視されます。制御C(USARTn.CTRLC)レジスタの文字 ビット数(CHSIZE)ビット領域が9ビット(下位ハイト先行)に構成設定されると、送信データ上位ハイト(TXDATAH)レジスタの前に送信データ下位 ハイト(TXDATAL)レジスタが書かれなければなりません。CHSIZEが9ビット(上位ハイト先行)に構成設定されると、TXDATALの前にTXDA TAHが書かれなければなりません。

### 25.3.2.3.1. 送信部禁止

送信部を禁止すると、その操作は進行中と保留中の送信が完了される、即ち、送信移動レジスタ、送信データ(USARTn.TXDATALとU SARTn.TXDATAH)レジスタ、送信緩衝レジスタが送信されるべきデータを含まない時まで有効になりません。送信部が禁止されると、もは やTxDビンを指定変更せず、PORT単位部がピン制御を取り戻します。ピンはそれの直前の設定に関わらず、ハートウェアによって自動的 に入力として構成設定されます。ピンは今やUSARTからのポート指定変更なしに標準入出力ピンとして使うことができます。

### 25.3.2.4. データ受信

USART受信部は検出して受信したデータを解釈するために受信線を採取します。従って、ピンの方向はデータ方向(PORTx.DIR)レジスタの対応するビットに'0'を書くことによって入力として構成設定されなければなりません。

受信部は有効な開始ビットが検出されと、データを受け入れます。開始ビットに後続する各ビットはボーレートまたはXCKクロックで採取され、フレームの最初の停止ビットが受信されるまで受信移動レジスタに移されます。第2停止ビットは受信部によって無視されます。最初の停止ビットが受信され、完全な直列フレームが受信移動レジスタに存在すると、移動レジスタの内容が受信緩衝部に移されます。状態(USARTn. STATUS)レジスタの受信完了割り込み要求フラグ(RXCIF)が設定(1)され、許可されていれば割り込みが生成されます。

RXDATAレジスタはRXCIFが設定(1)される時に応用ソフトウェアによって読むことができる2重緩衝される受信緩衝部の一部です。1フレーム だけが受信されたなら、そのフレームに対するデータと状態のビットはRXDATAレジスタに直接押し込まれます。RX緩衝部に2つのフレームが 存在する場合、RXDATAレジスタは最も古いフレームを含みます。 緩衝部は構成設定に応じてRXDATALまたはRXDARAHが読まれる時のどちらかでデータを移動します。移動前に両ハイトを読むことができるようにデータ移動を引き起こさないレジスタが先に読まれなければなりません。制御C(USARTn.CTRLC)レジスタの文字ビット数(CHSIZE)ビット領域が9ビット(下位ハイト先行)に構成設定される時に、RXDATAHの読み込みが受信緩衝部を移動します。さもなければ、RXDATALが緩衝部を移動します。

### 25.3.2.4.1. 受信異常フラグ

USART受信部は送信化けを暴く異常検出機構が特徴です。これらの機構は以下を含みます。

- ・フレーム異常検出 受信したフレームが有効かどうかを管理します。
- ・緩衝部溢れ検出 受信緩衝部が満杯で新しいデータによって上書きされたためのデータ損失を示します。

・ パリティ誤り検出 - 到着フレームのパリティを計算してパリティビットと比べることによって到着フレームの有効性を調べます。

各異常検出機構は受信データ上位バイト(USARTn.RXDATAH)レジスタで読むことができる各々1つの異常フラグを制御します。

### ・フレーム異常(FERR)

- ・緩衝部溢れ(BUFOVF)
- ・ パリティ誤り(PERR)

異常フラグはそれらが対応するフレームと共に受信緩衝部に置かれます。RXDATALレジスタ読み込みがRX緩衝部のRXDATAバイト移動 を起動するため、異常フラグを含むRXDATAHレジスタはRXDATALレジスタに先立って読まれなければなりません。

注:制御C(USARTn.CTRLC)レシ<sup>\*</sup>スタの文字ビット数(CHSIZE)ビット領域が9ビット下位ハ<sup>\*</sup>小先行(9BITL)に設定される場合、RXDATALレ ジ<sup>\*</sup>スタに代わってRXDATAHレジ<sup>\*</sup>スタがRXDATA<sup>\*</sup>小移動を起動します。その場合、RXDATALレジ<sup>\*</sup>スタがRXDATAHレジ<sup>\*</sup>スタに先立っ て読まれなければなりません。

### 25.3.2.4.2. 受信部禁止

受信部を禁止すると、その操作は即時です。受信緩衝部が破棄され、進行中の受信からのデータは失われます。

### 25.3.2.4.3. 受信緩衝部破棄

通常動作の間に受信緩衝部が破棄されなければならない場合、USARTn.RXDATAHレジスタの受信完了割り込み要求フラク(RXCIF)が解除(0)されるまでDATA位置(USARTn.RXDATAHとUSARTn.RXDATALのレジスタ)を繰り返し読んでください。

### 25.3.3. 通信動作形態

USARTは複数の異なる通信規約を支援する柔軟な周辺機能です。利用可能な動作形態は、同期と非同期の通信の2つの群に分けることができます。

同期通信はXCKビンを通してクロック信号を残りの装置に供給する主権があるバス上の1つの主装置に依存します。全ての装置は追加の同期機構を必要とせず、送受信両方にこの共通クロック信号を使います。

装置は同期バスで主装置または従装置のどちらかで動くように構成設定することができます。

非同期通信は共通クロック信号を使いません。代わりに、通信する装置に於いて同じボーレートで構成設定されることに頼ります。やって 来る伝送の受信時、受信する装置の周辺機能クロックでやって来る伝送を整列するのにハートウェア同期機構が使われます。

非同期に通信する時に4つの違う動作形態が利用可能です。それらの動作の1つは標準速度の倍で伝送を受信することができ、通常の16の代わりにビット毎に8回だけ採取します。他の3つの動作形態は同期論理回路の変種を使い、全て標準速度で受信します。

### 25.3.3.1. 同期動作

### 25.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クロック上昇端で採取されます。



### 25.3.3.1.2. 外部クロック制限

USARTが同期従装置動作に構成設定されると、XCK信号は主装置によって外部的に提供されなければなりません。このクロックが外部的に提供されるため、BAUDレジスタ構成設定は転送速度に何の影響も持ちません。クロック再生成功には各上昇端と下降端に対して最低2回採取するクロック信号を必要とします。従って、同期動作形態での最大XCK速度(f<sub>Slave\_SCK</sub>)は右式によって制限されます。

© 2022 Microchip Technology Inc.とその子会社

XCKクロックに細動(ジッタ)がある場合、またはHigh/Low区間のデューティサイクルが50%/50%でない場合、XCKが各端に対して最低2回採 取することを保証するために、それに応じて最大XCKクロック速度が低減されなければなりません。

### 25.3.3.1.3. 主装置SPI動作でのUSART

USARTは複数の異なる通信インターフェースを持つ機能に構成設定されるかもしれず、それらの1つが主装置として動くことができる直列 周辺インターフェース(SPI)です。SPIは主装置に1つ以上の従装置との通信を許す4線インターフェースです。

### フレーム形式

主装置SPI動作でのUSARTに対する直列フレームは常に8つのデータビットを含みます。データビットは制御C(USARTn.CTRLC)レジスタの データ順(UDORD)ビットに書くことによってLSB先行またはMSB先行のどちらかで送信されるように構成設定することができます。 SPIは開始、停止、ハッリティのビットを使わず、故に伝送フレームはデータビットだけで成り得ます。

### クロック生成

同期インターフェースでの主装置になる主装置SPI動作は従装置と共有されるインターフェース クロックを生成しなければなりません。このインタフェース クロックは「25.3.2.2.1. 分数ボーレート発生器」で記述される分数ボーレート発生器を使って生成されます。

各データビットは1つの完全なクロック周期に対してデータ線をHighまたはLowに引くことによって送信されます。受信部は下図で示される ように送信部保持期間の中央でビットを採取します。これはビンn制御(PORTx.PINnCTRL)レジスタの反転I/O許可(INVEN)ビットと制御C (USARTn.CTRLC)レジスタのUSARTクロック位相(UCPHA)ビットを使ってタイミングの仕組みをどう構成設定することができるかも示します。



右表は上図を更に説明します。

### 表25-2. INVENE゙ットとUCPHAE゙ットの機能

| SPI動作形態              | INVEN | UCPHA | 先行端 ( <mark>注</mark> ) | 後行端 ( <mark>注</mark> ) |  |  |  |  |
|----------------------|-------|-------|------------------------|------------------------|--|--|--|--|
| 0                    | 0     | 0     | 上昇端、採取                 | 下降端、送信                 |  |  |  |  |
| 1                    | 0     | 1     | 上昇端、送信                 | 下降端、採取                 |  |  |  |  |
| 2                    | 1     | 0     | 下降端、採取                 | 上昇端、送信                 |  |  |  |  |
| 3                    | 1     | 1     | 下降端、送信                 | 上昇端、採取                 |  |  |  |  |
| <b>计</b> , 出行把注加, 加国 |       |       |                        |                        |  |  |  |  |

注: 先行端はクロック周期の最初のクロック端です。後行端はクロック周期の最後のクロック端です。

### データ送信

主装置SPI動作でのデータ送信は「動作」項で記述されるような全般的なUSART動作と機能的に同じです。送信部割り込み要求フラグと対応するUSART割り込みも同じです。更なる記述については「25.3.2.3. データ送信」をご覧ください。

### データ受信

主装置SPI動作でのデータ受信は「動作」項で記述されるような全般的なUSART動作と機能的に同じです。使われずに常に'0'として 読む受信異常フラグを除き、受信部割り込み要求フラグと対応するUSART割り込みも同じです。更なる記述については「25.3.2.4. データ 受信」をご覧ください。

# 主装置SPI動作でのUSART対SPI

主装置SPI動作でのUSARTは独立型SPI周辺機能と 完全な互換性があります。それらのデータフレームとタイ ミング構成設定は同じです。けれども、以下のような いくつかのSPI特有特殊機能は主装置SPI動作での USARTで支援されません。

- ・書き込み衝突(WRCOL)フラグ保護
- ・倍速動作
- · 複数主装置支援

主装置SPI動作でのUSARTとSPIで使われるピンの比較が右表で示されます。

### 表25-3. 主装置SPI動作でのUSARTとSPIのピン比較

| USART | SPI  | 注釈                      |
|-------|------|-------------------------|
| TxD   | MOSI | 主装置出力                   |
| RxD   | MISO | 主装置入力                   |
| ХСК   | SCK  | 機能的に同一                  |
| 該当なし  | SS   | 主装置SPI動作でのUSARTで不支援 (注) |

注: 独立型SPI周辺機能について、このピンは複数主装置機能で、または専 用従装置選択として使われます。複数主装置機能は主装置SPI動作で のUSARTで利用不可で、専用従装置選択ピンは利用不可です。

### 25.3.3.2. 非同期動作

### 25.3.3.2.1. クロック再生

非同期動作使用時に共通クロック信号がないため、通信する各装置は独立したクロック信号を生成します。これらのクロック信号は行われ る通信に対して同じボーレートで動くように構成設定されなければなりません。従って、装置は同じ速度で動きますが、それらのタイミング はお互いの関係に於いて歪められています。これに対応するため、USARTはやって来る非同期直列フレームを内部的に生成したボー レート クロックと同期するハート・ウェア クロック再生部が特徴です。

下図は到着フレームの開始ビット用採取処理を図解します。これは標準と倍速の両動作(各々、'00'と'01'に構成設定された制御B(US ARTn.CTRLB)レシ、スタの受信部動作(RXMODE)ビット領域)に対するタイミングの仕組みを示します。標準動作用採取速度はボーレートの16倍、一方で倍速動作用採取速度はボーレートの8倍です(「25.3.3.2.4. 倍速動作」をご覧ください)。赤帯(訳注:原文は水平矢印)は最大同期誤差を示します。最大同期誤差が倍速動作でより大きいことに注意してください。



クロック再生論理回路がアイドル(High)状態から開始ビット(Low)への下降端を検出すると、開始ビット検出手順が始められます。上図に於いて、採取1は最初の'0'読み採取を記します。その後クロック再生論理回路は有効な開始ビットが受信されたかを判断するのに3つの 連続採取(標準動作で採取8,9,10、倍速動作で採取4,5,6)を使います。2つまたは3つの採取が'0'を読む場合、開始ビットが受け入れられます。クロック再生部が同期化され、データ再生を始めることができます。2つ未満の採取が'0'を読む場合、この開始ビットは捨てられます。この処理は各開始ビット毎に繰り返されます。

### 25.3.3.2.2. データ再生

クロック再生と同様に、データ再生部は倍速動作または標準動作で動いているかに依存して、各々、ボーレートよりも8または16倍速い速度 で採取します。下図は受信したフレームでのビット読み取り用採取処理を示します。

| 図25-7. データビッ                       | トとパリテ         | ィビットの         | )採            | 权             |               |               |               |   |               |                |               |          |               |                |               |               |               |
|------------------------------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---|---------------|----------------|---------------|----------|---------------|----------------|---------------|---------------|---------------|
| RxD                                | ビットn-         |               |               |               |               |               |               | Ł | :<br>'yh      | n              |               |          |               |                | X             | ごット           | n+1           |
| 採取位置<br>(RXMODE= <mark>00</mark> ) | ↑ ↑<br>15 10  | 6 1 2         | <b>↑</b><br>3 | <b>↑</b><br>4 | <b>↑</b><br>5 | <b>↑</b><br>6 |               |   |               | <b>↑</b><br>10 |               |          | <br>          | <b>↑</b><br>16 | <b>↑</b><br>1 | <b>↑</b><br>2 | <b>↑</b><br>3 |
| 採取位置<br>(RXMODE=01)                | <b>↑</b><br>8 | <b>↑</b><br>1 | <b>↑</b><br>2 |               | <b>↑</b><br>3 |               | <b>↑</b><br>4 |   | <b>↑</b><br>5 |                | <b>↑</b><br>6 | <b>1</b> | <b>↑</b><br>8 |                | <b>↑</b><br>1 |               | <b>↑</b><br>2 |

受信したビットの論理レベルを判断するのにクロック再生でのように中央3採取での多数決技法が使われます。この処理は完全なフレームが 受信されるまで各ビットに対して繰り返されます。

データ再生部は最初の停止ビットだけを受け取る一方で、もっとある場合に残りを無視します。採取した停止ビットが'0'を読む場合、受 信データ上位(USARTn.RXDADAH)レジスタのフレーム異常(FERR)フラグが設定(1)されます。下図は停止ビットの採取を示します。これは最 も早く可能な次のフレームの始めも示します。

| 図25-8. 停止ビットと次の開始ビットの採取            |                                                                                    |                                                                                |                                                                                                                                                                             |  |  |  |
|------------------------------------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| RxD                                |                                                                                    | 停止ビット                                                                          | A B、開始ビット C                                                                                                                                                                 |  |  |  |
| 採取位置<br>(RXMODE= <mark>00</mark> ) | $\begin{array}{c c} \uparrow & \uparrow & \uparrow \\ 15 & 16 & 1 & 2 \end{array}$ | $\begin{array}{c} \uparrow \\ 3 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \end{array}$     | $\uparrow \uparrow \uparrow$<br>9 10 0/1 0/1 0/1 14 15 16 1 2 3 |  |  |  |
| 採取位置<br>(RXMODE <mark>=01</mark> ) | <b>↑</b><br>8 1                                                                    | $ \begin{array}{c c} \uparrow & \uparrow & \uparrow \\ 2 & 3 & 4 \end{array} $ | $ \begin{array}{c c} \uparrow & \uparrow & \uparrow & \uparrow & \uparrow \\ \hline 5 & 6 & 0/1 & 8 & 1 & 2 \end{array} $                                                   |  |  |  |

新しいフレームの開始ビットを示すHighからLowへの遷移は多数決に使ったビットの最後の直後に来得ます。標準速動作については最初のLowレベル採取、上図でAと記された点で有り得ます。倍速動作については最初のLowレベルが多数決採取後の最初の採取であるB点に遅らされなければなりません。C点は公称ボーレートでの停止ビットの全長(の終点)を記します。

### 25.3.3.2.3. 許容誤差

内部的に生成したボーレートの速度と外部的に受信したデータ速度は理想的に同じでなければなりませんが、本来のクロック元誤差のため、これは通常、その状況ではありません。USARTはこのような誤差を許容し、この許容の限度が時に動作範囲として知られるものを 構成します。

以下の表は許容することができる最大受信部ボーレート誤差であるUSARTの動作範囲を一覧にします。標準速動作が倍速動作よりもより高いボーレート変化の許容誤差を持つことに注意してください。

| 表25-4 | 表25-4. 標準速と倍速での受信部ボーレート推奨最大許容誤差(訳注:原書の表25-4.と表25-5.は表25-4.として纏めました。) |                       |                    |           |                       |                                        |                    |           |  |  |  |
|-------|----------------------------------------------------------------------|-----------------------|--------------------|-----------|-----------------------|----------------------------------------|--------------------|-----------|--|--|--|
| D     | 標準速動作 (RXMODE=00(NORMAL))                                            |                       |                    |           |                       | 倍速動作 (RXMODE= <mark>01</mark> (CLK2X)) |                    |           |  |  |  |
| D     | R <sub>slow</sub> (%)                                                | R <sub>fast</sub> (%) | 総合許容誤差(%)          | 推奨許容誤差(%) | R <sub>slow</sub> (%) | Rfast(%)                               | 総合許容誤差(%)          | 推奨許容誤差(%) |  |  |  |
| 5     | 93.20                                                                | 106.67                | $-6.80 \sim +6.67$ | $\pm 3.0$ | 94.12                 | 105.66                                 | $-5.88 \sim +5.66$ | $\pm 2.5$ |  |  |  |
| 6     | 94.12                                                                | 105.79                | -5.88~+5.79        | $\pm 2.5$ | 94.92                 | 104.92                                 | $-5.08 \sim +4.92$ | $\pm 2.0$ |  |  |  |
| 7     | 94.81                                                                | 105.11                | -5.19~+5.11        | ±2.0      | 95.52                 | 104.35                                 | -4.48~+4.35        | $\pm 1.5$ |  |  |  |
| 8     | 95.36                                                                | 104.58                | $-4.54 \sim +4.58$ | ±2.0      | 96.00                 | 103.90                                 | $-4.00 \sim +3.90$ | $\pm 1.5$ |  |  |  |
| 9     | 95.81                                                                | 104.14                | -4.19~+4.14        | $\pm 1.5$ | 96.39                 | 103.53                                 | $-3.61 \sim +3.53$ | $\pm 1.5$ |  |  |  |
| 10    | 96.17                                                                | 103.78                | -3.83~+3.78        | ±1.5      | 96.70                 | 103.23                                 | -3.30~+3.23        | $\pm 1.0$ |  |  |  |

注: ・D: 文字(データ)ビット数とハッリティビットの合計(D=5~10)

・Rslow: 受信部ボーレートに関連して受け入れすることができる最低到着データ速度の比率

・Rfast: 受信部ボーレートに関連して受け入れすることができる最高到着データ速度の比率

最大受信部ボーレート誤差の推奨は受信側と送信側が最大総許容誤差を等しく分けるとの仮定の元で作られました。

以下の式は到着データ速度と内部受信部ボーレートの最大比率計算に使われます。

| S(D+1)                                       | D :文字(データ)ビット数とハッリティビットの合計(D=5~10)                |
|----------------------------------------------|---------------------------------------------------|
| $R_{slow} = \frac{S(D+1)}{S(D+1) + S_F - 1}$ | S : ビット当たりの採取数。標準速動作はS=16、倍速動作はS=8                |
| S(D+1)+SF-1                                  | SF : 多数決に使う最初の採取番号。標準速動作はSF=8、倍速動作はSF=4           |
| S(D+2)                                       | SM :多数決に使う中心の採取番号。標準速動作はSM=9、倍速動作はSM5             |
| $R_{fast} = \frac{S(D+2)}{S(D+1) + S_M}$     | Rslow : 受信側ボーレートに対して許容できる最低到着データ速度の比率             |
| 5(D+1)+5M                                    | R <sub>fast</sub> : 受信側ボーレートに対して許容できる最高到着データ速度の比率 |

### 25.3.3.2.4. 倍速動作

倍速動作はより低い周辺機能クロック周波数での非同期動作下でより高いボーレートを許します。この動作は制御B(USARTn.CTRLB)レジスタの受信部動作(RXMODE)ビット領域に'01'を書くことによって許可されます。

許可されると、「25.3.2.2.1. 分数ボーレート発生器」での式で示されるように、与えられた非同期ボーレート設定に対するボーレートが倍にされます。この動作では、受信部がデータ採取とクロック再生に対して(16から8に減らされた)半分の採取数を使います。これはもっと正確なボーレート設定と周辺機能クロックを必要とします。より多くの詳細については「25.3.3.2.3. 許容誤差」をご覧ください。

### 25.3.3.2.5. 自動ボーレート

自動ボーレート機能は通信装置からの入力に基づいてボーレート(USARTn.BAUD)レジスタの構成設定をUSARTにさせ、これは異なるボー レートで通信する複数装置と自律的に通信することを装置に許します。USART周辺機能は標準自動ボーレート動作とLIN制限自動ボー レート動作の2つの自動ボーレート動作が特徴です。

どちらの自動ボーレート動作も下図で見られるように自動ボーレートフレームを受け取らなければなりません。

中断領域は12以上の連続Low周期が採取される時に検出 され、これから同期領域を受信しようとすることをUSARTに 通知します。中断領域後、同期領域の開始ビットが検出され ると、周辺機能クロック速度で動く計数器が開始されます。計 数器はその後に同期領域の次の8Tbit間増やされます。全 8ビットが採取されると、計数器が停止されます。結果の計数 器値が事実上の新しいBAUDレジスタ値です。

図25-9. 自動ボーレート タイミング

| ◀ 中断領域 | → ← 同期領域>                        |
|--------|----------------------------------|
| 7      |                                  |
|        | $\rightarrow \leftarrow T_{bit}$ |
|        | C I DIL                          |

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である後続する同期領域文字を期待 します。2つの同期装置間のボーレートの違いに対する許容は制御D(USARTn.CTRLD)レシ、スタの自動ボーレート窓幅(ABW)ビットを使って 構成設定することができます。受信した同期領域文字が\$55でない場合、矛盾同期領域異常フラグ(USARTn.STATUSレシ、スタのISFIF ビット)が設定(1)され、ボーレートは無変化です。

### 25.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/RxDピンへ送信している時はその送信も受け取ります。これは受信したデータが送信したデータと同じであるかを調べることによって重なっている送信の検出に使うことができます。

### RS-485動作

RS-485はUSART周辺機能によって支援される通信規格です。これは通信回路の構成を定義する物理的インターフェースです。データは 通信を雑音に対して頑強にする差動信号を使って伝送されます。RS-485は制御A(USARTn.CTRLA)レジスタのRS-485動作(RS485) ビットに'1'を書くことによって許可されます。

RS-485動作は単一USART送信を対応する差動対信号に変換する外部線駆動部デバイスを支援します。これは線駆動部デバイスに対して送信または受信を許可するのに使うことができるXDIRビンの自動制御を許可します。USARTは送信している間、自動的にXDIRビンをHighに駆動し、送信完了時にLowへ引きます。このような回路の例が下図で示されます。

XDIRビンは外部線駆動部を許可するための若干の保護時間を許すため、データが移動出力される1ボーレート クロック周期前にHighになります。XDIRビンは停止ビットを含む完全なフレーム間Highに留まります。



### 図25-11. XDIR駆動タイミング



符号化されたRXD

復号したRXD

未符号化のTXD

符号化したTXD

RS-485動作は単線動作と互換性があります。単線動作はTxDピンを結合したTx D/RxD線にするTxDピンとUSART受信部間の内部接続を許します。RxDピンはU SART受信部から切り離され、違う周辺機能によって制御されるかもしれません。 このような回路の例が右図で示されます。

### 図25-12. 折り返し動作接続でのRS-485



### 25.3.3.2.7. IRCOM動作形態

USART周辺機能は115.2kbpsまでのボーレートに適合するIr DA<sup>®</sup> 1.4である赤外線通信動作(IRCOM:Infrared Commu nication mode)に構成設定することができます。許可され ると、IRCOM動作はUSARTに対して赤外線パルスの符号 化/復号を許します。

USARTは制御C(USARTn.CTRLC)レジスタの通信動作(C MODE)ビット領域に'10'を書くことによってIRCOM動作に 設定されます。TxD/RxDビン上のデータは送受信される赤 外パルスの反転値です。これはIRCOM受信部に対する入

力として事象システムからの事象チャネルを選ぶことも可能です。これは入出力ピンまたは対応するRxDピン以外の供給元からの入力の受信をIRCOMに許し、これはUSARTピンからのRxD入力を禁止します。

図25-13. 構成図

IRCOM

パルス復号

パルス符号化

© 2022 Microchip Technology Inc.とその子会社

事象システム 🖛 事象

USART

RxD

TxD

送信については以下のような3つのパルス変調方式が利用可能です。

- ・3/16ボーレート周期
- ・周辺機能クロック周波数に基いた設定可能な固定パルス時間
- ・パルス変調禁止

受信については論理'0'として復号されるべきパルスに対して定められた選択可能な最小Highレベル パルス幅が使われます。より短い パルスは破棄され、そのビットはパルスが全く受信されなかった場合に論理'1'に復号されます。

倍速動作はIRCOM動作が許可される時にUSARTに対して使うことができません。

# 25.3.4. 付加機能

### 25.3.4.1. パリティ

パリティ ビットはデータ フレームの有効性検査のため、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 ) 図25-14. 保護された識別子領域と識別子とパリティ ヒットの配置



# 25.3.4.2. フレーム開始検出

フレーム開始検出機能はデータ受信でスタンバイ休止動作から起き上がることをUSARTに許します。

RxDピンでHighからLowへの遷移が検出されると、発振器が給電されてUART周辺機能クロックが許可されます。始動後、ボーレートが発振器始動時間に関して充分遅ければ、データフレームの残りを受信することができます。発振器の始動時間は供給電圧と温度で変わります。発振器始動時間特性の詳細については「電気的特性」章を参照してください。

誤った開始ビットが検出された場合で別の供給元が起動してしまっていなければ、スタンバイ休止動作に戻ります。

フレーム開始検出は非同期動作でだけ動きます。これは制御B(USARTn.CTRLB)レシ<sup>、</sup>スタのフレーム開始検出許可(SFDEN)ビットを(1に)書 くことによって許可されます。デバイスがスタンバイ休止動作の間に開始ビットが検出された場合、UART開始割り込み要求フラグ(RXSIF) ビットが設定(1)されます。

UART受信完了フラグ(RXCIF)ビットとUART開始割り込み要求フラグ(RXSIF)ビットは同じ割り込み線を共用しますが、各々は専用の割り込み設定を持ちます。下表は割り込み設定に依存するUSARTフレーム開始検出動作を示します。

| 衣23=0. USART777=4用炉快工到作 |           |           |                                                                  |  |  |  |  |
|-------------------------|-----------|-----------|------------------------------------------------------------------|--|--|--|--|
| SFDEN                   | RXSIF割り込み | RXCIF割り込み | 注釈                                                               |  |  |  |  |
| 0                       | Х         | Х         | 標準動作                                                             |  |  |  |  |
| 1                       | 禁止 禁止     |           | 発振器はフレーム受信中にだけ給電されます。割り込みが禁止されて緩衝部溢れが<br>無視された場合、全ての到着データが失われます。 |  |  |  |  |
| 1                       | 禁止        | 許可        | システム/全てのクロックが受信完了割り込みで起き上がり(起動し)ます。                              |  |  |  |  |
| 1                       | 許可        | Х         | システム/全てのクロックが開始ビット検出時に起き上がり(起動し)ます。                              |  |  |  |  |

表25-6. USARTフレーム開始検出動作

注: SLEEP命令は進行中の通信がある場合に発振器を停止しません。

### 25.3.4.3. 複数プロセッサ通信

複数プロセッサ通信動作(MPCM)は同じ直列バス経由で複数のマイクロコントローラ通信を持つシステムで、受信部によって処理されなければ ならない到着フレーム数を効果的に減らします。この動作は制御B(USARTn.CTRLB)レジスタの複数プロセッサ通信動作(MPCM)ビットに'1' を書くことによって許可されます。この動作ではフレームがアドレスかデータのどちらのフレーム形式かを示すのにフレーム内の専用ビットが使わ れます。

受信部が5~8データビットを含むフレームを受信するように構成設定されたなら、最初の停止ビットはフレーム形式を示すのに使われます。 受信部が9データビットのフレームに構成設定されたなら、フレーム形式を示すのに第9ビットが使われます。フレーム形式(最初の停止または第 9)ビットが'1'の時にそのフレームはアトレスを含みます。フレーム形式ビットが'0'の時にそのフレームはデータフレームです。5~8ビット文字(データ) フレームが使われる場合、最初の停止ビットがフレーム形式を示すのに使われるため、送信部は2停止ビット使用に設定されなければなりま せん。

特定の従装置MCUがアドレス指定されたなら、そのMCUは後続するデータフレームを通常のように受信し、一方他の従装置MCUは別の アドレス フレームが受信されるまでフレームを無視します。

### 25.3.4.3.1. 複数プロセッサ通信動作の使い方

複数プロセッサ通信動作(MPCM)でデータを交換するには次の手順を使ってください。

- 1. 全ての従装置MCUは複数プロセッサ通信動作です。
- 2. 主装置MCUはアドレス フレームを送り、全ての従装置がこのフレームを受け取って読みます。
- 3. 各従装置MCUは選択されたかを判定します。
- 4. アドレス指定されたMCUはMPCMを禁止して全てのデータフレームを受信します。他の従装置MCUはデータフレームを無視します。
- 5. アドレス指定されたMCUが最後のデータフレームを受信してしまうと、再びMPCMを許可して主装置からの新しいアドレスフレームを待たなければなりません。

その後、手順は2.からを繰り返します。

### 25.3.5. 事象

USARTは下表で記述される事象を生成することができます。

#### 表25-7. USARTでの事象生成部

| 生      | 成部名 | 説明                            | 事象型 | 生成クロック領域 | 事象長     |  |
|--------|-----|-------------------------------|-----|----------|---------|--|
| 周辺機能   | 事象  | 品だり月                          | 争外空 | 王成加加加國   | 尹豕文     |  |
| USARTn | ХСК | SPI主装置動作と同期USART主装置動作でのクロック信号 | パルス | CLK_PER  | 1 XCK周期 |  |

下表は事象使用部とその関連機能を記述します。

| 表25-8. US | ARTでの事象使 | 用部              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        |  |  |  |  |  |
|-----------|----------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--|--|--|--|--|
| 使用部名      |          | =H =B           | 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 同期/非同期 |  |  |  |  |  |
| 周辺機能      | 入力       | 武明              | 説明のおいたので、「「「」」の「「」」の「「」」の「「」」の「「」」の「「」」の「」」の「「」」の「」」の「「」」の「」」の「「」」の「」」の「「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」の「」」。 |        |  |  |  |  |  |
| USARTn    | IREI     | USARTn IrDA事象入力 | パルス                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 同期     |  |  |  |  |  |

### 25.3.6. 割り込み

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

| 名称  | ベクタ説明        | 条件                                                                                                                                  |
|-----|--------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 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レジスタをご覧 ください。

# 25.4. レジスタ要約

| 変位    | 略称       | ビット位置       | ビット7  | ビット6   | ビット5  | ビット4           | ビット3    | ビット2  | ビット1      | ビットロ   |
|-------|----------|-------------|-------|--------|-------|----------------|---------|-------|-----------|--------|
| +\$00 | RXDATAL  | $7 \sim 0$  |       |        |       | DAT            | A7~0    |       |           |        |
| +\$01 | RXDATAH  | 7~0         | RXCIF | BUFOVF |       |                |         | FERR  | PERR      | DATA8  |
| +\$02 | TXDATAL  | $7 \sim 0$  |       |        |       | DAT            | A7~0    | 1     | 1         |        |
| +\$03 | TXDATAH  | $7 \sim 0$  |       |        |       |                |         |       |           | DATA8  |
| +\$04 | STATUS   | $7 \sim 0$  | RXCIF | TXCIF  | DREIF | RXSIF          | ISFIF   |       | BDF       | WFB    |
| +\$05 | CTRLA    | $7 \sim 0$  | RXCIE | TXCIE  | DREIE | RXSIE          | LBME    | ABEIE |           | RS485  |
| +\$06 | CTRLB    | $7 \sim 0$  | RXEN  | TXEN   |       | SFDEN          | ODME    | RXMC  | DE1,0     | MPCM   |
| +\$07 | CTRLC    | $7 \sim 0$  | CMO   | DE1.0  | PMO   | MODE1,0 SBMODE |         |       | CHSIZE2~0 |        |
| ±φ07  | CIRLU    | 1,00        | CMO   |        |       |                |         | UDORD | UCPHA     |        |
| +\$08 | BAUD     | $7 \sim 0$  |       | 1      |       | BAU            | D7~0    | I     | I         |        |
| +\$09 | DAUD     | $15 \sim 8$ |       | 1      |       | BAUI           | 015~8   | 1     | I         |        |
| +\$0A | CTRLD    | $7 \sim 0$  | ABV   | V1,0   |       |                |         |       |           |        |
| +\$0B | DBGCTRL  | $7 \sim 0$  |       |        |       |                |         |       |           | DBGRUN |
| +\$0C | EVCTRL   | $7 \sim 0$  |       |        |       |                |         |       |           | IREI   |
| +\$0D | TXPLCTRL | $7 \sim 0$  |       |        |       | TXPI           | L7~0    | I     | I         |        |
| +\$0E | RXPLCTRL | 7~0         |       |        |       |                | RXPL7~0 | 1     | 1         |        |

# 25.5. レジスタ説明

# 25.5.1. RXDATAL - 受信データ下位バル (Rceiver Data Register Low Byte)

名称:RXDATAL

**変位** : +\$00

リセット : \$00

特質 :-

このレジスタはUSART受信部によって受信されたデータの下位側8ビットを含みます。USART受信部は2重緩衝され、このレジスタは常に最 も古くに受信したフレームに対するデータを示します。受信緩衝部に1フレームに対するデータだけが存在する場合、このレジスタはそのデータ を含みます。

緩衝部は構成設定に依存してRXDATALまたはRXDATAHのどちらかが読まれる時にデータを移動します。移動前に両バイトを読むことができるようにデータ移動を引き起こさないレジスタが先に読まれなければなりません。

制御C(USARTn.CTRLC)レジスタの文字ビット数(CHSIZE)ビット領域が9ビット(下位ハイト先行)に構成設定される場合、RXDATAHの読み 込みが受信緩衝部を移動します。さもなければ、RXDATALが緩衝部を移動します。

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

# 25.5.2. RXDATAH - 受信データ上位ハイト (Rceiver Data Register High Byte)

名称:RXDATAH

**変位**:+\$01

リセット : \$00

特質 :-

このレジネタはUSART受信部によって受信されたデータの上位側ビットだけでなく、受信したデータフレームの状態を反映する状態ビットも含みます。USART受信部は2重緩衝され、このレジスタは常に最も古くに受信したフレームに対するデータと状態ビットを示します。受信緩衝部に17レームに対するデータと状態ビットだけが存在する場合、このレジスタはそのデータと状態ビットを含みます。

緩衝部は構成設定に依存してRXDATALまたはRXDATAHのどちらかが読まれる時にデータを移動します。移動前に両バイトを読むこ とができるようにデータ移動を引き起こさないレージスタが先に読まれなければなりません。

制御C(USARTn.CTRLC)レジ゙スタの文字ビット数(CHSIZE)、ット領域が9ビット(下位ハ・イト先行)に構成設定される場合、RXDATAHの読み 込みが受信緩衝部を移動します。さもなければ、RXDATALが緩衝部を移動します。

| ビット    | 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)されます。

### ● ビット6 - BUFOVF:緩衝部溢れフラグ(Buffer Overflow)

このフラグは緩衝部溢れが検出された場合に設定(1)されます。緩衝部溢れは受信緩衝部が満杯で、新しフレームが受信移動レジスタで 待っていて、新しい開始ビットが検出された時に起こります。このフラグは受信データ(USARTn.RXDATALとUSARTn.RXDATAH)レジスタ が読まれる時に解除(0)されます。

このフラグは主装置SPI動作形態で使われません。

### • ビット2 - FERR : フレーム異常フラク (Frame Error)

このフラグは最初の最初の停止ビットが、0'の場合に設定(1)され、それが、1'として正しく読めた時に解除(0)されます。 このフラグは主装置SPI動作形態で使われません。

### • ビット1 - PERR : パリティ誤りフラク (Parity Error)

このフラグはハ<sup>ッ</sup>リティ検査が許可され、受信したデータがハ<sup>ッ</sup>リティ誤りを持つ場合に設定(1)され、さもなければ、このフラグは解除(0)されます。 ハ<sup>ッ</sup>リティ計算の詳細については「25.3.4.1. ハ<sup>ッ</sup>リティ」を参照してください。

このフラグは主装置SPI動作形態で使われません。

• ビット0 - DATA8 : 受信データビット8 (Receiver Data Register)

9ビットの大きさのフレーム使用時、このビットは受信データの第9(最上位)ビットを保持します。

制御B(USARTn.CTRLB)レジスタの受信動作(RXMODE)ビット領域がLIN制限自動ホーレート(LINAUTO)動作に構成設定されると、この ビットは受信データがLINフレームの応答空間内かを示します。受信データが保護された識別子領域なら、このビットは解除(0)され、さもなけ れば、設定(1)されます。

25.5.3. TXDATAL - 送信データ下位バ仆 (Transmit Data Register Low Byte)

# 名称:TXDATAL

**変位** : +\$02

**リセット** : \$00

# 特質 :-

このレジスタに書かれたデータは自動的にTX緩衝部を通して専用の移動レジスタに設定されます。移動レジスタはビットの各々を直列に TxDピンに出力します。

9ビットの大きさのフレーム使用時、第9(最上位)ビットは送信データ上位ハイト(USARTn.TXDATAH)レシ、スタに書かれなければなりません。その場合、緩衝部は構成設定に応じて送信データ下位ハイト(USARTn.TXDATAL)レシ、スタまたは送信データ上位ハイト(USARTn.TXDATA H)レシ、スタのどちらかが書かれた時にデータを移動します。移動前に両ハイトを書くことができるようにデータ移動を引き起こさないレシ、スタ が先に書かれなければなりません。

制御C(USARTn.CTRLC)レジスタの文字ビット数(CHSIZE)ビット領域が9ビット(下位ハイト先行)に構成設定されると、送信データ上位ハイトレジスタの書き込みが送信緩衝部を移動します。さもなければ、信データ下位ハイトレジスタが緩衝部を移動します。

このレシ、スタは状態(USARTn.STATUS)レシ、スタのデータレシ、スタ空割り込み要求フラグ(DREIF)が設定(1)されている時にだけ書くことができます。

| ビット    | 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:送信データ (Transmit Data Register Low Byte)

25.5.4. TXDATAH - 送信データ上位バ仆 (Transmit Data Register High Byte)

### 名称:TXDATAH

**変位** : +\$03

### **リセット** : \$00

特質 :-

このレジスタに書かれたデータは自動的にTX緩衝部を通して専用の移動レジスタに設定されます。移動レジスタはビットの各々を直列に TxDピンに出力します。

9ビットの大きさのフレーム使用時、第9(最上位)ビットは送信データ上位ハイト(USARTn.TXDATAH)レシ、スタに書かれなければなりません。その場合、緩衝部は構成設定に応じて送信データ下位ハイト(USARTn.TXDATAL)レシ、スタまたは送信データ上位ハイト(USARTn.TXDATA H)レシ、スタのどちらかが書かれた時にデータを移動します。移動前に両ハイトを書くことができるようにデータ移動を引き起こさないレシ、スタ が先に書かれなければなりません。

制御C(USARTn.CTRLC)レジスタの文字ビット数(CHSIZE)ビット領域が9ビット(下位ハイト先行)に構成設定されると、送信データ上位ハイトレジスタの書き込みが送信緩衝部を移動します。さもなければ、信データ下位ハイトレジスタが緩衝部を移動します。

このレシ、スタは状態(USARTn.STATUS)レシ、スタのデータレシ、スタ空割り込み要求フラグ(DREIF)が設定(1)されている時にだけ書くことができます。

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

# • ビット7 - DATA8 : 送信データビット8 (Transmit Data Register High Byte)

このビットは制御C(USARTn.CTRLC)レジスタの文字ビット数(CHSIZE)=9BITLまたは9BITHの時に使われます。

25.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 | W   |
| リセット値  | 0     | 0     | 1     | 0     | 0     | 0 | 0   | 0   |

● ビット7 - RXCIF : 受信完了割り込み要求フラグ(Receive Complete Interrupt Flag)

このフラグは受信緩衝部内に未読データがある時に設定(1)され、受信緩衝部が空の時に解除(0)されます。

● ビット6 - TXCIF : 送信完了割り込み要求フラグ(USART Transmit Complete Interrupt Flag)

このフラグは送信移動レジスタのフレーム全体が移動出力されてしまい、送信緩衝部と送信データ(TXDATALとTXDATAH)レジスタ内に新し いデータがない時に設定(1)されます。これに、1'を書くことによって解除(0)されます。

# • ビット5 - DREIF : データレジスタ空割り込み要求フラグ(USART Data Register Empty Flag)

このフラグは送信データ(USARTn.TXDATALとUSARTn.TXDATAH)レジスタが空の時に設定(1)され、それらが送信移動レジスタ内へ未だ移されないデータを含む時に解除(0)されます。

# • ビット4 - RXSIF : 受信開始割り込み要求フラヴ(USART Receive Start Interrupt Flag)

このフラグはフレーム開始検出が許可され、デベイスがスタンベイ休止動作で、有効な開始ビットが検出された時に設定(1)されます。これに <sup>・</sup>1`を書くことによって解除(0)されます。

このフラグは主装置SPI動作形態で使われません。

# ● ビット3 - ISFIF : 矛盾同期領域割り込み要求フラグ(Inconsistent Sync Field Interrupt Flag)

このフラグは自動ボーレートが許可されて、同期領域が与えられた有効なボーレート設定に対して速すぎる、または遅すぎる場合に設定(1) されます。USARTがLINAUTO動作に設定され、同期(SYNC)文字が\$55のデータ値と違う時にも設定(1)されます。このフラグはこれに '1'を書くことによって解除(0)されます。より多くの情報については「自動ボーレート」項をご覧ください。

# • ビット1 - BDF : 中断検出フラグ(Break Detected Flag)

このフラグは自動ボーレート動作が許可され、有効な中断(BREAK)と同期(SYNC)の文字が検出された場合に設定(1)され、次のデータが 受信された時に解除(0)されます。これに'1'を書くことによっても解除(0)することができます。より多くの情報については「自動ボーレー 」」項をご覧ください。

### ● ビット0 - WFB : 中断待機 (Wait For Break)

このビットの設定(1)は後続する到着フレームに対する中断(BREAK)機能用待機を許可します。このフレーム後、この機能は自動的に禁止 されます。

# 25.5.6. CTRLA - 制御A (Control A)

名称:CTRLA

# **変位** : +\$05

リセット : \$00

特質 :-

| ビット    | 7     | 6     | 5     | 4     | 3    | 2     | 1 | 0     |
|--------|-------|-------|-------|-------|------|-------|---|-------|
|        | RXCIE | TXCIE | DREIE | RXSIE | LBME | ABEIE |   | RS485 |
| アクセス種別 | R/W   | R/W   | R/W   | R/W   | R/W  | R/W   | R | R/W   |
| リセット値  | 0     | 0     | 0     | 0     | 0    | 0     | 0 | 0     |

# ● ビット7 - RXCIE : 受信完了割り込み許可 (Receive Complete Interrupt Enable)

このビットは受信完了割り込みが許可されるか否かを制御します。許可されると、割り込みは状態(USARTn.STATUS)レジスタの受信完 了割り込み要求フラグ(RXCIF)ビットが設定(1)される時に起動されます。

| 値  | 0                | 1                |
|----|------------------|------------------|
| 説明 | 受信完了割り込みが禁止されます。 | 受信完了割り込みが許可されます。 |

# ● ビット6 - TXCIE : 送信完了割り込み許可 (Transmit Complete Interrupt Enable)

このビットは送信完了割り込みが許可されるか否かを制御します。許可されると、割り込みは状態(USARTn.STATUS)レジスタの送信完了割り込み要求フラク(TXCIF)ビットが設定(1)される時に起動されます。

| 値  | 0                | 1                |
|----|------------------|------------------|
| 説明 | 送信完了割り込みが禁止されます。 | 送信完了割り込みが許可されます。 |

### • ビット5 - DREIE : データレジスタ空割り込み許可 (Data Register Empty Interrupt Enable)

このビットはデータレジスタ空割り込み許可されるか否かを制御します。許可されると、割り込みは状態(USARTn.STATUS)レジスタのデータレジスタ空割り込み要求フラグ(DREIF)ビットが設定(1)される時に起動されます。

| 値  | 0                    | 1                    |
|----|----------------------|----------------------|
| 説明 | データレジスタ空割り込みが禁止されます。 | データレジスタ空割り込みが許可されます。 |

### ● ビット4 - RXSIE : 受信開始割り込み許可 (Receiver Start Frame Interrupt Enable)

このビットは受信開始割り込みが許可されるか否かを制御します。許可されると、割り込みは状態(USARTn.STATUS)レジスタの受信開始割り込み要求フラグ(RXSIF)ビットが設定(1)される時に起動されます。

| 值  | 0                | 1                |
|----|------------------|------------------|
| 説明 | 受信開始割り込みが禁止されます。 | 受信開始割り込みが許可されます。 |

# ● ビット3 - LBME : 折り返し動作許可 (Loop-back Mode Enable)

このビットは折り返し動作が許可されるか否かを制御します。許可されると、TxDピンとUSART受信部間の内部接続が作成され、RxDピ ンからUSART受信部への入力が切断されます。

| 値  | 0              | 1              |  |  |
|----|----------------|----------------|--|--|
| 説明 | 折り返し動作が禁止されます。 | 折り返し動作が許可されます。 |  |  |

# ● ビット2 - ABEIE : 自動ボーレート異常割り込み許可 (Auto-baud Error Interrupt Enable)

このビットは自動ボーレート異常割り込みが許可されるか否かを制御します。許可されると、割り込みは状態(USARTn.STATUS)レジスタの 矛盾同期領域割り込み要求フラグ(ISFIF)ビットが設定(1)される時に起動されます。

| 值  | 0                     | 1                     |
|----|-----------------------|-----------------------|
| 説明 | 自動ボーレート異常割り込みが禁止されます。 | 自動ボーレート異常割り込みが許可されます。 |

### • ビット0 - RS485 : RS-485動作 (RS-485 Mode)

このビットはRS-485動作が許可されるか否かを制御します。より多くの情報については「RS-485動作」項を参照してください。

| 值  | 0                | 1                |  |  |  |  |
|----|------------------|------------------|--|--|--|--|
| 説明 | RS-485動作が禁止されます。 | RS-485動作が許可されます。 |  |  |  |  |

# 25.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)

このビットはUSART受信部が許可されるか否かを制御します。より多くの情報については「25.3.2.4.2. 受信部禁止」項を参照してください。

| 值  | 0                 | 1                |  |  |  |
|----|-------------------|------------------|--|--|--|
| 説明 | RUSART受信部が禁止されます。 | USART受信部が許可されます。 |  |  |  |

# ● ビット6 - TXEN : 送信許可 (Transmitter Enable)

このビットはUSART送信部が許可されるか否かを制御します。より多くの情報については「25.3.2.3.1. 送信部禁止」項を参照してください。

| 值  | 0                 | 1                |
|----|-------------------|------------------|
| 説明 | RUSART送信部が禁止されます。 | USART送信部が許可されます。 |

# ● ビット4 - SFDEN : フレーム開始検出許可 (Start of Frame Detection Enable)

このビットはUSARTフレーム開始検出動作が許可されるか否かを制御します。より多くの情報については「25.3.4.2. フレーム開始検出」項 を参照してください。

| 値  | 0                 | 1                |  |  |
|----|-------------------|------------------|--|--|
| 説明 | RUSART送信部が禁止されます。 | USART送信部が許可されます。 |  |  |

# • ビット3 - ODME : オープントレイン動作許可 (Open Drain Mode Enable)

このビットはオープンドレイン動作が許可されるか否かを制御します。より多くの情報については「単線動作」項を参照してください。

| 值  | 0                  | 1                  |  |  |  |
|----|--------------------|--------------------|--|--|--|
| 説明 | オープンドレイン動作が禁止されます。 | オープンドレイン動作が許可されます。 |  |  |  |

# ● ビット2,1 - RXMODE1,0 : 受信動作 (Receiver Mode)

このビット領域書き込みはUSARTの受信部動作を選びます。

- ・これらのビットへの '00' 書き込みは標準速(NORMAL)動作を許可します。制御C(USARTn.CTRLC)レジスタのUSART通信動作(CM ODE)ビット領域が非同期USART(ASYNCHRONOUS)または赤外通信(IRCOM)に構成設定される時は常にRXMODEビット領域へ '00'を書いてください。
- ・これらのビットへの '01' 書き込みは倍速(CLK2X) 動作を許可します。より多くの情報については 「25.3.3.2.4. 倍速動作」 項を参照してください。
- ・これらのビットへの '10' 書き込みは標準自動ボーレート(GENAUT)動作を許可します。より多くの情報については「自動ボーレート」項を 参照してください。
- ・これらのビットへの '11' 書き込みはLIN制限自動ボーレート(LINAUTO)動作を許可します。より多くの情報については「自動ボーレート」 項を参照してください。

| 值  | 0 0    | 01    | 1 0         | 11             |  |
|----|--------|-------|-------------|----------------|--|
| 名称 | NORMAL | CLK2X | GENAUTO     | LINAUTO        |  |
| 説明 | 標準速動作  | 倍速動作  | 標準自動ボーレート動作 | LIN制限自動ボーレート動作 |  |

### • ビット0 - MPCM : 複数プロセッサ通信動作 (Multi-processor Communication Mode)

このビットは複数プロセッサ通信動作が許可されるか否かを制御します。より多くの情報については「25.3.4.3. 複数プロセッサ通信」をご覧 ください。

| 値  | 0                   | 1                   |  |  |  |  |
|----|---------------------|---------------------|--|--|--|--|
| 説明 | 複数プロセッサ通信動作が禁止されます。 | 複数プロセッサ通信動作が許可されます。 |  |  |  |  |

### 25.5.8. CTRLC - 制御C - 標準動作 (Control C - Normal Mode)

名称:CTRLC

**変位**:+\$07

リセット : \$03

このレジスタ記述は主装置SPI動作を除く全動作に対して有効です。このレジスタのUSART通信動作(CMODE)ビット領域が'MSPI'を書かれた時の正確な記述については「制御C(CTRLC) - 主装置SPI動作」レジスタをご覧ください。

| ヒット    | 7   | 6     | 5   | 4     | 3      | 2   | 1         | 0   |
|--------|-----|-------|-----|-------|--------|-----|-----------|-----|
|        | СМО | 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          | 01          | 1 0   | 11     |
|----|--------------|-------------|-------|--------|
| 名称 | ASYNCHRONOUS | SYNCHRONOUS | IRCOM | MSPI   |
| 説明 | 非同期USART     | 同期USART     | 赤外線通信 | 主装置SPI |

# ビット5,4 - PMODE1,0: パリティ動作 (Parity Mode)

このビット領域はパリティ生成の形式を選びます。より多くの情報については「25.3.4.1. パリティ」をご覧ください。

| 值  | 0 0      | 01   | 1 0       | 11        |
|----|----------|------|-----------|-----------|
| 名称 | DISABLED | -    | EVEN      | ODD       |
| 説明 | 禁止       | (予約) | 許可、偶数パリティ | 許可、奇数パリティ |

# ● ビット3 - SBMODE : 停止ビット動作 (Stop Bit Mode)

このビットは送信部によって挿入される停止ビット数を選びます。受信部はこの設定を無視します。

| 値  | 0      | 1      |
|----|--------|--------|
| 説明 | 1停止ビット | 2停止ビット |

# ビット2~0 - CHSIZE2~0:文字ビット数 (Character Size)

このビット領域はフレーム内のデータ ビット数を選びます。受信部と送信部は同じ設定を使います。9ビット文字に対しては、受信データ(RXD ATA)または送信データ(TXDATA)の下位または上位で先に読み書きするバイト順を構成設定することができます。

| 值  | 000  | 001  | 010  | 011   | 100  | 101  | 110           | 111           |
|----|------|------|------|-------|------|------|---------------|---------------|
| 名称 | 5BIT | 6BIT | 7BIT | 8BIT  | _    | _    | 9BITL         | 9BITH         |
| 説明 | 5ビット | 6ビット | 7ビット | 8Ľ ット | (予約) | (予約) | 9ビット(下位バイト先行) | 9ビット(上位ハイト先行) |

# 25.5.9. CTRLC - 制御C - 主装置SPI動作 (Control C - Master SPI Mode)

名称 : CTRLC

**変位** : +\$07

**リセット** : \$02

特質 :-

このレジスタ記述はUSARTが(通信動作(CMODE)がMSPIを書かれる)主装置SPI動作の時にだけ有効です。他のCMODE値ついての 正確な記述に関しては「制御C(CTRLC) - 標準動作」レジスタをご覧ください。

主装置SPI動作の完全な記述については「25.3.3.1.3. 主装置SPI動作でのUSART」をご覧ください。

| ビット    | 7   | 6     | 5 | 4 | 3 | 2     | 1     | 0 |
|--------|-----|-------|---|---|---|-------|-------|---|
| [      | СМО | 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          | 01          | 10    | 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)

このビットはインターフェースクロックの位相を制御します。より多くの情報については「クロック生成」項を参照してください。

| 值  | 0                   | 1                   |
|----|---------------------|---------------------|
| 説明 | データが先行(先頭)端で採取されます。 | データが後行(最終)端で採取されます。 |

# **25.5.10. BAUD** – **ホ**<sup>\*</sup>−**レ**−**ŀ** (Baud Register)

名称: BAUD (BAUDH, BAUDL)

**変位**:+\$08

**リセット** : \$0000

### 特質 :-

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

送信部と受信部の進行中の転送はボーレートが変更される場合に不正にされます。このレジスタへの書き込みはボーレート前置分周器の即時更新を起動します。ボーレートの設定方法のより多くの情報については表25-1.をご覧ください。

| Ľ ْ سِ ا | 15  | 14  | 13  | 12   | 11    | 10  | 9   | 8   |
|----------|-----|-----|-----|------|-------|-----|-----|-----|
|          |     |     |     | BAUI | 015~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   |
|          |     |     |     | 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ビットボーレートレジスタの下位バイトを保持します。

# 25.5.11. CTRLD - 制御D (Control D)

| 名称 | : | CTRLD |
|----|---|-------|
| 赤凸 |   | ±¢0∆  |

変位 : +\$0A リセット : \$00

特質:-

1寸良 ·

| ビット _  | 7   | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|-----|------|---|---|---|---|---|---|
|        | ABV | W1,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)

これらのビットはLIN制限自動ボーレート動作使用時に2つの同期する装置間のボーレートの違いに対する許容値を制御します。許容値は 毎回の2ビット間のボーレート採取数に基づきます。ボーレートが同じ時は各ビットが16回採取されるため、各ビット対間は32ボーレート採取でな ければなりません。

|   | 值  | 0 0          | 01           | 10           | 11           |
|---|----|--------------|--------------|--------------|--------------|
| ſ | 名称 | WDW0         | WDW1         | WDW2         | WDW3         |
|   | 説明 | 32±6 (18%許容) | 32±5 (15%許容) | 32±7 (21%許容) | 32±8 (25%許容) |

# **25.5.12. DBGCTRL - デバッグ制御** (Debug Control)

| 名称 : DBGCT<br>変位 : +\$0B<br>リセット : \$00<br>特質 : - | `RL |   |   |   |   |   |   |        |
|---------------------------------------------------|-----|---|---|---|---|---|---|--------|
| ビット                                               | 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停止時に走行継続 |  |  |

# 25.5.13. EVCTRL - 事象制御 (IrDA Control Register)

| 名称 | : EVCTRI |
|----|----------|
|    |          |

**変位**:+\$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 | 0    |

# • ビットO - IREI : IrDA事象入力許可 (IrDA Event Input Enable)

このビットはIrDA事象入力が許可されるか否かを制御します。より多くの情報については「25.3.3.2.7. IRCOM動作形態」項をご覧ください。

| 值  | 0                | 1                |  |  |
|----|------------------|------------------|--|--|
| 説明 | IrDA事象入力が禁止されます。 | IrDA事象入力が許可されます。 |  |  |

# 25.5.14. TXPLCTRL - IRCOM送信パルス長制御 (IRCOM Transmitter Pulse Length Control Register)

名称:TXPLCTRL

**変位** : +\$0D

リセット : \$00

特質 :-

| ビット    | 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                                                                                         | \$00 3/16ボーレート周期パルス変調が使われます。                                                                                         |  |  |  |  |  |
| <b>\$01~\$FE</b> 固定パルス長符号化が使われます。この8ビット値はパルスに対する周辺機能クロック周期数を設定します。パルスのはボーレートクロックの上昇端で同期されます。 |                                                                                                                      |  |  |  |  |  |
|                                                                                              | ハ <sup>°</sup> ルス符号化禁止。送受信の信号はIRCOM単位部を無変化で通過します。これは半二重USART、折り返し検査、<br>事象チャネルからのUSART受信入力のような、IRCOM単位部を通す他の機能を許します。 |  |  |  |  |  |

0

1

25.5.15. RXPLCTRL - IRCOM受信パルス長制御 (IRCOM Receiver Pulse Length Control Register)

| 変<br>リセ | 称 : RXPLC<br>位 : +\$0E<br>zyh : \$00<br>:質 : - | CTRL |     |     |     |         |     |
|---------|------------------------------------------------|------|-----|-----|-----|---------|-----|
|         | ビット                                            | 7    | 6   | 5   | 4   | 3       | 2   |
|         |                                                |      |     |     |     | RXPL6~0 |     |
|         | アクセス種別                                         | R    | R/W | R/W | R/W | R/W     | R/W |

| - / (  |   | ě   | 0   |     | •       | -   |     | \$  |
|--------|---|-----|-----|-----|---------|-----|-----|-----|
|        |   |     |     |     | RXPL6~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~0 - RXPL7~0 : 受信パルス長 (Receiver Pulse Length)

この7ビット値はIRCOM送受信部に対する濾波係数を設定します。このレジスタの設定はUSARTによってIRCOM動作が選択される場合にだけ有効で、USART受信部が許可(RXEN)される前に構成設定されなければなりせん。

| 値         | 説明                                                   |  |  |  |
|-----------|------------------------------------------------------|--|--|--|
| \$00      | 濾波が禁止されます。                                           |  |  |  |
| \$01~\$7F | 'F 濾波が許可されます。RXPL+1の値は受け入れるべき受信したパルスに必要とされる採取数を表します。 |  |  |  |

# 26. SPI - 直列周辺インターフェース

# 26.1. 特徴

- ・全二重、3線同期データ転送
- ・主装置または従装置の動作
- ・LSB先行またはMSB先行のデータ転送
- ・設定可能な7つのビット速度
- ・転送の最後での割り込み要求フラグ
- ・書き込み衝突フラグ保護
- ・アイドル休止動作からの起き上がり
- ・倍速(CK/2)主装置SPI動作

# 26.2. 概要

直列周辺インターフェース(SPI)は3または4つのピンを用いる高速同期データ転送インターフェースです。それはAVR®デバイスと周辺装置間、また は様々なマイクロコントローラ間での全二重通信を許します。SPI周辺機能は主装置または従装置のどちらかとして構成設定することがで きます。主装置が全てのデータ転送処理を始めて制御します。

SPIを持つ主装置と従装置のデバイス間の相互接続が下の構成図で示されます。このシステムは2つの移動レジスタと主装置クロック発生器から成ります。SPI主装置は望む従装置の従装置選択(SS)信号をLowに引くことによって通信周回を始めます。主装置と従装置は送るべきデータをそれらの各々の移動レジスタに用意して、主装置はデータを交換するためにSCK線上に必要とするクロックパルスを生成します。データは常に主装置出力従装置入力(MOSI)線で主装置から従装置へ、主装置入力従装置出力(MISO)線で従装置から主装置へ移動されます。

# 26.2.1. 構成図



SPIは同時にデータの移動出力と入力を行う8ビット移動レジスタ周辺を構築します。データ(DATA)レジスタは物理的なレジスタではありませんが、読み書きされる時に他のレジスタに割り当てられます。送信時のデータ(SPIn.DATA)レジスタは標準動作で移動レジスタに、緩衝動作で送信緩衝レジスタに書きます。受信時のデータ(SPIn.DATA)レジスタ読み込みは標準動作で受信データレジスタを、緩衝動作で受信データ緩衝レジスタを読みます。

主装置動作ではSPIがSCKクロックを生成するクロック生成器を持ちます。従装置では受け取ったSCKクロックが同期化されて移動レジスタで データの移動を起動するように採取されます。

# 26.2.2. 信号説明

# 表26-1. 主装置動作と従装置動作での信号

| 信号            | 形                         | 式                           |            |  |
|---------------|---------------------------|-----------------------------|------------|--|
| 语写            | 主装置動作                     | 従装置動作                       | 高元 9月      |  |
| MOSI          | 使用者定義 ( <mark>注</mark> 1) | 入力                          | 主装置出力従装置入力 |  |
| MISO          | 入力                        | 使用者定義 ( <mark>注1,2</mark> ) | 主装置入力従装置出力 |  |
| SCK           | 使用者定義 ( <mark>注</mark> 1) | 入力                          | 従装置クロック    |  |
| <del>SS</del> | 使用者定義 ( <mark>注</mark> 1) | 入力                          | 従装置選択      |  |

注1: ピンのデータ方向が出力として構成設定される場合、ピンのレベルはSPIによって制御されます。

注2: SPIが従装置動作でMISOピンのデータ方向が出力として構成設定される場合、以下のようにSSピンがMISOピンを制御します。

- SSt<sup>®</sup>ンがLowに駆動されるなら、MISOt<sup>®</sup>ンはSPIによって制御されます。

- SSピンがHighに駆動されるなら、MISOピンはHi-Zにされます。

SPI単位部が許可されると、MOSI、MISO、SCK、SSピンのデータ方向は表26-1.に従って上書きされます。

# 26.3. 機能的な説明

# 26.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を許可してください。

### 26.3.2. 動作

### 26.3.2.1. 主装置動作

SPIが主装置動作に構成設定されると、データ(SPIn.DATA)レジスタへの書き込みが新しい転送を開始します。SPI主装置は下で説明されるように2つの動作形態、標準と緩衝で動作することができます。

# 26.3.2.1.1. 標準動作

標準動作で、システムは送信方向で単一緩衝され、受信方向で2重緩衝されます。これは次のようにデータ処理に影響します。

- 1. 送られるべき次のハイトは転送全体が完了される前にデータ(SPIn.DATA)レジスタに書くことができません。早すぎる書き込みは送出 されるデータの不正を引き起こし、割り込み要求フラグ(SPIn.INTFLAGS)レジスタの書き込み衝突(WRCOL)フラグが設定(1)されます。
- 2. 受信したバイトは伝送が完了した後、直ちに受信データレジスタに書かれます。
- 3. 受信データレジスタは次の伝送が緩衝される、またはデータが失われる前に読まれなければなりません。このレジスタはSPIn.DATAを 読むことによって読まれます。
- 4. 送信緩衝レジスタと受信データ緩衝レジスタは標準動作で使われません。

転送完了後、割り込み要求フラグ(SPIn.INTFLAGS)レジスタで割り込み要求フラグ(IF)が設定(1)されます。これはこの割り込みと全体割り 込みが許可されている場合に実行されるべき対応する割り込みを引き起こします。割り込み制御(SPIn.INTCTRL)レジスタの割り込み 許可(IE)ビットが割り込みを許可します。

### 26.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)ビットが転送完了割り込みを許可します。

### 26.3.2.1.3. 主装置動作でのSSL<sup>2</sup>ンの機能 - 複数主装置支援

主装置動作ではSPIがSSピンをどう使うのかを制御B(SPIn.CTRLB)レジスタの従装置選択禁止(SSD)ビットが制御します。

- ・SPIn.CTRLBnのSSDが'0'なら、SPIは主装置動作から従装置動作への遷移にSSEンを使うことができます。これは同じSPIハスで複数SPI主装置を許します。
- ・ SPIn.CTRLBnのSSDが'0'でSSt<sup>2</sup>ンが出力ピンとして構成設定される場合、そのピンは通常の入出力として、または他の周辺機能単位部によって使うことができ、SPIシステムに影響を及ぼしません。
- ・SPIn.CTRLBnのSSDが'1'なら、SPIはSSt<sup>2</sup>ンを使いません。通常の入出力として、または他の周辺機能単位部によって使うことができます。

SPIn.CTRLBnのSSDビットが'0'でSSが入力ピンとして構成設定される場合、SSピンは主装置SPI動作を保証するためにHighを保たれな ければなりません。Lowレヘルは別の主装置がハスの制御を取ることを試みていると解釈されます。これはSPIを従装置に切り替えてSPI のハートウェアが以下の活動を実行します。

- 1. 制御A(SPIn.CTRLA)レジスタの主/従装置選択(MASTER)ビットが解除(0)され、SPIシステムは従装置になります。SPIピンの方向は表 26-2.の条件を満たす時に切り替えられます。
- 2. 割り込み要求フラグ(SPIn.INTFLAGS)レジスタの割り込み要求フラグ(IF)ビットが設定(1)されます。割り込みが許可されて全体割り込み が許可されているなら、その割り込みルーチンが実行されます。

| 表26-2. SPIn.C | 表26-2. SPIn.CTRLBのSSDが´0´の時のSSEン機能の概要 |                  |  |  |  |  |  |
|---------------|---------------------------------------|------------------|--|--|--|--|--|
| SS構成設定        | SSピン レヘル                              | 説明               |  |  |  |  |  |
| 入力            | High                                  | 主装置有効(選択)        |  |  |  |  |  |
|               | Low                                   | 主装置無効、従装置動作へ切り替え |  |  |  |  |  |
| 出力            | High                                  | 主装置有効(選択)        |  |  |  |  |  |
| щЛ            | Low                                   | 土衣但有为八迭八八        |  |  |  |  |  |

表26-2. SPIn.CTRLBのSSDが'0'の時のSSEン機能の概要

注: デバイスが主装置動作で、2つの送信の間にSSビンがHighに留まることを保証できない場合、新しいバイトが書かれる前にSPIn.CTR LAレジスタの主/従装置選択(MASTER)ビットが調べられなければなりません。SS線のLowレベルによってMASTERビットが解除(0)され てしまった後、SPI主装置動作を再許可するには応用によって設定(1)されなければなりません。

### 26.3.2.2. 従装置動作

従装置動作で、SPI周辺機能は主装置からSPIクロックと従装置選択を受け取ります。従装置動作は3つの動作形態、1つの標準動作と 緩衝動作用の2つの構成設定を支援します。従装置動作で、制御論理回路はSCKビンでやって来る信号を採取します。

### 26.3.2.2.1. 標準動作

標準動作で、SPI周辺機能はSSE<sup>®</sup>ンがHighに駆動される限りアイドルに留まります。この状態ではソフトウェアがデータ(SPIn.DATA)レジスタの 内容を更新するかもしれませんが、SSE<sup>®</sup>ンがLowに駆動されるまで、データはSCKE<sup>®</sup>ンでやって来るクロック パルスによって移動されません。SSE<sup>®</sup>ンがLowに駆動された場合、従装置は最初のSCKクロック パルスでデータの移動を開始します。1パイトが完全に移動されると、割り 込み要求フラグ(SPIn.INTFLAGS)レジスタのSPI割り込み要求フラグ(IF)が設定(1)されます。

使用者応用は到着データを読む前にDATAレジスタに送る新しいデータの配置を続けるかもしれません。送るべき新しいハイトは(直前の) 転送全体が完了されるのに先立ってDATAに書くことができません。早すぎる書き込みは無視され、ハートウェアがSPIn.INTFLAGSレジス タの書き込み衝突(WRCOL)フラグを設定(1)します。

SSビンがHighに駆動されると、SPI論理回路は停止され、SPI従装置は新しいどのデータも受け取りません。移動レジスタ内のどの部分的に受信したパケットも失われます。

図26-2.は標準動作での送信手順を示します。値\$45がDATAレジスタに書かれますが、何故決して送信されないかに注目してください。



上図は3つの転送と、SPIが転送で多忙の間でのDATAレジスタへの1つの書き込みを示します。この書き込みは無視され、SPIn.INTFL AGSレジスタの書き込み衝突(WRCOL)フラグが設定(1)されます。

### 26.3.2.2.2. 緩衝動作

データ衝突を避けるため、SPI周辺機能は制御B(SPIn.CTRLB)レジスタの緩衝動作許可(BUFEN)ビットに'1'を書くことによって緩衝動作 に構成設定することができます。この動作では2つの受信緩衝部と1つの送信緩衝部を持ちます。双方は独立した割り込み要求フラグ の送信完了と受信完了を持ちます。図26-1.は追加の緩衝部を示します。緩衝動作が許可される時に2つの異なる方法で動くことが できます。制御B(SPIn.CTRLB)レジスタの緩衝動作受信待機(BUFWR)ビットは緩衝動作がどう動くかを制御します。タイシング構成図を含 みそれらがどう動くかの詳細が下で記述されます。

注:緩衝動作で従装置として動作し、SPIクロックが最大周波数に近いと、従装置は連続転送間の最初の採取端に対して時間内にデータを準備できないかもしれません。詳細については「電気的特性」の「SPI」項を参照してください。

### 緩衝動作受信待機(BUFWR)=0での従装置緩衝動作

従装置動作で、SPIn.CTRLBレジスタの緩衝動作受信待機(BUFWR)ビットが'0'を書かれると、使用者データの送信を開始する前に偽装 ハイトが送られます。図26-3.はこの構成設定での送信手順を示します。値\$45がデータ(SPIn.DATA)レジスタに書かれますが、何故決し て送信されないかに注目してください。



### 図26-3. '0'を書かれたSPIn.CTRLBのBUFWRを持つ緩衝動作でのSPIタイミング構成図

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に駆 動されると直ぐに開始します。図26-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)ビットでと同じです。

### 26.3.2.2.3. 従装置動作でのSSビンの機能

従装置選択(SS)ヒンはSPIの操作で中心的な役割を演じます。SPI動作形態とこのヒンの構成設定に応じて、これは装置を有効または 無効にするのに使うことができます。SSピンはチップ選択ピンとして使われます。

従装置動作で、SS,MOSI,SCKは常に入力です。MISOピンの動きはポート周辺機能でのピンのデータ方向構成設定とSSの値に依存しま す。SSE゚ンがLowに駆動されると、SPIは有効にされ、使用者がMISOピンのデータ方向を出力として構成設定した場合にMISOでデータ出 力をクロック駆動するためのSCKパルスを受け取る責任があります。SSピンがHighに駆動されると、SPIは無効にされ、やって来るデータを 受け取らないことを意味します。MISOピンのデータ方向が出力として構成設定される場合、MISOピンはHi-Zにされます。表26-3.はSSピ ン機能の上書きを示します。

| 表26-3. SSEン機能の概要 |                         |            |          |          |  |
|------------------|-------------------------|------------|----------|----------|--|
| <br>SS構成設定       | SSL <sup>°</sup> > レヘブル | 説明         | MISOピン動作 |          |  |
| 35件成設定           | 332 7 04 10             | 5元 99<br>  | ポート方向=出力 | ポート方向=入力 |  |
| 常に入力             | High                    | 従装置無効(非選択) | Hi–Z     | 入力       |  |
| 市に八刀             | Low                     | 従装置有効(選択)  | 出力       | 入力       |  |

注: 従装置動作で、SPI状態機構はSSビンがHighに駆動される時にリセットされます。伝送中にSSビンがHighに駆動される場合、SPIは直 ちにデータの送受信を停止し、受信と送信の両データが失われたと見做されなければなりません。SSピンが転送の開始と終わりを合 図するのに使われるため、パケット/バイト同期を達成するのと主装置クロック発生器で同期された従装置ビット計数器を維持するのに 有用です。

# 26.3.2.3. データ転送形態

直列データに関してSCKの位相と極性の4つの組み合わせがあります。望む組み合わせは制御B(SPIn.CTRLB)レジスタの動作形態(MODE)とットに書くことによって選ばれます。

SPIデータ転送形式は以下で示されます。データビットはSCK信号の逆端で移動出力されてラッチされ、データ信号を安定にするための充分な時間を保証します。

先行端はクロック周期の最初のクロック端です。後行端はクロック周期の最終クロック端です。

# 図26-5. SPIデータ転送形態



### 26.3.2.4. 事象

SPIは以下の事象を生成することができます。

| 衣20-4. SP | 表26-4. SPIでの事家生成部 |            |              |          |               |  |
|-----------|-------------------|------------|--------------|----------|---------------|--|
| 生         | 成部名               | 説明         | 事象型 生成2口ッ2領域 |          |               |  |
| 周辺機能      | 事象                |            | 争豕空          | 主成フロッフ隕攻 | 事象長           |  |
| SPIn      | SCK               | SPI主装置クロック | レヘッル         | CLK_PER  | 最小2 CLK_PER周期 |  |

SPIは事象使用部を持ちません。

事象型と事象システム構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照してください。

# 26.3.2.5. 割り込み

# 表26-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レジスタをご覧く ださい。

# 26.4. レジスタ要約

| 変位    | 略称       | ビット位置 | ビット7  | ビット6  | ビット5   | <b>ビット4</b> | ビット3 | ビット2 | ビット1  | ビット0   |
|-------|----------|-------|-------|-------|--------|-------------|------|------|-------|--------|
| +\$00 | CTRLA    | 7~0   |       | DORD  | MASTER | CLK2X       |      | PRES | SC1,0 | ENABLE |
| +\$01 | CTRLB    | 7~0   | BUFEN | BUFWR |        |             |      | SSD  | MOI   | DE1,0  |
| +\$02 | INTCTRL  | 7~0   | RXCIE | TXCIE | DREIE  | SSIE        |      |      |       | IE     |
| +\$03 | INTFLAGS | 7~0   | IF    | WRCOL |        |             |      |      |       |        |
| +∌03  | INTELAGS | 7,00  | RXCIF | TXCIF | DREIF  | SSIF        |      |      |       | BUFOVF |
| +\$04 | DATA     | 7~0   |       |       |        | DAT         | A7~0 |      |       |        |

# 26.5. レジスタ説明

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

| 名称 | : CTRL | A |
|----|--------|---|
|    |        |   |

- **変位**:+\$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'を書かれると、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許可 |

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

| 名称 | : CTRLB |
|----|---------|
| 変位 | : +\$01 |
|    |         |

リセット : \$00

特質 :-

| ビット    | 7     | 6     | 5 | 4 | 3 | 2   | 1   | 0     |
|--------|-------|-------|---|---|---|-----|-----|-------|
| [      | BUFEN | BUFWR |   |   |   | SSD | MOE | DE1,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 | 01 | 10                         | 11 |  |  |
|---|----|-----|----|----------------------------|----|--|--|
| Γ | 名称 | 0   | 1  | 2                          | 3  |  |  |
|   | 説明 |     |    | 先行端:下降、入力採取<br>後行端:上昇、出力設定 |    |  |  |

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

名称: INTCTRL

**変位**:+\$02

リセット : \$00

特質 :-

| ヒット    | 7     | 6     | 5     | 4    | 3 | 2 | 1 | 0   |
|--------|-------|-------|-------|------|---|---|---|-----|
|        | RXCIE | TXCIE | DREIE | SSIE |   |   |   | IE  |
| アクセス種別 | 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)される時に起動されます。非緩衝動作ではこのビットが'0'です。

### ● ビット0 - IE : 割り込み許可 (Interrupt Enable)

このビット(=1)はSPIが緩衝動作でない時のSPI割り込みを許可します。許可した割り込みは割り込み要求フラグ(SPIn.INTFLAGS)レジスタでRXCIF/IFが設定(1)される時に起動されます。

# 26.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)されます。

### 26.5.5. INTFLAGS - 割り込み要求フラグ - 緩衝動作 (Interrupt Flags - Buffer Mode)

名称 : INTFLAGS

**変位 : +\$0**3

リセット : \$00

特質 :-

| ビット    | 7     | 6     | 5     | 4    | 3 | 2 | 1 | 0      |
|--------|-------|-------|-------|------|---|---|---|--------|
|        | RXCIF | 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)されます。

# **26.5.6. DATA** – τ̄ – 𝔅 (Data)

| DATA |
|------|
|      |

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

| 1.4    |         |     |     |     |     |     |     |     |  |
|--------|---------|-----|-----|-----|-----|-----|-----|-----|--|
| ビット    | 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 : データ (SPI Data)

DATAレジスタはデータの送受信に使われます。このレジスタへの書き込みは主装置動作の時にデータ送信を開始し、従装置動作では送るデータを準備します。このレジスタに書かれたバイトは処理が開始された時にSPI出力線へ移動出力されます。

SPIn.DATAレジスタは物理的なレジスタではありません。構成設定された動作形態に応じて、下で記述されるように他のレジスタに割り当てられます。

・標準動作:

- DATAレジスタ書き込みは移動レジスタを書きます。
- DATAレジスタからの読み込みは受信データレジスタから読みます。
- ・緩衝動作:
  - DATAレジスタ書き込みは送信データ緩衝レジスタを書きます。
  - DATAレジスタからの読み込みは受信データ緩衝レジスタから読みます。その後に受信データレジスタの内容が受信データ緩衝レジスタ に移動されます。

# 27. TWI - 2線インターフェース

# 27.1. 特徴

- ・2線通信インターフェース
- Phillips社I<sup>2</sup>C適合
  - 標準動作
  - 高速動作
  - 高速動作+
- ・システム管理バス(SMBus)2.0適合
  - 開始条件/再送開始条件とデータビット間での調停を支援
  - ソフトウェアでのアドレス解決規約(ARP)に対する支援を許す従装置調停
  - 構成設定可能なハートウェアでのSMBus階層1制限時間
  - 二元動作に対して独立した制限時間
- ・独立した主装置と従装置の動作
  - 結合(同ービン)と二元動作(分離ビン)
- 完全な調停支援での単一または複数の主装置バス動作
- ・従装置アドレス一致に対するハードウェア支援
  - 全ての休止動作での動作
  - 7ビットアドレス認識
  - 一斉呼び出しアドレス認識
  - アドレス範囲遮蔽または第2アドレス一致に対する支援
- ・バス雑音消去用入力濾波器
- · 簡便動作支援

# 27.2. 概要

2線インターフェース(TWI)は直列データ(SDA)線と直列クロック(SCL)線を持つ双方向2線通信インターフェース(バス)です。

TWIベスは1つまたは複数の従装置を1つまたは複数の主装置に接続します。ベスに接続されたどの装置も主装置、従装置、または両方として働くことができます。主装置はボーレート発生器(BRG)を使ってSCLを生成し、1つの従装置をアドレス指定してデータを送るまたは受け取るのどちらを望むかを告げることによってデータ処理を始めます。BRGは100kHzから1MHzまでの標準動作(Sm)と高速動作(Fm、Fm+)ベス周波数を生成することができます。

TWIは開始条件、停止条件、バス衝突、バス異常を検出します。協調損失、異常、衝突、クロック保持も検出され、主装置動作と従装置動作で利用可能な独立した状態フラクで示されます。

TWIは複数主装置のハス動作と調停を支援します。調停の仕組みは複数の主装置が同時にデータを送信しようとする場合を処理します。TWIは自動起動操作ができ、故にソフトウェアの複雑さを減らすことができる簡便動作も支援します。TWIは独立した許可と構成設定を持つ独立単位部として実装された主装置と従装置の同時動作を持つ2元動作を支援します。TWIはデータ交換なしに主装置が従装置をアドレス指定することができる迅速指令動作を支援します。

# 27.2.1. 構成図



# 27.2.2. 信号説明

| 信号  | 形式      | 説明      |
|-----|---------|---------|
| SCL | デジタル入出力 | 直列クロック線 |
| SDA | デジタル入出力 | 直列データ線  |

# 27.3. 機能的な説明

# 27.3.1. 一般的なTWIバスの概念

TWIは以下から成る簡素な双方向2線通信バスを提供します。

・ パケット転送用の直列データ(SDA)線

・ バス クロック用の直列クロック(SCL)線

2つの線は開放コレクタ(ドレイン)線(ワイヤードAND)です。

TWIベス形態は直列ベスで複数装置を接続する簡単で効率的な方法です。ベスに接続された装置は主装置または従装置にできます。主装置だけがベスとベス通信を制御できます。

ハネに接続した各従装置に固有のアトレスが割り当てられ、主装置は従装置を制御して処理を始めるのにこれを使います。複数の主装置を同じハネに接続することができ、複数主装置環境と呼ばれます。何時でも1つの主装置だけがハネを自身のものにできるので、主装置間でハネ所有権を解決するために調停機構が提供されます。

主装置はベス上に開始条件(S)を発行することによって転送処理の開始を指示します。主装置は転送処理用のクロック信号を提供します。7ビット従装置アドレス(ADDRESS)と、主装置がデータを読みまたは書きどちらをしたいのかを表す方向(R/W)ビットを持つアドレス パケットがその後に送られます。

アドレス指定されたI<sup>2</sup>C従装置はその後にアドレスを<mark>確認応答</mark>(ACK)し、データ パケット転送処理を始めることができます。毎回の9ビット デー タ パケットは8つのデータ ビットとそれに続き、受信側によってデータが受け取られたか否かのどちらかを示す1ビット応答から成ります。

全てのデータパケット(DATA)転送後、主装置は転送処理を終わるためにバス上で停止条件(P)を発行します。



# 27.3.2. TWI基本動作

# 27.3.2.1. 初期化

使われるなら、TWI周辺機能を許可する前に以下のビットを構成設定してください。

- ・制御A(TWIn.CTRLA)レジスタのSDA保持時間(SDAHOLD)ビット領域
- ・制御A(TWIn.CTRLA)レジスタの高速動作+(FMPEN)ビット

# 27.3.2.1.1. 主装置初期化

有効なTWIバス クロック周波数になる値を主装置ボーレート(TWIn.MBAUD)レジスタに書いてください。主装置制御A(TWIn.MCTRLA)レジス タのTWI主装置許可(ENABLE)ビットに'1'を書くことがTWI主装置を開始します。 バス状態をアイドル(IDLE)に強制するために主装置状態(TWIn.MSTATUS)レジスタのバス状態(BUSSTATE)ビット領域が'01'に設定されなければなりません。

### 27.3.2.1.2. 従装置初期化

従装置を初期化するには以下のこれらに従ってください。

1. TWI従装置を許可する前に制御A(TWIn.CTRLA)レジスタのSDA準備時間(SDASETUP)ビットを構成設定してください。

2. 従装置アドレスを従装置アドレス(TWIn.SADDR)レジスタに書いてください。

3. TWI従装置を許可するため、従装置制御A(TWIn.SCTRLA)レジスタの従装置許可(ENABLE)ビットに'1'を書いてください。 TWI従装置は主装置が開始条件を発行して従装置アトレスと一致するのを待ちます。

### 27.3.2.2. TWI主装置動作

TWI主装置は各ハイト後の任意選択の割り込みを持つハイト志向です。主装置の書き込みと読み込みの操作に対して独立した割り込み要求フラグがあります。割り込み要求フラグはポーリング操作にも使うことができます。専用の状態フラグが受信した(ACK)確認応答/(NACK)否認応答(RXACK)、ハス異常(BUSERR)、調停敗退(ARBLOST)、クロック保持(CLKHOLD)、ハス状態(BUSSTATE)を示します。 割り込み要求フラグが、1、に設定されると、SCLはLowを強制され、応答または何れかのデータを扱う時間を主装置に与え、殆どの場合でソフトウェアの介在を必要とするでしょう。割り込み要求フラグの解除(0)がSCLを開放します。生成された割り込み数は殆どの条件を自動的に処理することによって最小に留められます。

### 27.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>)の時間はハ<sup>\*</sup> ス形態によって決められます。



- ・tLOWはSCLクロックのLow期間です。
- ・t<sub>HIGH</sub>はSCLクロックのHigh期間です。
- ・tRは内部プルアップに対するバス インピーダンスによって決められます。詳細については「電気的特性」を参照してください。
- ・toFはオープンドレイン電流制限とバスインピーダンスによって決められます。詳細については「電気的特性」を参照してください。

# SCLクロックの特性

SCL周波数は右式によって与えられます。

SCL/ロックは50/50のデューティサイクルを持つように設計され、デューティサイクルのLow 部分はtoFとtLOWから成ります。 $t_{HIGH}$ はSCLのHigh状態が検出されるまで始ま りません。TWIn.MBAUDレジスタのホーレート(BAUD)ビット領域とSCL周波数は右式 (式1)によって関連付けられます。



式1はBAUDを表すように変形(式2)することができます。

# BAUD値の計算

望む速度動作(Sm、Fm、Fm+)の仕様内での動作を保証するため、これらの手順に従ってください。

- 1. 式2を使ってBAUDビット領域用の値を計算してください。
- 2. 手順1.からのBAUD値を使ってtLOWを計算してください。

| $t_{LOW\_Fm} = t_{LOW\_Fm^+} =$ | BAUD + 6 + min(SCLDUTY, BAUD) | (3.1) | $t_{LOW Sm} = \frac{BAUD + 6}{6} - t_{OF}$ (3.2)                               |  |
|---------------------------------|-------------------------------|-------|--------------------------------------------------------------------------------|--|
|                                 | fclk_per - lof                | (3.1) | $t_{\rm LOW_Sm} = \frac{f_{\rm CLK_PER}}{f_{\rm CLK_PER}} - t_{\rm OF}  (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)を超えるか調べてください。

- 計算されたtLOWが限度を超える場合、式2からのBAUDを使ってください。
- 限度に合わない場合、右の式4を使って新しいBAUD値を計算してください。ここでのt<sub>LOW\_mode</sub>は動作仕様からのt<sub>LOW\_Sm</sub>、t<sub>LOW\_Fm</sub>、t<sub>LOW\_Fm</sub>+のどれかです。

 $BAUD = f_{CLK_{PER}} \times (T_{LOW_{mode}} + t_{OF}) - 3 \quad (4)$ 

### 27.3.2.2.2. TWIバス状態論理

∧「ス状態論理回路は主装置動作が許可された時にTWIへス 上の動きを継続的に監視します。それはパワーダウンを含む全 ての休止動作形態で動作を続けます。

ハネ状態論理回路は開始条件と停止条件の検出器、衝突検 出、不活性パス時間超過検出、ビット計数器を含みます。これ らはハネ状態を決めるのに使われます。ソフトウェアは主装置状 態(TWIn.MSTATUS)レジスタのハス状態(BUSSTATE)ビット領域 を読むことによって現在のハス状態を得ることができます。

バス状態は未知、アイドル、使用中、所有者になることができ、 右で示される状態遷移図に従って決められます。



- 1. 未知: バス状態機構はTWI主装置が許可される時に有効です。TWI主装置許可、システム リセット実行、またはTWI主装置禁止後、 パス状態は未知です。
- 2.7(ドル: ベス状態(BUSSTATE)ビット領域に'01'を書くことによってベス状態機構をアイドル状態に入ることを強制することができます。 ^゙ス状態論理回路を他のどの状態にも強制することはできません。最初の停止条件が検出される時に応用ソフトウェアによっ て状態が設定されなければ、ベス状態はアイドルになります。主装置制御A(TWIn.MCTRLA)レジスタの主装置不活性ベス時 間制限(TIMEOUT)ビット領域が0以外の値に構成設定される場合、ベス状態は時間超過の発生でアイドルに変わります。
- 3. 使用中: バスがアイドルの時に外部的に生成された開始条件が検出された場合、バス状態が使用中になります。 バス状態は停止条 件が検出されるか、または構成設定されている場合に制限時間超過が設定される時にアイドルへ変わります。
- 4. 所有者: バスがアイドルの時に内部的に開始条件が生成される場合、バス状態が所有者になります。妨害なしで完全な転送処理が 実行された場合、主装置は停止条件を発行し、バス状態がアイドルに戻ります。衝突が検出されて調停に敗れた場合、バ ス状態は停止条件が検出されるまで使用中になります。

# 27.3.2.2.3. アドレス パケット送信

主装置は7ビット従装置アドレスとR/W方向ビットと共に主装置アドレス(TWIn.MADDR)レジスタが書かれる時にハス転送処理の実行を開始します。MADDRレジスタの値がその後に主装置データ(TWIn.MDATA)レジスタへ複写されます。ハス状態が使用中の場合、TWI主装置は開始条件を発行する前にハス状態がアイドルになるまで待ちます。TWIは開始条件を発行し、移動レジスタがハス上でハイト送信動作を実行します。

調停とR/W方向ビットに依存して、アドレス パケットの送信後に4つの事例(M1~M4)の1つが起きます。



# 27.3.2.2.3.1. 事例M1 : アドレス パケット送信完了 - 方向ビット=0

従装置がアドレス パケットに対して確認応答(ACK)で応答する場合、TWIn.MSTATUSレシジスタで書き込み割り込み要求フラグ(WIF)が'1' に設定され、受信応答(RXACK)フラグが'0'に設定され、クロック保持(CLKHOLD)フラグが'1'に設定されます。WIF、RXACK、CLKHO LDのフラグは主装置状態(TWIn.MSTATUS)レジスタに配置されます。

この時点でクロック保持が有効で、SCLにLowを強制し、クロック周波数全体を低下するようにクロックのLow期間を引き延ばし、データを処理 するのに必要とされる遅延を強制してバスでの更なる活動を防ぎます。 ソフトウェアは以下の準備をすることができます。

・従装置へデータパケット送信

### 27.3.2.2.3.2. 事例M2 : アドレス パケット送信完了 - 方向ビット=1

従装置がアドレス パケットに対して確認応答(ACK)で応答する場合、受信応答(RXACK)フラグが'0'に設定され、この時点で従装置がバ スを所有するため、従装置はどんな遅延もなしに主装置へのデータ送出を開始することができます。この時点でクロック保持が有効で、 SCLにLowを強制します。

ソフトウェアは以下の準備をすることができます。

・従装置から受け取ったデータパケットの読み込み

### 27.3.2.2.3.3. 事例M3 : アドレス パケット送信完了 - 従装置によるアドレス否認応答

従装置がアドレス パケットに応答しない場合、書き込み割り込み要求フラグ(WIF)と受信応答(RXACK)フラグが'1'に設定されます。この時 点でクロック保持が有効で、SCLにLowを強制します。

確認応答(ACK)欠落はI<sup>2</sup>C従装置が他の作業で多忙か、または休止動作で応答できないことを示し得ます。

ソフトウェアは以下の活動の1つを取るための準備をすることができます。

- ・アドレス パケットの再送信
- 主装置制御B(TWIn.MCTRLB)レジスタの指令(MCMD)ビット領域で停止条件を発行することによって転送処理を完了、これが推奨 される活動です。

### 27.3.2.2.3.4. 事例M4:調停敗退またはバス異常

調停で敗れた場合、主装置状態(TWIn.MSTATUS)レジスタで書き込み割り込み要求フラグ(WIF)と調停敗退(ARBLOST)のフラグが '1' に 設定されます。SDAは禁止されてSCLが開放されます。 ハス状態が使用中に変わり、主装置はハ、ス状態がアイドルに戻るまで、もはやハ スでどの操作も実行することを許されません。

ハベス異常は調停敗退状態と同じように振舞います。この場合、WIFとARBLOSTのフラグに加えて、TWIn.MSTATUSレジスタでハベス異常 (BUSERR)フラグが'1'に設定されます。

ソフトウェアは以下の準備をすることができます。

・TWIn.MSTATUSレジスタのハス状態(BUSSTATE)ビット領域を読むことによってバス状態がアイドルに変わるまで操作を中止して待機

### 27.3.2.2.4. データ パケット送信

上の事例M1と仮定し、TWI主装置は主装置データ(TWIn.MDATA)レジスタへ書くことによってデータ送信を開始することができ、それは 書き込み割り込み要求フラグ(WIF)も解除(0)します。データ転送の間、主装置は衝突と異常に関してバスを継続的に監視します。データ パケット転送完了後、WIFフラグが'1'に設定されます。

送信が成功して主装置が従装置からACKビットを受け取る場合、受信応答(RXACK)フラグが'1'に設定され、従装置が新しいデータハ<sup>®</sup> ケットを受け取る準備が整っていることを意味します。

ソフトウェアは以下の活動の1つを取るための準備をすることができます。

- ・新しいデータ パケットの送信
- ・新しいアドレスパケットの送信
- ・主装置制御B(TWIn.MCTRLB)レジスタの指令(MCMD)ビット領域で停止条件を発行することによって転送処理を完了

送信が成功して主装置が従装置から否認応答(NACK)ビットを受け取る場合、RXACKフラグが'1'に設定され、従装置がもっとデータを 受け取ることができないか、または必要でないことを意味します。

ソフトウェアは以下の活動の1つを取るための準備をすることができます。

・新しいアドレスパケットの送信

・主装置制御B(TWIn.MCTRLB)レジスタの指令(MCMD)ビット領域で停止条件を発行することによって転送処理を完了

受信応答(RXACK)フラグの状態はWIFフラグが'1'に設定され場合にだけ有効で、調停敗退(ARBLOST)とバス異常(BUSERR)のフラグ は'0'に設定されます。

送信は衝突が検出される場合、不成功になり得ます。その後、主装置は調停に敗れ、調停敗退(ARBLOST)フラグが'1'に設定されハ゛ ス状態が使用中に変わります。データ パケット転送中の調停敗退は上の事例M4と同じように扱われます。

WIF、ARBLOST、BUSERR、RXACKのフラグは全て主装置状態(TWIn.MSTATUS)レジスタに配置されます。

### 27.3.2.2.5. データ パケット受信

上の事例M2と仮定し、クロックが1ハイや間開放され。従装置がバス上に1ハイトのデータを出すのを許します。主装置は従装置から1ハイトの データを受け取り、クロック保持(CLKHOLD)フラグと共に読み込み割り込み要求フラグ(RIF)が'1'に設定されます。指令が主装置制御B (TWIn.MCTRLB)レジスタの指令(MCMD)ビット領域に書かれる時に、TWIn.MCTRLBレジスタの応答動作(ACKACT)ビットによって選ばれ た活動が自動的にバス上で送られます。 ソフトウェアは以下の活動の1つを取るための準備をすることができます。

- 主装置制御B(TWIn.MCTRLB)レジスタの応答動作(ACKACT)ビットに'0'を書くことによって確認応答(ACK)で応答し、新しいデータ パケットを受け取る準備
- ・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)され得ません。

### 27.3.2.3. TWI従装置動作

TWI従装置は各バイト後の任意選択の割り込みを持つバイト志向です。従装置データ用とアドレス/停止認識用に独立した割り込みフラグがあります。割り込みフラグはポーリング操作に使うこともできます。専用の状態フラグが受信した確認応答(ACK)/否認応答(NACK)、クロック保持、衝突、バス異常、R/W方向を示します。

割り込み要求フラグが'1'に設定されると、SCLはLowを強制され、応答または何かのデータを扱う時間を従装置に与え、殆どの場合でソ フトウェアの介在を必要とするでしょう。生成された割り込み数は殆どの条件の自動処理によって最小に留められます。

従装置制御A(TWIn.SCTRLA)レジスタのアトレス認識動作(PMEN)ビットは受信した全てのアトレスに応答することを従装置に許すように構成設定することができます。

### 27.3.2.3.1. アドレス パケット受信

TWIが従装置として構成設定されると、検出されるべき開始条件を待ちます。これが起こると、継続してアトレス パケットが受信されてアトレス一致論理回路によって調べられます。従装置は正しいアトレスに確認応答(ACK)し、従装置データ(TWIn.SDATA)レジスタにアトレスを保存します。受信したアトレスが一致しなければ、従装置は応答やアトレスの保存をせず、新しい開始条件を待ちます。

開始条件が以下によって後続されると、従装置状態(TWIn.SSTATUS)レジスタの従装置アドレス/停止割り込み要求フラグ(APIF)が'1'に 設定されます。

- ・有効なアドレスが従装置アドレス(TWIn.SADDR)レジスタのアドレス(ADDR7~1)ビット領域に格納されたアドレスと一致
- ・一斉呼び出しアトレス(\$00)で従装置アトレス(TWIn.SADDR)レシ、スタのアトレス(ADDR0)ビットが'1'に設定
- ・従装置アドレス遮蔽(TWIn.SADDRMASK)レシブスタでアドレス許可(ADDREN)ビットが'1'に設定され、有効なアドレスがアドレス遮蔽(ADDR MASK)ビット領域に格納されたアドレスと一致
- ・従装置制御A(TWIn.SCTRLA)レシブスタのアドレス認識動作(PMEN)ビットが'1'に設定された場合の全てのアドレス

開始条件直後の停止条件は不正操作で、従装置状態(TWIn.SSTATUS)レジスタのバス異常(BUSERR)フラグが設定(1)されます。

従装置状態(TWIn.SSTATUS)レジスタの読み/書き方向(DIR)ビットとハンス状況に応じて、アトレス パケットの受信後に続いて4つの事例(S1 ~S4)の1つが起きます。



### 27.3.2.3.1.1. 事例S1: アドレス パケット受け入れ - 方向ビット=0

アドレス パケット受信後に従装置によって確認応答(ACK)が送られ、従装置状態(TWIn.SSTATUS)レジスタの読み/書き方向(DIR)ビットが '0'に設定される場合、主装置が書き込み操作を指示します。

この時点でクロック保持が有効で、SCLにLowを強制し、クロック周波数全体を低下するようにクロックのLow期間を引き延ばし、データを処理 するのに必要とされる遅延を強制してバスでの更なる活動を防ぎます。 ソフトウェアは以下の準備をすることができます。

・主装置から受け取ったデータパケットの読み込み

#### 27.3.2.3.1.2. 事例S2 : アドレス パケット受け入れ - 方向ビット=1

アドレス パケット受信後に従装置によって確認応答(ACK)が送られ、従装置状態(TWIn.SSTATUS)レシ、スタで読み/書き方向(DIR)ビットが '1'に設定される場合、主装置が読み込み操作を指示し、データ割り込み要求フラグ(DIF)が'1'に設定されます。

この時点でクロック保持が有効で、SCLにLowを強制します。

ソフトウェアは以下の準備をすることができます。

・主装置へデータパケット送信

#### 27.3.2.3.1.3. 事例S3:停止条件受信

停止条件が受信されると、アドレス/停止条件フラグ(AP)が'0'に設定され、アドレス一致ではなく停止条件を示し、アドレス/停止割り込み要 求フラグ(APIF)が有効(1)にされます。

APとAPIFのフラグは従装置状態(TWIn.SSTATUS)レジスタに配置されます。

ソフトウェアは以下の準備をすることができます。

・新しいアドレスパケットがアドレス指定するまで待機

#### 27.3.2.3.1.4. 事例S4 : 衝突

従装置がHighレベルのデータビットまたは否認応答(NACK)を送ることができない場合、従装置状態(TWIn.SSTATUS)レジスタの衝突(CO LL)フラグが'1'に設定されます。従装置はSDAでLow値が移動出力されないことを除き、通常動作を始めます。従装置論理回路から のデータと応答の出力が禁止されます。クロック保持は開放されます。開始条件と再送開始条件は受け入れられます。

COLLE<sup>\*</sup>ットはアト<sup>\*</sup>レス解決規約(ARP)が使われるシステムに対して意図されています。非ARP状況で検出した衝突は規約違反があってハ<sup>\*</sup> ス異常として扱われなければならないことを示します。

#### 27.3.2.3.2. データ パケット受信

前の**事例S1**と仮定し、従装置はデータを受信する準備を整えなければなりません。データ パケットが受信されると、従装置状態(TWIn.SS TATUS)レジスタのデータ割り込み要求フラグ(DIF)が'1'に設定されます。指令が従装置制御B(TWIn.SCTRLB)レジスタの指令(SCMD)ビット領域に書かれる時に、TWIn.SCTRLBレジスタの応答動作(ACKACT)ビットによって選ばれた活動が自動的にバス上で送られます。 ソフトウェアは以下の活動の1つを取るための準備をすることができます。

- TWIn.SCTRLBレシ<sup>i</sup>スタのACKACTL<sup>i</sup>ットに<sup>'0</sup> を書くことによって確認応答(ACK)で応答、従装置がもっとデータを受け取る準備が 整っていることを示します。
- ・ACKACTビットに'1'を書くことによって否認応答(NACK)で応答、従装置がこれ以上データを受け取ることができず、主装置が停止 条件または再送開始条件を発行しなければならないことを示します。

#### 27.3.2.3.3. データ パケット送信

上の事例S2と仮定し、従装置は従装置データ(TWIn.SDATA)レジスタへ書くことによってデータ送信を開始することができます。データハ<sup>®</sup> ケット送信が完了されると、従装置状態(TWIn.SSTATUS)レジスタのデータ割り込み要求フラグ(DIF)が'1'に設定されます。

ソフトウェアは以下の活動の1つを取るための準備をすることができます。

- ・TWIn.SSTATUSレジスタの受信応答(RXACK)ビットを読むことによって主装置が確認応答(ACK)で応答したかを調べ、新しいデータ パケット送信を開始
- ・RXACKを読むことによって主装置が否認応答(NACK)で応答したかを調べ、データパケット送信を停止。主装置はNACK後に停止 条件または再送開始条件を送らなければなりません。

#### 27.3.3. 付加機能

#### 27.3.3.1. SMBus

TWIをSMBus環境で使う場合、主装置制御A(TWIn.MCTRLA)レジスタの不活性ハス制限時間(TIMEOUT)ビット領域が構成設定されな ければなりません。これはSMBus規格に適合するように時間基準(CLKCTRL.MCLKTIMEBASE)レジスタの時間基準(TIMEBASE)ビット 領域を構成設定する必要があります。より多くの情報については「CLKCTRL - クロック制御器」章を参照してください。

SMBus環境に対して100kHzの周波数を使うことができます。標準動作(Sm)と高速動作(Fm)に対して動作周波数はスリューレート制限された出力を持つ一方で、高速動作+(Fm+)に対しては10倍の出力駆動能力を持ちます。

TWIは制御A(TWIn.CTRLA)レジスタのSDA保持時間(SDAHOLD)ビット領域で構成設定されるSMBus互換SDA保持時間も許します。

#### 27.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)などが特徴です。これらは必要とされる場合にソフトウェアで実装することができます。

#### 27.3.3.2. 複数主装置

主装置はハネがアイドルなことを検出した場合にだけハネ転送処理を開始することができます。複数の主装置がハネトにある場合、他の装置が同時に転送処理を始めようとするかもしれず、結果的に複数の主装置がパネを所有することになります。TWIはSDAでHighレヘルのデータビットを送信することができず、主装置状態(TWIn.MSTATUS)レジネタのハネ状態(BUSSTATE)ビット領域が使用中に変わる場

合に主装置がバスの制御を失うような調停の仕組みを使う ことによってこの問題を解決します。調停で敗れた主装置 はバス所有権の再取得を試みる前にバスがアイドルになるま で待たなければなりません。

(図で)両装置は開始条件を発行することができますが、主装置1は主装置2がLowレベルを送信している間にHighレベル(ビット5)の送信を試みる時、調停に敗れます。



#### 27.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)を自動的 に'0'に設定します。この機能は従装置制御A(TWIn.SCTRLA)レジスタの簡便動作許可(SMEN)ビットが'1'に設定される時に許可され ます。

#### 27.3.3.4. 二元動作

TWIは主装置と従装置が同時に独立して動作する二元動作操作を支援します。この場合、制御A(TWIn.CTRLA)レジスタがTWI主装置を構成設定し、二元動作制御構成設定(TWIn.DUALCTRL)レジスタがTWI従装置を構成設定します。主装置構成設定についてのより多くの詳細に関しては「27.3.2.1.初期化」項をご覧ください。

使われる場合、TWI二元動作を許可する前に以下のビットが構成設定されなければなりません。

・DUALCTRLレシブスタのSDA保持時間(SDAHOLD)ビット領域

・DUALCTRLレジスタの高速動作+許可(FMPEN)ビット

二元動作はDUALCTRLレジスタの二元制御許可(ENABLE)ビットに'1'を書くことによって許可することができます。

#### 27.3.3.5. 迅速指令動作

迅速動作でのアドレス パケットのR/Wビットが指令を示します。この動作は主装置制御A(TWIn.MCTRLA)レジスタの迅速指令許可(QCEN) ビットに'1'を書くことによって許可されます。データの送受信はありません。

迅速指令はSMBus仕様で、R/Wビットを装置機能のON/OFF切り替え、または低電力待機動作の許可/禁止に使います。この動作は 自動起動操作を許してソフトウェアの複雑さ減らすことができます。

主装置が従装置から確認応答(ACK)を受け取った後、R/Wビットの値に応じて主装置読み割り込み要求フラグ(RIF)または主装置書き 割り込み要求フラグ(WIF)のどちらかが設定(1)されます。迅速指令発行後にRIFまたはWIFのフラグが設定(1)されると、TWIは主装置制 御B(TWIn.MCTRLB)レジスタの指令(MCMD)ビット領域を書くことによって停止(停止条件)指令を受け入れます。最後の受信応答(RXA CK)フラグと共にRIFとWIFのフラグは全て主装置状態(TWIn.MSTATUS)レジスタに配置されます。

| 図27-8. 迅速指令の流れ                    |                          |
|-----------------------------------|--------------------------|
| □→使用中                             | 主装置がバス上にデータを供給           |
| 使用中+P+F/IIル+S+F/Iレス+R/W+++所有者+A+P | アドレス指定された従装置がハベス上にデータを供給 |

#### 27.3.3.6. 10ビット アトレス

転送処理が読みか書きかに関わらず、主装置はR/W方向ビットを'0'に設定して10ビットアトレスを送ることによって開始されなければなりません。

従装置アドレス一致論理回路はアビット アドレスと一斉呼び出しアドレスの認識を支援するだけです。主装置がTWI従装置をアドレス指定した かを決めるため、従装置アドレス一致論理回路によって従装置アドレス(TWIn.SADDR)レジスタが使われます。

TWI従装置アドレス一致論理回路は10ビットアドレスの最初のバイトの認識を支援するだけで、第2パイトはソフトェアで処理されなければなりません。10ビットアドレスの最初のバイトは従装置アドレス(TWIn.SADDR)レジスタの上位5ビットが、11110、の場合に認識されます。従って、最初のパイトは5つの指示ビット、10ビットアドレスの上位2ビット(MSb)、R/W方向ビットから成ります。それに続く主装置からの下位側バイト(LSB)はデータパケットの形式で来ます。

| 図27-9.10ビット アドレス転送処理                                                                                                        |  |
|-----------------------------------------------------------------------------------------------------------------------------|--|
| $S \rightarrow 1 1 1 1 0 A9 A8 \overline{W} \rightarrow A \rightarrow A7 A6 A5 A4 A3 A2 A1 A0 \rightarrow A \rightarrow SW$ |  |
| 𝕵 ソフトウェア関連処理                                                                                                                |  |

#### 27.3.4. 割り込み

#### 表27-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のレジスタから割り込み要求フラグを読まなければなりません。

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

ハス状態論理回路とアドレス認識ハードウェアは全ての休止動作形態で動作を続けます。TWI従装置が休止動作で開始条件に続いて従 装置アドレスが検出された場合、主クロックが利用可能になるまでの起き上がり期間の間、クロック伸長が有効です。TWI主装置は全ての 休止動作で動作を停止します。二元動作が有効な時は、開始条件がTWI従装置によって受信された時にだけTWI周辺機能が起き 上がります。

### 27.3.6. デバッグ操作

走行時デ・バッグの間、TWIはそれの通常動作を続けます。デ・バッグ動作でのCPU停止はTWIの通常動作を停止します。TWIはデ・バッグ 制御(TWIn.DBGCTRL)レジ、スタのデ・バッグ時走行(DBGRUN)ビットに'1'を書くことによって停止されたCPUでの動作を強制することがで きます。デ・バッグ動作でCPUが停止され、DBGRUNビットが'1'の時に、主装置データ(TWIn.MDATA)レジ、スタと従装置データ(TWIn.SDAT A)レジ、スタの読み書きは決してバス操作を起動したり、送信を引き起こしてフラグを解除(0)しません。TWIが割り込みや同様のものを通し てCPUによって定期的な処理を必要とするように構成設定される場合、停止されたデバッグの間に不正な動作やデータ損失になるかも しれません。

## 27.4. レジスタ要約

| 変位    | 略称        | ビット位置      | ビット7 | ビット6     | ビット5    | ビット4                  | ビット3           | ビット2                                    | ビット1        | ビットロ   |
|-------|-----------|------------|------|----------|---------|-----------------------|----------------|-----------------------------------------|-------------|--------|
| +\$00 | CTRLA     | 7~0        |      | INPUTLVL |         | SDASETUP              | SDAHOLD1,0     |                                         | FMPEN       | FMEN   |
| +\$01 | DUALCTRL  | $7 \sim 0$ |      | INPUTLVL |         |                       | SDAH           | OLD1,0                                  | FMPEN       | ENABLE |
| +\$02 | DBGCTRL   | $7 \sim 0$ |      |          |         |                       |                |                                         |             | DBGRUN |
| +\$03 | MCTRLA    | 7~0        | RIEN | WIEN     |         | QCEN                  | TIMEOUT1,0     |                                         | SMEN        | ENABLE |
| +\$04 | MCTRLB    | $7 \sim 0$ |      |          |         |                       | FLUSH ACKACT   |                                         | MCMD1,0     |        |
| +\$05 | MSTATUS   | $7 \sim 0$ | RIF  | WIF      | CLKHOLD | RXACK                 | ARBLOST BUSERR |                                         | BUSSTATE1,0 |        |
| +\$06 | MBAUD     | $7 \sim 0$ |      | ,<br>,   |         | BAU                   | D7~0           | 1                                       | 1           |        |
| +\$07 | MADDR     | $7 \sim 0$ |      | 1        | 1       | ADD                   | R7~0           | 1                                       | 1           |        |
| +\$08 | MDATA     | $7 \sim 0$ |      | 1        |         | DAT                   | A7~0           | 1                                       | 1           |        |
| +\$09 | SCTRLA    | $7 \sim 0$ | DIEN | APIEN    | PIEN    |                       |                | PMEN                                    | SMEN        | ENABLE |
| +\$0A | SCTRLB    | $7 \sim 0$ |      |          |         |                       |                | ACKACT                                  | SCM         | D1,0   |
| +\$0B | SSTATUS   | $7 \sim 0$ | DIF  | APIF     | CLKHOLD | RXACK                 | COLL           | BUSERR                                  | DIR         | AP     |
| +\$0C | SADDR     | $7 \sim 0$ |      | ADDR7~0  |         |                       |                |                                         |             |        |
| +\$0D | SDATA     | 7~0        |      |          |         | DATA7~0               |                |                                         |             |        |
| +\$0E | SADDRMASK | 7~0        |      |          | AI      | DDRMASK6 <sup>-</sup> | ~0             | ı — — — — — — — — — — — — — — — — — — — |             | ADDREN |

## 27.5. レジスタ説明

## 27.5.1. CTRLA - 制御A (Control A)

名称:CTRLA

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

## 特質:-

| ビット    | 7 | 6        | 5 | 4        | 3    | 2      | 1     | 0    |
|--------|---|----------|---|----------|------|--------|-------|------|
|        |   | INPUTLVL |   | SDASETUP | SDAH | OLD1,0 | FMPEN | FMEN |
| アクセス種別 | R | R/W      | R | R/W      | R/W  | R/W    | R/W   | R/W  |
| リセット値  | 0 | 0        | 0 | 0        | 0    | 0      | 0     | 0    |

## ● ビット6 - INPUTLVL : 入力電圧遷移基準 (Input Voltage Transition Level)

このビットはI2CまたはSMBusを選びます。

| 值  | 0                        | 1                 |
|----|--------------------------|-------------------|
| 名称 | I2C                      | SMBUS             |
| 説明 | I <sup>2</sup> C入力電圧遷移基準 | SMBus 3.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     | 01    | 1 0                   | 11                |
|----|---------|-------|-----------------------|-------------------|
| 名称 | OFF     | 50NS  | 300NS                 | 500NS             |
| 説明 | 保持時間OFF | 短保持時間 | 代表的条件下のSMBus 2.0仕様に合致 | 全方面に渡ってSMBus仕様に合致 |

## ● ビット1 - FMPEN : 高速動作+許可 (Fast Mode Plus Enable)

このビットへの'1'書き込みはTWI既定構成設定または二元動作構成設定でのTWI主装置に対して1MHzハス速度を選びます。

| 値  | 0              | 1        |
|----|----------------|----------|
| 名称 | OFF            | ON       |
| 説明 | 標準動作または高速動作で動作 | 高速動作+で動作 |

## ● ビット0 - FMEN : 高速動作許可 (Fast Mode Enable)

主装置動作時のこのビットへの'1'書き込みは高速動作でのI2C仕様適合のためにSCLデューティサイクルを調整します。このビットは従装 置動作または高速動作+が許可される場合、無効です。

| 値  | Ī | 0                            | 1                            |
|----|---|------------------------------|------------------------------|
| 名和 | 弥 | OFF                          | ON                           |
| 説明 | 明 | 標準動作(SM)仕様に従って動くSCLデューティサイクル | 高速動作(FM)仕様に従って動くSCLデューティサイクル |

27.5.2. DUALCTRL - 二元動作制御構成設定 (Dual Mode Control Configuration)

|    | : DUALCTRL |
|----|------------|
| 変位 | : +\$01    |

リセット : \$00

特質 :-

| ビット    | 7 | 6        | 5 | 4 | 3     | 2      | 1     | 0      |
|--------|---|----------|---|---|-------|--------|-------|--------|
|        |   | INPUTLVL |   |   | SDAHO | DLD1,0 | FMPEN | ENABLE |
| アクセス種別 | R | R/W      | R | R | R/W   | R/W    | R/W   | R/W    |
| リセット値  | 0 | 0        | 0 | 0 | 0     | 0      | 0     | 0      |

## ● ビット6 - INPUTLVL : 入力電圧遷移基準 (Input Voltage Transition Level)

このビットはI2CまたはSMBusを選びます。このビットは2元動作が許可されない場合に無視されます。

| 値  | 0                        | 1                 |
|----|--------------------------|-------------------|
| 名称 | I2C                      | SMBUS             |
| 説明 | I <sup>2</sup> C入力電圧遷移基準 | SMBus 3.0入力電圧遷移基準 |

## • ビット3,2 - SDAHOLD1,0 : SDA保持時間 (SDA Hold Time)

このビット領域はTWI従装置に対するSDA保持時間を選びます。「電気的特性」章もご覧ください。このビットは2元動作が許可されない 場合に無視されます。

|   | 値  | 0 0     | 01    | 1 0                   | 11                |
|---|----|---------|-------|-----------------------|-------------------|
| ſ | 名称 | OFF     | 50NS  | 300NS                 | 500NS             |
|   | 説明 | 保持時間OFF | 短保持時間 | 代表的条件下のSMBus 2.0仕様に合致 | 全方面に渡ってSMBus仕様に合致 |

## ● ビット1 - FMPEN : 高速動作+許可 (FM Plus Enable)

このビットへの'1'書き込みはTWI従装置に対して1MHzバス速度を選びます。このビットは2元動作が許可されない場合に無視されます。

| 值  | 0              | 1        |
|----|----------------|----------|
| 名称 | OFF            | ON       |
| 説明 | 標準動作または高速動作で動作 | 高速動作+で動作 |

• ビット0 - ENABLE : 二元制御許可 (Dual Control Enable)

このビットへの'1'書き込みがTWI二元動作構成を許可します。

## 27.5.3. 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停止中のデバッグ動作中断で走行継続 |

## 27.5.4. MCTRLA - 主装置制御A (Host Control A)

| 名称   | : | MCTRLA |
|------|---|--------|
| 変位   | : | +\$03  |
| リセット | : | \$00   |

#### 特質:-

| ビット    | 7    | 6    | 5 | 4    | 3     | 2      | 1    | 0      |
|--------|------|------|---|------|-------|--------|------|--------|
|        | RIEN | WIEN |   | QCEN | TIMEC | )UT1,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      |

#### • ビット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)レシ<sup>\*</sup>スタの指令(MCMD)ヒ<sup>\*</sup>ット領域に(STOPを)書くことによって停止条件を発行しなければなりません。

#### • ビット3,2 - TIMEOUT1,0: 不活性バス制限時間 (Inactive Bus Timeout)

このビット領域に0以外の値を設定することが不活性ハス制限時間監視を許可します。ハスがTIMEOUT設定よりも長い間不活性の場合、ハス状態論理回路はアイドル状態に移行します。

| [ | 値  | 0 0                        | 01           | 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を主装置として許可します。

## 27.5.5. MCTRLB - 主装置制御B (Host Control B)

| 名称 | : | MCTRLB |
|----|---|--------|
| 変位 | · | +\$04  |

リセット: \$00

リビット . ⊅U #土555 .

特質:-

| FLUSH ACKACT MCMD          | D1.0  |
|----------------------------|-------|
|                            | iD1,0 |
| アクセス種別 R R R R R/W R/W R/W | R/W   |
| リセット値 0 0 0 0 0 0 0        | 0     |

#### • E'ット3 - FLUSH : 解消 (Flush)

このビットは主装置の内部状態を解消してバス状態をアイドルに変えます。TWIは主装置アドレス(TWIn.MADDR)レジスタに先立って主装置 データ(TWIn.MDATA)レジスタが書かれる場合に無効なデータを送信します。解消後の主装置アドレス(TWIn.MADDR)と主装置データ(TWI n.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'として読みます。 このビット領域への書き込みは下表によって定義されるような主装置動作を起動します。

注: ACKACTビットとMCMDビット領域は同時に書くことができます。

| MCMD1,0 | 群構成設定     | データ方向 | ~9方向                                          |  |
|---------|-----------|-------|-----------------------------------------------|--|
| 0 0     | NOACT     | ×     | (予約)                                          |  |
| 01      | REPSTART  | ×     | 再送開始条件が後続する応答動作を実行                            |  |
| 1.0     |           |       | バ小書き込み操作が後続する応答動作(活動なし)を実行 ( <mark>注</mark> ) |  |
| 10      | RECVTRANS | R     | バ 小 読 み 込 み 操 作 が 後 続 す る 応 答 動 作 を 実 行       |  |
| 11      | STOP      | ×     | 停止条件発行が後続する応答動作を実行                            |  |

注: 主装置書き込み操作に対して、TWIは主装置データ(TWIn.MDATA)レジスタに書かれる新しいデータを待ちます。

注: ACKACTビットとMCMDビット領域は同時に書くことができます。

#### 27.5.6. MSTATUS - 主装置状態 (Host Status)

名称 : MSTATUS

- **変位 : +\$0**5
- リセット : \$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'に設定されます。

WIF7ラグは主装置書き込み割り込みを生成することができます。主装置制御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'として読まれると、それは従装置からの最新応答ビットが否認応答(NACK)で従装置がより多くのデータの受信ができないかまたは必要でないことを示します。

#### ● ビット3 - ARBLOST : 調停敗退 (Arbitration Lost)

このビットが'1'として読まれると、それは主装置が調停で敗れたことを示します。これは以下の場合の1つで起き得ます。

- ・Highデータビットを送信している間
- ・ 否認応答(NACK)を送信している間
- ・開始条件(S)を発行している間
- ・再送開始条件(Sr)を発行している間

このフラグはRIFフラグに対して記述される方法の1つを選ぶことによって解除(0)することができます。

#### ビット2 - BUSERR : バス異常 (Bus Error)

BUSERR7ラグは不正なバス状態が起きたことを示します。不正なバス操作は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         | 01              | 10               | 11           |
|----|-------------|-----------------|------------------|--------------|
| 名称 | UNKNOWN     | IDLE            | OWNER            | BUSY         |
| 説明 | 未知のバス状態(未知) | アイドルのバス状態(アイドル) | このTWIがバスを制御(所有者) | 多忙なバス状態(使用中) |

#### 27.5.7. MBAUD - 主装置ボーレート (Host Baud Rate)

名称:MBAUD

**変位** : +\$06

リセット : \$00

特質 :-

| BAUD7~0           アクセス種別         R/W         R | ビット    | 7   | 6   | 5   | 4   | 3    | 2   | 1   | 0   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----|-----|-----|-----|------|-----|-----|-----|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |     |     |     | 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   |

#### • ビット7~0 - BAUD7~0 : ボーレート (Baud Rate)

このビット領域はSCLのHighとLowの時間を得るのに使われます。主装置が禁止されている間に書かれなければなりません。主装置は 主装置制御A(TWIn.MCTRLA)レジスタのTWI主装置許可(ENABLE)ビットに'0'を書くことによって禁止されます。

SCLの周波数を計算する方法のより多くの情報については「クロック生成」項を参照してください。

## 27.5.8. MADDR - 主装置アドレス (Host Address)

| 名称 : MADDR<br>変位 : +\$07<br>リセット : \$00<br>特質 : - |     |     |     |     |      |     |     |     |
|---------------------------------------------------|-----|-----|-----|-----|------|-----|-----|-----|
| ヒット                                               | 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を使います。

## 27.5.9. MDATA - 主装置データ (Host Data)

| 名称 | : | MDATA |
|----|---|-------|
| 変位 | : | +\$08 |

リセット: \$00

特質:-

| ۲<br>۲<br>۳ | 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)

このビット領域はハ<sup>・</sup>スでのデータ移動出力(送信)とハ<sup>・</sup>スから受け取るデータの移動入力(受信)に使われる主装置の物理的な移動レジスタへの直接アクセスを提供します。直接アクセスはハ<sup>・</sup>(小送信中にMDATAレジ<sup>・</sup>スタをアクセスすることができないことを意味します。

有効なデータの読み込みまたは送信されるべきデータの書き込みはクロック保持(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)レジスタに配置されます。

## 27.5.10. SCTRLA - 従装置制御A (Client 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 Client)

このビットに'1'を書くことがTWI従装置を許可します。

#### 27.5.11. SCTRLB - 従装置制御B (Client Control B)

| 名称 : SC <sup>~</sup><br>変位 : +\$0<br>リセット : \$00<br>特質 : - | A    |   |   |   |   |        |     |      |
|------------------------------------------------------------|------|---|---|---|---|--------|-----|------|
| ビット                                                        | 7    | 6 | 5 | 4 | 3 | 2      | 1   | 0    |
|                                                            |      |   |   |   |   | ACKACT | SCM | D1,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            |
|---|----|-------------|--------------|
| Γ | 名称 | АСК         | NACK         |
|   | 説明 | 確認応答(ACK)送出 | 否認応答(NACK)送出 |

## ビット1,0 - SCMD1,0 : 指令 (Command)

SCMD(注)ビット領域は瞬発(ストローブ)信号です。このビット領域は常に'0'として読みます。

このビット領域への書き込みは次表によって定義されるような従装置動作を起動します。

## 表27-3. 指令設定

| 122/ 3.1日丁 |           | -       |                                                          |       |  |  |  |  |  |  |
|------------|-----------|---------|----------------------------------------------------------|-------|--|--|--|--|--|--|
| SCMD1,0    | 群構成設定     | DIR(方向) | 説明                                                       |       |  |  |  |  |  |  |
| 0 0        | NOACT     | ×       | 活動なし                                                     |       |  |  |  |  |  |  |
| 01         | -         | ×       | (予約)                                                     |       |  |  |  |  |  |  |
| 1 0        |           | W       | 何れかの開始条件/再送開始条件(S/Sr)待機に先行する応答動作を実行                      | 転送処理  |  |  |  |  |  |  |
| 10         | COMPTRANS | R       | 何れかの開始条件/再送開始条件(S/Sr)待機                                  | 完了に使用 |  |  |  |  |  |  |
|            |           | W       | 次バ仆の受信に先行する応答動作を実行                                       |       |  |  |  |  |  |  |
| 11         |           |         | アドレス割り込み要求フラグ(APIF)に対する応答で使用:従装置データ割り込み(DIF)に先行する応答動作を実行 |       |  |  |  |  |  |  |
|            |           | R       | データ割り込み要求フラグ(DIF)に対する応答で使用:応答動作が後続するバイト読み取り<br>操作を実行     |       |  |  |  |  |  |  |

注: ACKACTビットとSCMDビット領域は同時に書くことができます。ACKACTは指令が起動されるのに先立って更新されます。

## 27.5.12. SSTATUS - 従装置状態 (Client Status)

名称:SSTATUS

**変位** : +\$0B

**リセット** : \$00

特質 :-

| DIF     APIF     CLKHOLD     RXACK     COLL     BUSERR     DIR     AP       アクセス種別     R/W     R/W     R     R     R/W     R/W     R     R | ビット    | 7   | 6    | 5       | 4     | 3    | 2      | 1   | 0  |
|--------------------------------------------------------------------------------------------------------------------------------------------|--------|-----|------|---------|-------|------|--------|-----|----|
| アクセス種別 R/W R/W R R R R/W R/W R R                                                                                                           |        | 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 0                                                                                                                    | リセット値  | 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'に設定されます。

・ 否認応答(NACK)ビット送信。従装置アトレス一致が既に起こされたために衝突が起き、結果としてアトレス/停止条件割り込み要求フラ グ(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二元動作またはTWI主装置が 許可され、主クロック周波数がSCL周波数の最低4倍でなければなりません。TWI二元動作は二元動作制御構成設定(TWIn.DUALCT RL)レジスタの二元制御許可(ENABLE)ビットに'1'を書くことによって許可することができます。TWI主装置制御A(TWIn.MCT RLA)レジスタの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フラグでの割り込みを生成 |  |  |

#### 27.5.13. SADDR - 従装置アドレス (Client Address)

名称 : SADDR

**変位** : +\$0C

リセット : \$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)

従装置アドレス(TWIn.ADDR)レジスタはTWI主装置がTWI従装置をアドレス指定したかを判断する従装置アドレス一致論理回路によって使われます。アドレス パケットが受信された場合、従装置状態(TWIn.SSTATUS)レジスタのアドレス/停止条件割り込み要求フラグ(APIF)とアドレス/停止条件割り込み要求フラグ(APIF)とアドレス/停止条件(AP)ビットが'1'に設定されます。

TWIn.SADDRレジスタの上位7ビット(ADDR7~1)は基本従装置アドレスを表します。

TWIn.SADDRレジスタの最下位ビット(ADDR0)はI<sup>2</sup>C規約の一斉呼び出しアドレス(\$00)の認識に使われます。この機能はこのビットが'1'に 設定される時に許可されます。

## 27.5.14. SDATA - 従装置データ (Client Data)

| 名称   | : SDATA |
|------|---------|
| + 1- |         |

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

特質:-

| ヒ <sup>*</sup> ット | 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)ビットの設定に依存します。

## 27.5.15. SADDRMASK - 従装置アドレス遮蔽 (Client Address Mask)

名称 : SADDRMASK 変位 : +\$0E リセット : \$00

## 特質:-

| ヒット    | 7           | 6   | 5   | 4   | 3   | 2      | 1   | 0   |
|--------|-------------|-----|-----|-----|-----|--------|-----|-----|
|        | ADDRMASK6~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アトレス一致またはアトレス遮蔽のレシ、スタとして働きます。

ADDRENE'ットが'0'を書かれる場合、ADDRMASKE'ット領域は7ビット従装置アトレス遮蔽値を設定することができます。従装置アトレス遮蔽(TWIn.SADDRMASK)レジスタ内の各ビットはTWI従装置アトレス(TWIn.SADDR)レジスタ内の対応するアトレスビットを遮蔽(禁止)することができます。この遮蔽のビットが'1'を書かれるなら、アトレス一致論理回路は着信アトレスビットと従装置アトレス(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つの独自のアドレスに応答します。

## 28. CRCSCAN - 巡回冗長検査メモリ走査

## 28.1. 特徴

- ・CRC-16-CCITTまたはCRC-32(IEEE 802.3)
- ・全フラッシュ メモリ領域、応用コード領域と/またはブート領域の検査
- ・選択可能な不成功でのNMI起動
- ・使用者構成設定可能な内部リセット初期化中の検査

## 28.2. 概要

巡回冗長検査(CRC)は重要な安全機能です。不揮発性メモリ(NVM)を走査してコードが正しいことを保証します。

デバイスはフラッシュメモリ誤りが起きた場合、コートを実行しません。コード化けが起きていないことを保証することにより、危険な状況を起こ し得る応用での潜在的な意図しない動きを避けることができます。CRC走査はフラッシュメモリ全体、フート領域だけ、フートと応用コートの 両領域を走査するように設定することができます。

CRCは予め計算されたチェックサムと比較されるチェックサムを生成します。2つのチェックサムが一致する場合、フラッシュメモリはOKで、応用コート は走行を開始することができます。

状態(CRCSCAN.STATUS)レジスタの多忙(BUSY)ビットはCRC走査が進行中か否かを示す一方で、状態(CRCSCAN.STATUS)レジスタの CRC OK(OK)ビットはチェックサム比較が一致か否かを示します。

CRCSCANはチェックサムが一致しない場合に遮蔽不可割り込み(NMI)を生成させるように設定することができます。

## 28.2.1. 構成図



## 28.3. 機能的な説明

## 28.3.1. 初期化

ソフトウェア(またはデバッガ経由)でCRCを許可するには、

1. 望む供給元設定を選ぶために制御B(CRCSCAN.CTRLB)レジスタの供給元(SRC)ビット領域を書いてください。

2. 制御A(CRCSCAN.CTRLA)レジスタの許可(ENABLE)ビットに'1'を書くことによってCRCSCANを許可してください。

3. CRCは3周期後に開始します。CPUはこれらの3周期の間も実行を続けます。

CRC32とCRC16の選択はヒュース、設定を通して行われます。CRCSCANはデバイスがリセットを出る前にコート、メモリ走査を実行するように構成設定することができます。この検査が失敗の場合、CPUは通常のコート、実行の開始を許されません。この機能はシステム構成設定0 (FUSE.SYSCFG0)ヒュース、のCRC供給元(CRCSRC)領域によって許可されて制御されます(より多くの情報については「ヒュース、」項をご 覧ください)。

CRCSCANが許可された場合、成功したCRC検査は以下の結果を持ちます。

- ・通常コード実行開始
- ・CRCSCAN.CTRLAレジスタのENABLEビットが'1'です。
- ・CRCSCAN.CTRLBレジスタのCRC供給元(SRC)ビット領域は検査した領域を反映します。
- ・状態(CRCSCAN.STATUS)レジスタのCRC OK(OK)フラグが'1'です。

CRCSCANが許可された場合、不成功のCRC検査は以下の結果を持ちます。

- ・通常コード実行は開始せず、CPUはコード実行を停止します。
- ・CRCSCAN.CTRLAレジスタのENABLEビットが'1'です。
- ・CRCSCAN.CTRLBレジスタのSRCビット領域は検査した領域を反映します。
- ・CRCSCAN.STATUSレジスタのOKフラケが'0'です。
- ・この状況はデバッグインターフェースを用いて観察することができます。

#### 28.3.2. 動作

動作時、CRCSCANはフラッシュ メモリへのアクセス優先権を持ち、完了されるまでCPUを停止します。

CRCは各16ビット取得に対して3クロック周期使います。CRCSCANは始動から走査を行うように構成設定することができます。

任意長のデータ塊に適用されるnビットCRCは長さでnビットまでのどんな単一改変(連続誤り)も検出します。より長い連続誤りについては 1-2<sup>-n</sup>分の1が検出されます。

CRC生成部はCRC-16-CCITT)とCRC-32(IEEE 802.3)を支援します。

多項式任意選択は次のとおりです。

• CRC-16-CCITT :  $X^{16}+X^{12}+X^{5}+1$ 

• CRC-32 :  $X^{32}+X^{26}+X^{23}+X^{22}+X^{16}+X^{12}+X^{11}+X^{10}+X^8+X^7+X^5+X^4+X^2+X^{11}$ 

CRCは検査に対して設定された領域の内容をハイト0で始めてハイト単位で読み、ハイト毎に新しいチェックサムを生成します。ハイトは最上位ビットから始めて下で描かれるような移動レジスタを通して送られます。領域の最後のハイトが正しいチェックサムを含む場合、CRCは(検査に)合格します。チェックサムかどう配置されるかについては「28.3.2.1. チェックサム」をご覧ください。チェックサムレジスタの初期値は\$FFFFです。



#### 28.3.2.1. チェックサム

検査される領域の最後の位置に予め計算されたチェックサムが存在しなければなりません。ブート(BOOT)領域が検査されるべきなら、 チェックサムはブート領域の最後の(2または4)バイトに保存されなければなりません。応用(APPLICATION)とフラッシュ全体に対しても同様で す。表28-1.と表28-2.は各種領域に対してチェックサムがどう格納されなければならないかを明確に示します。どの領域を検査するかを 構成設定する方法については制御B(CRCSCAN.CTRLB)レジスタ記述を参照してください。

| 表28-1. フラッシュ メモリでの予め計算さ          | 表28-1. フラッシュ メモリでの予め計算されたCRC16用チェックサムの配置 |                |  |  |  |  |  |  |  |
|----------------------------------|------------------------------------------|----------------|--|--|--|--|--|--|--|
| 検査する領域                           | チェックサム(ビット15~8)                          | チェックサム(ビット7~0) |  |  |  |  |  |  |  |
| ブート領域 (BOOT)                     | BOOTEND-1                                | BOOTEND        |  |  |  |  |  |  |  |
| ブート領域(BOOT)と<br>応用領域(APLICATION) | CODEEND-1                                | CODEEND        |  |  |  |  |  |  |  |
| 全フラッシュ メモリ                       | FLASHEND-1                               | FLASHEND       |  |  |  |  |  |  |  |

#### 表28-2. フラッシュ メモリでの予め計算されたCRC32用チェックサムの配置

| 検査する領域                           | ቻェッ <b>ク</b> サム(ビット31~24) | <del>ቻ</del> ェックサム(ヒ <sup>゙</sup> ット23~16) | <del>チ</del> ェックサム(ヒ <sup>゙</sup> ット15~8) | チェックサム(ビット7~0) |
|----------------------------------|---------------------------|--------------------------------------------|-------------------------------------------|----------------|
| ブート領域 (BOOT)                     | BOOTEND                   | BOOTEND-1                                  | BOOTEND-2                                 | BOOTEND-3      |
| ブート領域(BOOT)と<br>応用領域(APLICATION) | CODEEND                   | CODEEND-1                                  | CODEEND-2                                 | CODEEND-3      |
| 全フラッシュ メモリ                       | FLASHEND                  | FLASHEND-1                                 | FLASHEND-2                                | FLASHEND-3     |

## 28.3.3. 割り込み

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

| 名称  | ベクタ説明    | 条件    |
|-----|----------|-------|
| NMI | 遮蔽不可割り込み | CRC誤り |

割り込み条件が起こると、状態(CRCSCAN.STATUS)レジズタのCRC OK(OK)フラグが'0'に解除されます。

遮蔽不可割り込み(NMI)は制御A(CRCSCAN.CTRLA)レジ゙スタの対応する許可(NMIEN)ビットに'1'を書くことによって許可されますが、 システム リセットでだけ禁止することができます。 NMIはCRCSCAN.STATUSレジ゙スタのOKフラグが解除(0)され、 NMIENビットが'1'の時に生 成されます。 NMI要求はシステム リセットまで活性に留まり、禁止することができません。

NMIは例え割り込みが全体的に許可されなくても起動することができます。

## 28.3.4. 休止形態動作

全てのCPU休止動作でCRCSCANは停止され、CPUが起き上がる時に動作を再開します。

CRCSCANは制御A(CRCSCAN.CTRLA)レジスタのCRCSCAN許可(ENABLE)ビット書き込み後3周期で動作を開始します。これらの3周期の間に休止動作へ移行することが可能です。この場合、

1. CRCSCANはCPUが起き上がるまで開始しません。

2. CRCSCANが終了された後に何れかの割り込み処理部を実行します。

## 28.3.5. デバッグ操作

デバッガが周辺機能やメモリ位置を読み書きする時は必ずCRCSCANが禁止されます。

デバッガがデバイスをアクセスする時にCRCSCANが多忙の場合、CRCSCANはデバッガが内部レジスタをアクセスする時、またはデバッガ切断 時に進行中の動作を再始動します。

状態(CRCSCAN.STATUS)レジスタの多忙(BUSY)ビットはデバッカがこれを禁止にさせた時にCRCSCANが多忙だった場合に'1'を読み ますが、デバッカがこれの禁止を保つ限り、どの領域も積極的に検査しません。CRCSCANを禁止することなくデバッカによって読むこと ができる同期したCRC状態ビットがデバッカがの内部レジスタ空間にあります。デバッカの内部CRC状態ビット読み込みはCRCSCANが許可 されることを確実にします。

デバッガから直接CRCSCAN.STATUSレジスタ書き込みが可能なら、

- ・CRCSCAN.STATUSレシ<sup>\*</sup>スタ内の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からの書き込みと同様に扱われます。

28.4. レジスタ要約

| 変位    | 略称     | ビット位置 | ビット7  | ビット6 | ビット5 | ビット4 | ビット3 | ビット2 | ビット1  | ビットロ   |
|-------|--------|-------|-------|------|------|------|------|------|-------|--------|
| +\$00 | CTRLA  | 7~0   | RESET |      |      |      |      |      | NMIEN | ENABLE |
| +\$01 | CTRLB  | 7~0   |       |      |      |      |      |      | SRO   | C1,0   |
| +\$02 | STATUS | 7~0   |       |      |      |      |      |      | OK    | BUSY   |

## 28.5. レジスタ説明

## 28.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を起動します。

これはシステム リセットによってのみ解除(0)することができ、それはリセット(RESET)ビットへの書き込みによって解除(0)されません。

このビットはCRCSCANが多忙でない(CRCSCAN.STATUSレジスタの多忙(BUSY)ビットが'0'の)時に'1'へ書くことだけができます。

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

このビットに'1'を書くことが現在の設定でCRCSCANを許可します。これはCRC検査が完了した後でも'1'に留まりますが、再びこれに'1'を書くことが新しい検査を開始します。

#### このビットに'0'を書くことは無効です。

CRCSCANはCPUに通常のコート<sup>\*</sup>実行を始めさせる前にフラッシュ メモリ領域を確認するため、マイクロ コントローラ(MCU)始動手順中に走査を 動かすように構成設定することができます(「28.3.1. 初期化」項をご覧ください)。この機能が許可された場合、通常のコート<sup>\*</sup>実行が始ま ると、ENABLEL<sup>\*</sup>ットは'1'として読みます。

CRCSCANが進行中の検査で多忙かどうかを知るには、状態(CRCSCAN.STATUS)レジスタの多忙(BUSY)ビットをホーリングしてください。

## 28.5.2. CTRLB - 制御B (Control B)

名称 : CTRLB

**変位** : +\$01

リセット : \$00

## 特質:-

制御BレジスタはCRCに対する供給元設定を含みます。これはCRCSCANが多忙の時、またはNMIが起動されてしまった時に書き込み不可です。

| ビット    | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0    |
|--------|---|---|---|---|---|---|-----|------|
|        |   |   |   |   |   |   | SRO | Ç1,0 |
| アクセス種別 | R | R | R | R | R | R | R/W | R/W  |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0   | 0    |

#### ビット1,0 - SRC1,0 : CRC供給元 (CRC Source)

SRCビット領域はCRCSCANによって検査されるべきフラッシュ メモリの領域を選びます。領域の大きさを構成設定するには「ヒューズ」項を参照してください。

CPUを開始させる前にフラッシュメモリ領域を確認するために、内部リセット初期化中にCRCSCANを許可することができます(「ヒュース」」項を ご覧ください)。CRCSCANが内部リセット初期化中に許可された場合、通常のコート、実行が始まると、(構成設定に依存して)FLASH、BO OTAPP、BOOTとして読み出されます。

| 值  | 0 0                                            | 0 1                                | 1 0                         | 11   |
|----|------------------------------------------------|------------------------------------|-----------------------------|------|
| 名称 | FLASH                                          | BOOTAPP                            | BOOT                        | -    |
| 説明 | CRCはフラッシュメモリ全体(ブート、応用<br>コート、応用データの領域)で実行されます。 | CRCはフラッシュのブートと応用<br>コードの領域で実行されます。 | CRCはフラッシュのブート<br>領域で実行されます。 | (予約) |

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

名称 : STATUS

**変位 : +\$02** 

**リセット** : \$02

#### 特質 :-

| ビット    | 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'yh1 - OK : CRC OK (CRC OK)

このビットが'1'として読まれると、直前のCRCは成功裏に完了しました。このビットはCRC走査が走る前に既定で'1'に設定されます。 このビットは多忙(BUSY)が'0'でなければ無効です。

#### ビット0 - BUSY : CRC多忙 (CRC Busy)

このビットが'1'として読まれると、CRCSCANは多忙です。単位部が多忙である限り、制御レジスタへのアクセスは制限されます。

## 29. CCL - 構成設定可能な注文論理回路

## 29.1. 特徴

- ・汎用PCB設計用接続用論理回路(glue logic)
- ・4つの設定可能な参照表(LUT)
- ・組み合わせ論理回路機能:3入力までの機能の全ての論理式
- 逐次制御器論理回路機能
  - 門付きDフリップフロップ
  - JKフリッフ°フロッフ°
  - 門付きDラッチ
  - RSラッチ
- ・柔軟な参照表(LUT)入力選択
  - 入出力
  - 事象
  - 後続LUT出力
  - 内部周辺機能
    - ・アナログ比較器
    - ・タイマ/カウンタ
    - USART
    - SPI
- ・ システム クロックまたは他の周辺機能によるクロック駆動
- ・入出力ピンまたは事象システムへ接続可能な出力
- ・各LUT出力で利用可能な任意選択の同期化器、濾波器、端検出器
- ・各LUT出力からの任意選択割り込み生成
  - 上昇端
  - 下降端
  - 両端

## 29.2. 概要

構成設定可能な注文論理回路(CCL:Configurable Custom Logic)はデバイスのピン、事象、他の内部周辺機能に接続することができる 設定可能な論理回路周辺機能です。CCLはデバイスの周辺機能と外部デバイス間の'接続用論理回路(glue logic)'として扱うことがで きます。CCLは外部の論理回路部品の必要を無くすことができ、CPUと無関係に応用の最も時間が重要な部分を処理するためにコア から独立した周辺機能と組み合わせることによって実時間制限を克服することで設計者を手助けすることもできます。

CCL周辺機能はいくつかの参照表(LUT:LookUp Table)を提供します。各LUTは3つの入力、真理値表、同期部/濾波器、端検出器 から成ります。各LUTは3つの入力を持つ使用者設定可能な論理式として出力を生成することができます。出力は組み合わせ的な論 理回路を用いて入力から生成され、スパイクを取り除くために濾波することができます。CCLはLUT出力での変化で割り込み要求を生 成するように構成設定することができます。

隣接LUTは特定動作を実行するように結合することができます。逐次制御器は複雑な波形を生成するのに使うことができます。

## 29.2.1. 構成図



| 表29-1. 逐次制御器とLUTの接続 |           |  |  |  |
|---------------------|-----------|--|--|--|
| 逐次制御器               | 偶数と奇数のLUT |  |  |  |
| SEQ0                | LUT0とLUT1 |  |  |  |
| SEQ1                | LUT2とLUT3 |  |  |  |

## 29.2.2. 信号説明

| 信号         | 形式     | 説明                                       |
|------------|--------|------------------------------------------|
| LUTn-OUT   | デジタル出力 | 参照表からの出力                                 |
| LUTn-IN2~0 | デジタル入力 | 参照表への入力。LUTn-IN2はCLK_LUTnとして取り扱うことができます。 |

この周辺機能に対するピン割り当ての詳細については「入出力多重化と考察」章を参照してください。1つの信号を様々なピンに割り 当てることができます。

## 29.2.2.1. CCL入力選択多重器

CCL LUTへの入力として以下の周辺機能出力が利用可能です。

| 値             | 入力元                        | INSEL03~0   | INSEL13~0       | INSEL23~0  |  |  |
|---------------|----------------------------|-------------|-----------------|------------|--|--|
| 0 0 0 0 (\$0) | MASK                       | なし (遮蔽した入力) |                 |            |  |  |
| 0 0 0 1 (\$1) | FEEDBACK                   |             | LUTn (帰還入力)     |            |  |  |
| 0 0 1 0 (\$2) | LINK                       |             | LUTn+1 (連結)     |            |  |  |
| 0 0 1 1 (\$3) | EVENTA                     |             | EVENTA (事象入力元A) |            |  |  |
| 0 1 0 0 (\$4) | EVENTB                     |             | EVENTB (事象入力元B) |            |  |  |
| 0 1 0 1 (\$5) | INn                        | LUTn-IN0    | LUTn-IN1        | LUTn-IN2   |  |  |
| 0 1 1 0 (\$6) | AC                         | ACOのOUT     | AC1のOUT         |            |  |  |
| 0 1 1 1 (\$7) | USARTn ( <mark>注1</mark> ) | USART0のTXD  | USART1のTXD      | USART2のTXD |  |  |
| 1 0 0 0 (\$8) | SPI0 ( <mark>注2</mark> )   | SPIOC       | MOSI            | SPI0のSCK   |  |  |
| 1 0 0 1 (\$9) | TCA0                       | TCA0のWO0    | TCA0のWO1        | TCA0のWO2   |  |  |
| 1010(\$A)     | TCA1                       | TCA1のWO0    | TCA1のWO1        | TCA1のWO2   |  |  |
| 1011(\$B)     | TCBn                       | TCB0のWO     | TCB1のWO         | TCB2のWO    |  |  |
| その他           | _                          | (予約)        |                 |            |  |  |

注1: CCLへのUSART接続は非同期/同期USART主装置動作でだけ動きます。

**注2**: CCLへのSPI接続は主装置SPI動作でだけ動きます。

## 29.3. 機能的な説明

#### 29.3.1. 動作

#### 29.3.1.1. 許可保護される構成設定

LUTと逐次制御器の構成設定は許可保護され、対応する偶数LUTが禁止(LUTn制御A(CCL.LUTnCTRLA)レジスタのLUT許可(ENA BLE)=0、n=0,2)される時にだけそれらを構成設定することができることを意味します。これは(再)構成設定下でCCLからの望まれない 出力を抑えるための機構です。

以下のビットとレシスタが許可保護されます。

- ・逐次制御器制御n(CCL.SEQCTRLn)レジスタの逐次制御器選択(SEQSELn)
- ・CCL.LUTnCTRLAレジスタのENABLEビットを除くLUTn制御x(CCL.LUTnCTRLx)レジスタ
- ・真理値表n(CCL.TRUTHn)レジスタ

CCL.LUTnCTRLxレジスタの許可保護されたビットはCCL.LUTnCTRLAレジスタのENABLEが'1'を書かれるのと同じ時に書くことができますが、ENABLEが'0'を書かれるのと同じ時ではありません。

許可保護はレジスタ説明で許可保護された特質によって示されます。

(訳注) 29.2.2.1.の表でINSEL2の\$6が「AC1のOUT」ですが、29.5.7.(原書では29.5.8.)の表では「-」で矛盾しています。どちらかが誤っていると思われますが、どちらかは不明です。

#### 29.3.1.2. 許可、禁止、リセット

CCLは制御A(CCL.CTRLA)レジスタの許可(ENABLE)ビットに'1'を書くことによって許可されます。CCLはそのENABLEビットに'0'を書くことによって禁止されます。

各LUTはLUT制御A(CCL.LUTnCTRLA)レジスタのLUT許可(ENABLE)ビットに'1'を書くことによって許可されます。各LUTはCCL.LU TnCTRLAレジスタのENABLEビットに'0'を書くことによって禁止されます。

#### 29.3.1.3. 真理值表論理回路

各LUTの真理値表は3つの入力(LUTn-TRUTHSEL2~0)までの関数として組み合わせ 論理出力を生成することができます。1つのLUTを使ってどの3入力ブール論理関数の実 現も可能です。

以下のようなLUT制御レジスタの入力供給元選択ビット領域を書くことによって真理値表入力(LUTn-TRUTHSEL2~0)を構成設定してください。

- ・LUTn制御B(CCL.LUTnCTRLB)レジスタの入力0供給元選択(INSEL0)
- ・CCL.LUTnCTRLBレジスタの入力1供給元選択(INSEL1)
- ・LUTn制御C(CCL.LUTnCTRLC)レジスタの入力2供給元選択(INSEL2)



入力(LUTn-TRUTHSEL2~0)ビットの各組み合わせは下表で示されるように、真理値表 (CCL.TRUTHn)レシ、スタ内の1ビットに対応します。

#### 表29-2. LUTの真理値表

| LUTn-TRUTHSEL2 | 0       | 0       | 0       | 0       | 1       | 1       | 1       | 1       |
|----------------|---------|---------|---------|---------|---------|---------|---------|---------|
| LUTn-TRUTHSEL1 | 0       | 0       | 1       | 1       | 0       | 0       | 1       | 1       |
| LUTn-TRUTHSEL0 | 0       | 1       | 0       | 1       | 0       | 1       | 0       | 1       |
| OUT            | TRUTHn0 | TRUTHn1 | TRUTHn2 | TRUTHn3 | TRUTHn4 | TRUTHn5 | TRUTHn6 | TRUTHn7 |



重要:論理関数が作成される時にOFFに (Lowに結合)される未使用入力を考慮 してください。

#### 例29-1. CCL.TRUTHn=\$42に対するLUT出力

CCL.TRUTHnが\$42に構成設定される場合、LUT出力は入力が'001'または'110'の時に'1'で、他のどの組み合わせの入力に対しても'0'です。

## 29.3.1.4. 真理值表入力選択

## 入力概要

入力は個別に以下のようにすることができます。

- OFF
- ・周辺機能による駆動
- ・事象システムからの内部事象による駆動
- ・入出力ピン入力による駆動
- 他のLUTによる駆動

## 内部帰還入力 (FEEDBACK)

逐次制御器からの出力はそれが接続される2つのLUTに対する入力元とし て使うことができます。

選択(LUTnCTRLxレジスタのINSELy='0001'(FEEDBACK))されると、逐次制 御器(SEQ)出力が対応するLUTに対する入力として使われます。



#### 連結LUT(LINK)

LINK入力任意選択(INSELy='0010')選択時、次のLUTの直接出力がLUTの入力として使われます。一般的に、LUT[n+1]がLUT[n] の入力に連結されます。LUT0は最後のLUTの入力に連結されます。



#### 事象入力選択 (EVENTx)

事象システムからの事象はLUTn制御B/C(CCL.LUTnCTRLBとCCL.LUTnCTRLC)レシ<sup>、</sup>スタのINSELyビット群へ書くことによってLUTへの入力として使うことができます。

#### I/Oピン入力 (IO)

IO(INSELy='0101')任意選択選択時、LUT入力は対応するI/Oピンに接続されます。LUTn-INyピンが配置される場所についてのより 多くの詳細に関しては「入出力多重化と考察」章を参照してください。

#### 周辺機能

各LUTの3つの入力線での各種周辺機能はLUTn制御B/C(CCL.LUTnCTRLBとCCL.LUTnCTRLC)レジスタの入力選択y(INSELy) ビットへ書くことによって選ばれます。

#### 29.3.1.5. 濾波器

既定によって、LUT出力はLUT入力の組み合わせ関数です。これは入力が値を変える時にいくつかの短い不具合を起こし得ます。 これらの不具合は応用の要求によって求められた場合に濾波器を通してクロック駆動することで取り除くことができます。

LUTn制御A(CCL.LUTnCTRLA)レジスタの濾 波器選択(FILTSEL)ビットはデジタル濾波器任 意選択を定義します。

FILTSEL='10'(FILTER)時、2つを超えるCL K\_LUTn正端間を持続する入力だけが門付 きフリッププロップを通って出力へ渡されます。こ の出力は4 CLK\_LUTn正端によって遅らされ ます。

対応するLUTが禁止された後の1クロック周期 後に全ての内部濾波器論理回路が解消さ れます。



#### 29.3.1.6. 端検出器

端検出器はそれの入力で上昇端を検出する時にパルスを生成するのに使う ことができます。下降端を検出するため、反転する出力を提供するように真 理値表(CCL.TRUTHnレジスタ)を設定することができます。

端検出器はLUTn制御A(CCL.LUTnCTRLA)レジスタの端検出(EDGEDET) ビットに'1'を書くことによって許可されます。予測不能な動きを避けるため、 更に有効な濾波器任意選択が許可されなければなりません。

端検出はCCL.LUTnCTRLAレシ<sup>、</sup>スタのEDGEDETに<sup>'0</sup>'を書くことによって禁止されます。LUT禁止後、対応する内部端検出器論理回路は1クロック周期後に解消されます。



#### 29.3.1.7. 逐次制御器論理回路

各LUT対は逐次制御器に接続することができます。逐次制御器はDフリップフロップ、JKフリップフロップ、門付きDラッチ、RSラッチのどれかとして機能することができます。この機能は逐次制御器制御n(CCL.SEQCTRLn)レジスタの逐次制御器選択(SEQSELn)ビット群を書くことによって選ばれます。

逐次制御器は構成設定に依存して、LUT、濾波器、端検出器のどれかから入力を受け取ります。

逐次制御器は対応する偶数LUTと同じクロック元によってクロック駆動されます。このクロック元はLUTn制御A(CCL.LUTnCTRLA)レジスタのクロック元選択(CLKSRC)ビット群によって選ばれます。

フリッププロップ出力(OUT)はクロックの上昇端で更新されます。偶数LUTが禁止されると、ラッチは非同期に解消されます。フリップフロップリ セット信号(R)は1クロック周期間許可され続けます。

#### 門付きDフリップフロップ(DFF)

D入力は偶数LUT出力によって駆動され、G入力 は奇数LUT出力によって駆動されます。



| 表29- | 表29−3. DFF特性 |   |                      |  |  |  |  |
|------|--------------|---|----------------------|--|--|--|--|
| R    | G            | D | OUT                  |  |  |  |  |
| 1    | Х            | Х | 解除( <mark>0</mark> ) |  |  |  |  |
| 0    | 1            | 1 | 設定(1)                |  |  |  |  |
| 0    | 1            | 0 | 解除( <mark>0</mark> ) |  |  |  |  |
| 0    | 0            | Х | 状態保持(無変化)            |  |  |  |  |

#### JKDフリップフロップ(JK)

J入力は偶数LUT出力によって駆動され、K入力は 奇数LUT出力によって駆動されます。

| 図29-8. JKフリッフ <sup>°</sup> フロッフ <sup>°</sup> |  |  |  |  |  |  |
|----------------------------------------------|--|--|--|--|--|--|
| 【偶数LUT J Q→OUT                               |  |  |  |  |  |  |
| CLK_LUTn → KR                                |  |  |  |  |  |  |
|                                              |  |  |  |  |  |  |

| 表29- | 表29-4. JK特性 |   |                      |  |  |  |
|------|-------------|---|----------------------|--|--|--|
| R    | J           | К | OUT                  |  |  |  |
| 1    | Х           | Х | 解除( <mark>0</mark> ) |  |  |  |
| 0    | 0           | 0 | 状態保持(無変化)            |  |  |  |
| 0    | 0           | 1 | 解除( <mark>0</mark> ) |  |  |  |
| 0    | 1           | 0 | 設定(1)                |  |  |  |
| 0    | 1           | 1 | 逆へ切り替え               |  |  |  |

## 門付きDラッチ(DLATCH)

D入力は偶数LUT出力によって駆動され、G入力 は奇数LUT出力によって駆動されます。

| 図29-9. Dラッチ |     |              |  |
|-------------|-----|--------------|--|
| 偶数LUT       | D Q | <b>→</b> OUT |  |
| 奇数LUT       | G   |              |  |

#### 表29-5. Dラッチ特性

| JAL CO | X20 0. D777 NTL |                      |  |  |  |  |
|--------|-----------------|----------------------|--|--|--|--|
| G      | D               | OUT                  |  |  |  |  |
| 0      | Х               | 状態保持(無変化)            |  |  |  |  |
| 1      | 0               | 解除( <mark>0</mark> ) |  |  |  |  |
| 1      | 1               | 設定(1)                |  |  |  |  |

## RSラッチ (RS)

S入力は偶数LUT出力によって駆動され、R入力は 奇数LUT出力によって駆動されます。

| × | 図29-10. RSラッチ   |  |  |  |  |  |  |
|---|-----------------|--|--|--|--|--|--|
| I | 偶数LUT S Q → OUT |  |  |  |  |  |  |
| [ | 奇数LUT — R       |  |  |  |  |  |  |

| 表 | 表29-6. RSラッチ特性 |   |                      |  |  |  |
|---|----------------|---|----------------------|--|--|--|
|   | S              | R | OUT                  |  |  |  |
| Γ | 0              | 0 | 状態保持(無変化)            |  |  |  |
|   | 0              | 1 | 解除( <mark>0</mark> ) |  |  |  |
|   | 1              | 0 | 設定(1)                |  |  |  |
|   | 1              | 1 | 禁止状態                 |  |  |  |

#### 29.3.1.8. クロック元設定

濾波器、端検出器、逐次制御器は既定で周辺機能クロック(CLK\_PER)によってクロック駆動されます。それらの区部をクロック(下図のCLK\_ LUTn)駆動するのに他のクロック入力を使うことも可能です。これはLUTn制御A(CCL.LUTnCTRLA)レジスタのクロック元選択(CLKSRC) ビットを書くことによって構成設定されます。

クロック元選択(CLKSRC)ビットが'001'を書かれると、対応する 濾波器と端検出器をクロック(CLK\_LUTn)駆動するのにLUTn-TRUTHSEL2が使われます。逐次制御器は対の偶数LUTの CLK\_LUTnによってクロック駆動されます。CLKSRCビットが'00 1'を書かれると、真理値(TRUTH)表でLUTn-TRUTHSEL2 はOFF(='0')として扱われます。

CCL周辺機能は周辺機能からの未定義出力を避けるため にクロック元を変更する間は禁止されなければなりません。

# 29.3.2. 割り込み

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

| <u> </u> |       | IN THE D                                                                     |
|----------|-------|------------------------------------------------------------------------------|
| 名称       | ベクタ説明 | 条件                                                                           |
| CCL      |       | CCL.INTCTRLnレジスタの割り込み動作形態(INTMODEn)ビットによって構成設定されたように<br>INTFLAGSのINTnが掲げられる。 |

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

いくつかの割り込み要求条件が割り込みベクタによって支援される時に、割り込み要求は割り込み制御器に対して1つの結合された割り込み要求へ共に論理和(OR)されます。使用者はどの割り込み条件が存在するかを決めるために周辺機能のINTFLAGSレジスタを読まなければなりません。

#### 29.3.3. 事象

CCLは下表で示される事象を生成することができます。

#### 表29-8. CCLでの事象生成部

| 生    | 成部名  | 説明                | 事象型  | 生成クロック領域 | 事象長        |  |
|------|------|-------------------|------|----------|------------|--|
| 周辺機能 | 事象   | ■元 9 <del>月</del> | 争豕空  | 主成フロッフ損現 | ● ● 予承     |  |
| CCL  | LUTn | LUT出力レヘブル         | レヘッル | 非同期      | CCL構成設定に依存 |  |

CCLは入力事象での検出と活動のために下の事象使用部を持ちます。

| 表29-9. CC | Lでの事象使用 | 部               |      |         |  |
|-----------|---------|-----------------|------|---------|--|
| 使用        | 部名      | 説明              | 入力検出 | 同期/非同期  |  |
| 周辺機能      | 入力      | a元 99           | 入力使出 | 问册/7月间册 |  |
| CCL       | LUTn    | LUT入力xまたはクロック信号 | 検出なし | 非同期     |  |

事象信号は同期化または入力検出の論理回路なしに直接LUTに渡されます。

各LUTに対して2つの事象使用部が利用可能です。それらはLUTnの制御Bと制御C(CCL.LUTnCTRLBまたはCCL.LUTnCTRLC)レ ジスタのINSELnビット群を書くことによってLUTn入力として選ぶことができます。

事象型とEVSYS構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照してください。

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

制御A(CCL.CTRLA)レジスタのスタンハイ時走行(RUNSTDBY)ビットに'1'を書くことは選んだクロック元にスタンハイ休止動作で許可されることを許します。

RUNSTDBYビットが'0'の場合、周辺機能クロックはスタンバイ休止動作で禁止されます。濾波器、端検出器、または逐次制御器が許可される場合、スタンバイ休止動作でLUT出力は'0'を強制されます。アイドル休止動作では、RUNSTDBYビットと関係なく、真理値(TRUTH) 表復号部は動作を続け、それによってLUT出力が更新されます。

LUTn制御A(CCL.LUTnCTRLA)レジスタのクロック元選択(CLKSRC)が'001'を書かれる場合、LUTn-TRUTHSEL2が常に濾波器、端検 出器、逐次制御器をクロック駆動します。休止動作形態でのLUTn-TRUTHSEL2クロックの有効性は使う周辺機能の休止設定に依存しま す。



## 29.4. レジスタ要約

| 変位               | 略称        | ビット位置      | ビット7    | ビット6     | ビット5  | ヒット4   | ヒット3  | ビット2      | <b>ビット1</b> | ビットロ   |
|------------------|-----------|------------|---------|----------|-------|--------|-------|-----------|-------------|--------|
| +\$00            | CTRLA     | 7~0        |         | RUNSTDBY |       |        |       |           |             | ENABLE |
| +\$01            | SEQCTRL0  | 7~0        |         |          |       |        |       | SEQSE     | EL03~0      |        |
| +\$02            | SEQCTRL1  | $7 \sim 0$ |         |          |       |        |       | SEQSE     | EL13~0      |        |
| +\$03<br>~~+\$04 | 予約        |            |         |          |       |        |       |           |             |        |
| +\$04            | INTCTRL0  | 7~0        | INTMO   | DE31,0   | INTMC | DE21,0 | INTMO | DE11,0    | INTMO       | DE01,0 |
| +\$06            | 予約        |            |         |          |       |        |       |           |             |        |
| +\$07            | INTFLAGS  | 7~0        |         |          |       |        | INT3  | INT2      | INT1        | INT0   |
| +\$08            | LUT0CTRLA | 7~0        | EDGEDET | OUTEN    | FILTS | EL1,0  |       | CLKSRC2~0 | )           | ENABLE |
| +\$09            | LUT0CTRLB | $7 \sim 0$ |         | INSEL    | _13~0 | 1      |       | INSEI     | _03~0       |        |
| +\$0A            | LUT0CTRLC | 7~0        |         |          |       |        |       | INSEI     | 23~0        |        |
| +\$0B            | TRUTH0    | 7~0        |         |          |       | TRUT   | H07~0 | ı<br>1    | ı<br>I      |        |
| +\$0C            | LUT1CTRLA | 7~0        | EDGEDET | OUTEN    | FILTS | EL1,0  |       | CLKSRC2~0 | )           | ENABLE |
| +\$0D            | LUT1CTRLB | 7~0        |         | INSEI    | 13~0  |        |       | INSEI     | _03~0       |        |
| +\$0E            | LUT1CTRLC | 7~0        |         |          |       |        |       | INSEI     | 23~0        |        |
| +\$0F            | TRUTH1    | 7~0        |         |          |       | TRUT   | H17~0 | +         |             |        |
| +\$10            | LUT2CTRLA | 7~0        | EDGEDET | OUTEN    | FILTS | EL1,0  |       | CLKSRC2~0 | )           | ENABLE |
| +\$11            | LUT2CTRLB | 7~0        |         | INSEI    | _13~0 |        |       | INSEI     | 03~0        |        |
| +\$12            | LUT2CTRLC | 7~0        |         |          |       | 1      |       | INSEI     | 23~0        |        |
| +\$13            | TRUTH2    | 7~0        |         |          |       | TRUT   | H27~0 | +         |             |        |
| +\$14            | LUT3CTRLA | $7 \sim 0$ | EDGEDET | OUTEN    | FILTS | EL1,0  |       | CLKSRC2~0 | )           | ENABLE |
|                  | LUT3CTRLB | 7~0        |         | INSEI    | _13~0 |        |       | INSEI     | _03~0       |        |
| +\$16            | LUT3CTRLC | 7~0        |         |          |       |        |       | INSEI     | 23~0        |        |
| +\$17            | TRUTH3    | $7 \sim 0$ |         |          |       | TRUT   | H37~0 |           |             |        |

## 29.5. レジスタ説明

## **29.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)

このビットに'1'を書くことがこの周辺機能にスタンバイ休止動作での走行を許可します。

| 値  | 0                    | 1                   |
|----|----------------------|---------------------|
| 説明 | CCLはスタンバイ休止動作で動きません。 | CCLはスタンバイ休止動作で動きます。 |

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

| 值  | 0      | 1      |
|----|--------|--------|
| 説明 | 周辺機能禁止 | 周辺機能許可 |

#### 29.5.2. SEQCTRLn - 逐次制御器制御n (Sequencer Control n)

名称 : SEQCTRL0 : SEQCTRL1 変位 : +\$01 : +\$02 リセット : \$00

#### 特質:許可保護

| Ľ'ット   | 7   | 6   | 5   | 4   | 3   | 2          | 1   | 0   |
|--------|-----|-----|-----|-----|-----|------------|-----|-----|
|        |     |     |     |     |     | SEQSELn3~0 |     |     |
|        |     |     |     |     |     |            |     |     |
| アクセス種別 | R/W | R/W | R/W | R/W | R/W | R/W        | R/W | R/W |

#### ● ビット7~4,3~0 - SEQSELn3~0: 逐次制御器選択(Sequencer Selection)

このビット群はLUT2nとLUT2n+1(SEQCTRL0がLUT0/1、SEQCTRL1がLUT2/3)に対する逐次制御器構成を選びます。

| 値  | 0 0 0   | 001         | 010          | 011    | 100   | 101 | 110  | 111 |
|----|---------|-------------|--------------|--------|-------|-----|------|-----|
| 名称 | DISABLE | DFF         | JK           | DLATCH | RS    |     | -    |     |
| 説明 | 逐次制御器禁止 | Dフリッフ°フロッフ° | JKフリッフ°フロッフ° | Dラッチ   | RSラッチ |     | (予約) |     |

## 29.5.3. INTCTRL0 - 割り込み制御0 (Interrupt Control 0)

名称: INTCTRL0

**変位** : +\$05

リセット : \$00

特質 :-

| ビット    | 7     | 6      | 5     | 4      | 3     | 2      | 1     | 0      |
|--------|-------|--------|-------|--------|-------|--------|-------|--------|
|        | INTMO | DE31,0 | INTMC | DE21,0 | INTMO | DE11,0 | INTMC | DE01,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,6、5,4、3,2、1,0 - INTMODEn1,0 : 割り込み動作形態 (Interrupt Mode)

INTMODEnのビットはLUTn-OUTに対する割り込み感知構成設定を選びます。次頁の表参照。

(訳注) 原書での29.5.2. SEQCTRL0と29.5.3. SEQCTRL1は29.5.2. SEQCTRLnとして纏めました。

# AVR64EA28/32/48

| 値  | 0 0        | 01     | 1 0     | 11   |  |
|----|------------|--------|---------|------|--|
| 名称 | INTDISABLE | RISING | FALLING | BOTH |  |
| 説明 | 割り込み禁止     | 上昇端感知  | 下降端感知   | 両端感知 |  |

## 29.5.4. INTFLAGS - 割り込み要求7ラク (Interrupt Flags)

名称: INTFLAGS

**変位**:+\$07

リセット : \$00

特質 :-

| ビット    | 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|--------|---|---|---|---|------|------|------|------|
|        |   |   |   |   | INT3 | INT2 | INT1 | INT0 |
| アクセス種別 | R | R | R | R | R/W  | R/W  | R/W  | R/W  |
| リセット値  | 0 | 0 | 0 | 0 | 0    | 0    | 0    | 0    |

#### • ビット3,2,1,0 - INTn : 割り込みn要求フラク (Interrupt Flag)

INTn7ラケはLUTnの出力が割り込み制御n(CCL.INTCTRL0)レジスタで定義されるような割り込み感知動作形態と一致する時に設定(1)されます。このフラケのビット位置への'1'書き込みがこのフラケを解除(0)します。

#### 29.5.5. LUTnCTRLA - LUTn制御A (LUT n Control A)

名称:LUT0CTRLA:LUT1CTRLA:LUT2CTRLA:LUT3CTRLA 変位:+\$08:+\$0C:+\$10:+\$14 リセット:\$00

#### 特質:許可保護

| ビット    | 7       | 6     | 5     | 4     | 3   | 2         | 1   | 0      |
|--------|---------|-------|-------|-------|-----|-----------|-----|--------|
|        | EDGEDET | OUTEN | FILTS | EL1,0 |     | CLKSRC2~0 |     | ENABLE |
| アクセス種別 | 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 - EDGEDET : 端検出 (Edge Detection)

| 值  | 0      | 1      |
|----|--------|--------|
| 説明 | 端検出器禁止 | 端検出器許可 |

### ● ビット6 - OUTEN : 出力許可 (Output Enable)

このビットはLUTnOUTピンへのLUT出力を許可します。'1'を書かれると、ポート制御器のピン構成設定が無効にされます。

| 値  | 0        | 1        |
|----|----------|----------|
| 説明 | ピンへの出力禁止 | ピンへの出力許可 |

#### ● ビット5,4 - FILTSEL1,0 : 濾波器選択 (Filter Selection)

これらのビットはLUT出力濾波器任意選択を選びます。

| 值  | 0 0     | 01     | 10     | 11   |
|----|---------|--------|--------|------|
| 名称 | DISABLE | SYNCH  | FILTER | -    |
| 説明 | 濾波器禁止   | 同期化器許可 | 濾波器許可  | (予約) |

#### ビット3~1 - CLKSRC2~0: クロック元選択 (Clock Source Selection)

これらのビットはLUT用のクロック(CLK\_LUTn)として使われる様々なクロック元を選びます。

偶数LUTのCLK\_LUTnはLUT対の逐次制御器をクロック駆動するのに使われます。

| 値                 | 0 0 0                 | 001                          | 100                     | 101                            | 110                             | その他  |
|-------------------|-----------------------|------------------------------|-------------------------|--------------------------------|---------------------------------|------|
| 入力元               | CLKPER                | IN2                          | OSCHF                   | OSC32K                         | OSC1K                           | -    |
| 説明<br>(LUT駆動クロック) | CLK_PER<br>(周辺機能クロック) | LUTn-TRUTHSEL[2]<br>(UTn入力2) | 前置分周前の<br>内部高周波数<br>発振器 | 内部32.768kHz<br>発振器<br>(OSC32K) | OSC32Kの<br>DIV32後<br>(1.024kHz) | (予約) |

• ビット0 - ENABLE : LUT許可 (LUT Enable)

| 値  | 0     | 1     |
|----|-------|-------|
| 説明 | LUT禁止 | LUT許可 |

## 29.5.6. LUTnCTRLB - LUTn制御B (LUT n Control B)

名称 : LUT0CTRLB : LUT1CTRLB : LUT2CTRLB : LUT3CTRLB

**変位**:+\$09 :+\$0D :+\$11 :+\$15

リセット : \$00

#### 特質:許可保護

注:・CCLへのSPI接続は主装置SPI動作でだけ動きます。

- ・CCLへのUSART接続は以下の動作の1つの時にだけ動きます。
  - 非同期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 (\$0) | MASK     | なし(入力遮蔽)     | 0111 (\$7) | USART1 | USART1のTXD |
| 0001 (\$1) | FEEDBACK | LUTn出力(帰還入力) | 1000 (\$8) | SPI0   | SPI0のMOSI  |
| 0010 (\$2) | LINK     | LUTn+1出力(連結) | 1001 (\$9) | TCA0   | TCA0のWO1   |
| 0011 (\$3) | EVENTA   | 入力元として事象A    | 1010 (\$A) | TCA1   | TCA1のWO1   |
| 0100 (\$4) | EVENTB   | 入力元として事象B    | 1011 (\$B) | TCB1   | TCB1のWO    |
| 0101 (\$5) | IN1      | LUTn-IN1     | その他        | _      | (予約)       |
| 0110 (\$6) | AC1      | AC1のOUT      |            |        |            |

## ● ビット3~0 - INSEL03~0: LUTn入力0供給元選択 (LUT n Input 0 Selection)

これらのビットはLUTnの入力0(IN0)に対する供給元を選びます。

| 値          | 名称       | 説明           | 値          | 名称     | 説明         |
|------------|----------|--------------|------------|--------|------------|
| 0000 (\$0) | MASK     | なし(入力遮蔽)     | 0111 (\$7) | USART0 | USART0のTXD |
| 0001 (\$1) | FEEDBACK | LUTn出力(帰還入力) | 1000 (\$8) | SPI0   | SPI0のMOSI  |
| 0010 (\$2) | LINK     | LUTn+1出力(連結) | 1001 (\$9) | TCA0   | TCA0のWO0   |
| 0011 (\$3) | EVENTA   | 入力元として事象A    | 1010 (\$A) | TCA1   | TCA1のWO0   |
| 0100 (\$4) | EVENTB   | 入力元として事象B    | 1011 (\$B) | TCB0   | TCB0のWO    |
| 0101 (\$5) | IN0      | LUTn-IN0     | その他        | -      | (予約)       |
| 0110 (\$6) | AC0      | ACOのOUT      |            |        |            |

## 29.5.7. LUTnCTRLC - LUTn制御C (LUT n Control C)

名称 : LUT0CTRLC : LUT1CTRLC : LUT2CTRLC : LUT3CTRLC

- **変位**:+\$0A :+\$0E :+\$12 :+\$16
- リセット : \$00

#### 特質:許可保護

**注**:・CCLへのSPI接続は主装置SPI動作でだけ動きます。

- ・CCLへのUSART接続は以下の動作の1つの時にだけ動きます。
  - 非同期USART
  - 同期USART主装置

| ビット    | 7 | 6 | 5 | 4 | 3   | 2     | 1     | 0   |
|--------|---|---|---|---|-----|-------|-------|-----|
|        |   |   |   |   |     | INSEI | _23~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 (\$0) | MASK     | なし(入力遮蔽)     | 0111 (\$7) | USART2 | USART2のTXD |
| 0001 (\$1) | FEEDBACK | LUTn出力(帰還入力) | 1000 (\$8) | SPI0   | SPI0のSCK   |
| 0010 (\$2) | LINK     | LUTn+1出力(連結) | 1001 (\$9) | TCA0   | TCA0のWO2   |
| 0011 (\$3) | EVENTA   | 入力元として事象A    | 1010 (\$A) | TCA1   | TCA1のWO2   |
| 0100 (\$4) | EVENTB   | 入力元として事象B    | 1011 (\$B) | TCB2   | TCB2のWO    |
| 0101 (\$5) | IN2      | LUTn-IN2     | その他        | -      | (予約)       |
| 0110 (\$6) | _        | (予約)         |            |        |            |

## 29.5.8. TRUTHn - 真理值表n (TRUTHn)

| 名称:TRUTH0        | : TRUTH1 | : TRUTH2 | : TRUTH3 |
|------------------|----------|----------|----------|
| <b>変位</b> :+\$0B | :+\$0F   | : +\$13  | : +\$17  |
| リセット : \$00      |          |          |          |

#### 特質:許可保護

| ビット    | 7         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |
|--------|-----------|-----|-----|-----|-----|-----|-----|-----|--|--|--|
|        | TRUTHn7~0 |     |     |     |     |     |     |     |  |  |  |
|        |           |     |     |     |     |     |     |     |  |  |  |
| アクセス種別 | R/W       | R/W | R/W | R/W | R/W | R/W | R/W | R/W |  |  |  |

## ● ビット7~0 - TRUTHn7~0 : 真理値表 (Truth n Table)

これらのビットはLUTn-TRUTHSEL2~0入力に従ってLUTnの出力を決めます。

| <mark>ビット名</mark>     | TRU | THn7 | TRƯ | THn6 | TRU | THn5 | TRU | THn4 | TRƯ | THn3 | TRU | THn2 | TRU | THn1 | TRƯ | THn0 |
|-----------------------|-----|------|-----|------|-----|------|-----|------|-----|------|-----|------|-----|------|-----|------|
| 値                     | 0   | 1    | 0   | 1    | 0   | 1    | 0   | 1    | 0   | 1    | 0   | 1    | 0   | 1    | 0   | 1    |
| 説明 ( <mark>注</mark> ) | 1   | 11   | 1 1 | 10   | 1 ( | 01   | 1 ( | 0 0  | 0 ] | 11   | 0   | 10   | 0 ( | 01   | 0 ( | 0 0  |

注:入力が説明行の値の時にLUTnの出力が設定した値(値行の値(0または1))になります。

(訳注) 29.5.7.(原書では29.5.8.)の表でINSEL2の\$6が「-」ですが、29.2.2.1.の表では「AC1のOUT」で矛盾しています。どちらかが誤っていると思われますが、どちらかは不明です。

## 30. AC - アナログ比較器

## 30.1. 特徴

- ・選択可能な応答時間
- ・選択可能なヒステリシス
- ・ピンで利用可能なアナログ比較器出力
- ・比較器出力反転利用可能
- ・柔軟な入力選択
  - 5つの正入力ピン
  - 4つの負入力ピン
  - 内部基準電圧生成部(DACREF)
- ・以下での割り込み生成
  - 上昇端
  - 下降端
  - 両端
- ・以下での窓機能割り込み生成
  - 窓を超える信号
  - 窓内の信号
  - 窓未満の信号
  - 窓外の信号
- ・事象生成
  - 比較器出力
  - 窓機能

## 30.2. 概要

アナログ比較器(AC)は2つの入力の電圧水準を比較してその比較に基いたデジタル出力を与えます。ACは様々な異なる入力変化の組み合わせに基づいて割り込み要求や事象を生成するように構成設定することができます。

入力選択はアナログポートピンと内部的に生成された入力を含みます。ACデジタル出力は制御部論理回路を通って行き、事象システムと で内部的に、またはピンで外部的に使うために信号の独自化を許します。

ACの動的な動きはヒステリシス機能によって調節することができます。ヒステリシスは各応用に対する動作を最適化するために独自設定す ることができます。

個別の比較器は独立して(標準動作)または窓比較形式のために対にして(窓動作)使うことができます。

## 30.2.1. 構成図



## 30.2.2. 信号説明

| 信号    | 形式     | 説明       |
|-------|--------|----------|
| AINNn | アナログ入力 | 負入力n     |
| AINPn | アナログ入力 | 正入力n     |
| OUT   | デジタル出力 | ACの比較器出力 |

## 30.3. 機能的な説明

## 30.3.1. 初期化

基本的な操作については以下のこれらの手順に従ってください。

- 1. PORT周辺機能で望む入力ピンをアナログ入力として構成設定してください。
- **2.** 多重器制御(ACn.MUXCTRL)レジスタで正と負の入力多重器選択(MUXPOSとMUXNEG)ビット領域を書くことによって正と負の入力元を選んでください。

3. 任意選択: 制御A(ACn.CTRLA)レジスタの出力パット 許可(OUTEN)ビットに'1'を書くことによって出力を許可してください。

4. ACn.CTRLAレジスタのAC許可(ENABLE)ビットに'1'を書くことによってACを許可してください。

AC許可後の始動時間の間、ACの準備が整う前にAC出力を設定するのにACn.MUXCTRLレジスタのAC出力初期値(INITVAL)ビット を使うことができます。VREFが参照基準元として使われる場合、各々の参照基準元の始動時間が加算されなければなりません。AC とVREFの周辺機能の始動時間についての詳細に関しては「電気的特性」章を参照してください。

ACが禁止される時にピンがHi-Zにされて行くのを避けるため、OUTピンは出力として構成設定されなければなりません。

#### 30.3.2. 動作

#### 30.3.2.1. 入力ヒステリシス

入力ヒステリシスの適用は雑音に悩んでいる入力信号がお互いに近い時に出力の定常的な切り替わりを防ぐのを助けます。

入力ヒステリシスは禁止されるか、または3つのレヘルの1つを持つかのどれかにすることができます。ヒステリシスは制御A(ACn.CTRLA)レジス タのヒステリシス動作選択(HYSMODE)ビット領域に書くことによって構成設定することができます。ヒステリシス基準の代表値についての詳細 に関しては「電気的特性」章を参照してください。

### 30.3.2.2. 入力と参照基準の選択

ACnに対する入力選択は多重器制御(ACn.MUXCTRL)レジスタで正と負の入力多重器選択(MUXPOSとMUXNEG)ビット領域によって 制御されます。ACnの正入力についてアナログピンを選ぶことができる一方で、負入力についてはアナログピンと内部DAC参照基準電圧 (DACREF)で選択を行うことができます。可能な選択についての詳細に関しては多重器制御(ACn.MUXCTRL)レジスタ記述を参照して ください。

生成される電圧はDAC基準電圧(DACREF)レジスタ値とVREF単位部で選ばれる基準電圧に依存し、次のように計算されます。

 $VDACREF = \frac{DACREF}{256} \times VREF$ 

VREFAとVDDを除く内部基準電圧(VREF)は内部ハントギャップ参照基準から生成されます。

入出力ピンへの入力切替または新しい基準電圧設定後、ACnは安定のための時間を必要とします。より多くの詳細については「電気的特性」章を参照してください。

#### 30.3.2.3. 標準動作

ACは1つの正入力と1つの負入力を持ちます。比較器の出力は正と負の入力電圧間の差が正の時に'1'、さもなければ'0'です。この出力は論理XORを通して出力(OUT)とシで利用可能です。これは多重器制御(ACn.MUXCTRL)レジスタのAC出力反転(INVERT) ビットが'1'の時にOUTピンの反転を許します。

ACn初期化中の乱雑な出力を避けてOUTピンで特定基準を設定するのに同じレジスタのAC出力初期値(INITVAL)ビットが使われます。

## 30.3.2.4. 電力動作

電力を気にする応用に対して、ACは消費電力と応答時間の釣り合いを持つ複数の電力動作を提供します。動作形態は制御A(AC n.CTRLA)レジスタの電力特性(POWER)ビット領域に書くことによって選ばれます。

#### 30.3.2.5. 窓動作

各AC(即ち、ACn)は窓動作で別の比較器(即ち、ACm)と共に動くように構成設定することができます。この動作では電圧範囲(窓)が 定義され、選んだ比較器はこの範囲内か否かを示します。

制御B(ACn.CTRLB)レジスタの窓選択形態(WINSEL) ビット領域は窓比較器を作成するためにどのACm実 体が現在の比較器(ACn)に接続されるかを選びま す。使用者はACnとACmに対して多重器制御(MUX CTRL)レジスタの正入力多重器選択(MUXPOS)と負 入力多重器選択(MUXNEG)のビット領域を構成設定 する責任があり、故にそれらは右図での設定に一致 します。両ACのMUXCTRLレジスタのMUXPOSビット 領域が同じピンに構成設定されなければならないこ とに注意してください。



入力信号の状態は状態(ACn.STATUS)レシズタの窓状態(WINSTATE)フラグによって報告されます。この状態は以下が有り得ます。

- ・窓越え 入力信号は上限超えです。
- ・窓内側 入力信号は上限と下限の間です。
- ・窓未満 入力信号は下限未満です。

割り込み制御(ACn.INTCTRL)レジスタの割り込み動作(INTMODE)ビット領域は事象の起動または割り込みの要求に対してこれらの窓動作の1つを選びます。

- ・窓越え 入力信号は上限超えの時に割り込み/事象が発行されます。
- ・窓内側 入力信号は上限と下限の間の時に割り込み/事象が発行されます。
- ・窓未満 入力信号は下限未満の時に割り込み/事象が発行されます。
- ・窓外側 入力信号は上限と下限の間でない時に割り込み/事象が発行されます。

アナログ比較器状態(CMPSTATE)ビットは窓状態が選んだ割り込み動作(INTMODE)ビット領域と一致する時に'1'です。

窓割り込みは割り込み制御(ACn.INTCTRL)レジスタのアナログ比較器割り込み許可(CMP)ビットに'1'を書くことによって許可されます。

#### 30.3.3. 事象

ACは以下の事象を生成することができます。

## <u>表30-1.ACでの事象生成部</u>

| 生    | 成部名 | 説明       | 事象型  | 生成クロック領域 | 事象長                                    |  |  |
|------|-----|----------|------|----------|----------------------------------------|--|--|
| 周辺機能 | 事象  | 市の方      | 争豕空  | 主成フロッフ隕攻 | <b>●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●</b> |  |  |
| ACn  | OUT | 比較器出力レベル | レヘッル | 非同期      | AC出力レベルで与えられる                          |  |  |

ACは事象入力を持ちません。

事象型と事象システム構成設定に関するより多くの詳細については「EVSYS - 事象システム」章を参照してください。

#### 30.3.4. 割り込み

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

| 名称  | ベクタ説明       | 条件                                                                 |
|-----|-------------|--------------------------------------------------------------------|
| СМР | アナログ比較器割り込み | AC出力は割り込み制御(ACn.INTCTRL)レジスタの割り込み動作(INTMODE)によって構成設定されるように切り替わります。 |

割り込み条件が起こると、状態(ACn.STATUS)レジスタで対応する割り込み要求フラグが設定(1)されます。

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

ACは比較器割り込み(CMP)を生成することができ、比較器出力切り替わりの上昇端、下降端、両端のどれかでこの割り込みを要求 することができます。これは割り込み制御(ACn.INTCTRL)レジスタの割り込み動作(INTMODE)ビット領域に書くことによって構成設定さ れます。この割り込みは割り込み制御(ACn.INTCTRL)レジスタのアナログ比較器割り込み許可(CMP)ビットに'1'を書くことによって許可さ れます。割り込み要求は割り込み要求フラグ(CMPIF)が解除(0)されるまで活性(1)に留まります。割り込み要求フラグを解除する方法の 詳細については状態(ACn.STATUS)レジスタ記述を参照してください。

## 30.3.5. 休止形態動作

アイドル休止動作でACは通常のように動作を続けます。

スタンハイ休止動作では、既定でACが禁止されます。制御A(ACn.CTRLA)レジスタのスタンハイ休止動作時走行(RUNSTDBY)ビットが'1' を書かれる場合、例えスタンハイ休止動作でCLK\_PERが動いていなくても、ACは事象、割り込み、それとピンでのAC出力で通常のよう に動作を続けます。

パワーダウン休止動作ではACとそのパット、への出力が禁止されます。

## 30.4. レジスタ要約

| 変位             | 略称      | ビット位置      | ビット7     | ビット6    | ビット5  | ビット4      | ビット3  | ビット2  | ビット1     | ビットロ   |
|----------------|---------|------------|----------|---------|-------|-----------|-------|-------|----------|--------|
| +\$00          | CTRLA   | 7~0        | RUNSTDBY | OUTEN   |       | POW       | ER1,0 | HYSMO | ODE1,0   | ENABLE |
| +\$01          | CTRLB   | 7~0        |          |         |       |           |       |       | WINS     | EL1,0  |
| +\$02          | MUXCTRL | 7~0        | INVERT   | INITVAL | ١     | MUXPOS2~( | )     | Ν     | MUXNEG2~ | )      |
| +\$03          | 予約      |            |          |         |       |           |       |       |          |        |
| +\$04<br>+\$05 | DACREF  | 7~0        |          |         |       | DACD      | EF7~0 |       |          |        |
|                |         |            |          |         |       |           |       | 1     |          |        |
| +\$06          | INTCTRL | $7 \sim 0$ |          |         | INTMC | )DE1,0    |       |       |          | CMP    |
| +\$07          | STATUS  | 7~0        | WINST    | ATE1,0  |       | CMPSTATE  |       |       |          | CMPIF  |

## 30.5. レシ スタ説明

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

## 名称:CTRLA

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

特質:-

| ビット    | 7        | 6     | 5 | 4   | 3     | 2     | 1      | 0      |
|--------|----------|-------|---|-----|-------|-------|--------|--------|
|        | RUNSTDBY | OUTEN |   | POW | ER1,0 | HYSMO | DDE1,0 | ENABLE |
| アクセス種別 | R/W      | R/W   | R | 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 : 出力パット許可 (Output Pad Enable)

このビットに'1'を書くことがOUT信号をピンで利用可能にします。

## ビット4,3 - POWER1,0: 電力特性 (Power Profile)

この設定は比較器を通る電流を制御し、ACに応答時間と消費電力の交換を許します。消費電力と応答時間については「電気的特性」章を参照してください。

| 值  | 0 0                | 01       | 10   | 11   |
|----|--------------------|----------|------|------|
| 名称 | PROFILE0           | PROFILE1 | _    | -    |
| 説明 | 電力特性0(最短伝搬遅延と最高消費) | 電力特性1    | (予約) | (予約) |

## • ビット2,1 - HYSMODE1,0 : ヒステリシス動作選択 (Hysteresys Mode Select)

このビット領域への書き込みはAC入力に対してヒステリシスを選びます。ヒステリシス基準の代表値についての詳細に関しては「電気的特性」章を参照してください。

| 值  | 0 0      | 0 1     | 10      | 11      |  |
|----|----------|---------|---------|---------|--|
| 名称 | NONE     | SMALL   | MEDIUM  | LARGE   |  |
| 説明 | ヒステリシスなし | ヒステリシス小 | ヒステリシス中 | ヒステリシス大 |  |

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

このビットに'1'を書くことがACを許可します。

## 30.5.2. CTRLB - 制御B (Control B)

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

特質 :-

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

## ● ビット1,0 - WINSEL1,0 : 窓選択動作 (Window Selection Mode)

このビット領域は窓動作で現在の比較器に接続されるACを選びます。

| 値  | 0 0      | 01            | 10   | 11   |
|----|----------|---------------|------|------|
| 名称 | DISABLED | UPSEL1        | -    | -    |
| 説明 | 窓機能禁止    | ACn+1接続で窓機能許可 | (予約) | (予約) |

# 30.5.3. MUXCTRL - 多重器制御 (Mux Control)

| 名称 | : MUXCTRL |
|----|-----------|
| 変位 | : +\$02   |
|    |           |

**リセット** : \$00

特質 :-

| ビット    | 7      | 6       | 5   | 4         | 3   | 2   | 1         | 0   |
|--------|--------|---------|-----|-----------|-----|-----|-----------|-----|
|        | INVERT | INITVAL |     | MUXPOS2~0 |     |     | MUXNEG2~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 - INVERT : AC出力反転 (Invert AC Output)

このビットに'1'を書くことがACの出力の反転を許可します。この反転は他の周辺機能またはシステムの一部に入力信号としてAC出力 信号を使う時に考慮されなければなりません。

# • ビット6 - INITVAL : AC出力初期値 (AC Output Initial Value)

比較器の準備が整う前にAC出力が切り替わるのを避けるため、INITVALは比較器出力の初期状態を設定するのに使うことができます。

| ſī | 直 | 0            | 1            |
|----|---|--------------|--------------|
| 名  | 称 | LOW          | HIGH         |
| 説  | 明 | '0'に初期化された出力 | '1'に初期化された出力 |

# ● ビット5~3 - MUXPOS2~0:正入力多重器選択 (Positive Input Mux Selection)

このビット領域への書き込みがACの正入力への入力信号を選びます。

| 値  | 000    | 001    | 010    | 011    | 100    | その他  |
|----|--------|--------|--------|--------|--------|------|
| 名称 | AINP0  | AINP1  | AINP2  | AINP3  | AINP4  | -    |
| 説明 | 正入力ピン0 | 正入力ピン1 | 正入力ピン2 | 正入力ピン3 | 正入力ピン4 | (予約) |

# ● ビット2~0 - MUXNEG2~0:正入力多重器選択 (Negative Input Mux Selection)

このビット領域への書き込みがACの負入力への入力信号を選びます。

| 値  | 0 0 0  | 001    | 010    | 011    | 100       | その他  |
|----|--------|--------|--------|--------|-----------|------|
| 名称 | AINN0  | AINN1  | AINN2  | AINN3  | DACREF    | -    |
| 説明 | 負入力ピン0 | 負入力ピン1 | 負入力ピン2 | 負入力ピン3 | DAC参照基準電圧 | (予約) |

# 30.5.4. DACREF - DAC基準電圧 (DAC Voltage Reference)

名称: DACREF

**変位** : +\$05

**リセット** : \$FF

特質 :-

| ビット    | 7   | 6   | 5   | 4    | 3     | 2   | 1   | 0   |
|--------|-----|-----|-----|------|-------|-----|-----|-----|
|        |     |     |     | DACR | EF7~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 - DACREF7~0: DACREFデータ値 (DACREF Data Value)

このビット領域は内部分圧器からの出力電圧を定義します。DAC基準電圧はDACREF値とVREF単位部で選ばれた基準電圧に依存し、次のように計算されます。

 $V_{DACREF} = \frac{DACREF}{256} \times V_{REF}$ 

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

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

| ビット    | 7 | 6 | 5     | 4      | 3 | 2 | 1 | 0   |
|--------|---|---|-------|--------|---|---|---|-----|
|        |   |   | INTMO | DDE1,0 |   |   |   | CMP |
| アクセス種別 | R | R | R/W   | R/W    | R | R | R | R/W |
| リセット値  | 0 | 0 | 0     | 0      | 0 | 0 | 0 | 0   |

# • ビット5,4 - INTMODE1,0 : 割り込み動作 (Interrupt Modes)

このビット領域への書き込みはAC出力のどの端か、または窓状態移行が割り込み要求を起動する時を選びます。

#### 表30-3. 窓動作での割り込み生成

| 值  | 0 0         | 01          | 10          | 11          |
|----|-------------|-------------|-------------|-------------|
| 名称 | ABOVE       | INSIDE      | BELOW       | OUTSIDE     |
| 説明 | 越え窓動作割り込み許可 | 内側窓動作割り込み許可 | 未満窓動作割り込み許可 | 外側窓動作割り込み許可 |

#### 表30-4. 単独比較器での割り込み生成

|   | 値  | 0 0      | 01   | 10         | 11         |
|---|----|----------|------|------------|------------|
| Γ | 名称 | BOTHEDGE | -    | NEGEDGE    | POSEDGE    |
|   | 説明 | 正と負の入力交差 | (予約) | 正入力が負入力未満へ | 正入力が負入力越えへ |

# • ビット0 - CMP : AC割り込み許可 (AC Interrupt Enable)

このビット(='1')はAC割り込みを許可します。許可された割り込みは状態(ACn.STATUS)レジスタのAC割り込み要求フラグ(CMPIF)ビット が設定(1)される時に起動されます。

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

名称 : STATUS

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

# 特質 :-

| ヒット    | 7     | 6      | 5 | 4        | 3 | 2 | 1 | 0     |
|--------|-------|--------|---|----------|---|---|---|-------|
|        | WINST | ATE1,0 |   | CMPSTATE |   |   |   | CMPIF |
| アクセス種別 | R     | R      | R | R        | R | R | R | R/W   |
| リセット値  | 0     | 0      | 0 | 0        | 0 | 0 | 0 | 0     |

# ● ビット7,6 - WINSTATE1,0 : 窓状態 (Window State)

窓機能が許可されると、これらの7ラグは窓に対する現在の入力信号の状態を示します。 窓動作が禁止される時は無効です。

#### 表30-5. 窓状態設定

| 100 0. 心心心的 |       |        |       |      |
|-------------|-------|--------|-------|------|
| 値           | 0 0   | 01     | 10    | 11   |
| 名称          | AVOBE | INSIDE | BELOW | -    |
| 説明          | 窓越え   | 窓内     | 窓未満   | (予約) |

# ● ビット4 - CMPSTATE : AC状態 (AC State)

このビットが'1'の場合、OUT信号はHighです。このビットが'0'の場合、OUT信号はLowです。窓動作では、このビットが'1'の場合、窓 状態は選んだ割り込み動作(INTMODE)ビット領域と一致します。INTMODEが'OUTSIDE(外側)'の場合、'ABOVE(越え)'と'BELO W(未満)'の両方が有効な一致です。I/Oレジスタで更新されるのに(3周期の)同期化遅延を持ちます。

# • ビット0 - CMPIF : AC割り込み要求フラグ (AC Interrupt Flag)

このビットはOUT信号が割り込み制御(ACn.INTCTRL)レジスタの割り込み動作(INTMODE)ビット領域での定義と一致する時に'1'です。このフラグビット位置への'1'書き込みがこのフラグを解除(0)します。

# 31. ADC - A/D変換器

# 31.1. 特徴

- ・12ビット分解能
- 過採取で最大17ビット
- ・12ビット分解能で最大375kspsの変換速度
- ・20/24/28個までの入力
- ・差動とシングルエントの変換
- ・1倍~16倍の設定可能な利得増幅器(PGA: Programmable Gain Amplifier)
- ・-1100mV~VDD+100mVの入力電圧範囲
- ・複数の内部ADC参照基準電圧
  - VDD
  - 1.024V
  - 2.048V
  - 2.500V
  - **-** 4.096V
- 外部参照基準入力
- ・単独と自由走行の変換
- ・継続と集中の累積動作
- ・1024変換までの累積
- ・左または右に揃えられた結果
- ・変換完了での割り込み
- 任意選択の事象起動変換
- ・構成設定可能な窓比較器

# 31.2. 概要

A/D変換器(ADC)は12ビット分解能で最大375kspsの変換速度で設定可能な利得増幅器(PGA)を持つ12ビットの差動とシングルエント、の ADCです。ADCは多数のシングルエントと差動の入力間の選択用アナログ入力多重器に接続されます。シングルエント、変換ではADCが選 んだ入力と0V(GND)間の電圧を測定します。差動変換ではADCが選んだ2つの入力間の電圧を測定します。ADC入力は内部(例え ば、基準電圧)または外部アナログ入力ピンのどれかにすることができます。

ADC変換はソフトウェアによって、または他の周辺機能から事象を配線するのに事象システム(EVSYS)を使うことによって開始することができ、入力信号の周期的な採取、特別な条件でのADC変換の起動、スタンハイ休止動作でのADC変換の起動も可能にします。デジタル窓比較機能は入力信号を監視するのに利用可能で、必要とされる最小のソフトウェア介在で、採取が使用者定義された閾値未満または越え、または使用者定義された窓の内側または外側の場合にだけ割り込みを起動するように構成設定することができます。

ADC入力信号は変換中にADCへの入力電圧が一定水準で保たれることを保証する採取/保持(S/H)回路を通して供給されます。

ADCは構成設定可能な変換結果数が単一ADC結果内に累積される集中での採取(採取累積)を支援します。

ADC電圧参照基準は内部または外部アナログ参照基準(VREFA)ピンからの供給のどちらにすることができます。

# 31.2.1. 構成図



#### 31.2.2. 信号説明

| 信号     | 形式     | 説明         |
|--------|--------|------------|
| AINn~0 | アナログ入力 | アナログ入力ピン   |
| VREFA  | アナログ入力 | 外部参照基準電圧ピン |

# 31.3. 機能的な説明

#### 31.3.1. 定義

- ・変換: 選んだADC入力上のアナロク値がデジタル表現に変換される動作
- ・採取(試料):採取(ADCn.SAMPLE)レジスタに置かれた値、即ち、変換動作の結果(訳補:一部で採取/保持(S/H)部の採取部分)
- ・結果:結果(ADCn.RES)レジスタに置かれた値。ADC構成設定に応じてこの値は単一採取または複数累積した採取の合計です。

#### 31.3.2. 基本操作

基本動作でADC初期化して動かすには以下の手順が推奨されます。

- 1. クロック制御器の時間基準(CLKCTRL.MCLKTIMEBASE)レジスタの時間基準(TIMEBASE)ビット領域に書くことによって時間基準を 構成設定してください。
- 2. 制御A(ADCn.CTRLA)レジスタのADC許可(ENABLE)ビットに'1'を書くことによってADCを許可してください。
- 3. 制御B(ADCn.CTRLB)レジスタの前置分周器(PRESC)ビット領域を構成設定してください。
- 4. 制御C(ADCn.CTRLC)レジスタの参照基準選択(REFSEL)ビット領域を構成設定してください。
- 5. 制御E(ADCn.CTRLE)レシブスタの採取持続時間(SAMPDUR)ビット領域を構成設定してください。
- 6. 任意選択: 制御F(ADCn.CTRLF)レジスタの採取累積数選択(SAMPNUM)ビット領域を書くことによって累積される採取数を構成設 定してください。
- 7.任意選択:制御Fレジスタの自由走行(FREERUN)ビットに'1'を書くことによって自由走行動作を許可してください。
- 8. 正入力多重器(ADCn.MUXPOS)レジスタの正入力多重器(MUXPOS)ビット領域に書くことによって正入力を構成設定してください。
- 9. 任意選択: 負入力多重器(ADCn.MUXNEG)レジスタの負入力多重器(MUXNEG)ビット領域に書くことによって負入力を構成設定してください。
- 10. 任意選択:指令(ADCn.COMMAND)レジスタの差動(DIFF)ビットに'1'を書くことによって差動ADC変換を選んでください。
- 11. 指令レジスタの動作形態(MODE)ビット領域に書くことによってADCに対する動作形態を構成設定してください。
- 12. 指令レジスタの変換開始(START)ビット領域を書くことによってADC変換がどう始まるかを構成設定してください。IMMEDIATE指令が書かれた場合、直ちに変換が開始します。
- 13. 更新された結果(RESULT)レジスタを読む前に、割り込み要求フラク(ADCn.INTFLAGS)レジスタの結果準備可(RESRDY)ビットが'1'になるまで待ってください。

# 31.3.3. 動作

# 31.3.3.1. 動作形態

ADCは6つの異なる動作形態を支援すると共に各動作に対して差動とシングルエンドの変換が可能です。これは指令(ADCn.COMMA ND)レジスタで構成設定されます。

動作形態は次のように3つの群に分けることができます。

- ・単独動作 8または12ビット変換出力で起動毎に単一変換
- ・継続累積動作 n採取の累積で起動毎に1変換
- ・集中累積動作 単一起動後に可能な限り速く累積したn採取での集中

継続と集中の動作は12ビット変換を利用し、累積結果尺度調整有りまたはなしで構成設定することができます。制御F(ADCn.CTRLF) レジスタの採取累積数選択(SAMPNUM)ビット領域は累積する採取数を制御します。累積器は常に新しい継続または集中の累積が開 始される時に0へリセットされます。

| 右表は利用可能な動  |  |
|------------|--|
| 作形態の概要を示しま |  |
| す          |  |
| / 0        |  |

| 表31-1. 動作形態 |           |         |       |               |
|-------------|-----------|---------|-------|---------------|
| 動作形態        | 指令 - MODE | 起動毎の変換数 | 累積形式  | 結果更新          |
| 単独8ビット      | 0 (0 0 0) |         | 利用不可  | 変換毎           |
| 単独12ビット     | 1 (0 0 1) | 1       | 小小小小小 | 友1矢世          |
| 継続累積        | 2 (0 1 0) | 1       | 全体    |               |
| 尺度調整付き継続累積  | 3 (0 1 1) |         | 尺度調整  | SAMPNUM数変換後   |
| 集中累積        | 4 (1 0 0) |         | 全体    | SAIMFINUM数发换版 |
| 尺度調整付き集中累積  | 5 (1 0 1) | SAMPNUM | 尺度調整  |               |

#### 31.3.3.2. 変換起動

変換は指令(ADCn.COMMAND)レジスタの変換開始(START)ビット領域の構成設定に応じて以下の起動の1つによって開始されます。

・指令レジスタのSTARTビット領域へのIMMEDIATE値書き込み

・事象入力受け取り

・入力多重器(正入力多重器(ADCn.MUXPOS)または負入力多重器(ADCn.MUXNEG))レジスタの1つへの書き込み

最初の変換を開始する前に制御F(ADCn.CTRLF)レジズタの自由走行(FREERUN)ビットに'1'を書くことによって単独変換や集中累積を継続的に繰り返すことができます。このビットは継続累積に対して影響を及ぼしません。

進行中の変換は指令レジスタのSTARTビット領域にSTOP値を書くことによって中断され、新しい変換を直ちに開始することができます。 進行中の変換が終わる前に新しい変換の起動を試みると、割り込み要求フラグ(ADCn.INTFLAGS)レジスタの起動超過割り込み要求(T RIGOVR)フラグが設定(1)され、その試みた起動は無視されます。

割り込み要求フラグレジスタの結果準備可(RESRDY)と採取(試料)準備可(SAMPRDY)の割り込み要求フラグは変換または累積が終了したかを示します。これらのフラグは割り込み制御(ADCn.INTCTRL)レジスタで許可されていれば対応する割り込みも起動します。

#### 変換中断

以下のこれらの活動は進行中の変換を中断します。

・指令(ADCn.COMMAND)レジスタの変換開始(START)ビット領域へのSTOP書き込み。

・変換中の制御C(ADCn.CTRLC)レジスタの参照基準選択(REFSEL)ビット領域への書き込み。

・正または負の入力多重器(ADCn.MUXPOSまたはADCn.MUXNEG)のレジスタでのDACREF、TEMPSENSE、VDDの選択。

これは結果(RESULT)と採取(SAMPLE)のレジスタでの不定値に帰着します。(中断後の)新規変換起動時、最初に、変えられた要素に 関連する安定時間が過ぎるのを待ち、その後に変換を開始します。

#### 31.3.3.3. 出力形式

次式はADC変換からの出力を与えます。

| シンケル エント・12ビット変換 = <u>VINP</u> ×4096∈[0,4095] | シングル エント 8ビット変換 = <u>VINP</u> ×256∈[0,255] |
|-----------------------------------------------|--------------------------------------------|
| 差動12ビット変換 = (VINP-VINN)×利得                    | 差動8ビット変換 = (VINP-VINN)×利得                  |
| VREF ×2048∈[-2048,2047]                       | VREF ×128∈[-128,127]                       |

ここでのVINPとVINNはADCへの正と負の入力で、VREFは選んだ電圧参照基準です。利得はPGAで構成設定されるように1倍から64 倍の間で、PGAが使われない場合は1倍です。

ADCは2つのレジスタを持ちます。採取(ADCn.SAMPLE)と結果(ADCn.RESULT)。16ビット採取レジスタは常に最新のADC変換出力(1採取)で更新されます。全ての累積動作は制御F(ADCn.CTRLF)レジスタの採取累積数選択(SAMPNUM)ビット領域によって構成設定される内部採取累積器で採取を累積します。採取累積器は支援される累積構成設定に対して溢れを避けるのに充分な幅です。累積された結果は集中動作または継続動作の累積の最後で自動的に32ビット結果レジスタに転送します。単独変換動作では、結果レジスタが最新の採取で更新され、採取レジスタと同じです。

尺度調整を持つ動作形態は1累積された結果を16ビット分解能に制限するように選ぶことができます。尺度調整は集中動作と継続動作で最後の採取を累積した後、常に適用され、累積された結果をSAMPNUM-4ビット右移動することによって実行されます。

制御Fレジスタの左揃え(LEFTADJ)ビットはこれが支援される動作に於いて出力データの左移動を許可します。許可される場合、これは 結果と採取の両レジスタの出力を左移動します。

シングル エンド動作での採取に対するデータ形式は\$0000が0を表し、\$0FFFが最大数(全尺)を表す符号なし数です。アナログ入力がADC の参照基準よりも高い場合、12ビットADC出力は\$0FFFの最大値に等しくなります。同様に、入力が0V未満の場合、ADC出力は\$000 0です。差動動作について、データ形式は符号拡張を持つ2の補数です。

以降の表は動作形態と左揃えによるシングルエンドと差動の変換に対する結果レジスタ出力形式を示します。

| 101 2. NEOULI |                      |             |             |             |            |                  |
|---------------|----------------------|-------------|-------------|-------------|------------|------------------|
| MODE          | LEFTADJ              | RESULT31~24 | RESULT23~16 | RESULT15~12 | RESULT11~8 | RESULT7~0        |
| 0 0 0         | x( <mark>注1</mark> ) | \$00        |             |             |            | 変換7~0            |
| 0 0 1         | 0                    |             | \$00        |             | 変換         | 11~0             |
| 001           | 1                    | \$00        |             |             | 変換11~0巜4   |                  |
| 010,100       | x ( <b>注1</b> )      | \$00        |             | 累積          | 23~0       |                  |
| 011,101       | Х                    | \$00        |             | 尺月          | 度調整した累積15  | ~0 ( <b>注2</b> ) |

表31-2. RESULTレジスター シングル エント 動作

注1: 左揃えは8ビット動作や尺度調整なし累積動作で利用できません。

注2: SAMPNUM<4の場合、ビット15が最上位ビットになるように結果が4-SAMPNUMビット左移動されます。

#### 表31-3. RESULTレジスター差動動作

| MODE    | LEFTADJ               | RESULT31~24 | RESULT23~16 | RESULT15~12 | RESULT11~8 | RESULT7~0                |
|---------|-----------------------|-------------|-------------|-------------|------------|--------------------------|
| 0 0 0   | x ( <mark>注1</mark> ) | 符号拡張        |             |             |            | 符号付き変換7~0                |
| 0.0.1   | 0                     |             | 符号拡張 符号付き   |             |            | 変換11~0                   |
| 001     | 1                     | 符号          | 拡張          | 符           | 号付き変換11~0く | << 4                     |
| 010,100 | x ( <b>注1</b> )       | 符号拡張        |             | 符号付き        | 累積23~0     |                          |
| 011,101 | Х                     | 符号          | 符号拡張        |             | 整した符号付き累   | 積15~0( <mark>注2</mark> ) |

注1: 左揃えは8ビット動作や尺度調整なし累積動作で利用できません。

注2: SAMPNUM<4の場合、ビット15が最上位ビットになるように結果が4-SAMPNUMビット左移動されます。

下表は動作形態、左揃え、差動またはシングルエンドの変換による採取レジスタ出力形式を示します。

#### 表31-4. SAMPLEレジスタ

| MODE           | LEFTADJ | DIFF | SAMPLE15~12 | SAMPLE11~8 | SAMPLE~0  |  |  |  |
|----------------|---------|------|-------------|------------|-----------|--|--|--|
| 0 0 0          |         | 0    | \$(         | 00         | 変換7~0     |  |  |  |
| 000            | Х       | 1    | 符号拡張        |            | 符号付き変換7~0 |  |  |  |
|                | 0       | 0    | \$00        | 変換         | 11~0      |  |  |  |
| その他            | 0       | 1    | 符号拡張        | 符号付き       | 変換11~0    |  |  |  |
|                | 1       | 0    |             |            |           |  |  |  |
| 1 符号付き変換11~0<< |         |      |             | < 4        |           |  |  |  |

#### 31.3.3.4. ADCクロック

ADCクロック(CLK\_ADC)は周辺機能クロック(CLK\_PER)から下げられます。増減量は制御B(ADCn.CTRLB)レシ、スタの前置分周器(PRESC) ビット領域によって構成設定することができます。PGA制御(ADCn.PGACTRL)レシ、スタのPGAハ・イアス選択(PGABIASSEL)ビット領域は ADCクロック周波数に応じてPGA消費電力を減らすように構成設定することができます。

ADCとPGAの内部タイミングのいくつかはCLK\_ADCと無関係です。ADCクロック周波数に関わらずに正しい内部タイミングを保証するため、クロック制御器(CLKCTRL)周辺機能の時間基準(CLKCTRL.MCLKTIMEBASE)レジスタに(CLK\_PER周期で与えられる)1µs時間基準が書かれなければなりません。詳細についてはCLKCTRL章でMCLKTIMEBASEレジスタの説明を参照してください。

#### 31.3.3.5. 入力と参照基準の選択

ADCへの入力選択は正と負の入力多重器(ADCn.MUXPOSとADCn.MUXNEG)のレジスタによって制御されます。ADCがシングルェント 変換を走行している場合、MUXPOSだけが使われる一方で、差動変換では両方が使われます。

ADC用の参照基準電圧(VREF)はADCの変換範囲を制御します。VREFは制御C(ADCn.CTRLC)レジスタの参照基準選択(REFSEL) ビット領域に書くことによって選ぶことができます。VDDを除き、内部参照基準電圧は内部ハント・ギャップ参照基準から生成されます。 VDDは選んだハント・ギャップ参照基準電圧よりも最低0.5V高くなければなりません。

入力と参照基準の選択は緩衝されません。変換進行中のそれらのどの変更も出力を不正にします。自由走行動作使用時の安全な 入力または参照基準の変更のため、何れかの変更を行うのに先立って、自由走行動作を禁止して変換完了を待ってください。次の 変換を始める前に再び自由走行動作を許可してください。

入力または参照基準の切り替え後、ADCは安定時間を必要とします。更なる詳細については「電気的特性」章を参照してください。

#### 31.3.3.5.1. 設定可能な利得増幅器

設定可能な利得増幅器(PGA:Programmable Gain Amplifier)はADCへの入力信号を増幅するのに使うことができます。利用可能な 範囲は1~16倍利得です。PGAは全ての動作形態で使うことができます。

既定構成設定ではPGAが禁止され、入力信号は変換段で直接、即ち、内部増幅器なしで採取されます。入力信号特性に応じて、 信号を増幅するように内部PGA段を構成設定するのが望ましい場合があります。

内部PGAは特に外部増幅器との比較に於いて次のようないくつかの望まれる特性を持ちます。

#### ・少ない部品

- ・必要とされる少ないピン数
- ・入力多重化と共にファームウェア選択可能な利得が柔軟で機能豊富な応用を許可
- ・応用がPGAをON/OFFする動作を必要とする時に非反転増幅が符号/論理構造を維持

変換段への直接入力に代わるPGA使用は考慮すべき次の影響を持ちます。

- ・入力信号は増幅され、追加の増幅段(入力雑音、変位、利得誤差)の当然の有害反応と飽和の可能性があります。
- ・ADCがPGA採取を必要とするため、最大変換速度がより低くなります。
- ・消費電力が僅かに増されます。
- ・採取動作形態に応じて、変換の相対的なタイシングが変えられます。

PGAはPGA制御(ADCn.PGACTRL)レシ<sup>\*</sup>スタでPGA許可(PGAEN)ビットに'1'を書いて利得(GAIN)ビット領域を構成設定することによって 許可されます。

正と負の入力多重器(ADCn.MUXPOSとADCn.MUXNEG)のレジスタの経由(VIA)ビット領域は入力信号がPGA経由で接続されるかどう かを決めます。VIAビットは共有され、故にMUXPOSとMUXNEGのVIAビット領域に書かれた値は両レジスタで更新されます。従って、1 つの入力にPGAを使って他方にPGAを使わないことはできません。

# 31.3.3.5.2. 符号刻みによる変位(オフセット)削減

変換結果での変位は符号刻みを使って減らすことができます。符号刻みはPGAが許可去れているか否かに関わらず、シングルエンドと 差動の両変換に於いて累積動作(即ち、単独動作以外)でだけ使うことができます。

符号刻みは制御F(ADCn.CTRLF)レジスタの符号刻み(CHOPPING)ビットに'1'を書くことによって許可されます。

# 31.3.3.5.3. アナログ入力回路

右図はアナログ入力回路を図解します。アナログ入力(AINn)に接続されたアナログ源はピン容量と (IHとILで表現される)そのピン入力漏れに依存します。入力が選ばれると、その供給元は入 力経路の(RINによって表される)結合抵抗を通して採取/保持コンデンサ(CIN)も駆動しなけれ ばなりません。ADCの入力特性の詳細については「電気的特性」章を参照してください。

高インピーダンスを持つ供給元が使われる場合、採取時間を増すことが必要かもしれません。 必要とされる採取時間はCINコンデンサを充電するのに供給元がどれ位の長さが必要かに依存し、制御E(ADCn.CTRLE)レジスタの採取持続時間(SAMPDUR)ビット領域を使って構成設定 することができます。



初期化時間 (us)

20

60

35

35

10 (注1)

(注2)

#### 31.3.3.6. 変換タイミング

ADCのアナログ単位部のいくつかは変換間に禁止され、変換開始前に初期化する時間を必要とします。現在のADC構成設定によって使われる単位部だけが許可され、 初期化が並列で動くため、制限する要素は最も遅い初期化時間を持つ単位部です。 右表はアナログ単位部によって必要とされる各種初期化時間を示します。

- 注1: CLK\_PER<2MHzの場合、ADC初期化時間は20 CLK\_PER周期です。
- 注2: 低遅延(LOWLAT)ビットが'1'の場合、内部参照基準間を切り替える時の安定時間は2µsに減らされます。
- 例:入力として温度感知を選び、参照基準としてVDDを使うと、35µsの初期化時間を与えます。1.024V内部参照基準での温度感知の 使用は60µsの初期化時間になります。

ADCは制御A(ADCn.CTRLA)レジスタの低遅延(LOWLAT)ビットに'1'を書くことによって低遅延動作に置くことができ、これは構成設定 された単位部を継続的に許可し続け、変換開始での全ての初期化時間を効果的に取りまります。初回にADCを許可したり、初期化 を必要とする入力または参照基準の使用のためにADCを再構成設定する時に、初期化時間は未だ上の表で示されるように必要とさ れます。状態(ADCn.STATUS)レジスタのADC多忙(ADCBUSY)ビットは初期化が進行中かを調べるのに使うことができます。

PGAなしでのADCへの入力の採取期間は制御E(ADCn.CTRLE)レジスタの採取持続時間(SAMPDUR)ビット領域を通して(SAMPDUR +%)CLK\_ADC周期として構成設定されます。入力信号特性は採取期間がどの位長くなければならないかに影響を及ぼします。

PGAなしで内部参照基準が使われると、参照基準緩衝部の自動0が採取の始めで走行し、値≧4µs×fCLK\_ADCに設定されるSAMD URを必要とします。

PGAが使われると、ADCがPGA出力を採取する間で保持状態になるのを除き、継続的に入力を採取します。このADC PGA採取持続時間(ADCPGASAMPDUR)は右表で見られるように、PGA制御(ADCn.PGACTRL)レジスタのPGAハイアス選択(PGABIASSEL)ビット領域に依存します。採取持続時間(SAMPDUR)は未だPGAへの入力の最小採取期間を(SAMPDUR+1)CLK\_ADC周期として構成設定します。集中動作ではSAMPDU Rが≧12でなければならず、変換状態の長さによって制限されます。

| 表31-6. ADCPGASAMPDUR              |                             |  |  |  |
|-----------------------------------|-----------------------------|--|--|--|
| PGABIASSEL                        | ADCPGASAMPDUR (µs)          |  |  |  |
| 0 0 (100PCT)                      | 3 (または4 ( <mark>注</mark> )) |  |  |  |
| 0 1 (75PCT)                       | 5                           |  |  |  |
| 1 0 (50PCT)                       | 6                           |  |  |  |
| <b>1 1 (25PCT)</b> 12             |                             |  |  |  |
| 注: 内部参照基準を使う場合、最小PGA採取持続時間は4usです。 |                             |  |  |  |

表31-5. ADC初期化時間

アナログ単位部

ADC

PGA 内部参照基準の安定

内部温度感知器入力

内部DAC入力

継続と集中の累積動作は適切な入力信号と採取周波数を与えられると、5ビットまでのより高い分解能を達成するための過採取に使うことができます。nビットによる分解能増加は4n採取の累積と2nによる累積結果除算によって達成することができます。制御F(ADCn.CT RLF)レジ、スタの採取累積数(SAMPNUM)ビット領域は45=1024採取までに構成設定することができ、最大17ビット分解能になります。

次の2つの表はfcLK\_ADCと採取持続時間の可能な組み合わせの一部に対して計算された変換速度(fconv)を示します。より多くの詳細については以降の頁の関連タイミング図をご覧ください。

| 表31-7. fcLK_ADC=5MHzとPGABIASSEL=100PCTに対する変換速度(fconv)例 |     |                                        |                                         |                        |  |  |
|--------------------------------------------------------|-----|----------------------------------------|-----------------------------------------|------------------------|--|--|
| SAMPDUR                                                | PGA | <b>f<sub>conv</sub>(注)単一8ビット</b> (sps) | <b>f<sub>conv</sub>(注)単一12ビット</b> (sps) | <b>fconv集中累積</b> (sps) |  |  |
| 20                                                     |     | 161290                                 | 142857                                  | 147059                 |  |  |
| 64                                                     | OFF | 66667                                  | 63291                                   | 64103                  |  |  |
| 128                                                    | Off | 35971                                  | 34965                                   | 35211                  |  |  |
| 255                                                    |     | 18797                                  | 18519                                   | 18587                  |  |  |
| 15                                                     |     | 120482                                 | 109890                                  | 156250                 |  |  |
| 20                                                     | ON  | 107527                                 | 99010                                   | 135135                 |  |  |
| 64                                                     | ON  | 55249                                  | 52910                                   | 61728                  |  |  |
| 255                                                    |     | 17762                                  | 17513                                   | 18382                  |  |  |

# 表31-8. fCLK\_ADC=312.5kHzとPGABIASSEL=25PCTに対する変換速度(fconv)例

| SAMPDUR | PGA | <b>fconv(注)単一8ビット</b> (sps) | <b>f<sub>conv</sub>(注)単一12ビット</b> (sps) | <b>fconv集中累積</b> (sps) |
|---------|-----|-----------------------------|-----------------------------------------|------------------------|
| 2       |     | 24038                       | 18382                                   | 19531                  |
| 11      | OFF | 14205                       | 12019                                   | 12500                  |
| 64      | UN  | 4167                        | 3956                                    | 4006                   |
| 255     |     | 1175                        | 1157                                    | 1162                   |
| 2       |     | 18116                       | 14706                                   | 利用不可                   |
| 11      | ON  | 11905                       | 10331                                   | 18657                  |
| 64      | ON  | 3943                        | 3754                                    | 4480                   |
| 255     |     | 1156                        | 1139                                    | 1198                   |

**注**: 制御F(ADCn.CTRLF)レジスタで'1'に設定された自由走行(FREERUN)ビットでの変換速度、新しい変換は結果がADCで利用可能 になった後直ちに開始します。

#### 31.3.3.6.1. 単独変換

下図はPGAを使わずに単独の8または12ビット動作で動く時のADCに対するタイング図を示します。



**注2**: 制御A(ADCn.CTRLA)レジスタで低遅延(LOWLAT)ビットが'1'に設定される場合、ADC内のアナログ単位部は変換の最後で OFFに切り替わらず、次の変換の起動時の初期化時間をなくします。

注3: 変換が終わってから出力がレジスタで利用可能になる時間は0.5 CLK\_ADC周期と後続する1 CLK\_MAIN周期です。最小前置 分周で、これは合計で1 CLK\_ADC周期になります。

単独結果に対する総変換時間(tconv)は次によってµsで計算されます。

 $t_{\text{conv}}(12 \texttt{L}^{'} \texttt{y}) = 初期化時間 + \frac{\text{SAMPDUR} + 15}{f_{\text{CLK}} \text{ADC}}$ 

 $t_{\text{conv}}(8t') = 初期化時間 + \frac{\text{SAMPDUR} + 11}{f_{\text{CLK}}}$ 

制御F(ADCn.CTRLF)レジスタで自由走行(FREERUN)ビットが'1'に設定される場合、新しい変換は結果(ADCn.RESULT)レジスタで結 果が利用可能になる直後に開始されます。自由走行変換速度(fconv)は次によって計算されます。

 $f_{\text{conv}} (12 \texttt{t'yh}) = \frac{f_{\text{CLK\_ADC}}}{\text{SAMPDUR} + 15}$   $f_{\text{conv}} (8 \texttt{t'yh}) = \frac{f_{\text{CLK\_ADC}}}{\text{SAMPDUR} + 11}$ 

#### 31.3.3.6.2. 継続累積

下図はPGAを使わずに継続累積動作で動く時のADCに対するタイジグ図を示します。



注1: 制御A(ADCn.CTRLA)レシ<sup>゙</sup>スタで低遅延(LOWLAT)ヒ<sup>゙</sup>ットが<sup>'</sup>1'に設定される場合、ADC内のアナロケ<sup>゙</sup>単位部は変換の最後で OFFに切り替わらず、次の変換の起動時の初期化時間をなくします。

注2: 変換が終わってから出力がレジスタで利用可能になる時間は0.5 CLK\_ADC周期と後続する1 CLK\_MAIN周期です。最後の変換と累積は追加のCLK\_MAIN周期を必要とします。最小前置分周で、これは最終出力が利用可能になる前に合計で1.5 CL K\_ADC周期になります。

累積する採取数は制御F(ADCn.CTRLF)レジスタの採取数(SAMPNUM)ビット領域に よって設定されます。

各独立した採取に対する総変換時間(tconv)は右によってµsで計算されます。

 $t_{\text{conv}} = 初期化時間 + \frac{\text{SAMPDUR} + 15}{f_{\text{CLK ADC}}}$ 

#### 31.3.3.6.3. 集中累積

下図はPGAを使わずに集中累積動作で動く時のADCに対するタイミング図を示します。



注1: 制御A(ADCn.CTRLA)レジスタで低遅延(LOWLAT)ビットが'1'に設定される場合、ADC内のアナログ単位部は変換の最後で OFFに切り替わらず、次の変換の起動時の初期化時間をなくします。

注2: 変換が終わってから出力がレジスタで利用可能になる時間は0.5 CLK\_ADC周期と後続する1 CLK\_MAIN周期です。最後の変換と累積は追加のCLK\_MAIN周期を必要とします。最小前置分周で、これは最終出力が利用可能になる前に合計で1.5 CL K\_ADC周期になります。

累積する採取数は制御F(ADCn.CTRLF)レシ<sup>゙</sup>スタの採取数(SAMPNUM)ヒ<sup>\*</sup>ット領域によって設定されます。

集中累積に対する総変換時間(tconv)は次によってµsで計算されます。

 $t_{\text{conv}} = 初期化時間 + \frac{(\text{SAMPDUR} + 14) \times \text{SAMPNUM} + 1.5}{c}$ 

fclk\_adc

集中累積変換速度(fconv)は次によって計算されます。

 $f_{\rm conv} = \frac{f_{\rm CLK\_ADC}}{{\rm SAMPDUR} + 14}$ 

#### 31.3.3.6.4. PGAを含む単独累積

下図はPGAと共に単独8または12ビット動作で動く時のADCに対するタイジング図を示します。



制御F(ADCn.CTRLF)レジスタで自由走行(FREERUN)ビットが'1'に設定される場合、新しい変換は結果(ADCn.RESULT)レジスタで結果が利用可能になる直後に開始されます。自由走行変換速度(fconv)は次によって計算されます。

| $f_{\text{conv}}(12t^{*}yh) = \frac{1}{200000000000000000000000000000000000$                                        | $f_{\text{conv}}\left(8E^{*}yh\right) = \frac{1}{24445}$                                               |
|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| $f_{\text{conv}}(122\%) = \frac{1}{\frac{\text{SAMPDUR} + 15.5}{\text{for } k \text{ ADC}} + \text{ADCPGASAMPDUR}}$ | $J_{\text{conv}}(81.9\%) = \frac{\text{SAMPDUR} + 11.5}{\text{SAMPDUR} + 11.5} + \text{ADCPGASAMPDUR}$ |
| fclk_ADC                                                                                                            | fclk_ADC                                                                                               |

#### 31.3.3.6.5. PGAを含む継続累積

下図はPGAと共に継続累積動作で動く時のADCに対するタイング図を示します。



- 注2: 制御A(ADCn.CTRLA)レジスタで低遅延(LOWLAT)ビットが'1'に設定される場合、ADC内のアナログ単位部は変換の最後で OFFに切り替わらず、次の変換の起動時の初期化時間をなくします。PGAは新しいPGA採取が起きるまで入力採取状態に 留まります。
- 注3: 変換が終わってから出力がレジスタで利用可能になる時間は0.5 CLK\_ADC周期と後続する1 CLK\_MAIN周期です。最後の変換と累積は追加のCLK\_MAIN周期を必要とします。最小前置分周で、これは最終出力が利用可能になる前に合計で1.5 CLK\_ ADC周期になります。

累積する採取数は制御F(ADCn.CTRLF)レジズタの採取数(SAMPNUM)ビット領域によって設定されます。

各独立した採取に対するµsでの総変換時間(tconv)は次によって計算されます。

 $t_{\text{conv}} = 初期化時間 + \frac{\text{SAMPDUR} + 15.5}{f_{\text{CLK}_{ADC}}} + \text{ADCPGASAMPDUR}$ 

#### 31.3.3.6.6. PGAを含む集中累積

下図はPGAと共に集中累積動作で動く時のADCに対するタイシング図を示します。



注1: PGAは一旦PGA初期化が終わると、例えADC初期化が未だ進行中でも入力の採取を始めます。この場合、最初の採取時間は採取持続時間(SAMPDUR)によって構成設定されるよりも長くなります。

- 注2: 制御A(ADCn.CTRLA)レシ<sup>\*</sup>スタで低遅延(LOWLAT)ビットが<sup>\*</sup>1'に設定される場合、ADC内のアナログ単位部は変換の最後で OFFに切り替わらず、次の変換の起動時の初期化時間をなくします。PGAは新しいPGA採取が起きるまで入力採取状態に 留まります。
- 注3: 変換が終わってから出力がレジスタで利用可能になる時間は0.5 CLK\_ADC周期と後続する1 CLK\_MAIN周期です。最後の変換と累積は追加のCLK\_MAIN周期を必要とします。最小前置分周で、これは最終出力が利用可能になる前に合計で1.5 CLK\_ADC周期になります。

累積する採取数は制御F(ADCn.CTRLF)レジスタの採取数(SAMPNUM)ビット領域によって設定されます。

PGAを含む集中累積についてはSAMPDURが≧11でなければなりません。総変換時間(tconv)は次によってµsで計算されます。

|    | <i>t</i> conv = 初期化時間 +      | $\frac{(\text{SAMPDUR}+2) \times \text{SAMPNUM}+14}{f_{\text{CLK}\text{-ADC}}}$ | 4 + ADCPGAS | AMPDUR              | ×SAMPNUM                                                  |                    |
|----|------------------------------|---------------------------------------------------------------------------------|-------------|---------------------|-----------------------------------------------------------|--------------------|
| 集中 | 変換速度(f <sub>conv</sub> )は次によ | って計算されます。                                                                       |             | f <sub>conv</sub> = | $\frac{\overline{\text{SAMPDUR}+2}}{f_{\text{CLK}ADC}} +$ | 1<br>ADCPGASAMPDUR |

#### 31.3.3.7. 温度測定

チップ上の温度感知器が利用可能です。温度測定を行うには以下のこれらの手順に従ってください。

- 1. 制御C(ADCn.CTRLC)レジスタの参照基準選択(REFSEL)ビット領域を書くことによって参照基準電圧を内部1.024Vに構成設定して ください。
- 2. 正入力多重器(ADCn.MUXPOS)レジスタで入力として温度感知器を選んでください。
- 制御E(ADCn.CTRLE)レシ<sup>\*</sup>スタの採取持続時間(SAMPDUR)と<sup>\*</sup>ット領域に32µs×f<sub>CLK\_ADC</sub>以上(訳補:脚注参照)の値を書くことに よってADC採取持続時間を構成設定してください。
- 4.12ビット シングル エント 変換を走らせて温度感知器出力電圧を採取してください。
- 5. 次に記述されるように測定結果を処理してください。

(訳補) SAMPDURがCLK\_ADC周期数で設定するため、32µs以上になるCLK\_ADC周期数の意味です。

測定した電圧は温度に対して直線的関係を持ちます。製法変化のため、温度感知器出力電圧は同じ温度に於いて個別デバイス間 で変わります。製造検査の間に測定された個別補償係数は識票列で次のように格納されます。

- ・SIGROW.TEMPSENSE0は温度感知器の利得/傾斜補正です。
- ・SIGROW.TEMPSENSE1は温度感知器の変位(オフセット)補正です。

もっと正確な結果を達成するため、温度感知器測定の結果はデベイス製造または使用者校正からの補償値を用いて応用ソフトウェアで 処理されなければなりません。更なる詳細については「電気的特性」章を参照してください。 次式は(ヶルビンでの)温度を計算するのに使われます。

# T-(ADC結果-変位補正)×傾斜補正

4096

識票列からの補償値を使う時は応用コートで以下のこれらの手順に従うことが推奨されます。

| #define SCALING_FACTOR 4096                                                                                                                                                                                                                          | // 尺度調整値                                                        |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|
|                                                                                                                                                                                                                                                      | // 識票列から符号付き変位読み込み<br>// 識票列から符号付き傾斜読み込み<br>// ADC変換結果          |
| <pre>int32_t temp = ((int32_t) adc_reading) + sigrow_offset;<br/>temp *= sigrow_slope;<br/>temp += SCALING_FACTOR / 2;<br/>temp /= SCALING_FACTOR;<br/>uint16_t temperature_in_K = (uint_16t) temp;<br/>int16_t temperature_in_C = temp - 273;</pre> | // 結果が16ビット変数を溢れ得ます。<br>// 次の除算での正しい丸めを保証<br>// ケルビンでの最も近い整数へ丸め |

#### 31.3.3.8. 窓比較器

ADCは変換または累積の出力が或る閾値越えと/または未満の時に割り込み要求フラグ(ADCn.INTFLAGS)レジスタの窓比較器割り込み要求(WCMP)フラグを立てることができます。利用可能な動作形態は次のとおりです。

- ・結果が閾値超え
- ・結果が閾値未満
- ・結果が窓の内側(下側閾値以上で上側閾値以下)
- ・結果が窓の外側(下側閾値未満または上側閾値越えのどちらか)

閾値は窓比較器下側/上側閾値(ADCn.WINLTとADCn.WINHT)レジスタに書くことによって設定されます。使う窓動作は制御D(ADC n.CTRLD)レジスタの窓比較器動作(WINCM)ヒット領域によって選ばれます。

制御D(ADCn.CTRLD)レジスタの窓動作元(WINSRC)ビットは比較が結果(ADCn.RESULT)レジスタの下位16ビットまたは採取(ADCn.SAM PLE)レジスタのどちらで実行されるかを選びます。WCMPフラクに対して割り込み要求が許可される場合、WINSRCはRESRDYまたはSA MPRDYのどちらの割り込み、クタを要求するか選びます。

複数採取累積時、窓比較元が結果レジスタの場合、結果と閾値間の比較は最後の変換完了後に起きます。供給元が採取レジスタの場合、比較は毎回の変換後に起きます。

ADCが既に動くように構成設定されるとの仮定で、窓比較器を使うには以下のこれらの手順に従ってください。

- 1. 窓比較器下側/上側閾値(ADCn.WINLTとADCn.WINHT)レジスタを書くことによって必要とされる閾値を設定してください。
- 2. 任意選択:割り込み制御(ADCn.INTCTRL)レジスタの窓比較器割り込み許可(WCMP)ビットに'1'を書くことによって割り込み要求を 許可してください。

3. 制御D(ADCn.CTRLD)レジスタでWINSRCビットへとWINCMビット領域に0以外の値を書くことによって窓比較器を許可してください。 累積採取時、窓比較器閾値は各採取ではなく累積された値に対して適用されます。結果の左揃えを使うことが採取数と無関係な比較値にします。

# 31.3.4. 事象

ADCは以下の事象を生成することができます。

表31-9. ADC事象生成部

| 生    | <b></b> | =25 日日 | 事象型 | 生成クロック領域 | 事象長         |
|------|---------|--------|-----|----------|-------------|
| 周辺機能 | 事象      | 説明     |     | 主成ゲロジ項域  | 尹豕文         |
|      | RESRDY  | 結果準備可  |     |          |             |
| ADCn | SAMPRDY | 採取準備可  | パルス | CLK_PER  | 1 CLK_PER周期 |
|      | WCMP    | 窓比較一致  |     |          |             |

事象を生成する条件は割り込み要求フラク(ADCn.INTFLAGS)レンジスタで対応するフラグを掲げるそれらと同じです。

ADCは入力事象を検出して働くための1つの事象使用部を持ちます。下表は事象使用部と関連する機能を記述します。

| <u>表31-10.</u> A | 表31-10. ADC事象使用部と利用可能な事象活動 |                   |      |        |  |  |  |  |  |
|------------------|----------------------------|-------------------|------|--------|--|--|--|--|--|
| 使用部名 説明 入力検出     |                            |                   |      |        |  |  |  |  |  |
| 周辺機能             | 入力                         | 5元19 <del>月</del> | 入力検出 | 同期/非同期 |  |  |  |  |  |
| ADCn             | START                      | 事象でADC開始          | 端    | 非同期    |  |  |  |  |  |

START事象活動は指令(ADCn.COMMAND)レシ<sup>゙</sup>スタの変換開始(START)ビット領域にEVENT\_TRIGGER設定が書かれる場合に起動 することができます。

#### 31.3.5. 割り込み

#### 表31-11.利用可能な割り込みべりタと供給元

| 名前      | ベクタ説明                  | 割り込み要求フラク | 条件                                    |  |  |
|---------|------------------------|-----------|---------------------------------------|--|--|
|         |                        | TRIGOVR   | 別のものが進行中に新しい変換が起動される。                 |  |  |
| ERROR   | 異常割り込み                 | SAMPOVR   | 新しい変換がADCn.SAMPLEで未読試料を上書き            |  |  |
|         |                        | RESOVR    | 新しい変換または累積がADCn.RESULTで未読結果を上書き       |  |  |
| SAMPRDY | <b>授</b> 西淮借司宝[1013-75 | SAMPRDY   | ADCn.SAMPLEで試料が利用可能                   |  |  |
| SAMPRDY | 採取準備可割り込み              | WCMP      | ADCn.CTRLDのWINSRCとWINCMによって定義されたとおりの時 |  |  |
| RESRDY  | 結果準備可割り込み              | RESRDY    | ADCn.RESULTで結果が利用可能                   |  |  |
| RESKDY  | 和木宇圃り割り込み              | WCMP      | ADCn.CTRLDのWINSRCとWINCMによって定義されたとおりの時 |  |  |

割り込み条件が起こると、割り込み要求フラク(ADCn.INTFLAGS)レジスタで対応する割り込み要求フラクが設定(1)されます。

割り込み元は割り込み制御(ADCn.INTCTRL)レジスタで対応する許可ビットに書くことによって許可または禁止されます。

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

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

ADCはアイドル/スタンバイの休止動作へ行く前に変換を終えます。ADCは指令(ADCn.COMMAND)レシ、スタの変換開始(START)ビット領域が事象起動での変換開始に構成設定されていれば、アイトル休止動作で変換を開始することができます。これは制御A(ADCn.CTR LA)レシ、スタのスタンハ、イ時走行(RUNSTDBY)ビットが設定(1)される場合にスタンハ、イ休止動作でも可能です。

制御Aレジ゙スタで低遅延(LOWLAT)とRUNSTDBYの両ビットが設定(1)される場合、休止中の消費電力増加を犠牲にして、より速く変換 を開始するためにスタンバイ休止動作中に必要とされる全ての単位部をONに保ちます。

システムがパワータウン休止動作に入ると、ADCは進行中の変換を中断して直ちに休止動作に入ります。パワーダウン休止動作に移行するのに先立って変換が完了しているのを確実にしてください。

# 31.3.7. デバッグ操作

デバッグ制御(ADCn.DBGCTRL)レジスタのデバッグ時走行(DBGRUN)ビットが'1'を書かれる場合、ADCはCPUがデバッグ動作で停止される時に動作を続けます。

CPUが停止する時にDBGRUNが'0'の場合、ADCが停止するまでに進行中の変換が終わります。

# 31.4. レジスタ要約

| 変位         | 略称         | ビット位置       | ビット7     | ビット6     | ビット5    | ビット4    | ヒット3   | ビット2  | <b>ビット1</b> | ビットロ    |
|------------|------------|-------------|----------|----------|---------|---------|--------|-------|-------------|---------|
| +\$00      | CTRLA      | 7~0         | RUNSTDBY |          | LOWLAT  |         |        |       |             | ENABLE  |
| +\$01      | CTRLB      | 7~0         |          |          |         |         |        | PRES  | SC3~0       |         |
| +\$02      | CTRLC      | $7 \sim 0$  |          |          |         |         |        |       | REFSEL2~0   |         |
| +\$03      | CTRLD      | $7 \sim 0$  |          |          |         |         | WINSRC |       | WINCM2~0    |         |
| +\$04      | INTCTRL    | $7 \sim 0$  |          |          | TRIGOVR | SAMPOVR | RESOVR | WCMP  | SAMPRDY     | RESRDY  |
| +\$05      | INTFLAGS   | 7~0         |          |          | TRIGOVR | SAMPOVR | RESOVR | WCMP  | SAMPRDY     | RESRDY  |
| +\$06      | STATUS     | 7~0         |          |          |         |         |        |       |             | ADCBUSY |
| +\$07      | DBGCTRL    | 7~0         |          |          |         |         |        |       |             | DBGRUN  |
| +\$08      | CTRLE      | 7~0         |          |          |         | SAMPD   | UR7~0  |       | +           |         |
| +\$09      | CTRLF      | 7~0         |          | CHOPPING | FREERUN | LEFTADJ |        | SAMPN | IUM3~0      |         |
| +\$0A      | COMMAND    | 7~0         | DIFF     |          | MODE2~0 |         |        |       | START2~0    |         |
| +\$0B      | PGACTRL    | $7 \sim 0$  |          | GAIN2~0  |         | PGABIS. |        |       |             | PGAEN   |
| +\$0C      | MUXPOS     | 7~0         | VIA      |          |         |         |        | OS5~0 | +           |         |
| +\$0D      | MUXNEG     | 7~0         | VIA      | 1,0      |         |         | MUXN   | EG5~0 | 1           |         |
| +\$0E<br>∼ | 予約         |             |          |          |         |         |        |       |             |         |
| +\$0F      |            |             |          |          |         |         |        |       |             |         |
| +\$10      |            | 7~0         |          |          |         |         | LT7~0  |       | +           |         |
| +\$11      | RESULT     | $15 \sim 8$ |          |          |         | RESUL   |        | I     | +           |         |
| +\$12      |            | 23~16       |          |          |         | RESUL   |        | l     | +           |         |
| +\$13      |            | 31~24       |          |          |         | RESUL   |        | l     | +           |         |
| +\$14      | SAMPLE     | 7~0         |          |          |         |         | LE7~0  | l     | +           |         |
| +\$15      |            | $15 \sim 8$ |          |          |         | SAMPL   | LE15~8 |       | +           |         |
| +\$16<br>~ | 予約         |             |          |          |         |         |        |       |             |         |
| +\$17      | 3 71-3     |             |          |          |         |         |        |       |             |         |
| +\$18      | TEMP0      | 7~0         |          |          |         | TEM     | P7~0   |       | +           |         |
| +\$19      | TEMP1      | 7~0         |          |          |         | TEM     | P7~0   |       |             |         |
| +\$1A      | TEMP2      | 7~0         |          |          |         | TEM     | P7~0   |       | +           |         |
| +\$1B      | 予約         |             |          |          |         |         |        |       |             |         |
| +\$1C      | WINLT      | 7~0         |          |          |         | WINL    | T7~0   |       |             |         |
| +\$1D      |            | $15 \sim 8$ |          |          |         | WINL'   | T15~8  | ·     |             |         |
| +\$1E      | WINHT      | 7~0         |          |          |         | WINH    | IT7~0  |       |             |         |
| +\$1F      | VVIINI I I | $15 \sim 8$ |          |          |         | WINH    | T15~8  |       | 1           |         |

# 31.5. レジスタ説明

# 31.5.1. CTRLA - 制御A (Control A)

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

# 特質:-

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

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

このビットはスタンバイ休止動作でADCが動くか否かを制御します。

| 值      | 0 | 1                                                    |
|--------|---|------------------------------------------------------|
| = 2 HD |   | ADCはスタンバイ休止動作で動きます。ADCが変換実<br>行を起動されると、主クロックが要求されます。 |

#### ● ビット5 - LOWLAT : 低遅延 (Low Latency)

このビットはADCによって必要とされるアナログ単位部が継続的に許可されるかそれとも必要とされる時にだけかを制御します。

| 值  | 0              | 1 |
|----|----------------|---|
| 説明 | だけ必要とされるアナログ単位 |   |

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

このビットはADCが許可されるか否かを制御します。

| 值  | 0           | <u>1</u><br>ADCけ注示されます |  |  |  |  |
|----|-------------|------------------------|--|--|--|--|
| 説明 | ADCは禁止されます。 | ADCは許可されます。            |  |  |  |  |

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

| <b>惑</b> | ら称 : CTRLB<br>を位 : +\$01<br>セット : \$00<br>寺質 : - |   |   |   |   |     |      |      |   |
|----------|--------------------------------------------------|---|---|---|---|-----|------|------|---|
|          | ビット                                              | 7 | 6 | 5 | 4 | 3   | 2    | 1    |   |
|          |                                                  |   |   |   |   |     | PRES | C3~0 |   |
|          | アクセス種別                                           | R | R | R | R | R/W | R/W  | R/W  | I |
|          | リセット値                                            | 0 | 0 | 0 | 0 | 0   | 0    | 0    |   |

● ビット3~0 - PRESC3~0:前置分周器 (Prescaler)

このビット領域は周辺機能クロック(CLK\_PER)からADCクロック(CLK\_ADC)への分周係数を制御します。

|   | 値  | 0000            | 0001            | 0010       | 0011            | 0100       | 0101       | 0110       | 0111       |
|---|----|-----------------|-----------------|------------|-----------------|------------|------------|------------|------------|
|   | 名称 | DIV2            | DIV4            | DIV6       | DIV8            | DIV10      | DIV12      | DIV14      | DIV16      |
|   | 説明 | CLK_PER/2       | CLK_PER/4       | CLK_PER/6  | CLK_PER/8       | CLK_PER/10 | CLK_PER/12 | CLK_PER/14 | CLK_PER/16 |
|   | 値  | $1 \ 0 \ 0 \ 0$ | $1 \ 0 \ 0 \ 1$ | 1010       | $1 \ 0 \ 1 \ 1$ | 1 1 0 0    | 1 1 0 1    | 1110       | 1111       |
| Γ | 名称 | DIV20           | DIV24           | DIV28      | DIV32           | DIV40      | DIV48      | DIV56      | DIV64      |
|   | 説明 | CLK_PER/20      | CLK_PER/24      | CLK_PER/28 | CLK_PER/32      | CLK_PER/40 | CLK_PER/48 | CLK_PER/56 | CLK_PER/64 |

0

R/W 0

# **31.5.3. CTRLC - 制御C** (Control C)

| 名称 | : | CTRL |
|----|---|------|
|    |   |      |

**変位** : +\$02

リセット : \$00

#### 特質 :-

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

# ● ビット2~0 - REFSEL2~0:参照基準選択 (Reference Selection)

このビット領域はADCに対する参照基準電圧を制御します。内部参照基準の1つへの変更は60µs初期化時間を必要とします。

| 値  | 000 | 001  | 010             | 011  | 100              | 101              | 110              | 111              |
|----|-----|------|-----------------|------|------------------|------------------|------------------|------------------|
| 名称 | VDD | -    | VREFA           | -    | 1V024            | 2V048            | 4V096            | 2V500            |
| 説明 | VDD | (予約) | 外部VREFA<br>参照基準 | (予約) | 内部1.024V<br>参照基準 | 内部2.048V<br>参照基準 | 内部4.096V<br>参照基準 | 内部2.500V<br>参照基準 |

注:内部参照基準はVDD-0.5Vよりも低い場合にだけ使うことができます。

# 31.5.4. CTRLD - 制御D (Control D)

#### 名称 : CTRLD

**変位** : +\$03

**リセット** : \$00

# 特質 :-

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

# • ビット3 - WINSRC : 窓動作供給元 (Window Mode Source)

このビットは窓比較器によってどの供給元が使われるかを制御します。

| 値  | 0                                    | 1                                    |
|----|--------------------------------------|--------------------------------------|
| 名称 | RESULT                               | SAMPLE                               |
| 説明 | 窓比較器供給元としてADCn.RESULT15~0が<br>使われます。 | 窓比較器供給元としてADCn.SAMPLE15~0が<br>使われます。 |

# ● ビット2~0 - WINCM2~0: 窓比較器動作 (Window Comparator Mode)

このビット領域は窓比較器を許可するかどうかとどの閾値が割り込み要求フラグ(ADCn.INTFLAGS)レジスタの窓比較器割り込み要求(WCMP)フラグを設定(1)するかを制御します。

下表に於いて"出力"は窓動作供給元(WINSRC)によって選ばれた結果または採取です。WINLTとWINHTは各々、16ビット下側閾値と16ビット上側閾値です。

| 値  | 0 0 0  | 001                                                                                                                         | 010      | 011            | 100                               | その他  |
|----|--------|-----------------------------------------------------------------------------------------------------------------------------|----------|----------------|-----------------------------------|------|
| 名称 | NONE   | BELOW                                                                                                                       | ABOVE    | INSIDE         | OUTSIDE                           | -    |
| 説明 | 窓比較器禁止 | 出力 <winlt< th=""><th>出力&gt;WINHT</th><th>WINLT≦出力≦WINHT</th><th>出力<winltまたは出力>WINHT</winltまたは出力></th><th>(予約)</th></winlt<> | 出力>WINHT | WINLT≦出力≦WINHT | 出力 <winltまたは出力>WINHT</winltまたは出力> | (予約) |

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

| 名称: | INTCTRL |
|-----|---------|
|-----|---------|

**変位**:+\$04

リセット: \$00

| 少士省 | • | _ |
|-----|---|---|
| 1寸貝 | • |   |
|     |   |   |
|     |   |   |

| <b>ビット</b> | 7 | 6 | 5       | 4       | 3      | 2    | 1       | 0      |
|------------|---|---|---------|---------|--------|------|---------|--------|
|            |   |   | TRIGOVR | SAMPOVR | RESOVR | WCMP | SAMPRDY | RESRDY |
| アクセス種別     | R | R | R/W     | R/W     | R/W    | R/W  | R/W     | R/W    |
| リセット値      | 0 | 0 | 0       | 0       | 0      | 0    | 0       | 0      |

#### ● ビット5 - TRIGOVR : 起動超過割り込み許可 (Ttigger Overrun Interrupt Enable)

このビットは起動超過に対する割り込みが許可されるか否かを制御します。

| 値  | 0                | 1                |  |  |
|----|------------------|------------------|--|--|
| 説明 | 起動超過割り込みが禁止されます。 | 起動超過割り込みが許可されます。 |  |  |

● ビット4 - SAMPOVR : 採取上書き割り込み許可 (Sample Overwrite Interrupt Enable)

このビットは採取上書きに対する割り込みが許可されるか否かを制御します。

| 値  | 0                 | 1                 |
|----|-------------------|-------------------|
| 説明 | 採取上書き割り込みが禁止されます。 | 採取上書き割り込みが許可されます。 |

● ビット3 - RESOVR : 結果上書き割り込み許可 (Result Overwrite Interrupt Enable)

このビットは結果上書きに対する割り込みが許可されるか否かを制御します。

| 値  | 0                 | 1                 |
|----|-------------------|-------------------|
| 説明 | 結果上書き割り込みが禁止されます。 | 結果上書き割り込みが許可されます。 |

● ビット2 - WCMP:窓比較器割り込み許可(Window Comparator Interrupt Enable)

このビットは窓比較器に対する割り込みが許可されるか否かを制御します。

| 値  | 0                | 1                |
|----|------------------|------------------|
| 説明 | 窓比較器割り込みが禁止されます。 | 窓比較器割り込みが許可されます。 |

#### ● ビット1 - SAMPRDY:採取準備可割り込み許可 (Sample Ready Interrupt Enable)

このビットは採取準備可割り込みが許可されるか否かを制御します。

| 値  | 0                 | 1                 |
|----|-------------------|-------------------|
| 説明 | 採取準備可割り込みが禁止されます。 | 採取準備可割り込みが許可されます。 |

# ● ビット0 - RESRDY : 結果準備可割り込み許可 (Result Ready Interrupt Enable)

このビットは結果準備可割り込みが許可されるか否かを制御します。

| 值  | 0                 | 1                 |  |  |
|----|-------------------|-------------------|--|--|
| 説明 | 結果準備可割り込みが禁止されます。 | 結果準備可割り込みが許可されます。 |  |  |

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

名称 : INTFLAGS

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

#### 特質 :-

| ビット    | 7 | 6 | 5       | 4       | 3      | 2    | 1       | 0      |
|--------|---|---|---------|---------|--------|------|---------|--------|
|        |   |   | TRIGOVR | SAMPOVR | RESOVR | WCMP | SAMPRDY | RESRDY |
| アクセス種別 | R | R | R/W     | R/W     | R/W    | R/W  | R/W     | R/W    |
| リセット値  | 0 | 0 | 0       | 0       | 0      | 0    | 0       | 0      |

# ● ビット5 - TRIGOVR : 起動超過割り込み要求フラグ(Ttigger Overrun Interrupt Flag)

これに'1'を書くことによってこのフラグを解除(0)してください。このフラグは変換が進行中に開始起動を受け取った時に設定(1)されます。このビットへの'0'書き込みは無効です。このビットへの'1'書き込みは起動超過割り込み要求フラグを解除(0)します。

# ● ビット4 - SAMPOVR : 採取上書き割り込み要求フラグ(Sample Overwrite Interrupt Flag)

これに'1'を書くことによってこのフラグを解除(0)してください。このフラグは採取(ADCn.SAMPLE)レジスタで未読採取(試料)が上書きされ る時に設定(1)されます。このビットへの'0'書き込みは無効です。このビットへの'1'書き込みは採取上書き割り込み要求フラグを解除(0) します。

# ● ビット3 - RESOVR : 結果上書き割り込み要求フラグ(Result Overwrite Interrupt Flag)

これに'1'を書くことによってこのフラグを解除(0)してください。このフラグは結果(ADCn.RESULT)レジスタで未読採取(試料)が上書きされる時に設定(1)されます。このビットへの'0'書き込みは無効です。このビットへの'1'書き込みは結果上書き割り込み要求フラグを解除(0)します。

#### • ビット2 - WCMP : 窓比較器割り込み要求フラグ(Window Comparator Interrupt Flag)

これに'1'を書くことによってこのフラグを解除(0)してください。このフラグは変換または累積が完了し、閾値が制御D(ADCn.CTRLD)レジ スタの窓動作供給元(WINSRC)と窓比較器動作(WINCM)によって設定される、選んだ窓比較器の供給元と動作に一致する時に設定 (1)されます。このビットへの'0'書き込みは無効です。このビットへの'1'書き込みは窓比較器割り込み要求フラグを解除(0)します。

#### ● ビット1 - SAMPRDY : 採取準備可割り込み要求フラグ(Sample Ready Interrupt Flag)

これに'1'を書くこと、または採取(ADCn.SAMPLE)レジスタを読むことによってこのフラグを解除(0)してください。このフラグは変換が完了 して新しい採取(試料)の準備が整った時に設定(1)されます。このビットへの'0'書き込みは無効です。このビットへの'1'書き込みは採 取準備可割り込み要求フラグを解除(0)します。

#### ● ビット0 - RESRDY : 結果準備可割り込み要求フラグ(Result Ready Interrupt Flag)

これに'1'を書くこと、または結果(ADCn.RESULT)レジスタを読むことによってこのフラグを解除(0)してください。このフラグは変換または 累積が完了して新しい結果の準備が整った時に設定(1)されます。このビットへの'0'書き込みは無効です。このビットへの'1'書き込み は結果準備可割り込み要求フラグを解除(0)します。

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

- 名称:STATUS
- **変位** : +\$06
- リセット : \$00

#### 特質 :-

| ビット    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|--------|---|---|---|---|---|---|---|---------|
|        |   |   |   |   |   |   |   | ADCBUSY |
| アクセス種別 | R | R | R | R | R | R | R | R       |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0       |

#### • ビット0 - ADCBUSY : ADC多忙 (ADC Busy)

このビットはADC変換が完了し、構成設定変更に関連する安定時間が終えられた時に解除(0)します。このビットはADCが変換を行っている、または構成設定変更に関連する安定時間を待っている時にに設定(1)されます。

#### 31.5.8. DBGCTRL - デバッグ制御 (Debug Control)

- **変位**:+\$07
- リセット : \$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)

このビットはデベッグ動作でCPUが停止される時にADCが動作を続けるか否かを制御します。

| 値         | 0                                                              | 1                                  |
|-----------|----------------------------------------------------------------|------------------------------------|
| = 1 H H H | ADCはCPUが停止される時のデバッグ動作で動作を続けません。<br>進行中の変換や集中累積はADCが止まる前に終わります。 | ADCはCPUが停止される時のデバッグ動作<br>で動作を続けます。 |

#### **31.5.9. CTRLE - 制御E** (Control E)

| 名称 | : | CTRLE |
|----|---|-------|
|    |   |       |

**変位** : +\$08

リセット : \$00

特質:-

| <u> ビット</u> | 7          | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------------|------------|-----|-----|-----|-----|-----|-----|-----|
|             | SAMPDUR7~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 - SAMPDUR7~0:採取持続時間(Sample Duration)

このビット領域はADCクロック(CLK\_ADC)周期数で入力採取持続時間を制御します。PGAなしでの採取持続時間は(SAMPDUR+½)CLK \_ADC周期です。 PGAを使う場合、入力採取持続時間は(SAMPDUR+1)CLK\_ADC周期で、同時にADC PGA採取持続時間(ADCPGASAMPDUR)はADCがどの位の長さPGAを採取するかを制御します。

PGAなしで内部参照基準を使う場合、SAMPDURは値≧4µs×f<sub>CLK\_ADC</sub>に設定されなければなりません。

# 31.5.10. CTRLF - 制御F (Control F)

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

| ビット    | 7 | 6        | 5       | 4       | 3   | 2     | 1      | 0   |
|--------|---|----------|---------|---------|-----|-------|--------|-----|
|        |   | CHOPPING | FREERUN | LEFTADJ |     | SAMPN | IUM3~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 - CHOPPING : 符号刻み (Sign Shopping)

このビットは変位(オフセット)を減らすために符号刻みが許可されるかどうかを制御します。 単独動作は符号刻みを支援しません。

| 值  | 0       | 1      |
|----|---------|--------|
| 名称 | DISABLE | ENABLE |
| 説明 | 符号刻み禁止  | 符号刻み許可 |

# ● ビット5 - FREERUN : 自由走行 (Free Running)

このビットはADC自由走行動作が許可されるか否かを制御します。 継続累積動作は自由走行動作を支援しません。

| 值  | 0       | 1                                                    |  |  |
|----|---------|------------------------------------------------------|--|--|
| 名称 | DISABLE | ENABLE                                               |  |  |
| 説明 |         | ADC自由走行動作が許可されます。直前の変換また<br>は累積が完了すると直ぐに新しい変換が開始します。 |  |  |

# • ビット4 - LEFTADJ : 左揃え (Left Adjust)

このビットはADC出力が左揃えされるか否かを制御します。

| 值  | 0                | 1                |  |  |
|----|------------------|------------------|--|--|
| 名称 | DISABLE          | ENABLE           |  |  |
| 説明 | ADC出力左揃えが禁止されます。 | ADC出力左揃えが許可されます。 |  |  |

# ● ビット3~0 - SAMPNUM3~0:採取累積数選択 (Sample Accumulation Number Select)

このビット領域は自動的に結果(ADCn.RESULT)レジスタに累積される連続するADC採取数を制御します。ADC採取(ADCn.SAMPLE)レ ジスタで最新の採取が利用可能です。

| 値  |                 | 0000         |        | (  | 0 0 0 1 | C  | 0 0 1 0 | C  | 0 0 1 1 | C   | 100  |
|----|-----------------|--------------|--------|----|---------|----|---------|----|---------|-----|------|
| 名称 | NONE            |              |        |    | ACC2    | 1  | ACC4    | 1  | ACC8    | A   | CC16 |
| 説明 | 累積なし、変換結果毎に単一採取 |              |        | 2拶 | 彩取累積    | 4抣 | 和累積     | 8捋 | 和累積     | 16≹ | 采取累積 |
| 値  | 0101            | $0\ 1\ 1\ 0$ | 0111   | L  | 100(    | )  | 1001    | 1  | 101(    | )   | その他  |
| 名称 | ACC32           | ACC64        | ACC12  | 8  | ACC25   | 6  | ACC51   | .2 | ACC10   | 24  | -    |
| 説明 | 32採取累積          | 64採取累積       | 128採取專 | 累積 | 256採取專  | 累積 | 512採取專  | 累積 | 1024採取  | 累積  | (予約) |

# **31.5.11. COMMAND - 指令** (Command)

| 名称 | : | COMMAND |
|----|---|---------|
|----|---|---------|

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

特質 :-

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

# ● ビット7 - DIFF : 差動 (Differential)

このビットはADC変換がシングルエンドまたは差動のどちらかを制御します。

| [ | 值      | 0 | 1                                                             |
|---|--------|---|---------------------------------------------------------------|
|   | = 및 버린 |   | 符号付き差動変換。正入力多重器(ADCn.MUXPOS)と負入力多重器(ADCn.MUXNEG)の両レジスタが使われます。 |

#### ● ビット6~4 - MODE2~0 : 動作形態 (Mode)

このビット領域はADCに対する変換動作を制御します。累積動作の1つから単独動作への切り替えは累積器をリセットします。

| 値   | 名称             | 説明                                           |
|-----|----------------|----------------------------------------------|
| 000 | SINGLE_8BIT    | 8ビット分解能での単独変換                                |
| 001 | SINGLE_12BIT   | 12ビット分解能での単独変換                               |
| 010 | SERIES         | 継続累積、毎回の12ビット変換に対して独立した起動                    |
| 011 | SERIES_SCALING | 継続累積と尺度調整、毎回の12ビット変換に対して独立した起動               |
| 100 | BURST          | 集中累積。1回の起動が一続きで採取数(SAMPNUM)回の12ビット変換を実行      |
| 101 | BURST_SCALING  | 集中累積と尺度調整。1回の起動が一続きで採取数(SAMPNUM)回の12ビット変換を実行 |
| その他 | _              | (予約)                                         |

# ● ビット2~0 - START2~0:変換開始(Start Conversion)

このビット領域はADC変換を開始または停止するか、またはADC変換をどう開始するかを制御します。

| 値   | 名称            | 説明                                            |
|-----|---------------|-----------------------------------------------|
| 000 | STOP          | 進行中の変換を停止                                     |
| 001 | IMMEDIATE     | 直ちに変換開始。これは自由走行動作が許可されていない限り、変換終了時にSTOPに戻します。 |
| 010 | MUXPOS_WRITE  | 正入力多重器(MUXPOS)レジスタ書き込み終了時に開始                  |
| 011 | MUXNEG_WRITE  | 負入力多重器(MUXNEG)レジスタ書き込み終了時に開始                  |
| 100 | EVENT_TRIGGER | 事象がADCによって受け取られる時に開始                          |
| その他 | _             | (予約)                                          |

注:制御A(ADCn.CTRLA)レジスタのADC許可(ENABLE)ビットが'0'なら、STARTビット領域にIMMEDIATEを書くと、自動的にSTOP を設定します。

# 31.5.12. PGACTRL - PGA制御 (PGA Control)

名称: PGACTRL

- **変位** : +\$0B
- **リセット** : \$04

特質 :-

| ビット    | 7   | 6       | 5   | 4      | 3       | 2 | 1 | 0     |
|--------|-----|---------|-----|--------|---------|---|---|-------|
| [      |     | GAIN2~0 |     | PGABIA | SSEL1,0 |   |   | PGAEN |
| アクセス種別 | R/W | R/W     | R/W | R/W    | R/W     | R | R | R/W   |
| リセット値  | 0   | 0       | 0   | 0      | 0       | 1 | 0 | 0     |

ビット7~5 - GAIN2~0:利得 (Gain)

このビット領域はPGA利得設定を制御します。

| 值  | 000  | 001  | 010  | 011  | 100   | 101  | 110  | 111  |
|----|------|------|------|------|-------|------|------|------|
| 名称 | 1X   | 2X   | 4X   | 8X   | 16X   | _    | _    | -    |
| 説明 | 1倍利得 | 2倍利得 | 4倍利得 | 8倍利得 | 16倍利得 | (予約) | (予約) | (予約) |

# • ビット4,3 - PGABIASSEL1,0 : PGAハイアス選択 (PGA Bias Select)

このビット領域はPGAへ供給されるバイアス電流を制御します。

| 値  | 0 0                                          | 01                                            | 1 0                                                       | 11                                            |
|----|----------------------------------------------|-----------------------------------------------|-----------------------------------------------------------|-----------------------------------------------|
| 名称 | 100PCT                                       | 75PCT                                         | 50PCT                                                     | 25PCT                                         |
| 説明 | 100%バイアス電流<br>f <sub>CLK_ADC</sub> ≦6MHzで使用可 | 75%バイアス電流<br>f <sub>CLK_ADC</sub> ≦4.5MHzで使用可 | 50%ハ <sup>・</sup> イアス電流<br>f <sub>CLK_ADC</sub> ≦3MHzで使用可 | 25%バイアス電流<br>f <sub>CLK_ADC</sub> ≦1.5MHzで使用可 |

#### ビット0 - PGAEN : PGA許可 (PGA Enable)

このビットは窓比較器によってどの供給元が使われるかを制御します。入力多重器(ADCn.MUXPOSまたはADCn.MUXNEG)レジスタの経由(VIA)ビット領域によって選ばれた時にPGAが許可されるか否かを制御します。

| 値  | 0           | 1           |
|----|-------------|-------------|
| 説明 | PGAが禁止されます。 | PGAが許可されます。 |

注: 例えVIAビット領域によって選ばれていなくても、制御A(ADCn.CTRLA)レシ<sup>、</sup>スタの低遅延(LOWLAT)とPGAENの両方が'1'の場 合、PGAは継続的にONです。これはADCがPGAを使うように構成設定する場合に初期化時間をなくします。

#### 31.5.13. MUXPOS - 正入力多重器 (Positive Input Multiplexer)

名称:MUXPOS

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

#### 特質:-

| ビット    | 7   | 6    | 5   | 4   | 3    | 2     | 1   | 0   |
|--------|-----|------|-----|-----|------|-------|-----|-----|
|        | VIA | À1,0 |     | •   | MUXP | OS5~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,6 - VIA1,0 : 経由 (Via PGA)

このビット領域はアナログ入力がどうADCに接続されるかを制御します。

| 值  | 0 0           | 0 1               | その他  |
|----|---------------|-------------------|------|
| 名称 | DIRECT        | PGA               | -    |
| 説明 | ADCへ直接接続される入力 | PGA経由でADCへ接続される入力 | (予約) |

注: MUXPOSとMUXNEGのVIAE<sup>\*</sup>ット領域は共有され、故に2つのレジ<sup>\*</sup>スタの1つのVIAE<sup>\*</sup>ット領域に書かれた値は両方で更新されます。 従って、PGAを使う一方の入力とPGAを使わない他方を持つことはできません。

#### ● ビット5~0 - MUXPOS5~0:正入力多重器 (Positive Input Multiplexer)

このビット領域はどのアナログ入力がADC/PGAの正入力に接続されるかを制御します。この設定の変更は幾らかの安定時間を必要とします。更なる詳細については「電気的特性」章を参照してください。

|   | 值  | \$00 <b>∼</b> \$0B | \$10~\$1F    | \$30 | \$31     | \$32      | \$38    | その他  |
|---|----|--------------------|--------------|------|----------|-----------|---------|------|
| ſ | 名称 | AIN0~AIN11         | AIN16~AIN31  | GND  | VDDDIV10 | TEMPSENSE | DAC0    | -    |
|   | 説明 | ADC入力0~11ピン        | ADC入力16~31ピン | 接地   | VDD/10   | 温度感知器     | D/A変換器0 | (予約) |

# 31.5.14. MUXNEG - 負入力多重器 (Negative Input Multiplexer)

| 名称   | : | MUXNEG |
|------|---|--------|
| 変位   | : | +\$0D  |
| リセット | : | \$00   |

特質 · -

| 1 | r٩ | 貝 | • |  |
|---|----|---|---|--|
|   |    |   |   |  |

| ビット    | 7   | 6    | 5   | 4   | 3    | 2     | 1   | 0   |
|--------|-----|------|-----|-----|------|-------|-----|-----|
|        | VIA | Å1,0 |     |     | MUXN | EG5~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,6 - VIA1,0 : 経由 (Via PGA)

このビット領域はアナログ入力がどうADCに接続されるかを制御します。

| 值  | 0 0           | 0 1               | その他  |
|----|---------------|-------------------|------|
| 名称 | DIRECT        | PGA               | -    |
| 説明 | ADCへ直接接続される入力 | PGA経由でADCへ接続される入力 | (予約) |

注: MUXPOSとMUXNEGのVIAE<sup>\*</sup>ット領域は共有され、故に2つのレジ<sup>\*</sup>スタの1つのVIAE<sup>\*</sup>ット領域に書かれた値は両方で更新されます。 従って、PGAを使う一方の入力とPGAを使わない他方を持つことはできません。

# ●ビット5~0 - MUXNEG5~0: 負入力多重器 (Negative Input Multiplexer)

このビット領域はどのアナログ入力がADC/PGAの負入力に接続されるかを制御します。この設定の変更は幾らかの安定時間を必要とします。更なる詳細については「電気的特性」章を参照してください。

| 值  | \$00 <b>∼</b> \$0B | \$10~\$1F    | \$30 | \$38    | \$39         | \$3A         | その他  |
|----|--------------------|--------------|------|---------|--------------|--------------|------|
| 名称 | AIN0~AIN11         | AIN16~AIN31  | GND  | DAC0    | DACREF0      | DACREF1      | -    |
| 説明 | ADC入力0~11ピン        | ADC入力16~31ピン | 接地   | D/A変換器0 | AC0からのDACREF | AC1からのDACREF | (予約) |

# 31.5.15. RESULT - 結果 (Result)

名称: RESULT (RESULT3, RESULT2, RESULT1, RESULT0)

**変位** : +\$10

# **リセット** : \$00000000

特質 :-

ADCn.RESULT0~ADCn.RESULT3のレジネタは32ビット値のADCn.RESULTを表します。最下位ハイト(ビット7~0、接尾辞0)は変位原点でアクセスできます。n高レハイト(ビット31~8)は変位+nでアクスセすることができます。

このレジスタからの出力の詳細については「出力形式」項を参照してください。

| ۲ <sup>*</sup> ット | 31          | 30       | 29 | 28    | 27     | 26 | 25 | 24 |
|-------------------|-------------|----------|----|-------|--------|----|----|----|
|                   | RESULT31~24 |          |    |       |        |    |    |    |
| アクセス種別            | R           | R        | R  | R     | R      | R  | R  | R  |
| リセット値             | 0           | 0        | 0  | 0     | 0      | 0  | 0  | 0  |
| <b>ビット</b>        | 23          | 22       | 21 | 20    | 19     | 18 | 17 | 16 |
|                   |             |          |    | RESUL | T23~16 |    |    |    |
| アクセス種別            | R           | R        | R  | R     | R      | R  | R  | R  |
| リセット値             | 0           | 0        | 0  | 0     | 0      | 0  | 0  | 0  |
| ۲<br>۲. ۲         | 15          | 14       | 13 | 12    | 11     | 10 | 9  | 8  |
|                   |             | · · · ·  |    | RESUL | T15~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  |
|                   |             | <u>.</u> |    | RESUI | LT7~0  |    |    |    |
| アクセス種別            | R           | R        | R  | R     | R      | R  | R  | R  |
| リセット値             | 0           | 0        | 0  | 0     | 0      | 0  | 0  | 0  |
|                   |             |          |    |       |        |    |    |    |

# • ビット31~24 - RESULT31~24 : 結果バト3 (Result byte 3)

このビット領域はADCn.RESULTレジスタの最上位バイトを構成します。

- ビット23~16 RESULT23~16 : 結果バイト2 (Result byte 2)
- このビット領域はADCn.RESULTレジスタの第3バイトを構成します。
- ビット15~8 RESULT15~8 : 結果バイト1 (Result byte 1)
- このビット領域はADCn.RESULTレジスタの第2バイトを構成します。
- ビット7~0 RESULT7~0: 結果バイト0 (Result byte 0)

このビット領域はADCn.RESULTレジスタの最下位バイトを構成します。

# 31.5.16. SAMPLE - 採取 (Sample)

名称:SAMPLE (SAMPLEH,SAMPLEL)

**変位** : +\$14

リセット : \$0000

# 特質 :-

ADCn.SAMPLEHとADCn.SAMPLELのレシブスタ対は16ビット値のADCn.SAMPLEを表します。下位ハイト(ビット7~0、接尾辞L)は変位原 点でアクセスできます。上位ハイト(ビット15~8、接尾辞H)は変位+1でアクセスすることができます。 このレジブタからの出力の詳細については「出力形式」項を参照してください。

| 11  | 10          | 9   | 8                                                                                     |
|-----|-------------|-----|---------------------------------------------------------------------------------------|
| 5~8 |             |     |                                                                                       |
| R   | R           | R   | R                                                                                     |
| 0   | 0           | 0   | 0                                                                                     |
| 3   | 2           | 1   | 0                                                                                     |
| 7~0 |             |     |                                                                                       |
| R   | R           | R   | R                                                                                     |
| 0   | 0           | 0   | 0                                                                                     |
|     | R<br>0<br>3 | 5~8 | K         R         R           0         0         0           3         2         1 |

• ビット15~8 - SAMPLE15~8: 採取上位バイ (Sample high byte)

このビット領域はこの16ビットレジスタの上位バイトを構成します。

• ビット7~0 - SAMPLE7~0:採取下位バ仆 (Sample low byte)

このビット領域はこの16ビットレジスタのの下位バイトを構成します。

**31.5.17. TEMPn - 一時n** (Temporary n)

名称:TEMP0:TEMP1:TEMP2 変位:+\$18:+\$19:+\$1A リセット:\$00

特質 :-

一時レジスタはこの周辺機能の16ビットと32ビットのレジスタへの単一周期アクセスのためにCPUによって使われます。このレジスタはこの周辺 機能の全ての16ビットと32ビットのレジスタに対して共通で、ソフトウェアによって読み書きすることができます。16ビットと32ビットのレジスタの読 み書きのより多くの詳細については「メモリ」章の「24ビットと32ビットのレジスタのアクセス」を参照してください。

| ビット    | 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ビットと32ビットのレジスタに対する読み書き用の一時的なビット領域。

31.5.18. WINLT - 窓比較器下側閾値 (Window Comparator Low Threshold)

名称:WINLT (WINLTH,WINLTL)

**変位** : +\$1C

**リセット** : \$0000

特質 :-

このレジスタはADCの結果または採取(ADCn.RESULTまたはADCn.SAMPLE)のレジスタを監視するデジタル比較器用の16ビット下側閾値 です。データ形式は変換動作形態と左揃え設定に従わなければなりません。

ADCn.WINLTHとADCn.WINLTLのレジスタ対は16ビット値のADCn.WINLTを表します。下位バイト(ビット7~0、接尾辞L)は変位原点でア クセスできます。上位バイト(ビット15~8、接尾辞H)は変位+1でアクセスすることができます。

累積動作でADC結果レジスタ監視時、窓比較器閾値は全ての累積と任意選択の尺度調整が済んだ後の結果に対して適用されます。

| 15  | 14                   | 13                               | 12                                                                            | 11                                                                                                                                                                                                                                             | 10                                                                                                                                                                           | 9                                                                                                                                                                                                                                                                          | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|----------------------|----------------------------------|-------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                      |                                  | WINLT15                                                                       | ~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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|     |                      |                                  | WINLT7                                                                        | ~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<br>R/W | R/W R/W<br>0 0<br>7 6<br>R/W R/W | R/W     R/W     R/W       0     0     0       7     6     5       R/W     R/W | WINLT15           R/W         R/W         R/W         R/W           0         0         0         0           7         6         5         4           WINLT7         WINLT7         WINLT7           R/W         R/W         R/W         R/W | WINLT15~8           R/W         R/W         R/W         R/W           0         0         0         0           7         6         5         4         3           WINLT7~0 | WINLT15~8           R/W         R/W         R/W         R/W         R/W           0         0         0         0         0           7         6         5         4         3         2           WINLT7~0           R/W         R/W         R/W         R/W         R/W | WINLT15~8           R/W         R/W |

● ビット15~8 - WINLT15~8 : 窓比較器下側閾値上位バイト (Window Comparator Low Threshold high byte)

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

● ビット7~0 - WINLT7~0:窓比較器下側閾値下位ハイ (Window Comparator Low Threshold low byte) このビット領域は16ビットレジスタの下位バイトを保持します。

31.5.19. WINHT - 窓比較器上側閾値 (Window Comparator High Threshold)

名称:WINHT (WINHTH,WINHTL)

**変位** : +\$14

リセット : \$0000

特質:-

このレジスタはADCの結果または採取(ADCn.RESULTまたはADCn.SAMPLE)のレジスタを監視するデジタル比較器用の16ビット上側閾値 です。データ形式は変換動作形態と左揃え設定に従わなければなりません。

ADCn.WINHTHとADCn.WINHTLのレジスタ対は16ビット値のADCn.WINHTを表します。下位ハイト(ビット7~0、接尾辞L)は変位原点で アクセスできます。上位ハイト(ビット15~8、接尾辞H)は変位+1でアクセスすることができます。

累積動作でADC結果レジスタ監視時、窓比較器閾値は全ての累積と任意選択の尺度調整が済んだ後の結果に対して適用されます。

| ビット        | 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ビットレジスタの下位バイトを保持します。

# 32. DAC - D/A変換器

# 32.1. 特徴

- ・10ビット分解能
- ・高い駆動能力
- ・DAC出力は他のアナログ周辺機能への入力として使用可能

# 32.2. 概要

デジタル/アナログ変換器(DAC)はデータ(DACn.DATA)レジスタに書かれたデジタル値をアナログ電圧に変換します。変換範囲はGNDと基準 電圧(VREF)で選んだ電圧参照基準間です。DACは高い駆動能力を持つ1つの連続時間出力を持ちます。データ(DACn.DATA)レジ スタに書くことによって応用からDAC変換を開始してください。

# 32.2.1. 構成図



# 32.2.2. 信号説明

| 信号  | 形式     | 説明       |
|-----|--------|----------|
| OUT | アナログ出力 | D/A変換器出力 |

# 32.3. 機能的な説明

# 32.3.1. 初期化

DACを操作するには、以下の手順が必要とされます。

- 1. 適切な参照基準選択ビットを書くことによって基準電圧(VREF)周辺機能でDAC参照基準電圧を選んでください。
- 2. DAC出力の更なる使い方を構成設定してください。
  - DAC出力を使う内部周辺機能を構成設定してください。各々の周辺機能の記述を参照してください。
  - 制御A(DACn.CTRLA)レジスタの出力緩衝部許可(OUTEN)ビットに'1'を書くことによってピンへの出力を許可してください。DAC ピン用の入力はPORT周辺機能で禁止(PORTx.PINnCTRLのISC=INPUT\_DISABLEに)されなければなりません。
- 3. 初期デジタル値をデータ(DACn.DATA)レジスタに書いてください。
- 4. 制御A(DACn.CTRLA)レジスタのDAC許可(ENABLE)ビットに'1'を書くことによってDACを許可してください。

# 32.3.2. 動作

# 32.3.2.1. 許可、禁止、リセット

DACは制御A(DACn.CTRLA)レジスタのDAC許可(ENABLE)ビットに'1'を書くことによって許可され、このビットに'0'を書くことによって 禁止されます。

# 32.3.2.2. 変換開始

制御A(DACn.CTRLA)レジスタのDAC許可(ENABLE)ビットが'1'の時にデータ(DACn.DATA)レジスタが書かれると、直ぐに変換が始まります。

DACn.CTRLAレジスタのENABLEビットが'0'の時のDACn.DATAレジスタ書き込みは変換を起動しません。代わりに、DACn.CTRLAレジ、スタのENABLEビットが'1'の時に変換が始まります。

#### 32.3.2.3. DAC出力電圧(訳補:次頁の脚注をご覧ください。)

DAC周辺機能からのアナログ出力電圧はDACn.OUTピンで見つかります。詳細については「入出力多重化と考察」章をご覧ください。 次式はDAC出力電圧を定義します。

DACn出力電圧 =  $\left(\frac{\text{DACn.DATA}}{1024}\right) \times \text{DAC参照基準電圧}$ 

DATAレジスタに入った10ビット値は正しい電圧割合を得るためにレジスタの最大値(10ビット最大値は2<sup>10</sup>=1024)によって割られなければなりません。

得られる最大値はDATA=210の時で、結果として電圧は選んだDAC参照基準電圧になります。

最小の結果はDATA=0の時で、出力は0です。

電圧出力に対する段階量は DAC参照基準電圧 Vです。

# 32.3.2.4. DAC出力

DACはピンへの出力と下表で示される周辺機能への入力として使うことができます。

| DAC出力 | 周辺機能入力      | 注記                                                              |
|-------|-------------|-----------------------------------------------------------------|
| 非緩衝   | A/D変換器(ADC) | 周辺機能は非緩衝DAC出力に接続されます。「32.3.2.4.1. 内部周辺機能用供給元としての非緩衝出力」項をご覧ください。 |
| 緩衝    | -           | 周辺機能はDAC出力ピンに接続されます。「32.3.2.4.2. 緩衝出力」項をご覧ください。                 |

#### 32.3.2.4.1. 内部周辺機能用供給元としての非緩衝出力

DACの非緩衝アナログ出力は制御A(DACn.CTRLA)レジズタのDAC許可(ENABLE)ビットが'1'の時に内部周辺機能に対する供給元として使うことができます。

DACの非緩衝アナログ出力だけを使う時は、DACn.CTRLAの出力緩衝部許可(OUTEN)ビットを'0'にすることができ、DAC出力ピンを 他の周辺機能によって使われるように自由にします。

#### 32.3.2.4.2. 緩衝出力

制御A(DACn.CTRLA)レジスタの出力緩衝部許可(OUTEN)ビットに'1'を書くことによってDACの緩衝アナログ出力を許可してください。 DACn.CTRLAの出力緩衝部範囲(OUTRANGE)ビット領域に書くことによって出力緩衝部範囲を構成設定してください。DAC出力緩 衝部の駆動能力についての情報に関しては「電気的特性」章を参照してください。

注: 消費電力を減らすため、DAC出力ピンはPORT周辺機能でそれの禁止された入力を持たなければなりません。どのピンがDAC出力によって使われるかを判定するには「入出力多重化と考察」章を参照してください。

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

制御A(DACn.CTRLA)レジズタのスタンハイ時走行(RUNSTDBY)ビットが'1'の場合、DACはスタンハイ休止動作で動作を続けます。RUNST DBYビットが'0'の場合、DACはスタンハイ休止動作で変換を停止します。

スタンハイ休止動作で変換が停止された場合、消費電力を減らすためにDACと出力緩衝部が禁止されます。デバイスがスタンハイ休止動 作を止めると、DACと(DACn.CTRLAレジスタで出力緩衝部許可(OUTEN)ビットが'1'なら)出力緩衝部が再び許可されます。従って、新 しい変換が始められるのに先立って始動時間が必要とされます。

パワーダウン休止動作では、消費電力を減らすためにDACと出力緩衝部が禁止されます。

(訳注) 32.3.2.3.項で10ビットのDATAレジスタの最大値が1024とされていますが、実際は1023です。10ビットで表せる数は0~1023の1024 種で、最大値は1023です。これは理屈上の説明か、または誤りでしょう。ここでは単に0~基準電圧間を1024分割していると言 うことを説明しているだけと考えられます。他の資料でも一貫して出力値は(DATA/1024)×基準電圧と記載されているので、 実際の最高出力電圧は(1023/1024)×基準電圧と思われます。別の見方ですが、基準電圧自体の誤差を考慮すると、1 LSB の誤差は問題にならないとの考えかもしれません。

# 32.4. レジスタ要約

| 変位    | 略称         | ビット位置 | ビット7     | ビット6  | ビット5  | ビット4   | ビット3 | ビット2 | ビット1 | ビット0   |
|-------|------------|-------|----------|-------|-------|--------|------|------|------|--------|
| +\$00 | CTRLA      | 7~0   | RUNSTDBY | OUTEN | OUTRA | NGE1,0 |      |      |      | ENABLE |
| +\$01 | 予約         |       |          |       |       |        |      |      |      |        |
| +\$02 |            | 7~0   | DAT      | A1,0  |       |        |      |      |      |        |
| +\$03 | +\$03 DATA |       |          |       |       | DAT    | A9~2 |      | 1    |        |

# 32.5. レジスタ説明

# 32.5.1. CTRLA - 制御A (Control A)

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

特質 :-

| ビット    | 7        | 6     | 5 4   |        | 3 | 2 | 1 | 0      |
|--------|----------|-------|-------|--------|---|---|---|--------|
|        | RUNSTDBY | OUTEN | OUTRA | NGE1,0 |   |   |   | ENABLE |
| アクセス種別 | R/W      | R/W   | R/W   | R/W    | 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信号をピンへ送ります。

#### ● ビット5,4 - OUTRANGE1,0 : 出力緩衝部範囲 (Output Buffer Range)

このビット領域は出力緩衝部の範囲を制御します。出力緩衝部範囲はデータ(DACn.DATA)レジスタの低位値(LOW)、上位DATA値(HI GH)、またはこれら2つの設定間の交互切替(FULL)に最適化することができます。交互切替はDATAレジスタの最上位ビット(MSb)によって起動されます。各種ビット領域値に対するDAC出力緩衝部の駆動能力については「電気的特性」章を参照してください。

| 值  | 0 0      | 01   | 1 0      | 11       |
|----|----------|------|----------|----------|
| 名称 | FULL     | _    | LOW      | HIGH     |
| 説明 | 全出力緩衝部範囲 | (予約) | 低出力緩衝部範囲 | 高出力緩衝部範囲 |

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

このビットへの'1'書き込みがDACを許可します。

#### **32.5.2. DATA** − **7**<sup>\*</sup>−**9** (Data)

- 名称:DATA (DATAH,DATAL)
- **変位** : +\$02

# **リセット** : \$0000

# 特質 :-

DACn.DATAHとDACn.DATALのレジスタ対は次のように10ビット値のDACn.DATAを表します。

- ・DACn.DATA9~2 = (変位+1でアクセスすることができる) DACn.DATAH
- ・DACn.DATA1,0 = (変位原点でアクセスすることができる) DACn.DATAL

出力はDACn.DATAHが書かれた後に更新されます。

| <b>ビ</b> ット _ | 15  | 14   | 13  | 12  | 11   | 10  | 9   | 8   |
|---------------|-----|------|-----|-----|------|-----|-----|-----|
|               |     |      |     | DAT | A9~2 |     |     |     |
| アクセス種別        | 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   | 4 3  |     | 1   | 0   |
|               | DAT | A1,0 |     |     |      |     |     |     |
| アクセス種別        | R/W | R/W  | R   | R   | R    | R   | R   | R   |
| リセット値         | 0   | 0    | 0   | 0   | 0    | 0   | 0   | 0   |

# ビット15~6 - DATA9~0 : データ (Data)

これらのビットはアナログ電圧に変換してDAC出力に送るデジタルデータを含みます。

# 33. UPDI - 統一プログラム/デバッグ インターフェース

# 33.1. 特徴

- ・外部プログラミングとチップ上ディ、ック(OCD)用UPDI単線インターフェース
- 高電圧またはヒューズによるプログラミング許可
- UPDI機能の許可にRESETピンとプログラミング用にデバイスの1つのUPDIピンを使用
- 書き込み器に対する非同期半二重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層を通して許されます。

プログラミングとディバッグはデータの受信と送信に対して専用のUPDIピンを使う半二重インターフェースに基づく単線UARTのPHY層を通して行われます。PHY層のクロック駆動は専用内部発振器によって行われます。

ACC層はUPDIと接続されたバス配列間のインターフェースです。この層はメモリ、NVM、周辺機能のようなシステム部へのメモリ割り当てアクセスを 持つバス配列に対してUPDI経由でのアクセスを許します。

非同期システム インターフェース(ASI:Asynchronous System Interface)はOCD、NVM、システム管理系で機能を選ぶための直接インターフェース アクセスを提供し、これはバス アクセスを要求することなく、システム情報への直接アクセスをデバッガに与えます。

# 33.2.1. 構成図



# 33.2.2. プログラム メモリ空間のアドレス指定

CPUデータ空間で、I/Oメモリ、ヒューズ、EEPROM、SRAMは\$0000 ~\$7FFFのアトレスに置かれます。加えて、(32Kハ'イトまでの)フ ラッシュメモリの部分は\$8000~\$FFFFのアトレスに割り当てること ができます。これらのアトレス(\$0000~\$FFFF)はUPDI周辺機能 によるアクセスに対しても有効です。

CPUコート<sup>\*</sup>空間、即ち、フラッシュメモリ全体は相対アト<sup>\*</sup>レス\$0000から始まるLPM/SPM命令を使ってCPUによってアクセスすることができます。UPDIによるアクセスについてはCPUデータ空間とCPUコート<sup>\*</sup>空間が仮想的に1つの続いたアト<sup>\*</sup>レス空間で、コート<sup>\*</sup>空間は常に\$80\_000の変位アト<sup>\*</sup>レスで始まります。

与えられたデバイスでのメモリ空間の正確なアドレスとより多くの詳細については「メモリ」章をご覧ください。

#### 図33-2. UPDIから見たメモリ割り当て



# 33.2.3. クロック

PHY層とACC層は違うクロック領域で動くことができます。PHY層クロックは専用内部発振器から得られ、ACC層クロックは周辺機能クロックと同じです。PHY層とACC層間にはクロック領域間の正しい動作を保証する同期境界があります。UPDIクロック出力周波数はASIを通して 選ばれ、UPDI許可またはリセット後の既定UPDIクロック始動周波数は4MHzです。UPDIクロック周波数はASI制御A(UPDI,ASI\_CTRLA)レシ スタのUPDIクロック分周器選択(UPDICLKSEL)とット領域を書くことによって変更することができます。



# 33.2.4. 物理層

PHY層は接続された書き込み器/デ・バッガとデ・バイス間の通信インターフェースです。PHY層の主な機能は次のように要約することができます。

- ・UPDIピンで半二重UART通信を使い、UPDI単線非同期動作を支援
- ・内部ボーレート検出、UARTフレームでのクロックとデータの再生
- ・異常検出(パリティ、クロック再生、フレーム、システム異常)
- ・送信応答生成(ACK)
- ・動作中の異常識票の生成
- ・保護時間制御

# 33.2.5. ピン配置説明

次表はUPDIによって使われるピンの機能を示します。UPDI物理ピンについてのより多くの情報に関してはデバイスのデータシートの「入出 力多重化と考察」章をご覧ください。

| 機能   | ピン名        |  |  |  |  |  |  |
|------|------------|--|--|--|--|--|--|
| UPDI | UPDI / PF7 |  |  |  |  |  |  |

# 33.3. 機能的な説明

#### 33.3.1. 動作の原理

UPDIを通す通信は固定フレーム形式、クロックとデータの再生 に対する自動ボーレート検出を用いる標準USART通信に 基づきます。データフレームに加えて、通信のためにいくつ かの制御フレーム(DATA、IDLE、BREAK、SYNCH、ACK) が重要です。



| フレーム  | 説明                                                                                                                                                                                                                                                   |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DATA  | DATAフレームは常にLowの1開始(St)ビット、8データビット、偶数パリティ用の1パリティ(P)ビット、常にHighの2停止(S1とS2)ビット<br>から成ります。パリティビットまたは停止ビットが不正な値を持つ場合、誤りが検出されてUPDIによって合図されます。UP<br>DIでのパリティビット検査は制御A(UPDI.CTRLA)レジスタのパリティ禁止(PARD)ビットに('1'を)書くことによって禁止すること<br>ができ、その場合、デバッガからのパリティ生成は無視されます。 |
| IDLE  | IDLEは最低12個のHighビットから成る特別なフレームで、送信線をアイトル(IDLE)状態で維持するのと同じです。                                                                                                                                                                                          |
| BREAK | BREAKは最低12個のLowt'ットから成る特別なフレームです。UPDIを既定状態に戻してリセットするのに使われ、代表的に<br>異常回復に使われます。                                                                                                                                                                        |
| SYNCH | ボーレート生成部は到着する伝送に対してボーレートを設定するためにSYNCHフレームを使います。SYNCH文字は毎回の<br>新しい命令の前とBREAKが成功裏に送信された後でUPDIによって常に期待されます。                                                                                                                                             |
| ACK   | ACKフレームはSTまたはSTSの命令が成功裏に同期境界を渡ってバス アクセスを得られた時に必ずUPDIから送信されま<br>す。デバッガによってACKが受信されると、次の送信を開始することができます。                                                                                                                                                |

#### 33.3.1.1. UPDI UART

通信はデバッガ/書き込み器側から開始されます。毎回の送信はSYNCH文字で開始しなければならず、これはUPDIが送信ボーレートを 再生して到着データ用にこの設定を格納するのに使うことができます。SYNCH文字によって設定されるボーレートは後続する命令とデータ のバイトの受信と送信の両方に使われます。次のSYNCH文字が命令の流れで予期される時の詳細については「UPDI命令一式」項を ご覧ください。

UPDIには書き込み可能なボーレートレジスタがなく、故にデータ バイトを採取する時のデータ再生にSYNCH文字から採取されたボーレートが使われます。

PHY層の送信ボーレートは選んだUPDIクロックに関連付けされ、ASI制御A(UPDI.ASI\_CTRLA)レジスタのUPDIクロック分周器選択(UPDICLK

SEL)ビット領域を書くことによって調整することができます。送受信の ボーレートは自動ボーレートの精度内で常に同じです。このクロックは望む ボーレートに必要な周波数よりも速く走行しないことが推奨されます。リ セット、許可後の既定UPDICLKSEL設定は4MHzです。他のどのクロッ ク出力選択もBODが最高基準の時にだけ推奨されます。他の全て のBOD設定に対し、既定の4MHz選択が推奨されます。

UPDIボーレート生成部は送信誤差を最小にするために分数ボーレート

計数を利用します。UPDIによって 使われる固定フレーム形式での最大 と推奨される受信部転送誤差限 度は表33-2.で見ることができま す。

| 表33-2. 受信部ボーレート誤差 |                       |          |             |               |  |  |  |  |  |  |  |
|-------------------|-----------------------|----------|-------------|---------------|--|--|--|--|--|--|--|
| テ゛ータ+ハ゜リティ ヒ゛ット   | R <sub>slow</sub> (%) | Rfast(%) | 最大総合許容誤差(%) | 推奨最大受信許容誤差(%) |  |  |  |  |  |  |  |
| 9                 | 96.39                 | 104.76   | -3.61~+4.76 | ±1.5          |  |  |  |  |  |  |  |

UPDICLKSEL1,0

11(4MHz)-既定

0 0 (32MHz)

0 1 (16MHz)

10 (8MHz)

表33-1. UPDICLKSEL設定に基づく推奨UARTボーレート

最大推奨ボーレート

1.8 Mbps

0.9Mbps

450kbps

225kbps

最小推奨ボーレート

600 bps

300 bps

150 bps

75bps

#### 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クロック選択にリセットされ、これは上の「U PDICLKSEL設定に基づく推奨UARTボーレート」表に従ってUPDIのボーレート範囲を変更します。

#### 33.3.1.2.1. 単線動作でのBREAK

単線動作で、書き込み器/デバッカ\*とUPDIは完全に同期が外れることがあり、 UPDIがそれを検出できることを保証するためにBREAK文字の最悪長を必要 とします。4MHz(250ns)の最低UPDI/Dロック速度と仮定し、16ビットに含まれ得る 8ビットSYNCH様式値の最大長は、65535×250ns=16.4ms/パイト=16.4ms/8ビッ ト=2.05ms/ビットです。

これは最低の前置分周器設定に対して2.05ms×12ビット≒24.6msの最悪 BREAK7レーム持続時間を与えます。前置分周器設定が既知なら、BREAK7 レームの時間は**表33-3**.からの値に従って緩和されます。

| 表33−3. 推奨中断(BREAK)文字持続時間 |               |  |  |  |  |  |  |  |  |
|--------------------------|---------------|--|--|--|--|--|--|--|--|
| UPDICLKSEL1,0            | 推奨BREAK文字持続時間 |  |  |  |  |  |  |  |  |
| 0 0 (32MHz)              | 3.075ms       |  |  |  |  |  |  |  |  |
| 0 1 (16MHz)              | 6.15ms        |  |  |  |  |  |  |  |  |
| 1 0 (8MHz)               | 12.30 ms      |  |  |  |  |  |  |  |  |
| 1 1 (4MHz)               | 24.60ms       |  |  |  |  |  |  |  |  |

#### 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ヒンをどう構成設定したかに応じて、UPDIを許可するにの以下の2つの方法の1つを使うことができます。

- 単線許可 この方法はシステム構成設定0(SYSCFG0)ヒューズのUPDIビン構成設定(UPDIPINCFG)ビットを'1'に設定することによって UPDI機能動作で構成設定されるUDPIビンを必要とします。
- UPDIL<sup>®</sup>ンのHV指定変更 この方法はUPDIL<sup>®</sup>ンがGPIO動作(SYSCFG0ヒューズのUPDIPINCFG)L<sup>®</sup>ットの<sup>'0</sup>、設定)に構成設定される 場合に使われます。RESETでのHV(高電圧)ハ<sup>®</sup>ルス印加はUPDIL<sup>®</sup>ンをUPDI機能動作に再構成設定し、 従ってSYSCFG0ヒューズでの構成設定を無効にします。

#### 33.3.2.1.1. 単線許可

UPDIピンは許可時に一定のプルアップを持ち、200nsを超える間UPDIピンをLowに駆動することにより、接続された書き込み器/デバッガ が始動手順を始めます。事前要件として、UPDIピンはSYSCFG0ヒュース、のUPDIPINCFGを'1'に設定するか、またはRESET ピンにHVパ ルスを印加し、結果としてUPDIPINCFGの構成設定を無効にするかのどちらかによってUPDI機能動作に構成設定されなければなりま せん。

UPDIを許可するには次のこの手順に従ってください。

- 1. UPDIピンを200nsを超える間Lowに駆動してそれを開放してください。UPDIピンは内部プルアップ抵抗を持ち、200nsを超える間UPD IピンをLowに駆動することにより、接続された書き込み器が始動手順を始めます。
  - ・端検出器はUPDIピンのLow駆動を始め、故に書き込み器が線を開放した時にLowに留まります。
  - ・ UPDIクロックが開始されます。UPDIはクロックが安定し、UPDIが使う準備が整うまで線をLowに駆動します。クロックに対して期待される到来時間は精度、行き過ぎ、発振器校正の読み出しに関する発振器実装に依存します。
  - ・データ線はUPDIによって解放され、発振器の準備が整って安定な時にHighに引かれます。

- 2. ピンが再びHighに遷移する時を検出するためにUPDIピンをホーリングしてください。この遷移は端検出器がピン(プルアップ)を開放し、 UPDIがSYNCH文字を受信することができることを示します。
- 3. SYNCH文字(\$55)を送ってください。SYNCH文字送信成功後、最初の命令フレームを送信することができます。
- 4. KEY命令を使ってNVMPROG鍵を送ってください。この鍵の送出が施錠ビットを解除し、ASIシステム状態(ASI\_SYS\_STATUS)レジスタのNVMプログラミング開始(PROGSTART)ビットが設定(1)されます。デバイスは今やプログラミング用に準備されています。
- 5. プログラミング完了後、STCS命令を使って制御B(UPDI.CTRLB)レジスタのUPDI禁止(UPDIDIS)ビットに'1'を書くことによってUPDIをリ セットしてください。UPDI、従って付随するクロック要求の禁止は消費電力を減らします。

許可手順のタイミングが図33-5.で示され、ここでは書き込み器と端検出器に対する駆動活動期間が含まれます。'UPDIピン'波形は常にピン値を示します。

#### 図33-5. UPDI許可手順 (1)① UPDIクロックを要求するためにデバッガからLow駆動 St /D0 D1 /D2 D3 /D4 D5 /D6 D7 P /Sp1 Sp2 UPDIピン ハント・シェーク/BREAK (t<sub>RES</sub>) 同期(SYNCH(\$55))(自動ボーレート) (無効) UPDI.rxd (2)UPDI.txd Hi-Z - Hi–Z -② UPDIクロック準備可、通信チャネル準備可 UPDI.txd=<mark>0</mark> (t<sub>UPDI</sub>) デバッガの Hi-Z· -- **--** Hi-Z -UPDI.txd デバッカ.txd=0 (t<sub>Deb0</sub>) デバッカ.txd=z (tDebZ)

端検出器駆動活動期間に対して与えられる遅延は代表的に32MHz発振器での256周期間の始動時間待ち+校正読み出しです。予 測される始動時間の詳細については「電気的特性」章を参照してください。

注: 許可手順のSYNCHが最初の命令に対してボーレート生成部を準備するため、最初の許可SYNCH後に発行される最初の命令は余分なSYNCHが不要です。

線がHighなことをデバッガが検出すると、UPDI通信データ速度を同期するために最初のSYNCH文字(\$55)が送られなければなりません。SYNCH文字の開始ビットが最大t<sub>DebZ</sub>内に送られない場合、UPDIは自身を禁止し、UPDI許可手順は再び始められなければなりません。タイシング違反の場合、UPDIの意図せぬ許可を避けるためにUPDIは禁止されます。より多くの詳細については「33.3.2.2.1. 始動中の禁止」をご覧ください。

注: tRES、tUPDI、tDeb0、tDebZに対する実際の値は「電気的特性」章で見つけることができます。

# 33.3.2.1.2. UPDIL<sup>°</sup>ンの高電圧無効化でのUPDI許可

応用はUDPIピンを入出力ピンとして構成設定することができます。この場合、通常の単線許可手順を使くことができません。

- RESETピンへ印加したHV(高電圧)パルスがUPDIピンのピン機能をUPDI機能に切り換えます。
- 1. 図33-6.と「電気的特性」章で記述されるようにHV信号を印加してください。HVはPORが解放されてしまった後に印加されなけれ ばなりません。これはUPDIヒンのビン構成設定を無効にします。HV検出回路はデバイスリセットを起動します。CPUは有効なUPDI鍵 の受信またはtuPDI\_TIMEOUTの経過まで停止に留まります。このような鍵が受信されない場合、デバイスはリセットし、UPDIヒンは ヒューズによって指定される構成設定を持ちます。
- 2. 「33.3.2.1.1. 単線許可」で記述されるような通常の単線許可手順に従ってください。tuppI\_TIMEOUT(経過)の前に有効なUPDI鍵が送られなければなりません。
- 3. HVハ<sup>°</sup>ルスによってUPDIが許可されると、PORだけがUPDIヒ<sup>°</sup>ンの無効化を禁止して設定をヒュースによって構成設定されるように回復します。



- 注: ・ UPDIピンに不充分な外部保護しか追加されない場合、デバイスによってESDパルスが高電圧無効化とUPDI許可として解釈される可能性があります。
  - ・UPDI HV活性化の実際の閾値電圧はVDDに依存します。より多くの詳細については「電気的特性」章をご覧ください。
  - ・tuppi TIMEOUTの値については「電気的特性」章をご覧ください。

#### 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文字の扱いについては「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文字が先行されなければなりません。送信に対するボーレート設定についての情報に関しては「UPDI UART」をご覧ください。図33-8.はUPDI命令一式の概要を与えます。

| 凶33-8. UPDI命令一式概要 |            |            |     |     |          |       |      |                               |    |     |          |          |     |       |      |      |     |     |          |       |       |
|-------------------|------------|------------|-----|-----|----------|-------|------|-------------------------------|----|-----|----------|----------|-----|-------|------|------|-----|-----|----------|-------|-------|
|                   | 指令 A量 D量   |            |     |     |          |       |      |                               |    |     |          |          |     |       |      |      |     |     |          |       |       |
| LDS               | 0 0 0      |            | 0   | 0   | Х        | 0     | Х    | 指令                            |    |     |          |          |     |       |      |      |     |     |          |       |       |
| STS               | 0 1 0      |            | 0   | 0   | Х        | 0     | Х    | 000LDS(直接アドレス指定データ取得)         |    |     |          |          |     |       |      |      |     |     |          |       |       |
|                   | · · ·      |            |     | PTI | R種別      | A/D   | )量   | 0                             | 0  | 1   | LD (間接   | 妾アトレス打   | 指定  | データ   | 取往   | 导)   |     |     |          |       |       |
| LD                | 0 0 1      |            | 0   | Х   | Х        | 0     | X    | 0                             | 1  | 0   | STS (直   | 接アドレス    | 指定  | ミデー   | 般    | 定)   | )   |     |          |       |       |
| ST                | 0 1 1      |            | 0   | Х   | X        | 0     | X    | 0                             | 1  | 1   | ST (間接   | 妾アト・レス 扌 | 指定: | データ   | 設分   | Ë)   |     |     |          |       |       |
|                   |            |            |     |     | CS7      | ドレス   |      | 1                             | 0  | 0   | LDCS (I  | LDS 制銜   | 卸/状 | 能レ    | ジス   | 9)   |     |     |          |       |       |
| LDCS              | 1 0 0      |            | 0   | Х   | Х        | Х     | Х    | 1                             | 0  | 1   | REPEAT   | Г (繰り返   | えし指 | 諚)    |      |      |     |     |          |       |       |
| STCS              | 1 1 0      |            | 0   | Х   | X        | X     | Х    | 1                             | 1  | 0   | STCS (S  | STS 制御   | ₪/状 | 態い    | バスタ  | ()   |     |     |          |       |       |
|                   |            |            |     |     |          | D₫    | 量    | 1                             | 1  | 1   | KEY (作   | ≡動鍵)     |     |       |      |      |     |     |          |       |       |
| REPEAT            | 1 0 1      |            | 0   | 0   | 0        | 0     | 0    |                               |    | (3) | ステム情報    | 立成現中、    | )   |       |      |      |     |     |          |       |       |
|                   |            |            |     |     | SIB      | K₫    | 量    | _                             | _  |     |          | 们还们      | )   |       |      |      |     |     |          |       |       |
| KEY               | 1 1 1      |            | 0   | 0   | Х        | 0     | Х    | 0 鍵受信<br>1 SIB送出              |    |     |          |          |     |       |      |      |     |     |          |       |       |
|                   |            |            |     |     |          |       |      | 1                             | 21 | DĮ  | ŚЩ       |          |     |       |      |      |     |     |          |       |       |
| A量 (アト            | レス長)       |            |     | D   | 量 (デー    | -9長)  |      | K                             | 量  | (鉧  | #長)      |          | PT  | R種    | 別    |      |     |     |          |       |       |
| 0 0 1ハ            | 个          |            |     | 0   | 0 1 パ    | 사     |      | 0                             | 0  | 64  | ヒット (8ハ  | 、イト)     | 0 ( | ) *(j | ptr) | (木°  | °イン | ンタト | 間接       | データ)  |       |
| 0 1 2ハ            | /仆(語) ≦64K | B⊁:        | モリ  | 0   | 1 2 パ    | 사 (語  | ī)   | 0                             | 1  | 12  | 28ビット(16 | 6バイト)    | 0   | 1 *() | ptr+ | +) ( | (間  | 間接  | נ+ג°∕    | シタ進   | 行)    |
| 1 0 31            | イト >64K    | B⊁:        | モリ  | 1   | 0 (子;    | 約)    |      | 1                             | 0  | (=  | 5約)      |          | 1 ( | 0 pt  | r (ホ | ゜イン  | 19  | レシ  | /スタ)     |       |       |
| 11(予              |            |            |     | 1   | 1 (予;    |       |      | 1 1 (予約) 1 1 *(ptr)(間接+ポインタ後退 |    |     |          |          |     |       | 退)   |      |     |     |          |       |       |
|                   |            | 2 1 -      | (h) |     |          |       |      |                               |    |     |          |          |     |       |      |      |     | _   |          |       |       |
|                   | ス(制御/状態レ   | <b>—</b> — |     |     | ( = 41.) |       |      |                               | 0  | 0   |          |          |     |       |      |      |     |     | <u> </u> | 0.000 | DI IO |
|                   | ) STATUSA  | -          |     | 0   | (予約)     |       |      | -                             | -  | -   |          | ESET_RI  | EQ  | 1 1   |      | 0    | -   |     |          | _STA  | rus   |
| 0 0 0             | 1 STATUSB  | -          | 1 0 | -   | (予約)     |       |      | 1                             | 0  | 0   | 1 ASI_C  |          |     | 1 1   | . 0  | 1    |     | 予彩  |          |       |       |
| 0 0 1             | O CTRLA    | 0          | 1 1 | 0   | (予約)     | (ASI) |      | 1                             | 0  | 1   | 0 ASI_SY | YS_CTRI  | LA  | 1 1   | 1    | 0    | (-  | 予彩  | 句)       |       |       |
| 0 0 1             | 1 CTRLB    | 0          | 1 1 | 1   | ASI_KI   | EY_ST | ATUS | 1                             | 0  | 1   | 1 ASI_SY | YS_STAT  | ГUS | 1 1   | 1    | 1    | (=  | 予彩  | 句)       |       |       |

#### 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命令は直接アドレス指定に基づき、アドレスはデータ転送を開始するための命令に対する被演算子として与えられなければなりません。アドレスは被演算子の最初の組で データが次の組です。アドレスとデータの被演算子の大きさは図33-10.で提示される大きさ(量)領域で与えられます。アドレスとデータの両方 の最大の大きさは32ビットです。

STS命令はREPERT命令と組み合わせた時に繰り返しメモリ アクセスを支援します。



STS命令に関する転送規約は図33-10.で描かれ、以下のこの手順に従ってください。

- 1. アドレスを送られます。
- 2. 転送が成功した場合にUPDIから応答(ACK)が送り返されます。
- 3. STS命令で指定されるバイ数が送られます。
- 4. データが成功裏に送信されてしまった後に応答(ACK)が受信されます。

#### 33.3.3.3. LD - 間接アドレス指定を使うデータ空間からのデータ取得

LD命令は直列読み出しのためにデータ空間からPHY層移動レジスタ内ヘデータを取得するのに使われます。LD命令は間接アトレス指定 に基き、UPDIのアトレスポインタがデータ空間読み込みアクセスに先立って書かれる必要があることを意味します。自動ポインタ事後増加動 作が支援され、LD命令がREPERT命令と共に使われる時に有用です。それはUPDIポインタレジスタからLDを行うことも可能です。アトレ スとデータの取得に対して支援される最大の大きさは32ビットです。



図33-11.は保護時間区間後にデータが受信される代表的なLD手順の例を示します。UPDIホペンタレジスタからのデータ取得は同じ転送処理規約に従います。

データ空間からのLD命令に対し、ポインタレジスタはUPDIポインタレジスタに対してST命令を使うことによって設定されなければなりません。ポインタレジスタ書き込み成功でACKが受信された後、LD命令は望むデータ量被演算子で設定されなければなりません。UPDIポインタレジスタに対するLDはLD命令で直接行われます。

#### 33.3.3.4. ST - 間接アドレス指定を使うデータ空間へのデータ格納

ST命令はUPDI PHY移動レジスタからのデータをデータ空間へ格納するのに使われます。ST命令はPHY層へ直列に移動されるデータを 格納するのに使われます。ST命令は間接アドレス指定に基き、UPDIのアドレスポインタがデータ空間に先立って書かれる必要があることを 意味します。自動ポインタ事後増加動作が支援され、ST命令がREPERT命令と共に使われる時に有用です。ST命令はポインタレジスタ にUPDIアドレスポインタを格納するのにも使われます。アドレスとデータを格納することに対して支援される最大の大きさは32ビットです。



図33-12.は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レジスタ空間だけをアクセスすることができます。この命令はハイトアクセスだけを支援し、データ量(長)は構成設定不可です。

| 図33−13. LDCS命令操作       | ]33-13. LDCS命令操作          |                          |            |  |  |  |  |  |  |  |  |  |  |
|------------------------|---------------------------|--------------------------|------------|--|--|--|--|--|--|--|--|--|--|
| 指令<br>LDCS <u>1 0</u>  |                           |                          |            |  |  |  |  |  |  |  |  |  |  |
| CSアドレス (制御/状態レ         | <b>CSアドレス</b> (制御/状態レジスタ) |                          |            |  |  |  |  |  |  |  |  |  |  |
| 0000 STATUSA           |                           |                          |            |  |  |  |  |  |  |  |  |  |  |
| 0001 STATUSB           | 0 1 0 1 (予約) (ASI)        | 1 0 0 1 ASI_CTRLA 1      | 101(予約)    |  |  |  |  |  |  |  |  |  |  |
| 0010CTRLA              | 0 1 1 0 (予約) (ASI)        | 1 0 1 0 ASI_SYS_CTRLA 1  | 1 1 0 (予約) |  |  |  |  |  |  |  |  |  |  |
| 0 0 1 1 CTRLB          | 0 1 1 1 ASI_KEY_STATUS    | 1 0 1 1 ASI_SYS_STATUS 1 | 1 1 1 (予約) |  |  |  |  |  |  |  |  |  |  |
|                        |                           |                          |            |  |  |  |  |  |  |  |  |  |  |
| UPDI受信 SYNCH<br>(\$55) | LDCS                      |                          |            |  |  |  |  |  |  |  |  |  |  |
| UPDI送信                 | Data                      |                          |            |  |  |  |  |  |  |  |  |  |  |
| ⊿GT(保護                 | 時間) → 🖌                   |                          |            |  |  |  |  |  |  |  |  |  |  |

図33-13.はLDCSデータ送信の代表的な例を示します。CS空間からのデータバイルは保護時間が完了した後にUPDIから送信されます。

#### 33.3.3.6. STCS - 制御/状態レジスタ空間へのデータ格納

STCS命令はUPDI制御/状態(CS)レジスタ空間ヘデータを格納するのに使われます。データはPHY層移動レジスタに直列で移動され、選んだCSレジスタに完全なハイトとして書かれます。STCS命令はアトレスが命令被演算子の一部である直接アトレス指定に基づきます。 STCS命令は内部UPDIレジスタ空間だけをアクセスすることができます。この命令はハイトアクセスだけを支援し、データ量(長)は構成設定不可です。

| 図33                       | -14                                                                                                                                                                                                                                              | . S | TCS命令操作 | F |   |   |   |                |   |   |     |                |   |   |   |   |      |  |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------|---|---|---|---|----------------|---|---|-----|----------------|---|---|---|---|------|--|
| S                         | 指令 CSアドレス<br>STCS 1 1 0 0 x x x x                                                                                                                                                                                                                |     |         |   |   |   |   |                |   |   |     |                |   |   |   |   |      |  |
| <b>CSアドレス</b> (制御/状態レジスタ) |                                                                                                                                                                                                                                                  |     |         |   |   |   |   |                |   |   |     |                |   |   |   |   |      |  |
| 0                         | 0       0       0       1       0       0       (部四) (於照 2 × 2)         1       0       0       ASI_RESET_REQ       1       1       0       0         1       0       0       ASI_RESET_REQ       1       1       0       0       ASI_CRC_STATUS |     |         |   |   |   |   |                |   |   |     |                |   |   |   |   |      |  |
| 0                         | 0 0                                                                                                                                                                                                                                              | 1   | STATUSB | 0 | 1 | 0 | 1 | (予約) (ASI)     | 1 | 0 | 0 1 | ASI_CTRLA      | 1 | 1 | 0 | 1 | (予約) |  |
| 0                         | 0 1                                                                                                                                                                                                                                              | 0   | CTRLA   | 0 | 1 | 1 | 0 | (予約) (ASI)     | 1 | 0 | 1 0 | ASI_SYS_CTRLA  | 1 | 1 | 1 | 0 | (予約) |  |
| 0                         | 0 1                                                                                                                                                                                                                                              | 1   | CTRLB   | 0 | 1 | 1 | 1 | ASI_KEY_STATUS | 1 | 0 | 1 1 | ASI_SYS_STATUS | 1 | 1 | 1 | 1 | (予約) |  |
|                           |                                                                                                                                                                                                                                                  |     |         |   |   |   |   |                |   |   |     |                |   |   |   |   |      |  |
| UP                        | UPDI受信 SYNCH STCS Data                                                                                                                                                                                                                           |     |         |   |   |   |   |                |   |   |     |                |   |   |   |   |      |  |
| UP                        | DIì                                                                                                                                                                                                                                              | 送付  |         |   |   |   |   |                |   |   |     |                |   |   |   |   |      |  |

図33-14.は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文字を送ることによってのみ中止することができます。



図33-15.はポインタ事後増加操作を用いる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)によって有効にされる機能の概要ついて「鍵保護されたインターフェースの 許可」項の「鍵認証概要」表をご覧ください。KEY命令に対しては64ビット鍵(KEY)の大きさだけが支援されます。SIBに対して支援され る最大量は128ビットです。



図33-17.は鍵(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)文字を使う例については図33-18.をご覧ください。
- ・TCB比較/捕獲(TCBn.CCMP)レシ<sup>、</sup>スタを読むことによって同期(SYNCH)文字直後の捕獲値を読み出すことが可能で、また、値は一 旦捕獲が行われると、CPUによってメモリに書くこともできます。より多くの詳細については「TCB - 16ビットタイマ/カウンタB型」章を参 照してください。



#### 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)は「KEY - 活性化鍵設定また はシステム情報部送出」からKEY命令に従ってSIBビットを設定(1)することに よって何時でも読み出すことができます。SIBは施錠ビット設定に関わらず、 常にデバッガのためにアクセス可能で、デバイスとデバッガ用のシステム要素につ いての情報提供の簡潔な形式を提供します。この情報はデベイスとの正し い通信チャネルを認識して準備することに於いて重要です。SIBの出力は ASCII符号として解釈されます。K量領域は完全なSIBを読み出す時に16 バイトに設定されなければならず、8バイトの大きさは系統IDだけを読み出す のに使うことができます。SIB形式記述とどのデータが異なる読み出し量で利 用可能かについては図33-20.をご覧ください。

#### 図33-20.システム情報部形式

| <b>K</b> 量( | バイト) | バイト          | ビット         | 領域名       |  |  |  |  |  |  |  |  |  |
|-------------|------|--------------|-------------|-----------|--|--|--|--|--|--|--|--|--|
| 16          | 8    | MAR          | L YF        | マスロ       |  |  |  |  |  |  |  |  |  |
| 0           | 0    | $6 \sim 0$   | $55 \sim 0$ | 系統ID      |  |  |  |  |  |  |  |  |  |
| 0           | 0    | 7            | $7 \sim 0$  | (予約)      |  |  |  |  |  |  |  |  |  |
| 0           | X    | 10~8         | 23~0        | NVM版番号    |  |  |  |  |  |  |  |  |  |
| 0           | ×    | $13 \sim 11$ | 23~0        | OCD版番号    |  |  |  |  |  |  |  |  |  |
| 0           | ×    | 14           | 7~0         | (予約)      |  |  |  |  |  |  |  |  |  |
| 0           | ×    | 15           | 7~0         | デバッグ発振周波数 |  |  |  |  |  |  |  |  |  |

# 33.3.8. 鍵保護されたインターフェースの許可

いくつかの内部インターフェースと機能へのアクセスはUPDI鍵機構によって保護されます。鍵を認証するには、「33.3.3.8. KEY - 活性化鍵 設定またはシステム情報部送出」で記述されるように、KEY命令を用いることによって正しい鍵データが送信されなければなりません。表 33-4.は利用可能な鍵と鍵が読み込まれた後に操作を開始するのに必要とされる条件を記述します。

| 表33-4. 鍵認 | 証概要                    |                                                                                                     |                         |
|-----------|------------------------|-----------------------------------------------------------------------------------------------------|-------------------------|
| 鍵名        | 説明                     | リセット                                                                                                |                         |
|           | NVMチップ消去開始。<br>施錠ビット解除 | なし                                                                                                  | UPDI禁止/UPDIリセット         |
| NVMPROG   | NVMプログラミング活性           | 施錠ビット解除。ASIシステム状態(ASI_SYS_STATUS)レシ <sup>、</sup> スタのNVMプ <sup>°</sup><br>ログラミング開始(PROGSTART)を設定(1)。 | プログラミング終了/<br>UPDIリセット  |
|           |                        | 施錠ビット設定。ASIシステム状態(ASI_SYS_STATUS)レジスタの使用者<br>列プログラミング開始(UROWSTART)を設定(1)。                           | 鍵状態ビット書き込み/<br>UPDIリセット |

表33-5.はインターフェースを活性にするために移動入力され 表33-5. 鍵認証符号 なければならない利用可能な鍵符号の概要を与えます。

| 鍵名       | 鍵名 鍵符号(LSB先行で書かれています。) |       |  |  |  |  |  |  |
|----------|------------------------|-------|--|--|--|--|--|--|
| チップ消去    | \$4E564D4572617365     |       |  |  |  |  |  |  |
| NVMPROG  | \$4E564D50726F6720     | 64ビット |  |  |  |  |  |  |
| 使用者列書き込み | \$4E564D5573267465     |       |  |  |  |  |  |  |

### 33.3.8.1. チップ 消去

チップ消去を発行するには次の手順に従わなければなりません。

- 1. KEY命令を使うことによってチップ消去鍵を入力してください。チップ消去符号については「鍵認証符号」表をご覧ください。
- 2. KEY命令を使うことによってNVMプログラミング鍵を入力してください。NVMPROG識票については「鍵認証符号」表を御覧くださ い。これは新たに消去されたデバイスを(有効にされている場合の)CRC失敗から守ります。
- 3. チップ消去鍵状態(CHER)とットと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. に戻ってください。
- 8. チップ消去が成功したかを確認するためにUPDI\_ASI\_SYS\_STATUSレジスタのチップ消去鍵失敗(ERASEFAIL)ビットを調べてください。

9. ERASEFAILビットが'0'なら、チップ消去は成功しました。

チップ消去成功後、施錠ビットが解除され、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フ<sup>°</sup>ロク<sup>\*</sup>ラミンク<sup>\*</sup>

デバイスが解錠されているなら、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. ASIJセット要求(UPDI.ASI\_RESET\_REQ)レジズタのリセット要求(RESREQ)ビット領域に識票を書いてください。これはシステム リセットを発行 します。
- 5. システム リセットを解除するためにUPDI.ASI\_RESET\_REQレジスタに\$00を書いてください。
- 6. ASIシステム状態(UPDI.ASI\_SYS\_STATUS)レジスタのNVMプログラミング開始(PROGSTART)ビットを読んでください。
- 7. NVMプログラミングはPROGSTARTが'1'の時に開始することができます。PROGSTARTが'0'なら、手順6.に戻ってください。
- 8. UPDIを通してNVMにデータを書いてください。
- 9. UPDI.ASI\_RESET\_REQレジスタのRESREQビット領域に識票を書いてください。これはシステム リセットを発行します。
- 10. システム リセットを解除するためにUPDI.ASI\_RESET\_REQレシ<sup>\*</sup>スタに\$00を書いてください。
- 11. プログラミングは完了です。

#### 33.3.8.3. 使用者列プログラミング

使用者列プログラミング機能は施錠されたデバイスで使用者列(USERROW)に新しい値を書くことを許します。許可されたこの機能で書き 込むには、次の手順に従わなければなりません。

- 1. KEY命令を使うことによって表33-5.で示される使用者列書き込み(UROWWRITE)鍵を入力してください。UROWWRITE符号については表33-5.をご覧ください。
- 2. 任意選択: 鍵が認証されたかを知るためにASI鍵状態(UPDI.ASI\_KEY\_STATUS)レジスタの使用者列書き込み鍵状態(UROWWR) ビットを読んでください。
- 3. ASIJセット要求(UPDI.ASI\_RESET\_REQ)レジスタのリセット要求(RESREQ)ビット領域に識票を書いてください。これはシステム リセットを発行 します。
- 4. システム リセットを解除するためにUPDI.ASI\_RESET\_REQレシ、スタに\$00を書いてください。
- 5. ASIシステム状態(UPDI.ASI\_SYS\_STATUS)レシブスタの使用者列プログラミング開始(UROWSTART)ビットを読んでください。
- 6. 使用者列プログラミングはURWOSTARTが'1'の時に開始することができます。UROWSTARTが'0'なら、手順5.に戻ってください。
- 7. 使用者列に書かれるデータは最初にRAM内の緩衝部に書かれなければなりません。RAMの書き込み可能な領域は64バイトで、 SRAMの最初の64バイトのアドレスにだけ使用者列データを書くことが可能です。このメモリ範囲外のアドレス指定は実行されない書き込みに終わります。書き込み手順の完了でデータが使用者列データに複写される時に、このデータが使用者列空間と1対1で割り当てら れます。
- 8. 全ての使用者列データがSRAMに書かれると、ASIシステム制御A(UPDI.ASI\_SYS\_CTRLA)レジスタの使用者列書き込み終了(URO WDONE)ビットに('1'を)書いてください。
- 9. UPDI.ASI\_SYS\_STATUSレシブスタのUROWSTARTビットを読んでください。
- 10. 使用者列プログラミングはUROWSTARTが'0'の時に完了されます。UROWSTARTが'1'なら、手順9.に戻ってください。
- 11. ASI鍵状態(UPDI.ASI\_KEY\_STATUS)レジスタの使用者列書き込み鍵状態(UROWWR)ビットを書いてください。
- 12. ASIJセット要求(UPDI.ASI\_RESET\_REQ)レシ<sup>\*</sup>スタのリセット要求(RESREQ)ビット領域に識票を書いてください。これはシステム リセットを発行 します。
- 13. システム リセットを解除するためにUPDI.ASI\_RESET\_REQレシ スタに \$00を書いてください。
- 14. 使用者列プログラミングは完了です。
- この動作形態でSRAMからデータを読み戻すことはできません。SRAMの最初の64バイトへの書き込みだけが許されます。

#### 33.3.9. 事象

UPDIは以下の事象を生成することができます。

#### 表33-6. UPDIでの事象生成部

| 生    | 成部名   | また 日日      | 市名刑         |          | 市在目                               |  |  |
|------|-------|------------|-------------|----------|-----------------------------------|--|--|
| 周辺機能 | 事象    | 説明         | <b>争</b> 豕空 | 生成クロック領域 | 事象長                               |  |  |
| UPDI | SYNCH | 同期(SYNC)文字 | レヘッル        |          | CLK_UPDIに同期した<br>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      | ビットロ       |
|-------|----------------|------------|-------|-----------|--------|---------|-----------|-----------|-----------|------------|
| +\$00 | STATUSA        | 7~0        |       | UPDIR     | EV3~0  | 1       |           |           |           |            |
| +\$01 | STATUSB        | $7 \sim 0$ |       |           |        |         |           |           | PESIG2~0  |            |
| +\$02 | CTRLA          | $7 \sim 0$ | IBDLY |           | PARD   | DTD     | RSD       |           | GTVAL2~0  |            |
| +\$03 | CTRLB          | $7 \sim 0$ |       |           |        | NACKDIS | CCDETDIS  | UPDIDIS   |           |            |
| +\$04 | 又如             |            |       |           |        |         |           |           |           |            |
| +\$06 | 予約             |            |       |           |        |         |           |           |           |            |
| +\$07 | ASI_KEY_STATUS | 7~0        |       |           | UROWWR | NVMPROG | CHER      |           |           |            |
| +\$08 | ASI_RESET_REQ  | $7 \sim 0$ |       |           | 1      | RSTRI   | EQ7~0     |           |           |            |
| +\$09 | ASI_CTRLA      | $7 \sim 0$ |       |           |        |         |           |           | UPDICL    | KSEL1,0    |
| +\$0A | ASI_SYS_CTRLA  | $7 \sim 0$ |       |           |        |         |           |           | UROWDONE  | CLKREQ     |
| +\$0B | ASI_SYS_STATUS | 7~0        | BDEF  | ERASEFAIL | SYSRST | INSLEEP | PROGSTART | UROWSTART | BOOTDONE  | LOCKSTATUS |
| +\$0C | ASI_CRC_STATUS | 7~0        |       |           |        |         |           | CR        | C_STATUS2 | ~0         |

## 33.5. レジスタ説明

これらのレジスタは特別な命令でUPDIを通してだけ読み込み可能で、CPUを通して読み込み可能ではありません。

# **33.5.1. STATUSA - 状態A** (Status A)

# 名称 : STATUSA

**変位** : +\$00

# **リセット** : \$30

# 特質 :-

| ビット    | 7 | 6      | 5     | 4 | 3 | 2 | 1 | 0 |
|--------|---|--------|-------|---|---|---|---|---|
|        |   | UPDIRI | EV3~0 |   |   |   |   |   |
| アクセス種別 | R | R      | R     | R | R | R | R | R |
| リセット値  | 0 | 0      | 1     | 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 | 0        |   |  |  |
|--------|---|---|---|---|---|---|----------|---|--|--|
|        |   |   |   |   |   |   | PESIG2~0 |   |  |  |
| アクセス種別 | R | R | R | R | R | R | R        | R |  |  |
| リセット値  | 0 | 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    | 異常なし          | 検出された異常なし(既定)                     |
| 001      | パリティ誤り        | パリティビットの不正な採取                     |
| 010      | フレーム異常        | 停止ビットの不正な採取                       |
| 011      | アクセス層制限時間超過異常 | UPDIはアクセス層からデータや応答を得られないことが有り得ます。 |
| 100      | クロック再生異常      | 開始ビットの不正な採取                       |
| 101      | _             | (予約)                              |
| 110      | バス異常          | アドレス異常またはアクセス優先権異常                |
| 111      | 競合異常          | UPDIピンでの駆動競合を示します。                |

# **33.5.3. CTRLA - 制御A** (Contorl A)

名称:CTRLA

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

| ビット    | 7     | 6 | 5    | 4   | 3   | 2   | 1   | 0   |
|--------|-------|---|------|-----|-----|-----|-----|-----|
|        | IBDLY |   | PARD | DTD | RSD |     |     |     |
| アクセス種別 | 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によって使われる保護時間値を選びます。

| 值                 | 000     | 001 | 010 | 011 | 100 | 101 | 110 | 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 |
|--------|---|---|--------|---------|------|---|---|---|
|        |   |   | UROWWR | NVMPROG | CHER |   |   |   |
| アクセス種別 | R | R | R/W    | R       | R    | R | R | R |
| リセット値  | 0 | 0 | 0      | 0       | 0    | 0 | 0 | 0 |

#### ● ビット5 - UROWWR : 使用者列書き込み鍵状態 (User Row Write Key Status)

このビットは使用者列書き込み(UROWWRITE)鍵が成功裏に復号された場合に'1'に設定されます。このビットはプログラミング作業を正しくリセットするために使用者列書き込み手順の最後の部分として書かれなければなりません。

# ビット4 - NVMPROG: NVMプログラミング鍵状態 (NVM Programming Key Status)

このビットはNVMPROG鍵が成功裏に復号された場合に'1'に設定されます。このビットはNVMプログラミング手順が開始される時に解除 (0)され、ASIシステム状態(ASI\_SYS\_STATUS)レシブスタのNVMプログラミング開始(PROGSTART)ビットが設定(1)されます。

#### • ビット3 - CHER : チッフ 消去鍵状態 (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

特質 :-

このアドレスにリセット識票を書く時にシステムへリセットが合図されます。

| ビット    | 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   | 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   |
|--------|---|---|---|---|---|---|---------------|-----|
|        |   |   |   |   |   |   | UPDICLKSEL1,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 Divider Select)

これらのビットの書き込みがUPDIクロック出力周波数を選びます。リセットと許可後の既定設定は4MHzです。可能なUPDI発振器周波数のより多くの情報については「電気的特性」章をご覧ください。

| 値  | 0 0            | 01             | 10            | 11                 |  |
|----|----------------|----------------|---------------|--------------------|--|
| 説明 | 32MHz UPDIクロック | 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      |
|--------|---|---|---|---|---|---|----------|--------|
| [      |   |   |   |   |   |   | UROWDONE | CLKREQ |
| アクセス種別 | R | R | R | R | R | R | R/W      | R/W    |
| リセット値  | 0 | 0 | 0 | 0 | 0 | 0 | 0        | 0      |

● ビット1 - UROWDONE : 使用者列書き込み終了 (User Row Programming Done)

このビットは使用者列データがSRAMに書かれた時にこのビットを書いてください。このビットへの'1'書き込みはフラッシュ メモリへの使用者列 データ書き込みの処理を開始します。

UPDIによって使用者列データがSRAMに書かれる前にこのビットが('1'を)書かれた場合、CPUは書かれるデータなしで進行します。 このビットは使用者列書き込み鍵が成功裏に復号された場合にだけ書き込み可能です。

### • ビット0 - CLKREQ : システム クロック要求 (Request System Clock)

このビットが'1'を書かれた場合、ASIはシステムの休止動作と無関係にシステムクロックを要求します。これは例えシステムが休止動作でも UPDIに対してACC層のアクセスを可能にします。

このビットへの'0'書き込みはクロック要求を下げます。

このビットはUPDIが許可された時に既定で設定(1)されます。

33.5.9. ASI\_SYS\_STATUS - ASIシステム状態 (ASI System Status)

名称 : ASI\_SYS\_STATUS 変位 : +\$0B リセット : \$01 特質 : -

| ビット        | 7    | 6         | 5      | 4       | 3         | 2         | 1        | 0          |
|------------|------|-----------|--------|---------|-----------|-----------|----------|------------|
|            | BDEF | ERASEFAIL | SYSRST | INSLEEP | PROGSTART | UROWSTART | BOOTDONE | LOCKSTATUS |
| アクセス種別     | R    | R         | R      | R       | R         | R         | P        | P          |
| // [//]生月月 | 11   | 1         | 11     | 11      | 11        | 11        | IX       | IX.        |

● ビット7 - BDEF : ブート手順終了またはチップ消去失敗 (Boot Sequence Done or Chip Erase Failed)

このビットはチップ消去が失敗(ERASEFAILビットが'1')、またはブート手順が完了(BOOTDONEビットが'1')の場合に'1'に設定されます。

#### • ビット6 - ERASEFAIL : チッフ。消去鍵失敗 (Chip Erase Key Failed)

このビットはチップ消去が失敗した場合に'1'に設定されます。このビットはリセットで'0'に設定されます。ASIリセット要求(ASI\_RESET\_REQ) レジスタで保持されるリセットもこのビットに影響を及ぼします。

#### • ビット5 - SYSRST : システム リセット活性 (System Reset Active)

このビットが'1'設定の時はシステム領域で有効なリセットがあります。このビットが'0'設定の時はシステムがリセット状態ではありません。 このビットは読み込みで'0'に設定されます。

ASIリセット要求(UPDI.ASI\_RESET\_REQ)レジスタで保持されるリセットもこのビットに影響を及ぼします。

#### • ビット4 - INSLEEP : システム領域休止中 (System Domain in Sleep)

このビットが'1'に設定されると、システム領域はアイドルまたはより深い休止動作です。このビットが'0'に設定されると、システムはどの休止動作でもありません。

#### • ビット3 - PROGSTART : NVMプログラミング開始 (Start NVM Programming)

このビットが'1'に設定されると、UPDIからNVMプログラシングを開始することができます。 UPDIが終了される時にUPDIJセット要求(ASI\_RESET\_REQ)レジスタを通してJセットしてください。

#### • ビット2 - UROWSTART : 使用者列プログラミング開始 (Start User Row Programming)

このビットが'1'に設定されると、UPDIから使用者列プログラミングを開始することができます。

使用者列データがRAMに書かれてしまうと、ASIシステム制御A(UPDI.ASI\_SYS\_CTRLA)レジスタの使用者列書き込み終了(UROWDONE) ビットは('1'を)書かなければなりません。

### • ビット1 - BOOTDONE : ブート手順終了 (Boot Sequence Done)

このビットはCPUがブート手順を終えた時に'1'に設定されます。UPDIはこのビットが'1'に設定されるまでアクセスできません。 続行する前にシステムリセット活性(SYSRST)が'0'であることも調べてください。

### • ビット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
- 特質 :-

| <b>ビット</b> | 7 | 6 | 5 | 4 | 3 | 2 | 1                       | 0        |
|------------|---|---|---|---|---|---|-------------------------|----------|
|            |   |   |   |   |   | С | RC_STATUS2 <sup>,</sup> | $\sim 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'の)単一ビット活性符号化されます。

| 值  | 000 | 001          | 010                   | 100                       | その他  |
|----|-----|--------------|-----------------------|---------------------------|------|
| 説明 | 不許可 | CRC許可、<br>多忙 | CRC許可、<br>成功(OK)符号で終了 | CRC許可、<br>失敗(FAILED)符号で終了 | (予約) |

# 34. 命令一式要約

命令一式要約はwww/microchip.com/DS40002198に置かれた「AVR命令一式手引書」の一部です。このデータシートで文書化されたデ バイスに関する詳細についてはAVRxtと呼ばれるCPU版を参照してください。

# 35. 電気的特性

# 35.1. お断り

特に指定のない限り、全ての代表値はTA=25℃とVDD=3.0Vで測定されています。全ての最小値と最大値は特に指定のない限り、動作温度と動作電圧に渡って有効です。

一般的に与えられた値は設計指針に対してだけ考慮されなければならず、これらの値周辺の実部品変動が予想されます。

# 35.2. 絶対最大定格

本項で一覧にされるこれらを超える負荷はデベイスに定常的な損傷を引き起こすかもしれず、これは負荷定格だけです。本仕様の動 作部分で示されるこれらを超える他の条件やそれらでのデベイスの機能的な動作は含まれません。長時間絶対最大定格状態に晒す ことはデベイスの信頼性に影響を及ぼすかもしれません。

#### 表35-1. 絶対最大定格

| 項目                        | 条件                                                                  | 定格              | 単位 |  |  |  |  |  |  |  |
|---------------------------|---------------------------------------------------------------------|-----------------|----|--|--|--|--|--|--|--|
| 通電下の周囲温度                  |                                                                     | $-40 \sim +125$ |    |  |  |  |  |  |  |  |
| 最大接合部温度                   |                                                                     | 140             | °C |  |  |  |  |  |  |  |
| 保存温度                      |                                                                     | $-65 \sim +150$ |    |  |  |  |  |  |  |  |
| GNDに対するピンの電圧              |                                                                     |                 |    |  |  |  |  |  |  |  |
| ・ VDDピン                   |                                                                     | -0.3~+6.0       |    |  |  |  |  |  |  |  |
| ・ RESET ピン                |                                                                     | -0.3~+9.0       | V  |  |  |  |  |  |  |  |
| ・他の全てのピン                  |                                                                     | -0.3~(VDD+0.3)  |    |  |  |  |  |  |  |  |
| 最大電流                      |                                                                     | _               |    |  |  |  |  |  |  |  |
| ・ GNDピン (注1)              | $-40^{\circ}\mathrm{C} \leq \mathrm{TA} \leq +85^{\circ}\mathrm{C}$ | 200             |    |  |  |  |  |  |  |  |
|                           | $+85^{\circ}\mathrm{C} \le \mathrm{TA} \le +125^{\circ}\mathrm{C}$  | 100             |    |  |  |  |  |  |  |  |
| ・ VDDピン (注1)              | $-40^{\circ}C \leq TA \leq +85^{\circ}C$                            | 200             | mΛ |  |  |  |  |  |  |  |
|                           | $+85^{\circ}\mathrm{C} < \mathrm{TA} \leq +125^{\circ}\mathrm{C}$   | 100             | mA |  |  |  |  |  |  |  |
| ・全標準I/Oピン                 |                                                                     | $\pm 40$        |    |  |  |  |  |  |  |  |
| クランプ電流(IK)                | VPIN<0またはVPIN>VDD                                                   | $\pm 20$        |    |  |  |  |  |  |  |  |
| 総消費電力 ( <mark>注2</mark> ) |                                                                     | _               | mW |  |  |  |  |  |  |  |

注1: 最大電流定格はI/Oピンにそれぞれに渡る均等な負荷分散を必要とします。デバイス外囲器消費電力特性は最大電流定格を 制限するかもしれません。デバイス仕様を計算するには「温度仕様」をご覧ください。

注2: 次のように消費電力を計算してください。PDIS=VDD×{IDD-ΣIOH}+Σ{(VDD-VOH)×IOH}+Σ(VOL×IOL)

# 35.3. 標準動作条件

他の全てのデバイス特性が有効であるためには、本項で一覧にされる定格内でデバイスが動作しなければなりません。

-般的な動作条件: ・動作電圧: VDDMIN≦VDD≦VDDMAX

#### ・動作温度:TA\_MIN≦TA≦TA\_MAX

全てのデバイスに対する標準動作条件は次のように定義されます。

#### 表35−2. 標準動作条件

| 項目                              | シンホール  | 定格   | 単位 |  |  |  |  |  |
|---------------------------------|--------|------|----|--|--|--|--|--|
| VDD - 動作供給電圧 ( <mark>注</mark> ) |        |      |    |  |  |  |  |  |
| 工業と拡張温度                         | VDDMIN | +1.8 | V  |  |  |  |  |  |
| 工業と1位本価度                        | VDDMAX | +5.5 | V  |  |  |  |  |  |
|                                 |        |      |    |  |  |  |  |  |
| 工業温度                            | TA_MIN | -40  |    |  |  |  |  |  |
| 上未価度                            | TA_MAX | +85  | °C |  |  |  |  |  |
| 拡張温度                            | TA_MIN | -40  |    |  |  |  |  |  |
| <b>仏派</b> 価度                    | TA_MAX | +125 |    |  |  |  |  |  |

注:「35.4. 供給電圧」で供給電圧要素を参照してください。

# 35.4. 供給電圧

| 表35-3. 供給電圧              |                   |        |                        |      |                           |  |  |  |  |  |
|--------------------------|-------------------|--------|------------------------|------|---------------------------|--|--|--|--|--|
| シンホ゛ル                    | 最小                | 代表 (†) | 最大                     | 単位   | 条件                        |  |  |  |  |  |
| 供給電圧 ( <u>注</u> 1)       |                   |        |                        |      |                           |  |  |  |  |  |
| VDD                      | 1.8 ( <b>注2</b> ) | _      | 5.5                    | V    |                           |  |  |  |  |  |
| RAMデータ保持電圧 ( <u>注</u> 3) |                   |        |                        |      |                           |  |  |  |  |  |
| VDR                      | 1.7               | -      | -                      | V    | パワーダウン動作でのデバイス            |  |  |  |  |  |
| 電源ONJセット開放電圧 (注5)        |                   |        |                        |      |                           |  |  |  |  |  |
| VPOR                     | -                 | 1.6    | -                      | V    | BOD禁止 ( <b>注4</b> )       |  |  |  |  |  |
| tpor                     | -                 | -      | -                      | μs   | BOD宗正 ( <del>注4</del> )   |  |  |  |  |  |
| 電源ONリセット機能再開電圧           | (注5)              |        |                        |      |                           |  |  |  |  |  |
| VPORR                    | -                 | 1.1    | -                      | V    | BOD禁止 ( <b>注4</b> )       |  |  |  |  |  |
| tporr                    | -                 | -      | -                      | μs   | BOD示亚 ( <del>/工4</del> )  |  |  |  |  |  |
| 内部電源ONリセット信号を保護          | 証するため             | のVDD上昇 | 速度 ( <mark>注6</mark> ) |      |                           |  |  |  |  |  |
| SVDD                     | -                 | -      | 0.2                    | V/µs | BOD禁止 ( <mark>注4</mark> ) |  |  |  |  |  |
|                          |                   |        | 0                      |      |                           |  |  |  |  |  |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

**注1**: チップ<sup>®</sup>消去中、BODLEVEL0で構成設定された低電圧検出器(BOD)がONを強制されます。供給電圧(VDD)がBODLEVEL0に 対するVBOD未満の場合、消去の試みは失敗します。

注2: 1.8VまたはBODが有効の時にBOD起動基準(VBOD)に落ちるまで動作は保証されます。

注3: これはRAMデータを失うことなく休止動作でVDDを低めることができる限度です。

注4: BOD切り替わり点情報については「35.11. RSTCTRLとBOD」項を参照してください。

注5: 図35-1.を参照してください。

**注6**: 設計の手引きのためだけで、製造で検査されません。



# 35.5. 消費電力

# 表35-4. 活動動作とアイドル動作での消費電力

| シンホ゛ル    | 説明                 | 最小 | 代表<br>( <del>†</del> ) | 最大<br>85℃ | 最大<br>125℃ | 単位 | 条件                             |
|----------|--------------------|----|------------------------|-----------|------------|----|--------------------------------|
|          |                    | -  | 12                     | -         | -          |    | OSCHF=20MHz, VDD=5V            |
|          |                    | -  | 3.7                    | -         | -          | mА | OSCHF=10MHz (OSCHF/2)          |
| IDD      | 活動消費電力             | -  | 2.2                    | -         | -          |    | OSCHF=5MHz (OSCHF/4)           |
|          |                    | -  | -                      | -         | -          |    | OSC32K=32.768kHz               |
|          |                    | -  | 10                     | -         | -          | μA | XOSC32K=32.768kHz              |
|          |                    | -  | 3.5                    | -         | -          |    | OSCHF=20MHz, VDD=5V            |
|          |                    | -  | 1.5                    | -         | -          | mA | OSCHF=10MHz (OSCHF/2)          |
| IDD_IDLE | アイドル消費電力           | -  | 1.0                    | -         | -          |    | OSCHF=5MHz (OSCHF/4)           |
|          |                    | -  | -                      | -         | -          |    | OSC32K=32.768kHz               |
|          |                    | _  | 3.3                    | _         | -          | μA | XOSC32K=32.768kHz              |
| IDD_BASE | 各種休止動作での<br>最小消費電力 | -  | 0.08                   | -         | _          | μΑ | パワーダウン動作またはスタンバイ動作、全周辺機能<br>禁止 |

†: "代表 ダリのテータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

# 35.6. 周辺機能消費電力

様々な動作形態で各種入出力周辺機能に対して追加消費電流を計算するのに下表を使ってください。いくつかの周辺機能はスタン バイ動作で動く時に許可されるべきクロックを要求します。更なる情報については周辺機能章を参照してください。

#### 表35-5. 周辺機能消費電力(注1)

動作条件:

- ・ クロック元として使われた6分周係数の前置分周器を持つ20MHzのOSCHF
- ・デバイスはスタンバイ休止動作

| ・デバイスはスタン     |                                       |    |                        |           |            |    |                                                                                                                                                                      |  |
|---------------|---------------------------------------|----|------------------------|-----------|------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| シンホ゛ル         | 説明                                    | 最小 | 代表<br>( <del>†</del> ) | 最大<br>85℃ | 最大<br>125℃ | 単位 | 条件                                                                                                                                                                   |  |
| IDD_WDT       | ウォッチト`ック` タイマ (WDT)                   | -  | 0.68                   | -         | -          |    | 32.768kHz内部発振器                                                                                                                                                       |  |
| IDD_BG        | ハント・キャップ                              | -  | 19                     | -         | -          |    |                                                                                                                                                                      |  |
| IDD_VREF      | 参照基準電圧 (VREF)                         | -  | 54                     | -         | -          |    | DAC0REF.REFSEL='001'       ジン         (2.048V)       ド         ACREF.REFSEL='001'(2.048V)       ギ         継続動作       ジプ         128Hz採取動作       IDD_OSC32K         除 |  |
|               |                                       | -  | 48                     | -         | -          |    | ACREF.REFSEL='001'(2.048V)                                                                                                                                           |  |
|               |                                       | -  | 14                     | -         | -          |    | 継続動作                                                                                                                                                                 |  |
| IDD_BOD       | 低電圧検出器 (BOD)                          | -  | 0.60                   | -         | -          |    | 128Hz採取動作 IDD_OSC32K 除                                                                                                                                               |  |
|               |                                       | _  | 0.40                   | 6         |            |    | 32Hz採取動作 を含む ぐ                                                                                                                                                       |  |
| IDD_TCA       | 16ビット タイマ/カウンタA型 (TCA)                | -  | 38                     | -         | -          |    | アイドル休止動作                                                                                                                                                             |  |
| IDD_TCB       | 16ビット タイマ/カウンタB型 (TCB)                | -  | 19                     | -         | -          |    |                                                                                                                                                                      |  |
| IDD_RTC       | 実時間計数器 (RTC)                          | -  | 18                     | -         | -          |    | 32.768kHz内部発振器(OSC32K)                                                                                                                                               |  |
| IDD_OSC32K    | 32,768kHz内部発振器(OSC32K)                | -  | 0.42                   | -         | -          |    |                                                                                                                                                                      |  |
| IDD_XOSC32K   | 32,768kHzクリスタル用発振器 (XOSC32K)          | -  | 1.3                    | _         | -          |    | XOSC32KCTRLA.<br>LPMODE='1'(許可) ESR=50kΩ,                                                                                                                            |  |
| IDD_A03032R   | 32,768kHZクリメタル用発振器(XUSU32K)           |    | 5.7                    | -         | -          | μΑ | XOSC32KCTRLA. CL=12.5pF<br>LPMODE='0'(禁止)                                                                                                                            |  |
| IDD_OSCHF     | 内部高周波数発振器 (OSCHF)                     | -  | 85                     | -         | -          |    |                                                                                                                                                                      |  |
| IDD_XOSCHF    | 高周波数クリスタル用発振器(XOSCHF)                 | -  | -                      | -         | -          |    |                                                                                                                                                                      |  |
| IDD_ADC       | アナログ⇒デジタル変換器 (ADC) ( <b>注2</b> )      | -  | 295                    | -         | -          |    | CTRLC.REFSEL='000' (VDD)                                                                                                                                             |  |
| IDD_ADC       | ///////////////////////////////////// | -  | 570                    | -         | -          |    | CTRLC.REFSEL='101' (2.048V)                                                                                                                                          |  |
| IDD_AC        | アナログ比較器 (AC)                          | -  | 150                    | -         | -          |    | CTRLA.POWER='00'                                                                                                                                                     |  |
| IDD_AC        | // 10/ 10 #X 奋 (AC)                   | -  | 110                    | -         | -          |    | CTRLA.POWER='01'                                                                                                                                                     |  |
|               |                                       | -  | 106                    | -         | -          |    | VDACREF=1.024V<br>休止動作                                                                                                                                               |  |
| IDD_DAC       | デジタル⇒アナログ変換器 (DAC)                    | -  | 125                    | -         | -          |    | VDACREF=4.096V                                                                                                                                                       |  |
|               |                                       | -  | 100                    | -         | -          |    | VDACREF=VDD                                                                                                                                                          |  |
| IDD_USART     | 万能同期/非同期送受信器 (USART)                  | -  | 51                     | -         | -          |    | 9600ボーでUART許可                                                                                                                                                        |  |
| IDD_SPI       | 直列周辺インターフェース (SPI)                    | -  | 14                     | -         | -          |    | 100kHzでSPI主装置                                                                                                                                                        |  |
|               |                                       | -  | 56                     | -         | -          |    | 100kHzでTWI主装置<br>ない動作                                                                                                                                                |  |
| IDD_TWI       | 2線インターフェース(TWI)                       | -  | 46                     | -         | -          |    | 100kHzでTWI 2 表置<br>100kHzでTWI 従装置                                                                                                                                    |  |
| IDD_NVM_ERASE | フラッシュ プログラミング - 消去                    | -  | 7                      | -         | -          |    |                                                                                                                                                                      |  |
| IDD NVM WRITE | フラッシュ プログラミング - 書き込み                  | _  | 10                     | -         | -          | mA |                                                                                                                                                                      |  |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

注1:単位部だけの消費電流。マイクロ コントローラの総内部消費電力を計算するには使われる全ての周辺機能とクロック元の消費電力 値を「電気的特性」の「35.5. 消費電力」項で与えられる基本消費電力に加えてください。

注2: 以下の条件での平均消費電力

- シンク・ル エント・12ビットADC
- 自由走行動作でADC活動
- CLK\_ADC=1MHz
- アイト・ル休止動作でのデバイス

# 35.7. 入出力ピン

# 表35-6. 入出力ピン仕様

| シンボル          | 人出力とン仕様説明                   | 最小            | 代表 (†) | 最大      | 単位 | 条件                           |
|---------------|-----------------------------|---------------|--------|---------|----|------------------------------|
| Low入力         |                             | 取小            |        | 取八      | 中世 |                              |
| LOW           |                             | _             | _      | 0.2VDD  |    | PINnCTRL.INLVL='0'           |
| <b>1</b> .711 | 入出力・ シュミットトリカ 緩衝部ポート・ TTL基準 | _             |        | 0.2 VDD | V  |                              |
| VIL           |                             |               | <0.8   | -       | V  | PINnCTRL.INLVL='1', VDD>2.7V |
| 10174         | RESETピン                     | -             | -      | 0.2VDD  |    |                              |
| High入力        |                             | 0.017         |        |         |    |                              |
|               | 入出力・シュミットトリガ緩衝部             | 0.8VDD        | -      | -       |    | PINnCTRL.INLVL='0'           |
| VIH           | ポート ・TTL基準                  | -             | >2.0   | -       | V  | PINnCTRL.INLVL='1', VDD>2.7V |
|               | RESETピン                     | 0.8VDD        | _      | _       |    |                              |
| 入力漏∤          | 1電流 ( <u>注</u> 1)           |               |        |         |    |                              |
| IIL           | 入出力ポート                      | -             | <50    | -       | nA | GND≦VPIN≦VDD、高インピーダンスピン、     |
| IIL           | RESETピン (注2)                | -             | <50    | -       |    | TA=85℃                       |
| プルアッフ゜        | 抵抗                          |               |        |         |    |                              |
| Rp            | -                           | _             | 26     | _       | kΩ |                              |
| Low出力         | 電圧                          |               | •      |         |    |                              |
| VOL           | 標準入出力ポート                    | _             | -      | _       | V  | VDD=3.0V, IOL=6mA            |
| High出力        | 」電圧                         |               |        |         | •  | 1                            |
| VOH           | 標準入出力ポート                    | -             | -      | -       | V  | VDD=3.0V, IOH=6mA            |
| 入出力と          | シ上昇/下降時間                    |               | I      |         |    | 1                            |
|               |                             | -             | 22     | -       |    | PINnCTRL.SRL='0'             |
|               | 上昇時間                        | -             | 45     | _       |    | PINnCTRL.SRL='1'             |
| $t_{SR}$      |                             | _             | 16     | _       | ns | PINnCTRL.SRL='0'             |
|               | 下降時間                        | _             | 30     | _       |    | PINnCTRL.SRL='1'             |
| ピン容量          |                             |               |        |         |    |                              |
| CIO           | 全入出力ピン                      | _             | 5      | _       | pF |                              |
|               |                             | ц<br>Пр та-25 |        | のいです    | -  | 」<br>D要素は設計指針用だけで検査されません     |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

注1: 負(-)の電流はピンによって吐き出される電流です。

注2: RESETピンの漏れ電流は印加される電圧水準に大きく依存します。指定した基準は標準的な動作条件を表します。違う入力 電圧ではより高い漏れ電流が測定されるかもしれません。

# 35.8. メモリ プログラミンク゛仕様

#### 表35-7. メモリ プログラミング仕様

| シンボル            | 説明              | 最小          | 代表 (†) | 最大     | 単位      | 条件      |  |  |  |  |  |  |
|-----------------|-----------------|-------------|--------|--------|---------|---------|--|--|--|--|--|--|
| データ用EEP         | ROMメモリ仕様        |             |        |        |         |         |  |  |  |  |  |  |
| ED (*)          | データEEPROMバイト耐久性 | 100000      | -      | -      | 消去/書き回数 |         |  |  |  |  |  |  |
| td_ret          | 保持特性            | -           | 40     | -      | 年       | TA=55°C |  |  |  |  |  |  |
| VD_RW           | 読みまたは消去/書き操作VDD | VDDMIN      | -      | VDDMAX | V       |         |  |  |  |  |  |  |
| td_ce           | EEPROM全体消去時間    | -           | 4      | -      |         |         |  |  |  |  |  |  |
| td_bpw          | バイト/ページ書き込み時間   | -           | 2      | -      | ms      |         |  |  |  |  |  |  |
| td_bpe          | バイト/ページ消去時間     | -           | 2      | -      |         |         |  |  |  |  |  |  |
| プログラム用フ         | フラッシュ メモリ仕様     |             |        |        |         |         |  |  |  |  |  |  |
| EP ( <b>*</b> ) | フラッシュ メモリ セル耐久性 | 10000       | -      | -      | 消去/書き回数 |         |  |  |  |  |  |  |
| tp_ret          | 保持特性            | -           | 40     | -      | 年       |         |  |  |  |  |  |  |
| VP_RD           | 読み操作VDD         | VDDMIN      | -      | VDDMAX | V       |         |  |  |  |  |  |  |
| VP_REW          | 消去/書き操作VDD      | VDDMIN (注1) | -      | VDDMAX | v       |         |  |  |  |  |  |  |
| tp_ce           | チップ消去時間         | _           | 10     | -      |         |         |  |  |  |  |  |  |
| tp_pe           | ページ/複数ページ消去時間   | -           | 6      | -      | ms      |         |  |  |  |  |  |  |
| tp_pw           | ページ書き込み時間       | -           | 4      | -      |         |         |  |  |  |  |  |  |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

\*: これらの要素は特性付けされますが、製造で検査されません。

**注1**: チップ 消去の間、BODLEVEL0で構成設定された低電圧検出器(BOD)がONを強制されます。VDD供給電圧がBODLEVEL0 に対するVBOD未満の場合、消去の試みは失敗するでしょう。

# 35.9. 温度仕様

## 表35-8. 温度仕様

| シンホール   | 説明           | 代表   | 単位   | 条件                  |
|---------|--------------|------|------|---------------------|
|         |              | 60.0 |      | 28ピンPDIP外囲器 (SP)    |
|         |              | 47.0 |      | 28リートSOIC外囲器 (SO)   |
|         |              | 67.1 |      | 28リートSSOP外囲器 (SS)   |
| heta JA | 周囲に対する接合部熱抵抗 | 36.1 | °C/W | 32パット VQFN外囲器 (RXB) |
|         |              | 58.8 |      | 32リートTQFP外囲器 (PT)   |
|         |              | 33.7 |      | 48パッドVQFN外囲器 (6LX)  |
|         |              | 55.6 |      | 48リートTQFP外囲器 (PT)   |
| TJMAX   | 最大接合部温度      |      |      | 「絶対最大定格」項を参照してください。 |

**注**: ・ 次のように消費電力を計算してください。: PDIS=VDD×{IDD-ΣIOH}+Σ{(VDD-VOH)×IOH}+Σ(VOL×IOL)

・次のように内部消費電力を計算してください。: PINTERNAL = IDD × VDD、ここでIDDは出力ピンでどの負荷も駆動していない チップ単独走行電流です。

・次のように減電力(デレーティング)を計算してください。: PDER=PDMAX(TJ-TA)/ のJA、ここでTA=周囲温度、TJ=接合部温度

# 35.10. CLKCTRL

## 35.10.1. 内部発振器

# 表35-9. 内部発振器仕様 (注1)

| シンホール                                | 説明             | 最小 | 代表 (†) | 最大 | 単位      | 条件                   |
|--------------------------------------|----------------|----|--------|----|---------|----------------------|
| <i>f</i> oschf                       | 精度校正された        | -  | 20     | —  |         | OSCCFG.OSCHFFRQ='00' |
| JUSCHF                               | OSCHF周波数       | -  | 16     | -  | MHz     | OSCCFG.OSCHFFRQ='01' |
| $f_{\rm CAL}$                        | 周波数調節範囲        | -  | _      | -  | IVII IZ | OSCCFG.OSCHFFRQ='00' |
| JCAL                                 | /可 仪 妖 响 印 电口口 | -  | _      | -  |         | OSCCFG.OSCHFFRQ='01' |
| %CAL                                 | OSCHF調節段階量     | -  | 0.2    | -  |         |                      |
| Eoschf                               | 16/20MHz周波数    | -  | <1     | -  | %       | TA=25℃, VDD=3.0V     |
| _TOTAL                               | 選択での総合誤差       | -  | <3     | -  | /0      | 全動作範囲                |
| Doschf                               | デューティ サイクル     | -  | 50     | -  |         |                      |
| toschf_st ( <b>注2</b> )              | OSCHF始動時間      | -  | 10     | -  | μs      | 2%精度内                |
| fosc32k                              | 内部OSC32K周波数    | -  | 32.768 | -  | kHz     |                      |
| Eosc32K                              | 目的周波数からの       | _  | <1     | _  |         | TA=25℃, VDD=3.0V     |
| _TOTAL                               | 総合誤差           | _  | <10    | _  | %       | 全動作範囲                |
| Dosc32K                              | デューティ サイクル     | -  | 50     | _  |         |                      |
| t <sub>OSC32K_ST</sub> ( <b>注2</b> ) | OSC32K始動時間     | -  | 220    | _  | μs      |                      |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

注1: これらの発振器周波数公差を保証するため、VDDとGNDは可能な限りデバイスの近くで容量性雑音分離(デカップ)されなけれ ばなりません。詳細については「ハート・ウェアの指針」章の「電源用接続」項をご覧ください。

注2: 起き上がり時間は起こし事象からコード実行までで測定されます。

#### 35.10.2. XOSC32K

#### 表35-10. 32.768kHzクリスタル用発振器(XOSC32K)仕様

| シンホ゛ル                      | 説明         | 最小 | 代表 (†) | 最大 | 単位   | 条件                      |
|----------------------------|------------|----|--------|----|------|-------------------------|
| <i>f</i> xosc32k           | 周波数        | -  | 32.768 | —  | kHz  |                         |
| CXTAL32K1/XTAL32K2 (*)     | ピン寄生容量     | -  | 5      | _  |      |                         |
| CL (*)                     | クリスタル負荷容量  |    | 18     | _  | pF   | XOSC32KCTRLA.LPMODE='0' |
| ∪_(↑)                      |            | -  | 8      | _  |      | XOSC32KCTRLA.LPMODE='1' |
| ESR ( <b>*</b> )           | 等価直列抵抗     |    | 100    | _  | kΩ   | XOSC32KCTRLA.LPMODE='0' |
| LON (*)                    | 守屾直列抵抗     | -  | 50     | _  | K 52 | XOSC32KCTRLA.LPMODE='1' |
| twoscos or (*)             | XOSC32始動時間 | _  | 300    | _  |      | XOSC32KCTRLA.LPMODE='0' |
| t <sub>XOSC32_ST</sub> (*) | 入03032如到时间 | -  | 1000   | _  | ms   | XOSC32KCTRLA.LPMODE='1' |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

\*: これらの要素は特性付けされますが、製造で検査されません。

#### 35.10.3. XOSCHF

#### 表35-11. 高周波数クリスタル用発振器(XOSCHF)仕様

| シンホ゛ル                      | 説明         | 最小 | 代表 (†) | 最大 | 単位   | 条件                               |
|----------------------------|------------|----|--------|----|------|----------------------------------|
| <i>f</i> xoschf            | 周波数        | 4  | -      | 8  | MHz  | HS発振器動作                          |
| JXUSCHF                    |            | 8  | -      | 20 | MITZ | HS発振器動作、VDD=2,5~5.5V             |
| CXTALHF1/XTALHF2(*)        | ピン寄生容量     | 1  | 5      |    | ηĘ   |                                  |
| CL (*)                     | クリスタル負荷容量  | 1  | 12     |    | pF   | $f_{\rm XOSCHF} \ge 4 {\rm MHz}$ |
|                            |            | 1  | 200    |    |      | XTALHF=4MHz                      |
| ESR (*)                    | 等価直列抵抗     | -  | 100    | Ι  | Ω    | XTALHF=8MHz                      |
| LOR (†)                    | 守屾但刘松饥     | I  | 80     | I  | 52   | XTALHF=12MHz                     |
|                            |            | -  | 50     | _  |      | XTALHF=20MHz                     |
| t <sub>XOSCHF_ST</sub> (*) | XOSCHF始動時間 | _  | -      | _  | ms   |                                  |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。 \*: これらの要素は特性付けされますが、製造で検査されません。

#### 35.10.4. 外部クロック



# 表35-12. 外部クロック仕様

| シンボル          | 説明      | 最小 | 代表 ( <del>†</del> ) | 最大 | 単位  | 条件 |
|---------------|---------|----|---------------------|----|-----|----|
| <i>f</i> clcl | クロック周波数 | -  | -                   | 20 | MHz |    |
| TCLCL         | クロック周期  | 50 | -                   | -  | ns  |    |
| tchcx         | High時間  | -  | 40                  | -  |     |    |
| tclcx         | Low時間   | -  | 40                  | -  | %   |    |
| ⊿TCLCL        | 周期間変化時間 | -  | 20                  | -  |     |    |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

## 35.10.5. システム クロック

#### 表35-13. システム クロック タイミング 特性

| シンホル                | 説明                        | 最小   | 代表 (†)                    | 最大 | 単位 | 条件       |                                                                    |  |
|---------------------|---------------------------|------|---------------------------|----|----|----------|--------------------------------------------------------------------|--|
|                     |                           | 0    | -                         | 5  |    | VDD≧1.8V |                                                                    |  |
|                     | 主クロック周波数、<br>工業温度範囲(注1)   | 0    | _                         | 10 |    | VDD≧2.7V | $-40^{\circ}\mathrm{C} \leq \mathrm{TA} \leq 85^{\circ}\mathrm{C}$ |  |
| $f_{\rm CLK\_MAIN}$ |                           | 0    | _                         | 20 |    | VDD≧4.5V |                                                                    |  |
|                     | 主クロック周波数、                 | 0    | -                         | 8  |    | VDD≧2.7V | $-40^{\circ}C \leq TA \leq 125^{\circ}C$                           |  |
|                     | 拡張温度範囲( <mark>注1</mark> ) | 0    | -                         | 16 |    | VDD≧4.5V |                                                                    |  |
| <i>f</i> cy         | 命令クロック周波数                 | 0    | <i>f</i> clk_main         | -  |    |          |                                                                    |  |
| T <sub>CY</sub>     | 命令周期 ( <mark>注2</mark> )  | 41.6 | 1/ <i>f</i> <sub>CY</sub> | _  | ns |          |                                                                    |  |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

**注1**: 主クロック(CLK\_MAIN)周波数は「CLKCTRL - クロック制御器」章で記述されるように、クロック選択(CLKSEL)ビット領域によって構成設定されます。

注2: 命令周期時間(TCY)は入力発振器時間基準周期と等価です。それらの指定された限度を超えると、不正なコート、実行や予期 されるよりも高い消費電流になるかもしれません。全てのデバイスはEXTCLKビンに印加された外部クロックと共に"最小"値で動 作することを検査されます。外部クロック入力が使われる時の"最大"周期時間限度は全てのデバイスに対して"DC"(クロックなし) です。

# 35.11. RSTCTRLŁBOD

#### 表35-14. リセット、WDT、発振器始動計時器、起動計時器、低電圧検出器仕様

| シンホール                         | 説明                      | 最小   | 代表 (†)             | 最大   | 単位  | 条件            |
|-------------------------------|-------------------------|------|--------------------|------|-----|---------------|
| t <sub>RST</sub> ( <b>*</b> ) | リセットを保証するRESETヒンLowハルス幅 | 2.5  | -                  | -    | μs  |               |
| RRST_UP (*)                   | RESETピン プルアップ 抵抗        | -    | 35                 | -    | kΩ  |               |
| TOST (*)                      | 発振器始動計時器期間(注1)          | 1    | 1024               | 1    | 周期数 |               |
|                               |                         | I    | 1.75               | 1    |     | BODLEVEL0     |
| VBOD+                         | 上見傾斜 低雲正於出哭雲正 (汁)       |      | 1.90               | 2.10 |     | BODLEVEL1     |
| V BOD+                        | + 上昇傾斜、低電圧検出器電圧(注2)     | -    | 2.60               | 2.80 |     | BODLEVEL2     |
|                               |                         | I    | 4.30               | 4.60 | V   | BODLEVEL3     |
|                               |                         | 1.62 | 1.75               | 1    | V   | BODLEVEL0     |
| VBOD-                         | 下降傾斜、低電圧検出器電圧(注2)       | 1.80 | 1.90               | 1    |     | BODLEVEL1     |
| VBOD-                         | 一件項科、吆电儿伙山盆电儿(/土2)      | 2.43 | 2.60               | 1    |     | BODLEVEL2     |
|                               |                         | 4.05 | 4.30               | -    |     | BODLEVEL3     |
| VBOD_HYS                      | 低電圧検出器ヒステリシス            | -    | 25                 | -    | mV  |               |
| t <sub>bod_st</sub>           | 休止からの低電圧検出器始動時間         | -    | 30                 | -    | μs  |               |
| t <sub>BOD</sub>              | 採取動作BOD採取時間             |      | 1/f <sub>BOD</sub> | -    | ms  |               |
| t <sub>bod_rst</sub>          | 低電圧リセット応答時間             | _    | 4                  | _    | μs  | VDD=VBOD-0.1V |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

\*: これらの要素は特性付けされますが、製造で検査されません。

注1: 設計により、発振器始動計時器(TOST)は周波数と無関係に最初の1024周期を計数します。

注2: これらの電圧公差を保証するため、VDDとGNDは可能な限りデバイスの近くで容量性雑音分離(デカップ)されなければなりません。詳細については「ハート・ウェアの指針」章の「電源用接続」項をご覧ください。

#### 表35-15. 電圧水準監視部閾値仕様

| シンホール    | 説明     | 最小 | 代表 (†) | 最大 | 単位            | 条件          |
|----------|--------|----|--------|----|---------------|-------------|
|          |        | 1  | 5      | 10 | DOD間は         | VLMLVL='01' |
| VDET (*) | 電圧検出閾値 | 9  | 15     | 22 | BOD閾値<br>越えの% | VLMLVL='10' |
|          |        | 19 | 25     | 32 | 100 × V / 10  | VLMLVL='11' |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

\*: これらの要素は特性付けされますが、製造で検査されません。

#### 35.12. VREF

#### 表35-16. VREF仕様

| シンホ゛ル                    | 説明              | 最小    | 代表 (†)  | 最大      | 単位  |           | 条件                                        |
|--------------------------|-----------------|-------|---------|---------|-----|-----------|-------------------------------------------|
| VVREF_2V048 (注)          | 内部電圧参照基準2.048V  | -     | ±2      | _       |     | VDD≧2.55V |                                           |
| VVREF_1V024 (注)          | 内部電圧参照基準1.024V  |       |         |         |     | VDD≧1.8V  | $VDD \leq 5.5V$ ,                         |
| VVREF_2V500 (注)          | 内部電圧参照基準2.5V    | -     | $\pm 3$ | -       |     | VDD≧3.0V  | $-40^{\circ}C \leq TA \leq +85^{\circ}C$  |
| VVREF_4V096 (注)          | 内部電圧参照基準4.096V  |       |         |         | %   | VDD≧4.6V  |                                           |
| VVREF_1V024 (注)          | 内部電圧参照基準1.024V  |       |         |         | %   | VDD≧1.8V  |                                           |
| VVREF_2V048 (注)          | 内部電圧参照基準2.048V  | _     | $\pm 5$ |         |     | VDD≧2.55V | $VDD \leq 5.5V$ ,                         |
| VVREF_2V500 (注)          | 内部電圧参照基準2.5V    |       | $\pm 0$ |         |     | VDD≧3.0V  | $-40^{\circ}C \leq TA \leq +125^{\circ}C$ |
| VVREF_4V096 (注)          | 内部電圧参照基準4.096V  |       |         |         |     | VDD≧4.6V  |                                           |
| VVREF                    | 内部電圧参照基準        | -     | -       | VDD-0.4 | V   |           |                                           |
| t <sub>INTREF</sub> (*)  | 電圧参照基準変更遅延      | -     | -       | _       | 110 |           |                                           |
| t <sub>VREF_ST</sub> (*) | 内部VREF始動時間      | _     | 130     | 180     | μs  |           |                                           |
| VVREFA                   | VREFA外部基準ピン入力電圧 | 1.024 | -       | VDD     | V   |           |                                           |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

\*: これらの要素は特性付けされますが、製造で検査されません。

注: VVREF\_xVxxxシンボルはADC0.CTRLC、VREF.DAC0REF、VREF.ACREFのレジスタの各々のREFSELビット領域値を示します。

#### 35.13. USART



#### 表35-17. 主装置SPI動作でのUSART - タイミング仕様

| シンホ゛ル                                | 説明              | 最小                      | 代表 ( <del>†</del> )  | 最大                   | 単位  | 条件 |
|--------------------------------------|-----------------|-------------------------|----------------------|----------------------|-----|----|
| <i>f</i> <sub>SCK</sub> ( <b>*</b> ) | SCKクロック周波数      | -                       | -                    | $f_{\rm CLK\_PER/2}$ | MHz |    |
| $T_{SCK}(\mathbf{*})$                | SCK周期           | $2 \times T_{CLK\_PER}$ | -                    | _                    |     |    |
| t <sub>SCKW</sub>                    | SCK High/Low幅   | —                       | $0.5 \times T_{SCK}$ | _                    |     |    |
| t <sub>SCKR</sub>                    | SCK上昇時間         | _                       | 2.7                  | _                    |     |    |
| tsckf                                | SCK下降時間         | -                       | 2.7                  | -                    |     |    |
| t <sub>MIS</sub>                     | SCKに対するMISO準備時間 | -                       | 10                   | -                    | ns  |    |
| t <sub>MIH</sub>                     | SCK後MISO保持時間    | -                       | 10                   | -                    |     |    |
| t <sub>MOS</sub>                     | SCKに対するMOSI準備時間 | -                       | 0.5×T <sub>SCK</sub> | -                    |     |    |
| t <sub>MOH</sub>                     | SCK後MOSI保持時間    | -                       | 1.0                  | -                    |     |    |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

\*: これらの要素は特性付けされますが、製造で検査されません。

#### 35.14. SPI

### 図35-4. SPI - 主装置動作でのタイミング必要条件



#### 表35-18. SPI - 主装置動作でのタイミング仕様

| シンホ゛ル                     | 説明              | 最小                      | 代表 ( <del>†</del> )  | 最大                   | 単位  | 条件 |
|---------------------------|-----------------|-------------------------|----------------------|----------------------|-----|----|
| $f_{\rm SCK}(\mathbf{*})$ | SCKクロック周波数      | -                       | -                    | $f_{\rm CLK\_PER}/2$ | MHz |    |
| $T_{SCK}(\mathbf{*})$     | SCK周期           | $2 \times T_{CLK\_PER}$ | -                    | -                    |     |    |
| tsckw                     | SCK High/Low幅   | _                       | $0.5 \times T_{SCK}$ | _                    |     |    |
| t <sub>MIS</sub>          | SCKに対するMISO準備時間 | -                       | TCLK_PER             | -                    | 200 |    |
| t <sub>MIH</sub>          | SCK後MISO保持時間    | -                       | 0                    | -                    | ns  |    |
| t <sub>MOS</sub>          | SCKに対するMOSI準備時間 | -                       | $0.5 \times T_{SCK}$ | -                    |     |    |
| t <sub>MOH</sub>          | SCK後MOSI保持時間    | _                       | $0.5 \times T_{SCK}$ | _                    |     |    |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

\*: これらの要素は特性付けされますが、製造で検査されません。



## 表35-19. SPI - 従装置でのタイミング仕様

| シンホル                   | 説明              | 最小                      | 代表 ( <del>†</del> ) | 最大                   | 単位  | 条件                                      |
|------------------------|-----------------|-------------------------|---------------------|----------------------|-----|-----------------------------------------|
| $f_{\rm SSCK}(*)$      | 従装置SCKクロック周波数   | -                       | _                   | $f_{\rm CLK\_PER}/6$ | MHz |                                         |
| T <sub>SSCK</sub> (*)  | 従装置SCK周期        | $6 \times T_{CLK\_PER}$ | _                   | -                    |     |                                         |
| t <sub>SSCKW</sub> (*) | SCK High/Low幅   | $3 \times T_{CLK\_PER}$ | _                   | _                    |     |                                         |
| $t_{SIS}(\mathbf{*})$  | SCKに対するMOSI準備時間 | 0                       | _                   | -                    |     |                                         |
| t <sub>SIH</sub> (*)   | SCK後MOSI保持時間    | $3 \times T_{CLK\_PER}$ | _                   | -                    |     |                                         |
| t <sub>SSS</sub> (*)   | SCKに対するSS準備時間   | TCLK_PER                | _                   | -                    | na  |                                         |
| t <sub>SSH</sub> (*)   | SCK後SS保持時間      | TCLK_PER                | _                   | -                    | ns  |                                         |
| tsos                   | SCK後のMISO有効時間   | -                       | t <sub>SR</sub> (注) | -                    |     | $f_{\rm SSCK} \ge f_{\rm CLK\_PER}/6$   |
| 1202                   | SCK後のMISO有 劝时间  | -                       | -                   | _                    |     | fssck <fclk_per 6<="" th=""></fclk_per> |
| tsoss                  | SS Low後MISO準備時間 | _                       | t <sub>SR</sub> (注) | _                    |     |                                         |
| t <sub>SOSH</sub>      | SS Low後MISO保持時間 | _                       | t <sub>SR</sub> (注) | _                    |     |                                         |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

\*: これらの要素は特性付けされますが、製造で検査されません。

注: t<sub>SR</sub>は入出力ピン上昇/下降時間です。

# 35.15. TWI



| 表35-20. TV      | VI – タイミング仕様            |                    |       |                                             |     |                                                       |
|-----------------|-------------------------|--------------------|-------|---------------------------------------------|-----|-------------------------------------------------------|
| シンホール           | 項目                      | 最小                 | 代表(†) | 最大                                          | 単位  | 条件                                                    |
| $f_{ m SCL}(*)$ | SCLクロック周波数              | -                  | -     | 1000                                        | kHz | 最大周波数は12MHz以上のシ<br>ステム クロックを必要とします。                   |
| VHYS (*)        | シュミットトリガ入力ヒステリシス電圧      | 0.05×VDD           | -     | 0.4×VDD                                     |     |                                                       |
| VOL             | Low出力電圧                 | _                  | -     | 0.4<br>0.2×VDD                              | V   | $I_{load}=3mA, VDD>2V$<br>$I_{load}=2mA, VDD \leq 2V$ |
| IOL(*)          | Lowレヘル出力電流              | 3                  | _     | 0.2~VDD                                     | mA  | VOL= $0.4V$                                           |
| tsp(*)          | 入力濾波による抑制尖頭雑音           | 0                  | _     | 50                                          | ns  | VOL-0.1V                                              |
| IL ( <b>*</b> ) | 各I/Oピンの入力電流             | -                  | _     | 1                                           | μΑ  | 0.1×VDD <vi<0.9×vdd< td=""></vi<0.9×vdd<>             |
| CI (*)          | AI/Ot <sup>°</sup> ンの容量 | _                  | _     | 10                                          | pF  |                                                       |
| 01(1)           |                         | (VDD-VOL(max))/IOL | _     | $1000 \text{ ns}/(0.8473 \times \text{CB})$ | рі  | $f_{\rm SCL} \leq 100 \rm kHz$                        |
| Rp ( <b>*</b> ) | プルアップ抵抗値                | (VDD-VOL(max))/IOL | -     | $300 \text{ns}/(0.8473 \times \text{CB})$   | Ω   | $f_{SCL} \leq 400 \text{kHz}$                         |
| T(P)(*)         |                         | (VDD-VOL(max))/IOL | _     | $120 \text{ns}/(0.8473 \times \text{CB})$   |     | $f_{SCL} \le 1$ MHz                                   |
|                 |                         | 4.0                | _     | -                                           |     | $f_{SCL} \leq 100 \text{kHz}$                         |
| thd sta(*)      | (再送)開始条件保持時間            | 0.6                | -     | -                                           |     | $f_{SCL} \leq 400 \text{kHz}$                         |
| 0112_0111()     |                         | 0.26               | -     | -                                           |     | $f_{SCL} \le 1 MHz$                                   |
|                 |                         | 4.7                | -     | -                                           |     | $f_{SCL} \leq 100 \text{kHz}$                         |
| TLOW (*)        | SCLクロックLow時間            | 0.6                | -     | -                                           |     | $f_{SCL} \leq 400 \text{kHz}$                         |
|                 |                         | 0.35               | -     | -                                           |     | $f_{SCL} \leq 1 MHz$                                  |
|                 |                         | 4.0                | _     | -                                           | μs  | $f_{SCL} \leq 100 \text{kHz}$                         |
| THIGH (*)       | SCLクロックHigh時間           | 0.6                | -     | -                                           |     | $f_{SCL} \leq 400 \text{kHz}$                         |
|                 |                         | 0.26               | _     | -                                           |     | $f_{SCL} \leq 1 MHz$                                  |
|                 |                         | 4.7                | -     | -                                           |     | $f_{SCL} \leq 100 \text{kHz}$                         |
| tsu sta (*)     | 再送開始条件準備時間              | 0.6                | -     | -                                           |     | $f_{SCL} \leq 400 \text{kHz}$                         |
| _ 、 , ,         |                         | 0.26               | _     | -                                           |     | $f_{SCL} \leq 1 MHz$                                  |
| + · - (·)       |                         | -                  | 0     | -                                           |     | SDAHOLD='00'                                          |
| LHD_DAT (*)     | データ保持時間                 | 300                | -     | 900                                         |     | SDAHOLD='11'                                          |
|                 |                         | 250                | -     | -                                           | ns  | $f_{\rm SCL} \leq 100 \rm kHz$                        |
| tsu_dat (*)     | データ準備時間                 | 100                | -     | -                                           |     | $f_{SCL} \leq 400 \text{kHz}$                         |
|                 |                         | 50                 | -     | -                                           |     | $f_{\rm SCL} \leq 1 \rm MHz$                          |
|                 |                         | 4                  | -     | -                                           |     | $f_{\rm SCL} \leq 100 \rm kHz$                        |
| tsu_sto (*)     | 停止条件準備時間                | 0.6                | -     | -                                           |     | $f_{\rm SCL} \leq 400 \rm kHz$                        |
|                 |                         | 0.26               | -     | -                                           | μs  | $f_{SCL} \leq 1 MHz$                                  |
| tour            | 停止条件→開始条件間              | 4.7                | -     | -                                           |     | $f_{SCL} \leq 100 \text{kHz}$                         |
| tbuf (*)        | バス開放時間                  | 1.3                | -     | -                                           |     | $f_{SCL} \leq 400 \text{kHz}$                         |
| tcs(*)          | 従装置クロック伸長遅延             | -                  | -     | 250                                         | ns  |                                                       |
| · "/\>+??*      | のデータナ別の定めがない阻り          |                    |       |                                             |     | ふットートケートリン                                            |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

\*: これらの要素は特性付けされますが、製造で検査されません。

# 35.16. DAC

#### 表35-21. DAC電気的仕様

| VDACREF= | VDD                      |     |        |         |     |                           |
|----------|--------------------------|-----|--------|---------|-----|---------------------------|
| シンホール    | 説明                       | 最小  | 代表 (†) | 最大      | 単位  | 条件                        |
| VDD      | 供給電圧                     | 1.8 |        | 5.5     | V   |                           |
| VOUT     | 出力電圧範囲                   | GND |        | VDD-0.1 | v   |                           |
| VLSB     | 分解能                      | -   | 10     | -       | ビット |                           |
| VACC     | 絶対精度                     | -   | 1      | -       | LSb |                           |
| tst      | 整定時間 ( <mark>注</mark> 1) | 1   | 7      | -       | μs  | 50pF負荷                    |
| INL      | 積分非直線性誤差                 | -   | 0.3    | -       |     | \$030≦DAC.DATA<\$3D0      |
| DNL      | 微分非直線性誤差                 | -   | 0.1    | _       | LSb | \$030 ≦ DAC. DATA < \$3D0 |
| EOFF     | 変位(オフセット)誤差              | -   | -2.0   | -       | LSD |                           |
| EGAIN    | 利得誤差                     | Ι   | 0.5    | -       |     |                           |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

注1: 整定時間はDACn.DATA9~0の'\$000'(GND)から'\$1FF'(中間点)への遷移間で測定され、これは最も遅い遷移です。

### 35.17. ADC

#### 表35-22. 電源、参照基準、入力範囲

動作条件:

- ・自由走行動作のADCでSAMPDUR=\$02に定義された採取速度
- ・別の指定がない限り、VREF選択と採取速度の許された全ての組み合わせに対して適用
- ・別の指定がない限り、許可されたPGAありとなしで特性は同じです。

| シンホール | 説明     | 最小    | 代表 (†) | 最大      | 単位   | 条件        |
|-------|--------|-------|--------|---------|------|-----------|
| VDD   | 供給電圧   | 1.8   | -      | 5.5     | V    |           |
| VREF  | 参照基準電圧 | 1.024 | -      | VDD     | V    |           |
| CIN   | 入力容量   |       | 2.5    |         | ъF   | PGA禁止     |
| CIN   | 八刀谷里   | -     | 7      | -       | pF   | PGA許可     |
| Rin   | 入力抵抗   | -     | 3      | -       | kΩ   | PGA禁止     |
| KIN   | 八刀抵机   | -     | 2.5    | -       | K 52 | PGA許可     |
| V/INI | 入力電圧範囲 | 0     | -      | VREF    | V    | シングルエンド動作 |
| VIN   | 八刀甩圧軋曲 | -0.1  | -      | VDD+0.1 | V    | 差動動作      |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

#### 表35-23. クロックとタイミングの特性

動作条件:

・自由走行動作のADCでSAMPDUR=\$02に定義された採取速度

・別の指定がない限り、VREF選択と採取速度の許された全ての組み合わせに対して適用

・別の指定がない限り、許可されたPGAありとなしで特性は同じです。

| シンホ゛ル   | 説明         | 最小  | 代表 ( <del>†</del> ) | 最大   | 単位    | 条件                  |
|---------|------------|-----|---------------------|------|-------|---------------------|
|         | ADCクロック周波数 | 300 | -                   | 2000 | 1.1.1 | REFSEL=内部参照基準       |
| CLK_ADC | ADC/19/月波数 | 300 | -                   | 6000 | kHz   | REFSEL=外部参照基準またはVDD |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

#### 表35-24. 精度仕様

#### 動作条件:

- VREF=VDD
- $f_{CLK\_ADC}=2MHz$
- ・自由走行動作のADCでSAMPDUR=\$02に定義された採取速度
- ・別の指定がない限り、VREF選択と採取速度の許された全ての組み合わせに対して適用
- ・別の指定がない限り、許可されたPGAありとなしで特性は同じです。

|                  |             |    | -      |    |     |                                   |
|------------------|-------------|----|--------|----|-----|-----------------------------------|
| シンホ゛ル            | 説明          | 最小 | 代表 (†) | 最大 | 単位  | 条件                                |
| Res              | 分解能         | -  | -      | 12 | ビット |                                   |
| E <sub>INL</sub> | 積分非直線性誤差    | -  | 0.8    | -  |     | VREF=2.048V, CLK_ADC=2.5MHz, 差動動作 |
| EDNL             | 微分非直線性誤差    | -  | 0.8    | -  |     |                                   |
| EOFF             | 変位(オフセット)誤差 | -  | 1.5    | -  | LSb |                                   |
| Egain            | 利得誤差        | -  | 0.6    | -  |     |                                   |
| Ет               | 総未調整誤差      | -  | 5      | -  |     |                                   |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

#### 表35-25. PGA許可での精度特性

#### 動作条件:

•  $-40^{\circ}C \leq TA \leq 125^{\circ}C$ 

・自由走行動作のADCでSAMPDUR=\$02に定義された採取速度

・別の指定がない限り、VREF選択と採取速度の許された全ての組み合わせに対して適用

| シンホール | 説明   | 最小 | 代表 ( <del>†</del> ) | 最大 | 単位    | 条件        |  |
|-------|------|----|---------------------|----|-------|-----------|--|
|       |      | -  | 32                  | -  |       | PGA利得=1倍  |  |
|       |      | -  | 63                  | -  |       | PGA利得=2倍  |  |
| NRMS  | 入力雑音 | -  | 125                 | -  | μVRMS | PGA利得=4倍  |  |
|       |      | -  | 250                 | -  |       | PGA利得=8倍  |  |
|       |      | -  | 500                 | -  |       | PGA利得=16倍 |  |
|       |      | -  | -0.2                | -  |       | PGA利得=1倍  |  |
|       |      | -  | -0.2                | -  |       | PGA利得=2倍  |  |
| Egain | 利得誤差 | -  | -0.3                | -  | %     | PGA利得=4倍  |  |
|       |      | -  | -0.6                | -  |       | PGA利得=8倍  |  |
|       |      | -  | -0.8                | -  |       | PGA利得=16倍 |  |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。

### 35.18. AC

# 表35-26. アナログ比較器仕様

| シンホ゛ル                        | 説明            | 最小   | 代表 ( <del>†</del> ) | 最大  | 単位 | 条件                                              |  |
|------------------------------|---------------|------|---------------------|-----|----|-------------------------------------------------|--|
| V <sub>IN</sub> ( <b>*</b> ) | 入力電圧範囲        | -0.2 | —                   | VDD | V  |                                                 |  |
| IL                           | 入力漏れ電流        | -    | 5                   | -   | nA |                                                 |  |
| Voff                         | 入力変位(オフセット)電圧 | -30  | $\pm 10$            | 30  | mV | -0.1V <vin<(vdd-0.1v)< th=""></vin<(vdd-0.1v)<> |  |
| CMRR (*)                     | 同相信号除去比       | -    | 70                  | -   | dB |                                                 |  |
|                              |               | -    | 10                  | 1   |    | CTRLA.HYSMODE='01'                              |  |
| Vhyst                        | ヒステリシス        | -    | 20                  | -   | mV | CTRLA.HYSMODE='10'                              |  |
|                              |               | -    | 30                  | -   |    | CTRLA.HYSMODE='11'                              |  |
| t <sub>RESP</sub> (*)        | 上昇端応答時間       | _    | 50                  | -   | na | CTRLA.POWER='00',                               |  |
| KESP (*)                     | 下降端応答時間       | _    | 150                 | _   | ns | VCM=VDD/2                                       |  |

+: "代表"列のデータは別の定めがない限り、TA=25℃とVDD=3.0Vです。これらの要素は設計指針用だけで検査されません。 \*: これらの要素は特性付けされますが、製造で検査されません。

# 35.19. UPDI



#### 表35-27. UPDIタイミング仕様

| シンホ゛ル                          | 説明                             | 最小  | 最大    | 単位    | 条件                                     |                                                    |
|--------------------------------|--------------------------------|-----|-------|-------|----------------------------------------|----------------------------------------------------|
| t <sub>RES</sub> (*)           | RESETでのハント・シェーク/BREAKの<br>持続時間 | 10  | 200   |       |                                        |                                                    |
| t <sub>UPDI</sub> (*)          | UPDI.txd=0の持続時間                | 10  | 200   | μs    |                                        |                                                    |
| t <sub>Deb0</sub> ( <b>*</b> ) | デバッガ.txd=0の持続時間                | 0.2 | 1     |       |                                        |                                                    |
| t <sub>DebZ</sub> (*)          | デバッガ.txd=z(Hi-Z)の持続時間          | 200 | 14000 |       |                                        |                                                    |
|                                |                                | -   | 4     |       | TA<0℃またはTA>+50℃                        | $1.8V \leq VDD \leq 5.5V$                          |
|                                |                                | -   | 8     |       | $0^{\circ}C \leq TA \leq +50^{\circ}C$ | $1.8V \ge VDD \ge 0.5V$                            |
| from (th)                      | UPDIクロック周波数                    | -   | 8     | N411- | TA<0℃またはTA>+50℃                        | $2.7V \leq VDD \leq 5.5V$                          |
| f <sub>UPDI</sub> (*)          | UPDI/LUY/同位数                   | -   | 16    | MHz   | $0^{\circ}C \leq TA \leq +50^{\circ}C$ | $2.1 \text{ V} \geq \text{VDD} \geq 5.5 \text{ V}$ |
|                                |                                | -   | 16    |       | TA<0℃またはTA>+50℃                        |                                                    |
|                                |                                | -   | 32    |       | $0^{\circ}C \leq TA \leq +50^{\circ}C$ | $4.5V \leq VDD \leq 5.5V$                          |

\*: これらの要素は特性付けされますが、製造で検査されません。

# <mark>36</mark>. 特性図

特性図は現時点に於いて利用できません。

# 37. 注文情報

- ・入手可能な注文選択は以下によって見つけることができます。
  - 以下の製品頁リンクの1つをクリック
    - AVR64EA28製品頁
    - AVR64EA32製品頁
    - AVR64EA48製品頁

- www.microchipdirect.comで製品名による検索
- 最寄りの販売会社へのお問い合わせ

注: 車載級注文符号(VAO接尾辞)は要請によって設定され、下表で一覧にされません。各々の製品頁に存在しないVAO注文符号 を要請するには最寄りのMicrochip営業担当者にお問い合わせください。

| 注文符号             | フラッシュ/SRAM | ピン数 | 外囲器形式 | 供給電圧     | 温度範囲                                              | 搬送形式            |
|------------------|------------|-----|-------|----------|---------------------------------------------------|-----------------|
| AVR64EA28T-E/SS  |            |     |       |          | -40°C∼125°C                                       | ≂               |
| AVR64EA28T-I/SS  |            | 28  | SSOP  | 1.8~5.5V | -40°C∼85°C                                        | テーフ。&リール        |
| AVR64EA28-E/SS   |            |     |       |          | -40°C∼125°C                                       | チューブ            |
| AVR64EA28-I/SS   |            |     |       |          | -40°C∼85°C                                        | 99-             |
| AVR64EA28T-E/STX |            |     | VQFN  |          | -40°C∼125°C                                       | テーフ°&リール        |
| AVR64EA28T-I/STX |            |     |       |          | $-40^{\circ}\mathrm{C}\sim\!85^{\circ}\mathrm{C}$ | アーノ&リール         |
| AVR64EA28-E/STX  |            |     |       |          | -40°C∼125°C                                       | トレイ             |
| AVR64EA28-I/STX  |            |     |       |          | $-40^{\circ}\mathrm{C}\sim85^{\circ}\mathrm{C}$   | rv1             |
| AVR64EA28-E/SP   |            | 32  | SPDIP |          | -40°C∼125°C                                       | チューフ            |
| AVR64EA28-I/SP   |            |     |       |          | $-40^{\circ}\mathrm{C}\sim85^{\circ}\mathrm{C}$   |                 |
| AVR64EA32T-E/PT  |            |     | TQFP  |          | -40°C∼125°C                                       | テープ&リール         |
| AVR64EA32T-I/PT  |            |     |       |          | -40°C∼85°C                                        |                 |
| AVR64EA32-E/PT   | 64KB/6KB   |     |       |          | -40°C∼125°C                                       | トレイ             |
| AVR64EA32-I/PT   | 04KD/0KD   |     |       |          | $-40^{\circ}\mathrm{C}\sim85^{\circ}\mathrm{C}$   | rv 1            |
| AVR64EA32T-E/RXB |            |     | VQFN  |          | -40°C∼125°C                                       | テープ&リール<br>トレイ  |
| AVR64EA32T-I/RXB |            |     |       |          | $-40^{\circ}\mathrm{C}\sim85^{\circ}\mathrm{C}$   |                 |
| AVR64EA32-E/RXB  |            |     |       |          | -40°C∼125°C                                       |                 |
| AVR64EA32-I/RXB  |            |     |       |          | $-40^{\circ}\mathrm{C}\sim85^{\circ}\mathrm{C}$   | rv7             |
| AVR64EA48T-E/PT  |            | 48  | TQFP  |          | -40°C∼125°C                                       | テーフ°&リール<br>トレイ |
| AVR64EA48T-I/PT  |            |     |       |          | $-40^{\circ}\mathrm{C}\sim85^{\circ}\mathrm{C}$   |                 |
| AVR64EA48-E/PT   |            |     |       |          | -40°C∼125°C                                       |                 |
| AVR64EA48-I/PT   |            |     |       |          | -40°C∼85°C                                        |                 |
| AVR64EA48T-E/6LX |            |     | VQFN  |          | -40°C∼125°C                                       | テーフ°&リール        |
| AVR64EA48T-I/6LX |            |     |       |          | -40°C∼85°C                                        | ) — ) & y — /V  |
| AVR64EA48-E/6LX  |            |     |       |          | -40°C∼125°C                                       | h./             |
| AVR64EA48-I/6LX  |            |     |       |          | -40°C∼85°C                                        | トレイ             |

注1: 有害物質使用制限に関する欧州指令(RoHS指令)適合の鉛フリー製品。またハロゲン化合物フリーで完全に安全。 注2: 外囲器外形図は「外囲器図」章で見つけることができます。



注: ソーノとリールの識別子は自動部品番号記述 Cにり現れより。 注义目的にこの識別子を使ってくたさい。 ソーノとリール住意選択 C の外囲器入手可能性についてはMicrochip営業所で調べてください。

注: VAO変種は車載応用に対するAEC-Q100要件用に設計、製造、検査、認定されています。これらの製品は非VAO部品と違う 外囲器を使うかもしれず、それらの電気的特性で追加の仕様を持ちます。

# 38. 外囲器図

# 38.1. オンライン外囲器図

最新の外囲器図については次のとおりです。

- 1. www.microchip.com/packagingへ行ってください。
- 2. 外囲器型式特定頁、例えば、VQFNへ行ってください。
- 3. 最新の外囲器図を見つけるために図番号と型式を探してくださ W.

| ピン数 | 外囲器型式                      | 図番号       | 型式  |
|-----|----------------------------|-----------|-----|
| しノ奴 | 77团备空式                     | 凶笛与       | 至式  |
|     | SPDIP                      | C04-00070 | SP  |
| 28  | SSOP                       | C04-00073 | SS  |
| 20  | VQFN                       | C04-00456 | STX |
|     | VQFN WF ( <mark>注</mark> ) | C04-00565 | 3LW |
|     | TQFP                       | C04-00074 | PT  |
| 32  | VQFN                       | C04-21395 | RXB |
|     | VQFN WF ( <mark>注</mark> ) | C04-21511 | QZB |
|     | TQFP                       | C04-00300 | PT  |
| 48  | VQFN                       | C04-00494 | 6LX |
|     | VQFN WF ( <mark>注</mark> ) | C04-00504 | 6MX |

注:この外囲器形式は濡れ性側面で、車載(VAO)注文符 号に使われるVQFN外囲器です。

注: 最新の外囲器図についてはhttp://www.microchip.com/packagingに置かれたMicrochip外囲器仕様をご覧ください。

# 38.2. 外囲器表示情報

| 凡例: XX~X | お客様指定情報またはMicrochip部品番号                         |
|----------|-------------------------------------------------|
| Y        | 年符号 (暦年の最終桁)                                    |
| YY       | 年符号 (暦年の最後の2桁)                                  |
| WW       | 週符号(1月第1週が'01'週です。)                             |
| NNN      | 英数字追跡可能性符号                                      |
| e3       | 無光沢錫(Sn)用鉛なしJEDEC <sup>®</sup> 指示子              |
|          | 完全なMicrochip部品番号は1行で記すこと<br>、次の行に持ち越され、従ってお客様指定 |
|          | · · · · · · · · · · · · · · · · · · ·           |
| 情報に利     | 用可能な文字数を制限します。                                  |

# 38.2.1. 28ピンSPDIP



38.2.2. 28U-FSOIC



## 38.2.3. 28パット VQFN



### 38.2.4. 32IJ-ドTQFP



### 38.2.5. 32パット VQFN



### 38.2.6. 48リート TQFP



# 38.2.7. 48 / ้ v VQFN



# 38.3. 28ピンSPDIP

28ピン狭幅プラスティック2列(SP) - 300mil本体 [SPDIP]



# 38.4. 28リート SSOP

28リート<sup>\*</sup>プラスティック縮小小外形外囲器(SS) - 5.30mm本体、2.00mm [SSOP]



# <mark>38.5</mark>. 28/\°้งโ`VQFN

28パット<sup>\*</sup>超薄型プラスティック四角平板、リート<sup>\*</sup>なし外囲器(STX) - 4×4×1.0mm本体 [VQFN]、2.65×2.65mm露出パット<sup>\*</sup>付き



## 38.6. 28 パッド VQFN 濡れ性側面

28パット<sup>\*</sup>超薄型プラスティック四角平板、リート<sup>\*</sup>なし外囲器(3LW) - 4×4×1.0mm本体 [VQFN] 2.65mm露出パット<sup>\*</sup>付き、段付き濡れ性側面





|                  | 単位 |      | mm      |      |
|------------------|----|------|---------|------|
| 寸法               | 限度 | 最小   | 標準      | 最大   |
| 接触子間隔            | Е  | 0    | .40 BS0 | 0    |
| 中央パッド幅           | X2 | I    | I       | 2.75 |
| 中央パッド長           | Y2 | -    | -       | 2.75 |
| 接触パット空間          | C1 | -    | 4.00    | -    |
| 接触パッド空間          | C2 | -    | 4.00    | -    |
| 接触パッド幅(×28)      | X1 | -    | -       | 0.20 |
| 接触パッド長(×28)      | Y1 | -    | -       | 0.80 |
| 接触パッド中央パッド間(×28) | G1 | 0.23 | -       | -    |
| 接触パッド間(×24)      | G2 | 0.20 | -       | -    |
| 放熱ビア直径           | φV | -    | 0.30    | -    |
| 放熱ビア間隔           | EV | -    | 1.00    | -    |

BSC: 基本寸法。公差なしで示される理論的に正確な値。 注2: 最良の半田付け結果のため、使うなら、放熱ビアはリフロー処理中の半田損失を 避けるためにベダ塗またはテンティングされるべきです。

Microchip Technology作図C04-2565改訂A

### **38.7**. 32リート TQFP

32リードプラスティック薄型四角平板外囲器(PT) - 7×7×1.0mm本体、2.00mm [TQFP] (Atmel旧一般外囲器符号AUT)



### 38.8. 32パット VQFN

#### 32パット<sup>\*</sup>超薄型プラスティック四角平板、リート<sup>\*</sup>なし外囲器(RXB) - 5×5×0.9mm本体 [VQFN] 3.1×3.1mm露出パット<sup>\*</sup>付き、Atmel旧一般外囲器符号ZMF



# 38.9. 32 パッドVQFN 濡れ性側面

32パット<sup>\*</sup>超薄型プラスティック四角平板、リート<sup>\*</sup>なし外囲器(QZB) - 5×5×0.9mm本体 [VQFN] 3.1mm露出パット<sup>\*</sup>付き、段付き濡れ性側面



### 38.10. 48IJート TQFP

48リート<sup>\*</sup>薄型四角平板外囲器(PT) - 7×7×1.0mm本体 [TQFP]



### <mark>38</mark>.11. 48/ນໍ<sub>ິ</sub> ງໂັVQFN

48パット、超薄型プラスティック四角平板、リート、なし外囲器(6LX) - 6×6×0.8mm本体 [VQFN] 4.1×4.1mm露出パット、付き



# 38.12. 48 パッドVQFN 濡れ性側面

48パット<sup>\*</sup>超薄型プラスティック四角平板、リート<sup>\*</sup>なし外囲器(6MX) - 6×6mm本体 [VQFN] 4.1×4.1mm露出パット<sup>\*</sup>付き、段付き濡れ性側面



# 39. 障害情報

(訳注)原書では障害情報が独立した文書で提供されていますが、本書では便宜性のためここにも記載します。

# 39.1. シリコン問題要約

### 凡例

- 障害は適用されません。
- × 障害が適用されます。

| 周辺機能           | 簡単な説明                                         |     | シリコン改                 | 訂に対する | 有効性 |
|----------------|-----------------------------------------------|-----|-----------------------|-------|-----|
| 同辺俄能           | 間甲な説明                                         | 改訂  | B1 ( <mark>注</mark> ) | B2    |     |
|                | 39.2.1. 2.7V未満で動かないNVMプログラミング                 |     | ×                     | -     |     |
| デバイス           | 39.2.2. BODLEVEL3未満のVDDに対して減らされるフラッシュ メモリ寿命   |     | ×                     | -     |     |
|                | 39.2.3. 特定アドレス空間への連続書き込みの場合に失われる書き込み操作        |     | ×                     | -     |     |
|                | 39.2.4. フラッシュ ブートの大きさとフラッシュ コートの大きさのヒューズでの制限  |     | _                     | ×     |     |
| CRCSCAN        | 39.3.1. 機能しないフラッシュ メモリの一部でのCRC走査実行            |     | ×                     | -     |     |
| NVMCTRL        | 39.4.1. UDPIから機能しないフラッシュ メモリ複数ページ消去           |     | ×                     | ×     |     |
| IN VIVIC I KL  | 39.4.2. プログラミング中のフラッシュ読み込み時に失敗するフラッシュ自己プログラミン | (ク) | ×                     | -     |     |
| USART          | 39.5.1. 矛盾する同期領域検出後に機能しない受信部                  |     | ×                     | ×     |     |
| <u>注</u> :この改訂 | がシリコンの初公開です。                                  |     |                       |       |     |

### <u>39.2</u>. デバイス

#### 39.2.1. 2.7V未満で動かないNVMプログラミング

VDDが2.7V未満の時の消去または書き込みの操作実行は失敗するかもしれません。消去または書き込みの操作を開始する前に VDDが2.7V以上であることを確実にしてください。代わりに基準をBODLEVEL2またはそれ以上に設定したBODを許可することがで きます。

#### 対策/対処:

ありません。

#### 影響を及ぼされるシリコン改訂

| 改訂 | B1 B2 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|-------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | × -   |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 39.2.2. BODLEVEL3未満のVDDに対して減らされるフラッシュ メモリ寿命

BODLEVEL3未満のVDDで動作する場合、フラッシュメモリ寿命は1000消去/書き込み回数に減らされます。この減少は消去/書き込み中のVDD水準と無関係です。

#### 対策/対処:

ありません。

#### 影響を及ぼされるシリコン改訂

| 改訂 | B1 | B2 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|----|----|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | ×  | -  |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 39.2.3. 特定アドレス空間への連続書き込みの場合に失われる書き込み操作

アドレス≧64への<mark>ST/STD/STS</mark>命令に続く、アドレス<64への<mark>ST/STD</mark>命令または休止制御器の制御A(SLPCTRL.CTRLA)レジスタへの書 き込みのどちらでも最後の書き込みを失います。

#### 対策/対処:

書き込み操作の消失を避けるため、アドレス空間に応じて以下の対策の1つを使ってください。

- ・アドレス<64への書き込み前にNOP命令を挿入するか、またはST/STDの代わりにOUT命令を使ってください。
- ・SLPCTRL.CTRLAレジスタへの書き込み前にNOP命令を挿入してください。

#### 影響を及ぼされるシリコン改訂

| 改訂 | B1 | B2 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|----|----|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | ×  | -  |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 39.2.4. フラッシュ ブートの大きさとフラッシュ コート の大きさのヒュース での制限

CRCが(FUSE.SYSCFG0のCRCSRC)ヒューズを通して許可される、またはCRCSCANを使ってソフトウェアから開始される場合、フラッシュフートの大きさ(FUSE.BOOTSIZE)とフラッシュコードの大きさ(FUSE.CODESIZE)は512パイトの乗数に構成設定され(FUSE.BOOTSIZEとFUS E.CODESIZEのLSb(最下位ビット)が'0'で)なければなりません。

### 対策/対処:

ありません。

### 影響を及ぼされるシリコン改訂

| 改訂 | B1 | B2 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|----|----|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | -  | ×  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### 39.3. CRCSCAN - 巡回冗長検査メモリ走査

### 39.3.1. 機能しないフラッシュ メモリの一部でのCRC走査実行

- ・ブートの大きさ(FUSE.BOOTSIZE)が\$00以外の場合、ブート領域でのCRC走査実行は動きません。
- ・コードの大きさ(FUSE.CODESIZE)が\$00以外の場合、ブート領域と応用領域でのCRC走査実行は動きません。
- ・フラッシュ メモリ全体でのCRC走査実行は動きます。

### 対策/対処:

ありません。

影響を及ぼされるシリコン改訂

| 改訂 | B1 B2 |  |  |  |  |  |  |  |  |  |  |  |  |
|----|-------|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | × -   |  |  |  |  |  |  |  |  |  |  |  |  |

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

#### 39.4.1. UDPIから機能しないフラッシュ メモリ複数ページ 消去

UPDIからのフラッシュメモリ複数ヘ゜ージ消去(制御A(NVMCTRL.CTRLA)の指令(CMD)と、ット領域へのFLMPERn書き込み)の実行はブート 領域で動きません。どのフラッシュメモリ領域でも複数ヘ゜ージ消去を使うことは推奨されません。

#### 対策/対処:

フラッシュメモリ ヘージ 消去(NVMCTRL.CTRLAのCMDビット領域へのFLPER(\$08)書き込み)を使ってください。

#### 影響を及ぼされるシリコン改訂

| 改訂 | B1 | B2 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|----|----|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | ×  | ×  |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 39.4.2. プログラミング中のフラッシュ読み込み時に失敗するフラッシュ自己プログラミング

フラッシュ メモリのRWW領域が書かれているまたは消去されている(フラッシュ ページ書き込みまたはフラッシュ メージ消去の)間にデータがフラッ シュ メモリのNRWW領域から読まれる場合、消去や書き込みが失敗するかもしれません。フラッシュ メモリのNRWW領域からの命令取得は フラッシュ メモリのRWW領域への消去や書き込みの操作に影響を及ぼされません。

#### 対策/対処:

選択1:RWW機能が不要

・NRWW領域から実行している時にフラッシュ メモリ自己プログラミングを使わないでください。

選択2:RWW機能が必要

- ・継続動作でBODを許可(低電圧検出器構成設定(FUSE.BODCFG)ヒュースで、BOD基準(LVL)ビット領域にBODLEVEL1かより高い 値を、活動とアイドルでのBOD動作形態(ACTIVE)ビット領域に'11'を設定)してください。
- ・ ページ消去/書き込み操作(制御A(NVMCTRL.CTRLA)の指令(CMD)ビット領域への\$05書き込み)を使わないでください。代わりに2 つの独立した操作としてフラッシュメモリ ページ消去とフラッシュメモリ ページ 書き込みを実行してください。

#### 影響を及ぼされるシリコン改訂

| 改訂 | B1 | B2 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|----|----|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | ×  | -  |  |  |  |  |  |  |  |  |  |  |  |  |  |

#### 39.5. USART - 万能同期/非同期送受信器

#### 39.5.1. 矛盾する同期領域検出後に機能しない受信部

USART受信部は状態(USARTn.STATUS)レジスタの矛盾同期領域割り込み要求フラグ(ISFIF)が設定(1)された時に機能しなくなります。 ISFIF割り込み要求フラグは制御B(USARTn.CTRLB)レジスタの受信動作(RXMODE)ヒット領域が標準自動ボーレート(GENAUTO)動作また はLIN制限自動ボーレート(LINAUTO)動作に構成設定され、受信した動作フレームがデータシートで記述されたような条件に従わない時に 設定(1)されます。このフラグの解除(0)はUSART受信部を再許可しません。

#### 対策/対処:

ISFIF7ラゲが設定(1)された時は、USART制御B(USARTn.CTRLB)レジスタの受信許可(RXEN)ビットに'0'を書き、その後に'1'を書くこと により、USART受信部を禁止してその後に再許可してください。

#### 影響を及ぼされるシリコン改訂

| 改訂 | B1       | B2 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|----------|----|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 影響 | $\times$ | X  |  |  |  |  |  |  |  |  |  |  |  |  |  |

# 40. データシート改訂履歴

注: データシートの改訂はダイ改訂とデバイス変種(注文番号の最後の文字)と無関係です。

# 40.1. 改訂A - 2022年9月

| 章  | 説明     |
|----|--------|
| 文書 | 初回文書公開 |

# Microchip情報

# Microchipウェフ゛サイト

Microchipはwww.microchip.com/で当社のウェブサイト経由でのオンライン支援を提供します。このウェブサイトはお客様がファイルや情報を容易に利用可能にするのに使われます。利用可能な情報のいくつかは以下を含みます。

- ・製品支援 データシートと障害情報、応用記述と試供プログラム、設計資源、使用者の手引きとハートウェア支援資料、最新ソフトウェア配布と保管されたソフトウェア
- ・全般的な技術支援 良くある質問(FAQ)、技術支援要求、オンライン検討グループ、Microchip設計協力課程会員一覧
- ・Microchipの事業 製品選択器と注文の手引き、最新Microchip報道発表、セミナーとイベントの一覧、Microchip営業所の一覧、代理 店と代表する工場

# 製品変更通知サービス

Microchipの製品変更通知サービスはMicrochip製品を最新に保つのに役立ちます。加入者は指定した製品系統や興味のある開発ツールに関連する変更、更新、改訂、障害情報がある場合に必ず電子メール通知を受け取ります。

登録するにはwww.microchip.com/pcnへ行って登録指示に従ってください。

# お客様支援

Microchip製品の使用者は以下のいくつかのチャネルを通して支援を受け取ることができます。

- ・代理店または販売会社
- ・最寄りの営業所
- ・組み込み解決技術者(ESE:Embedded Solutions Engineer)
- ・技術支援

お客様は支援に関してこれらの代理店、販売会社、またはESEに連絡を取るべきです。最寄りの営業所もお客様の手助けに利用できます。営業所と位置の一覧はこの資料の後ろに含まれます。

技術支援はwww.microchip.com/supportでのウェブ サイトを通して利用できます。

# 製品識別システム

注文する、または例えば、価格や納品の情報を得るには工場または一覧にされた販売代理店にお問い合わせください。



- 注: テープとリールの識別子は目録部品番号記述でだけ現れます。注文目的にこの識別子を使ってください。テープとリール任意選択での 外囲器入手可能性についてはMicrochip営業所で調べてください。
- 注: VAO変種は車載応用に対するAEC-Q100要件用に設計、製造、検査、認定されています。これらの製品は非VAO部品と違う外 囲器を使うかもしれず、それらの電気的特性で追加の仕様を持ちます。

# Microchipデバイスコート、保護機能

Microchip製品での以下のコード保護機能の詳細に注意してください。

- ・Microchip製品はそれら特定のMicrochipデータシートに含まれる仕様に合致します。
- ・Microchipは動作仕様内で意図した方法と通常条件下で使われる時に、その製品系統が安全であると考えます。
- ・Microchipはその知的所有権を尊重し、積極的に保護します。Microchip製品のコード保護機能を侵害する試みは固く禁じられ、デジ タルミレニアム著作権法に違反するかもしれません。
- ・Microchipや他のどの半導体製造業者もそれのコートの安全を保証することはできません。コート、保護は製品が"破ることができない" ことを当社が保証すると言うことを意味しません。コート、保護は常に進化しています。Microchipは当社製品のコート、保護機能を継続的 に改善することを約束します。

# 法的通知

この刊行物と契約での情報は設計、試験、応用とのMicrochip製品の統合を含め、Microchip製品でだけ使えます。他の何れの方法 でのこの情報の使用はこれらの条件に違反します。デバイス応用などに関する情報は皆さまの便宜のためにだけ提供され、更新に よって取り換えられるかもしれません。皆さまの応用が皆さまの仕様に合致するのを保証するのは皆さまの責任です。追加支援につ いては最寄りのMicrochip営業所にお問い合わせ頂くか、www.microchip.com/en-us/support/design-help/client-support-services で追加支援を得てください。

この情報はMicrochipによって「現状そのまま」で提供されます。Microchipは非侵害、商品性、特定目的に対する適合性の何れの黙 示的保証やその条件、品質、性能に関する保証を含め、明示的にも黙示的にもその情報に関連して書面または表記された書面ま たは黙示の如何なる表明や保証もしません。

如何なる場合においても、Microchipは情報またはその使用に関連するあらゆる種類の間接的、特別的、懲罰的、偶発的または結果的な損失、損害、費用または経費に対して責任を負わないものとします。法律で認められている最大限の範囲で、情報またはその使用に関連する全ての請求に対するMicrochipの全責任は、もしあれば、情報のためにMicrochipへ直接支払った料金を超えないものとします。生命維持や安全応用でのMicrochipデバイスの使用は完全に購入者の危険性で、購入者はそのような使用に起因する全ての損害、請求、訴訟、費用からMicrochipを擁護し、補償し、免責にすることに同意します。他に言及されない限り、Microchipのどの知的財産権下でも暗黙的または違う方法で許認可は譲渡されません。

# 商標

Microchipの名前とロゴ、Mcicrochipロゴ、Adaptec、AVR、AVRロゴ、AVR Freaks、BesTime、BitCloud、CryptoMemory、CryptoRF、 dsPIC、flexPWR、HELDO、IGLOO、JukeBlox、KeeLoq、Kleer、LANCheck、LinkMD、maXStylus、maXTouch、MediaLB、megaAVR、 Microsemi、Microsemiロゴ、MOST、MOSTロゴ、MPLAB、OptoLyzer、PIC、picoPower、PICSTART、PIC32ロゴ、PolarFire、Prochip De signer、QTouch、SAM-BA、SenGenuity、SpyNIC、SST、SSTロゴ、Super Flash、Symmetricom、SyncServer、Tachyon、TimeSource、ti nyAVR、UNI/O、Vectron、XMEGAは米国と他の国に於けるMicrochip Technology Incor poratedの登録商標です。

AgileSwitch、APT、ClockWorks、The Embedded Control Solutions Company、EtherSynch、Flashtec、Hyper Speed Control、Hyper Light Load、IntelliMOS、Libero、motorBench、mTouch、Powermite 3、Precision Edge、ProASIC、ProASIC Plus、ProASIC Plusロゴ、 Quiet-Wire、SmartFusion、SyncWorld、Temux、TimeCesium、TimeHub、TimePictra、TimeProvider、TrueTime、ZLは米国に於ける Microchip Technology Incorporatedの登録商標です。

Adjacent Key Suppression、AKS、Analog-for-the-Digital Age、Any Capacitor、AnyIn、AnyOut、Augmented Switching、BlueSky、Bo dyCom、Clockstudio、CodeGuard、CryptoAuthentication、CryptoAutomotive、CryptoCompanion、CryptoController、dsPICDEM、 dsPICDEM.net、Dynamic Average Matching、DAM、ECAN、Espresso T1S、EtherGREEN、GridTime、IdealBridge、In-Circuit Serial Programming、ICSP、INICnet、Intelligent Paralleling、IntelliMOS、Inter-Chip Connectivity、JitterBlocker、Knob-on-Display、KoD、 maxCrypto、maxView、memBrain、Mindi、MiWi、MPASM、MPF、MPLAB Certifiedロゴ、MPLIB、MPLINK、MultiTRAK、NetDetach、 Omniscient Code Generation、PICDEM、PICDEM.net、PICkit、PICtail、PowerSmart、PureSilicon、QMatrix、REAL ICE、Ripple Bloc ker、RTAX、RTG4、SAM-ICE、Serial Quad I/O、simpleMAP、SimpliPHY、SmartBuffer、SmartHLS、SMART-I.S.、storClad、SQI、Su perSwitcher、SuperSwitcher II、Switchtec、SynchroPHY、Total Endurance、Trusted Time、TSHARC、USBCheck、VariSense、Vector Blox、VeriPHY、ViewSpan、WiperLock、XpressConnect、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の登録商標です。 ここで言及した以外の全ての商標はそれら各々の会社の所有物です。

© 2022年、Microchip Technology Incorporatedとその子会社、不許複製

# 品質管理システム

Microchipの品質管理システムに関する情報についてはwww.microchip.com/qualityを訪ねてください。

#### 日本語© HERO 2024.

本データシートはMicrochipのAVR64EA28/32/48英語版データシート(DS40002443A-2022年9月)の翻訳日本語版です。日本語では不自 然となる重複する形容表現は省略されている場合があります。日本語では難解となる表現は大幅に意訳されている部分もあります。 必要に応じて一部加筆されています。頁割の変更により、原本より頁数が少なくなっています。

汎用入出力ポートの出力データレジスタとピン入力は、対応関係からの理解の容易さから出力レジスタと入力レジスタで統一表現されています。一部の用語がより適切と思われる名称に変更されています。必要と思われる部分には()内に英語表記や略称などを残す形で表記しています。

青字の部分はリンクとなっています。一般的に赤字の0,1は論理0,1を表します。その他の赤字は重要な部分を表します。 原書に対して若干構成が異なるため、一部の節/項番号が異なります。



米国

# 世界的な販売とサービス

本社 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 技術支援: www.microchip.com/support ウェブ アトレス: 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 D-J-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 ポーラント゛ー ワルシャワ 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