

CMOS 16-BIT SINGLE CHIP MICROCONTROLLER

**S1C17001**  
**テクニカルマニュアル**

本資料のご使用につきましては、次の点にご留意願います。

本資料の内容については、予告なく変更することがあります。

1. 本資料の一部、または全部を弊社に無断で転載、または、複製など他の目的に使用することは堅くお断りいたします。
2. 本資料に掲載される応用回路、プログラム、使用方法等はあくまでも参考情報であり、これら起因する第三者の知的財産権およびその他の権利侵害あるいは損害の発生に対し、弊社はいかなる保証を行うものではありません。また、本資料によって第三者または弊社の知的財産権およびその他の権利の実施権の許諾を行うものではありません。
3. 特性値の数値の大小は、数直線上の大小関係で表しています。
4. 本資料に掲載されている製品のうち、「外国為替及び外国貿易法」に定める戦略物資に該当するものについては、輸出する場合、同法に基づく輸出許可が必要です。
5. 本資料に掲載されている製品は、生命維持装置その他、きわめて高い信頼性が要求される用途を前提としていません。よって、弊社は本(当該)製品をこれらの用途に用いた場合のいかなる責任についても負いかねます。
6. 本資料に掲載されている会社名、商品名は、各社の商標または登録商標です。

本製品はSilicon Storage Technology, Inc.よりライセンスされたSuperFlash®テクノロジを使用しています。

## 製品型番体系

### ●デバイス



### ●開発ツール



## - 目 次 -

|                                        |    |
|----------------------------------------|----|
| <b>1 概要</b>                            | 1  |
| 1.1 特長                                 | 1  |
| 1.2 ブロック図                              | 2  |
| 1.3 端子                                 | 3  |
| 1.3.1 端子配置図                            | 3  |
| 1.3.2 パッケージ(QFP12-48pin)               | 4  |
| 1.3.3 端子説明                             | 6  |
| <b>2 CPU</b>                           | 7  |
| 2.1 S1C17コアの特長                         | 7  |
| 2.2 CPUレジスタ                            | 8  |
| 2.3 命令セット                              | 9  |
| 2.4 ベクタテーブル                            | 13 |
| 2.5 プロセッサ情報                            | 14 |
| <b>3 メモリマップ, バス制御</b>                  | 15 |
| 3.1 バスサイクル                             | 16 |
| 3.1.1 アクセスサイズ制限                        | 16 |
| 3.1.2 命令実行サイクルの制限                      | 16 |
| 3.2 内蔵ROMエリア                           | 17 |
| 3.2.1 内蔵ROM                            | 17 |
| 3.2.2 ROMのリードアクセスサイクルの設定               | 17 |
| 0x5320: ROM Control Register (MISC_FL) | 17 |
| 3.3 内蔵RAMエリア                           | 18 |
| 3.3.1 内蔵RAM                            | 18 |
| 3.4 内蔵周辺回路エリア                          | 19 |
| 3.4.1 内蔵周辺回路エリア1(0x4000~)              | 19 |
| 3.4.2 内蔵周辺回路エリア2(0x5000~)              | 19 |
| 3.4.3 I/Oマップ                           | 20 |
| 3.5 コアI/O予約エリア                         | 23 |
| <b>4 電源電圧</b>                          | 25 |
| <b>5 イニシャルリセット</b>                     | 27 |
| 5.1 イニシャルリセット要因                        | 27 |
| 5.1.1 #RESET端子                         | 27 |
| 5.1.2 P0ポートキー入力リセット                    | 28 |
| 5.1.3 ウォッチドッグタイマによるリセット                | 28 |
| 5.2 イニシャルリセットシーケンス                     | 29 |
| 5.3 イニシャルリセット時の初期設定                    | 30 |
| <b>6 割り込みコントローラ(ITC)</b>               | 31 |
| 6.1 ITCの構成                             | 31 |
| 6.2 ベクタテーブル                            | 32 |
| 6.3 マスク可能割り込みの制御                       | 33 |
| 6.3.1 ITCイネーブル                         | 33 |
| 6.3.2 周辺モジュールからの割り込み要求と割り込みフラグ         | 33 |
| 6.3.3 割り込みの許可/禁止                       | 34 |
| 6.3.4 複数の割り込み発生時の処理                    | 35 |
| 6.3.5 割り込みのトリガモード                      | 36 |
| 6.3.6 S1C17コアの割り込み処理                   | 38 |
| 6.4 NMI                                | 39 |

---

|                                                                    |           |
|--------------------------------------------------------------------|-----------|
| 6.5 ソフトウェア割り込み .....                                               | 40        |
| 6.6 割り込み要因によるHALT, SLEEPモードの解除 .....                               | 41        |
| 6.7 制御レジスタ詳細 .....                                                 | 42        |
| 0x4300: Interrupt Flag Register (ITC_IFLG) .....                   | 43        |
| 0x4302: Interrupt Enable Register (ITC_EN) .....                   | 45        |
| 0x4304: ITC Control Register (ITC_CTL) .....                       | 46        |
| 0x4306: External Interrupt Level Setup Register 0 (ITC_ELV0) ..... | 47        |
| 0x4308: External Interrupt Level Setup Register 1 (ITC_ELV1) ..... | 48        |
| 0x430a: External Interrupt Level Setup Register 2 (ITC_ELV2) ..... | 49        |
| 0x430c: External Interrupt Level Setup Register 3 (ITC_ELV3) ..... | 50        |
| 0x430e: Internal Interrupt Level Setup Register 0 (ITC_ILV0) ..... | 51        |
| 0x4310: Internal Interrupt Level Setup Register 1 (ITC_ILV1) ..... | 52        |
| 0x4312: Internal Interrupt Level Setup Register 2 (ITC_ILV2) ..... | 53        |
| 0x4314: Internal Interrupt Level Setup Register 3 (ITC_ILV3) ..... | 54        |
| 6.8 注意事項 .....                                                     | 55        |
| <b>7 発振回路(OSC) .....</b>                                           | <b>57</b> |
| 7.1 OSCモジュールの構成 .....                                              | 57        |
| 7.2 OSC3発振回路 .....                                                 | 58        |
| 7.3 OSC1発振回路 .....                                                 | 60        |
| 7.4 システムクロックの切り換え .....                                            | 61        |
| 7.5 8ビットOSC1タイマクロックの制御 .....                                       | 62        |
| 7.6 クロック外部出力(FOUT3, FOUT1) .....                                   | 63        |
| 7.7 RESET, NMI入力ノイズフィルタ .....                                      | 65        |
| 7.8 制御レジスタ詳細 .....                                                 | 66        |
| 0x5060: Clock Source Select Register (OSC_SRC) .....               | 67        |
| 0x5061: Oscillation Control Register (OSC_CTL) .....               | 68        |
| 0x5062: Noise Filter Enable Register (OSC_NFEN) .....              | 69        |
| 0x5064: FOUT Control Register (OSC_FOUT) .....                     | 70        |
| 0x5065: T8OSC1 Clock Control Register (OSC_T8OSC1) .....           | 71        |
| 7.9 注意事項 .....                                                     | 72        |
| <b>8 クロックジェネレータ(CLG) .....</b>                                     | <b>73</b> |
| 8.1 クロックジェネレータの構成 .....                                            | 73        |
| 8.2 CPUコアクロック(CCLK)の制御 .....                                       | 74        |
| 8.3 周辺モジュールクロック(PCLK)の制御 .....                                     | 75        |
| 8.4 制御レジスタ詳細 .....                                                 | 76        |
| 0x5080: PCLK Control Register (CLG_PCLK) .....                     | 77        |
| 0x5081: CCLK Control Register (CLG_CCLK) .....                     | 78        |
| 8.5 注意事項 .....                                                     | 79        |
| <b>9 プリスケーラ(PSC) .....</b>                                         | <b>81</b> |
| 9.1 プリスケーラの構成 .....                                                | 81        |
| 9.2 制御レジスタ詳細 .....                                                 | 82        |
| 0x4020: Prescaler Control Register (PSC_CTL) .....                 | 82        |
| 9.3 注意事項 .....                                                     | 83        |
| <b>10 入出力ポート(P) .....</b>                                          | <b>85</b> |
| 10.1 入出力ポートの構成 .....                                               | 85        |
| 10.2 入出力端子機能の選択(ポートMUX) .....                                      | 86        |
| 10.3 データの入出力 .....                                                 | 87        |
| 10.4 プルアップ制御 .....                                                 | 88        |
| 10.5 入力インタフェースレベル .....                                            | 89        |
| 10.6 P0ポートのチャタリング除去機能 .....                                        | 90        |

|                                                                                 |            |
|---------------------------------------------------------------------------------|------------|
| 10.7 ポート入力割り込み                                                                  | 91         |
| 10.8 制御レジスタ詳細                                                                   | 94         |
| 0x5200/0x5210/0x5220/0x5230: Px Port Input Data Registers (Px_IN)               | 95         |
| 0x5201/0x5211/0x5221/0x5231: Px Port Output Data Registers (Px_OUT)             | 96         |
| 0x5202/0x5212/0x5222/0x5232: Px Port I/O Direction Control Registers (Px_IO)    | 97         |
| 0x5203/0x5213/0x5223/0x5233: Px Port Pull-up Control Registers (Px_PU)          | 98         |
| 0x5205/5215: Px Port Interrupt Mask Registers (Px_IMSK)                         | 99         |
| 0x5206/5216: Px Port Interrupt Edge Select Registers (Px_EDGE)                  | 100        |
| 0x5207/5217: Px Port Interrupt Flag Registers (Px_IFLG)                         | 101        |
| 0x5208: P0 Port Chattering Filter Control Register (P0_CHAT)                    | 102        |
| 0x5209: P0 Port Key-Entry Reset Configuration Register (P0_KRST)                | 103        |
| 0x52a0: P0 Port Function Select Register (P0_PMUX)                              | 104        |
| 0x52a1: P1 Port Function Select Register (P1_PMUX)                              | 105        |
| 0x52a2: P2 Port Function Select Register (P2_PMUX)                              | 106        |
| 0x52a3: P3 Port Function Select Register (P3_PMUX)                              | 107        |
| 10.9 注意事項                                                                       | 108        |
| <b>11 16ビットタイマ(T16)</b>                                                         | <b>109</b> |
| 11.1 16ビットタイマの概要                                                                | 109        |
| 11.2 16ビットタイマの動作モード                                                             | 110        |
| 11.2.1 内部クロックモード                                                                | 110        |
| 11.2.2 外部クロックモード                                                                | 111        |
| 11.2.3 パルス幅測定モード                                                                | 112        |
| 11.3 カウントモード                                                                    | 113        |
| 11.4 16ビットタイマリロードレジスタとアンダーフロー周期                                                 | 114        |
| 11.5 16ビットタイマのリセット                                                              | 115        |
| 11.6 16ビットタイマRUN/STOP制御                                                         | 116        |
| 11.7 16ビットタイマ出力信号                                                               | 117        |
| 11.8 16ビットタイマ割り込み                                                               | 118        |
| 11.9 制御レジスタ詳細                                                                   | 119        |
| 0x4220/0x4240/0x4260: 16-bit Timer Ch.x Input Clock Select Registers (T16_CLKx) | 120        |
| 0x4222/0x4242/0x4262: 16-bit Timer Ch.x Reload Data Registers (T16_TRx)         | 121        |
| 0x4224/0x4244/0x4264: 16-bit Timer Ch.x Counter Data Registers (T16_TCx)        | 122        |
| 0x4226/0x4246/0x4266: 16-bit Timer Ch.x Control Registers (T16_CTLx)            | 123        |
| 11.10 注意事項                                                                      | 125        |
| <b>12 8ビットタイマ(T8F)</b>                                                          | <b>127</b> |
| 12.1 8ビットタイマの概要                                                                 | 127        |
| 12.2 8ビットタイマのカウントモード                                                            | 128        |
| 12.3 カウントクロック                                                                   | 129        |
| 12.4 8ビットタイマリロードレジスタとアンダーフロー周期                                                  | 130        |
| 12.5 8ビットタイマのリセット                                                               | 131        |
| 12.6 8ビットタイマRUN/STOP制御                                                          | 132        |
| 12.7 8ビットタイマ出力信号                                                                | 133        |
| 12.8 フайнモード                                                                    | 134        |
| 12.9 8ビットタイマ割り込み                                                                | 135        |
| 12.10 制御レジスタ詳細                                                                  | 136        |
| 0x4200: 8-bit Timer Input Clock Select Register (T8F_CLK)                       | 137        |
| 0x4202: 8-bit Timer Reload Data Register (T8F_TR)                               | 138        |
| 0x4204: 8-bit Timer Counter Data Register (T8F_TC)                              | 139        |
| 0x4206: 8-bit Timer Control Register (T8F_CTL)                                  | 140        |
| 12.11 注意事項                                                                      | 142        |
| <b>13 PWM&amp;キャプチャタイマ(T16E)</b>                                                | <b>143</b> |

---

|                                                                      |            |
|----------------------------------------------------------------------|------------|
| 13.1 PWM&キャプチャタイマの概要 .....                                           | 143        |
| 13.2 PWM&キャプチャタイマの動作モード .....                                        | 144        |
| 13.3 カウンタ値のセット/リセット .....                                            | 145        |
| 13.4 コンペアデータの設定 .....                                                | 146        |
| 13.5 PWM&キャプチャタイマRUN/STOP制御 .....                                    | 147        |
| 13.6 クロック出力の制御 .....                                                 | 148        |
| 13.7 PWM&キャプチャタイマ割り込み .....                                          | 151        |
| 13.8 制御レジスタ詳細 .....                                                  | 153        |
| 0x5300: PWM Timer Compare Data A Register (T16E_CA) .....            | 154        |
| 0x5302: PWM Timer Compare Data B Register (T16E_CB) .....            | 155        |
| 0x5304: PWM Timer Counter Data Register (T16E_TC) .....              | 156        |
| 0x5306: PWM Timer Control Register (T16E_CTL) .....                  | 157        |
| 0x5308: PWM Timer Input Clock Select Register (T16E_CLK) .....       | 159        |
| 0x530a: PWM Timer Interrupt Mask Register (T16E_IMSK) .....          | 160        |
| 0x530c: PWM Timer Interrupt Flag Register (T16E_IFLG) .....          | 161        |
| 13.9 注意事項 .....                                                      | 162        |
| <b>14 8ビットOSC1タイマ(T8OSC1) .....</b>                                  | <b>163</b> |
| 14.1 8ビットOSC1タイマの概要 .....                                            | 163        |
| 14.2 8ビットOSC1タイマのカウントモード .....                                       | 164        |
| 14.3 カウントクロック .....                                                  | 165        |
| 14.4 8ビットOSC1タイマのリセット .....                                          | 166        |
| 14.5 コンペアデータの設定 .....                                                | 167        |
| 14.6 8ビットOSC1タイマRUN/STOP制御 .....                                     | 168        |
| 14.7 8ビットOSC1タイマ割り込み .....                                           | 169        |
| 14.8 制御レジスタ詳細 .....                                                  | 171        |
| 0x50c0: 8-bit OSC1 Timer Control Register (T8OSC1_CTL) .....         | 172        |
| 0x50c1: 8-bit OSC1 Timer Counter Data Register (T8OSC1_CNT) .....    | 173        |
| 0x50c2: 8-bit OSC1 Timer Compare Data Register (T8OSC1_CMP) .....    | 174        |
| 0x50c3: 8-bit OSC1 Timer Interrupt Mask Register (T8OSC1_IMSK) ..... | 175        |
| 0x50c4: 8-bit OSC1 Timer Interrupt Flag Register (T8OSC1_IFLG) ..... | 176        |
| 14.9 注意事項 .....                                                      | 177        |
| <b>15 計時タイマ(CT) .....</b>                                            | <b>179</b> |
| 15.1 計時タイマの概要 .....                                                  | 179        |
| 15.2 動作クロック .....                                                    | 180        |
| 15.3 計時タイマのリセット .....                                                | 181        |
| 15.4 計時タイマRUN/STOP制御 .....                                           | 182        |
| 15.5 計時タイマ割り込み .....                                                 | 183        |
| 15.6 制御レジスタ詳細 .....                                                  | 185        |
| 0x5000: Clock Timer Control Register (CT_CTL) .....                  | 186        |
| 0x5001: Clock Timer Counter Register (CT_CNT) .....                  | 187        |
| 0x5002: Clock Timer Interrupt Mask Register (CT_IMSK) .....          | 188        |
| 0x5003: Clock Timer Interrupt Flag Register (CT_IFLG) .....          | 189        |
| 15.7 注意事項 .....                                                      | 190        |
| <b>16 ストップウォッチタイマ(SWT) .....</b>                                     | <b>191</b> |
| 16.1 ストップウォッチタイマの概要 .....                                            | 191        |
| 16.2 BCDカウンタ .....                                                   | 192        |
| 16.3 動作クロック .....                                                    | 193        |
| 16.4 ストップウォッチタイマのリセット .....                                          | 194        |
| 16.5 ストップウォッチタイマRUN/STOP制御 .....                                     | 195        |
| 16.6 ストップウォッチタイマ割り込み .....                                           | 196        |

|                                                                  |            |
|------------------------------------------------------------------|------------|
| 16.7 制御レジスタ詳細 .....                                              | 198        |
| 0x5020: Stopwatch Timer Control Register (SWT_CTL) .....         | 199        |
| 0x5021: Stopwatch Timer BCD Counter Register (SWT_BCNT) .....    | 200        |
| 0x5022: Stopwatch Timer Interrupt Mask Register (SWT_IMSK) ..... | 201        |
| 0x5023: Stopwatch Timer Interrupt Flag Register (SWT_IFLG) ..... | 202        |
| 16.8 注意事項 .....                                                  | 203        |
| <b>17 ウオッチドッグタイマ(WDT) .....</b>                                  | <b>205</b> |
| 17.1 ウオッチドッグタイマの概要 .....                                         | 205        |
| 17.2 動作クロック .....                                                | 206        |
| 17.3 ウオッチドッグタイマの制御 .....                                         | 207        |
| 17.3.1 NMI/リセットモードの選択 .....                                      | 207        |
| 17.3.2 ウオッチドッグタイマのRUN/STOP制御 .....                               | 207        |
| 17.3.3 ウオッチドッグタイマのリセット .....                                     | 207        |
| 17.3.4 スタンバイモード時の動作 .....                                        | 207        |
| 17.4 制御レジスタ詳細 .....                                              | 209        |
| 0x5040: Watchdog Timer Control Register (WDT_CTL) .....          | 210        |
| 0x5041: Watchdog Timer Status Register (WDT_ST) .....            | 211        |
| <b>18 UART .....</b>                                             | <b>213</b> |
| 18.1 UARTの構成 .....                                               | 213        |
| 18.2 UART端子 .....                                                | 214        |
| 18.3 転送クロック .....                                                | 215        |
| 18.4 転送データの設定 .....                                              | 216        |
| 18.5 データ送受信の制御 .....                                             | 217        |
| 18.6 受信エラー .....                                                 | 220        |
| 18.7 UART割り込み .....                                              | 221        |
| 18.8 IrDAインターフェース .....                                          | 223        |
| 18.9 制御レジスタ詳細 .....                                              | 225        |
| 0x4100: UART Status Register (UART_ST) .....                     | 226        |
| 0x4101: UART Transmit Data Register (UART_TXD) .....             | 228        |
| 0x4102: UART Receive Data Register (UART_RXD) .....              | 229        |
| 0x4103: UART Mode Register (UART_MOD) .....                      | 230        |
| 0x4104: UART Control Register (UART_CTL) .....                   | 231        |
| 0x4105: UART Expansion Register (UART_EXP) .....                 | 232        |
| 18.10 注意事項 .....                                                 | 233        |
| <b>19 SPI .....</b>                                              | <b>235</b> |
| 19.1 SPIの構成 .....                                                | 235        |
| 19.2 SPI入出力端子 .....                                              | 236        |
| 19.3 SPIクロック .....                                               | 237        |
| 19.4 データ転送条件の設定 .....                                            | 238        |
| 19.5 データ送受信の制御 .....                                             | 239        |
| 19.6 SPI割り込み .....                                               | 242        |
| 19.7 制御レジスタ詳細 .....                                              | 244        |
| 0x4320: SPI Status Register (SPI_ST) .....                       | 245        |
| 0x4322: SPI Transmit Data Register (SPI_TXD) .....               | 246        |
| 0x4324: SPI Receive Data Register (SPI_RXD) .....                | 247        |
| 0x4326: SPI Control Register (SPI_CTL) .....                     | 248        |
| 19.8 注意事項 .....                                                  | 250        |
| <b>20 I<sup>2</sup>C .....</b>                                   | <b>251</b> |
| 20.1 I <sup>2</sup> Cの構成 .....                                   | 251        |
| 20.2 I <sup>2</sup> C入出力端子 .....                                 | 252        |

---

|                                                                      |            |
|----------------------------------------------------------------------|------------|
| 20.3 I <sup>2</sup> Cクロック .....                                      | 253        |
| 20.4 データ転送前の設定項目 .....                                               | 254        |
| 20.5 データ送受信の制御 .....                                                 | 255        |
| 20.6 I <sup>2</sup> C割り込み .....                                      | 262        |
| 20.7 制御レジスタ詳細 .....                                                  | 263        |
| 0x4340: I <sup>2</sup> C Enable Register (I2C_EN) .....              | 264        |
| 0x4342: I <sup>2</sup> C Control Register (I2C_CTL) .....            | 265        |
| 0x4344: I <sup>2</sup> C Data Register (I2C_DAT) .....               | 267        |
| 0x4346: I <sup>2</sup> C Interrupt Control Register (I2C_ICTL) ..... | 269        |
| <b>21 リモートコントローラ (REMC) .....</b>                                    | <b>271</b> |
| 21.1 REMCの構成 .....                                                   | 271        |
| 21.2 REMC入出力端子 .....                                                 | 272        |
| 21.3 キャリアの生成 .....                                                   | 273        |
| 21.4 データ長カウンタのクロック設定 .....                                           | 274        |
| 21.5 データ送受信の制御 .....                                                 | 275        |
| 21.6 REMC割り込み .....                                                  | 278        |
| 21.7 制御レジスタ詳細 .....                                                  | 280        |
| 0x5340: REMC Configuration Register (REMC_CFG) .....                 | 281        |
| 0x5341: REMC Prescaler Clock Select Register (REMC_PSC) .....        | 282        |
| 0x5342: REMC H Carrier Length Setup Register (REMC_CARH) .....       | 283        |
| 0x5343: REMC L Carrier Length Setup Register (REMC_CARL) .....       | 284        |
| 0x5344: REMC Status Register (REMC_ST) .....                         | 285        |
| 0x5345: REMC Length Counter Register (REMC_LCNT) .....               | 286        |
| 0x5346: REMC Interrupt Mask Register (REMC_IMSK) .....               | 287        |
| 0x5347: REMC Interrupt Flag Register (REMC_IFLG) .....               | 288        |
| 21.8 注意事項 .....                                                      | 289        |
| <b>22 オンチップデバッガ (DBG) .....</b>                                      | <b>291</b> |
| 22.1 リソース要件とデバッグツール .....                                            | 291        |
| 22.2 デバッガブレーク時の動作状態 .....                                            | 292        |
| 22.3 制御レジスタ詳細 .....                                                  | 293        |
| 0x5322: OSC1 Peripheral Control Register (MISC_OSC1) .....           | 294        |
| 0xffff90: Debug RAM Base Register (DBRAM) .....                      | 295        |
| <b>23 基本外部結線図 .....</b>                                              | <b>297</b> |
| <b>24 電気的特性 .....</b>                                                | <b>299</b> |
| 24.1 絶対最大定格 .....                                                    | 299        |
| 24.2 推奨動作条件 .....                                                    | 299        |
| 24.3 DC特性 .....                                                      | 300        |
| 24.4 消費電流 .....                                                      | 301        |
| 24.5 AC特性 .....                                                      | 302        |
| 24.5.1 SPI AC特性 .....                                                | 302        |
| 24.5.2 I <sup>2</sup> C AC特性 .....                                   | 302        |
| 24.5.3 外部クロック入力AC特性 .....                                            | 303        |
| 24.5.4 システムAC特性 .....                                                | 303        |
| 24.6 発振特性 .....                                                      | 304        |
| <b>25 パッケージ .....</b>                                                | <b>305</b> |
| <b>Appendix A I/Oレジスター一覧 .....</b>                                   | <b>307</b> |
| 0x4020              Prescaler .....                                  | 310        |
| 0x4100–0x4105      UART (with IrDA) .....                            | 311        |
| 0x4200–0x4206      8-bit Timer (with Fine Mode) .....                | 312        |

---

|                                                  |                            |     |
|--------------------------------------------------|----------------------------|-----|
| 0x4220–0x4266                                    | 16-bit Timer .....         | 313 |
| 0x4300–0x4314                                    | Interrupt Controller ..... | 315 |
| 0x4320–0x4326                                    | SPI .....                  | 317 |
| 0x4340–0x4346                                    | I <sup>2</sup> C .....     | 318 |
| 0x5000–0x5003                                    | Clock Timer .....          | 319 |
| 0x5020–0x5023                                    | Stopwatch Timer .....      | 320 |
| 0x5040–0x5041                                    | Watchdog Timer .....       | 321 |
| 0x5060–0x5065                                    | Oscillator .....           | 322 |
| 0x5080–0x5081                                    | Clock Generator .....      | 323 |
| 0x50c0–0x50c4                                    | 8-bit OSC1 Timer .....     | 324 |
| 0x5200–0x52a3                                    | P Port & Port MUX .....    | 325 |
| 0x5300–0x530c                                    | PWM & Capture Timer .....  | 327 |
| 0x5320–0x5322                                    | MISC Registers .....       | 328 |
| 0x5340–0x5347                                    | Remote Controller .....    | 329 |
| 0xfffff80–0xfffff90                              | S1C17 Core I/O .....       | 330 |
| <b>Appendix B パワーセーブ .....</b>                   | <b>331</b>                 |     |
| B.1 クロック制御によるパワーセーブ .....                        | 331                        |     |
| <b>Appendix C 実装上の注意事項 .....</b>                 | <b>334</b>                 |     |
| <b>Appendix D 初期化ルーチン .....</b>                  | <b>337</b>                 |     |
| <b>Appendix E S1C17001マスクROMコードの開発について .....</b> | <b>339</b>                 |     |
| <b>Appendix F 更新履歴 .....</b>                     | <b>340</b>                 |     |
| <b>改訂履歴表</b>                                     |                            |     |

# 1 概要

S1C17001は、高速かつ低電力動作、省サイズ、広アドレス空間、オンチップICEを実現した16ビットMCUです。S1C17 CPUコアを中心に、32KバイトのROM、2KバイトのRAM、高ビットレートおよびIrDA1.0に対応したUART、SPI、I<sup>2</sup>Cなどの各種センサに対応可能なシリアルインタフェース、8ビットタイマ、16ビットタイマ、PWM&キャプチャタイマ、計時タイマ、ストップウォッチタイマ、ウォッチドッギングタイマ、28本の汎用入出力ポートを内蔵しています。

1.8Vの動作電圧でも8.2MHzの高速動作が可能で、16ビットRISC処理により1命令を1クロックで実行します。

## 1.1 特長

以下にS1C17001の主な機能と特長を示します。

- CPU
  - EPSONオリジナル16ビットRISC CPUコア S1C17
- メイン(OSC3)発振回路
  - 水晶発振回路、セラミック発振回路または外部クロック入力 8.2MHz (max.)
- サブ(OSC1)発振回路
  - 水晶発振回路または外部クロック入力 32.786kHz(typ.)
- 内蔵ROM
  - 32Kバイト
- 内蔵RAM
  - 2Kバイト
- 入出力ポート
  - 最大28ビットの汎用入出力(周辺回路の入出力と端子を共用)
- シリアルインタフェース
  - SPI(マスタ/スレーブ) 1ch.
  - UART(IrDA1.0対応) 1ch.
  - I<sup>2</sup>C(マスタ) 1ch.
  - リモートコントローラ(REMC) 1ch.
- タイマ
  - 8ビットタイマ(T8F) 1ch.
  - 16ビットタイマ(T16) 3ch.
  - PWM&キャプチャタイマ(T16E) 1ch.
  - 計時タイマ(CT) 1ch.
  - ストップウォッチタイマ(SWT) 1ch.
  - ウオッチドッギングタイマ(WDT) 1ch.
  - 8ビットOSC1タイマ(T8OSC1) 1ch.
- 割り込み
  - リセット
  - NMI
  - ハードウェア割り込み14本(8レベル)
- 電源電圧
  - コア電圧(LV<sub>DD</sub>) 1.65~2.7V
  - I/O電圧(HV<sub>DD</sub>) 1.65~3.6V
- 動作温度
  - -40~85°C
- 消費電流(typ.)
  - SLEEP時 0.5μA
  - HALT時 2.5μA (32kHz)
  - 動作時 10μA (32kHz)
  - 1800μA (8MHz)
- 出荷形態
  - WCSP-48pinパッケージ
- マスクROMコード
  - S1C17704
- 開発用Flashメモリ品
  - (詳細はAppendix E参照)

## 1.2 ブロック図



図1.2.1 ブロック図

## 1.3 端子

### 1.3.1 端子配置図



図1.3.1.1 端子配置図 (WCSP-48pin)

### 1.3.2 パッケージ (QFP12-48pin)

#### QFP12-48pin/パッケージ



図1.3.2.1 QFP12-48pin/パッケージ寸法

## QFN7-48pinパッケージ

Top View



Bottom View



| Symbol         | Dimension in Millimeters |     |      |
|----------------|--------------------------|-----|------|
|                | Min                      | Nom | Max  |
| D              | -                        | 7   | -    |
| E              | -                        | 7   | -    |
| A              | -                        | -   | 1    |
| A <sub>1</sub> | 0                        | -   | -    |
| b              | 0.17                     | -   | 0.3  |
| ε              | -                        | 0.5 | -    |
| L              | 0.3                      | -   | 0.5  |
| x              | -                        | -   | 0.1  |
| y              | -                        | -   | 0.08 |

図1.3.2.2 QFN7-48pin/パッケージ寸法

### 1.3.3 端子説明

表1.3.3.1 端子説明

| 端子 / ボール No.   |                 |      | 名称               | I/O | 初期状態         | 機能                                          |
|----------------|-----------------|------|------------------|-----|--------------|---------------------------------------------|
| QFN7<br>-48PIN | QFP12<br>-48PIN | WCSP |                  |     |              |                                             |
| 37             | 37              | A1   | #TEST2           | I   | I(Pull-Up)   | テスト端子(通常動作時はHighに固定)                        |
| 38             | 38              | A2   | P05/REMO         | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)*/リモート出力端子                  |
| 39             | 39              | B3   | P04/REMI         | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)*/リモート入力端子                  |
| 40             | 40              | A3   | Vss              | -   | -            | 電源端子(GND)                                   |
| 41             | 41              | B4   | P03              | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)                            |
| 42             | 42              | A4   | P02              | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)                            |
| 43             | 43              | C4   | P01              | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)                            |
| 44             | 44              | D4   | P00              | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)                            |
| 45             | 45              | A5   | HV <sub>DD</sub> | -   | -            | 電源端子(HV <sub>DD</sub> +)                    |
| 46             | 46              | B5   | P12              | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)                            |
| 47             | 47              | A6   | P11              | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)                            |
| 48             | 48              | C5   | P10              | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)                            |
| 1              | 1               | A7   | #TEST3           | I   | I(Pull-Up)   | テスト端子(通常動作時はHighに固定)                        |
| 2              | 2               | B6   | #RESET           | I   | I(Pull-Up)   | イニシャルセット入力端子                                |
| 3              | 3               | B7   | Vss              | -   | -            | 電源端子(GND)                                   |
| 4              | 4               | C6   | P27/EXCL3        | I/O | I(Pull-Up)   | 入出力ポート端子*/T16E 外部クロック入力端子                   |
| 5              | 5               | C7   | P26/TOUT         | I/O | I(Pull-Up)   | 入出力ポート端子*/T16E PWM 信号出力端子                   |
| 6              | 6               | D5   | P13/FOUT1        | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)*/OSC1 クロック出力端子             |
| 7              | 7               | D7   | P30/FOUT3        | I/O | I(Pull-Up)   | 入出力ポート端子*/OSC3 分周クロック出力端子                   |
| 8              | 8               | D6   | LV <sub>DD</sub> | -   | -            | 電源端子(LV <sub>DD</sub> +)                    |
| 9              | 9               | E6   | Vss              | -   | -            | 電源端子(GND)                                   |
| 10             | 10              | E7   | OSC1             | I   | I            | OSC1 発振入力端子(外部クロック入力可能)                     |
| 11             | 11              | F7   | OSC2             | O   | O            | OSC1 発振出力端子                                 |
| 12             | 12              | F6   | #TEST4           | I   | I(Pull-Up)   | テスト端子(通常動作時はHighに固定)                        |
| 13             | 13              | G7   | #TEST5           | I   | I(Pull-Up)   | テスト端子(通常動作時はHighに固定)                        |
| 14             | 14              | G6   | OSC3             | I   | I            | OSC3 発振入力端子(外部クロック入力可能)                     |
| 15             | 15              | G5   | OSC4             | O   | O            | OSC3 発振出力端子                                 |
| 16             | 16              | F5   | Vss              | -   | -            | 電源端子(GND)                                   |
| 17             | 17              | E5   | P25/SCLK         | I/O | I(Pull-Up)   | 入出力ポート端子*/UART クロック入力端子                     |
| 18             | 18              | G4   | P24/SOUT         | I/O | I(Pull-Up)   | 入出力ポート端子*/UART データ出力端子                      |
| 19             | 19              | F4   | P23/SIN          | I/O | I(Pull-Up)   | 入出力ポート端子*/UART データ入力端子                      |
| 20             | 20              | G3   | HV <sub>DD</sub> | -   | -            | 電源端子(HV <sub>DD</sub> +)                    |
| 21             | 21              | E4   | P22/SPICLK       | I/O | I(Pull-Up)   | 入出力ポート端子*/SPI クロック入出力端子                     |
| 22             | 22              | G2   | P21/SDO          | I/O | I(Pull-Up)   | 入出力ポート端子*/SPI データ出力端子                       |
| 23             | 23              | F3   | P20/SDI          | I/O | I(Pull-Up)   | 入出力ポート端子*/SPI データ入力端子                       |
| 24             | 24              | F2   | P17/#SPISS       | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)*/SPI スレーブセレクト入力端子          |
| 25             | 25              | G1   | #TEST1           | I   | I(Pull-Up)   | テスト端子(通常動作時はHighに固定)                        |
| 26             | 26              | F1   | TEST0            | I   | I(Pull-Down) | テスト端子(通常動作時はLowに固定)                         |
| 27             | 27              | E3   | DCLK/P31         | I/O | O(H)         | オンチップデバッガクロック出力端子*/入出力ポート端子                 |
| 28             | 28              | E2   | DST2/P32         | I/O | O(L)         | オンチップデバッガステータス出力端子*/入出力ポート端子                |
| 29             | 29              | E1   | DSIO/P33         | I/O | I(Pull-Up)   | オンチップデバッガデータ入出力端子*/入出力ポート端子                 |
| 30             | 30              | D2   | Vss              | -   | -            | 電源端子(GND)                                   |
| 31             | 31              | D1   | LV <sub>DD</sub> | -   | -            | 電源端子(LV <sub>DD</sub> +)                    |
| 32             | 32              | D3   | P14/SDA          | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)*/I <sup>2</sup> C データ入出力端子 |
| 33             | 33              | C1   | P15/SCL          | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)*/I <sup>2</sup> C クロック出力端子 |
| 34             | 34              | C2   | P16/EXCL0        | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)*/T16 Ch.0 外部クロック入力端子       |
| 35             | 35              | B1   | P07/EXCL1        | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)*/T16 Ch.1 外部クロック入力端子       |
| 36             | 36              | B2   | P06/EXCL2        | I/O | I(Pull-Up)   | 入出力ポート端子(割り込み付き)*/T16 Ch.2 外部クロック入力端子       |

注：太字の端子名、および“\*”の付いた機能がデフォルト設定の内容です。

# 2 CPU

S1C17001はコアプロセッサとしてS1C17コアを搭載しています。

S1C17コアはセイコーエプソンオリジナルの16ビットRISCプロセッサです。

低消費電力、高速動作、広いアドレス空間、主要命令の1クロック実行、省ゲート設計を特長とし、8ビットCPUがよく使われるコントローラやシーケンサ等への組み込み用に最適です。

S1C17コアの詳細については、“S1C17 Family S1C17コアマニュアル”を参照してください。

## 2.1 S1C17コアの特長

### プロセッサ形式

- セイコーエプソンオリジナル16ビットRISCプロセッサ
- 0.35～0.15μm低電力CMOSプロセステクノロジ

### 命令セット

- コード長 16ビット固定長
- 命令数 基本命令111個(全184命令)
- 実行サイクル 主要命令は1サイクルで実行
- 即値拡張命令 即値を24ビットまで拡張
- Cによる開発用に最適化されたコンパクトかつ高速な命令セット

### レジスタセット

- 24ビット汎用レジスタ × 8
- 24ビット特殊レジスタ × 2
- 8ビット特殊レジスタ × 1

### メモリ空間、バス

- 最大16Mバイトのメモリ空間(24ビットアドレス)
- 命令バス(16ビット)とデータバス(32ビット)を分離したハーバードアーキテクチャ

### 割り込み

- リセット、NMI、32種類の外部割り込みに対応
- アドレス不整割り込み
- デバッグ割り込み
- ベクタテーブルからベクタを読み込み、割り込み処理ルーチンへ直接分岐
- ベクタ番号によるソフトウェア割り込みを発生可能(全ベクタ番号を指定可能)

### パワーセーブ

- HALT(halt命令)
- SLEEP(slp命令)

## 2.2 CPUレジスタ

S1C17コアは、8本の汎用レジスタおよび3本の特殊レジスタを内蔵しています。



図2.2.1 レジスタ

## 2.3 命令セット

S1C17コアの命令コードはすべて16ビットの固定長で、パイプライン処理を行うことによって主要な命令を1サイクルで実行します。各命令の詳細については“S1C17 Family S1C17コアマニュアル”を参照してください。

表2.3.1 S1C17コア命令一覧

| 種類    | ニーモニック          | 機能                                            |
|-------|-----------------|-----------------------------------------------|
| データ転送 | ld.b %rd, %rs   | 汎用レジスタ(16ビット) → 汎用レジスタ(符号拡張)                  |
|       | %rd, [%rb]      | メモリ(16ビット) → 汎用レジスタ(符号拡張)                     |
|       | %rd, [%rb] +    | メモリアドレスのポストインクリメント、ポストデクリメント、プリデクリメント機能を使用可能  |
|       | %rd, [%rb] -    |                                               |
|       | %rd, -[%rb]     |                                               |
|       | %rd, [%sp+imm7] | スタック(16ビット) → 汎用レジスタ(符号拡張)                    |
|       | %rd, [imm7]     | メモリ(16ビット) → 汎用レジスタ(符号拡張)                     |
|       | [%rb], %rs      | 汎用レジスタ(16ビット) → メモリ                           |
|       | [%rb] +, %rs    | メモリアドレスのポストインクリメント、ポストデクリメント、プリデクリメント機能を使用可能  |
|       | [%rb] -, %rs    |                                               |
|       | -[%rb], %rs     |                                               |
|       | [%sp+imm7], %rs | 汎用レジスタ(16ビット) → スタック                          |
|       | [imm7], %rs     | 汎用レジスタ(16ビット) → メモリ                           |
|       |                 |                                               |
| ld.ub | %rd, %rs        | 汎用レジスタ(16ビット) → 汎用レジスタ(ゼロ拡張)                  |
|       | %rd, [%rb]      | メモリ(16ビット) → 汎用レジスタ(ゼロ拡張)                     |
|       | %rd, [%rb] +    | メモリアドレスのポストインクリメント、ポストデクリメント、プリデクリメント機能を使用可能  |
|       | %rd, [%rb] -    |                                               |
|       | %rd, -[%rb]     |                                               |
|       | %rd, [%sp+imm7] | スタック(16ビット) → 汎用レジスタ(ゼロ拡張)                    |
|       | %rd, [imm7]     | メモリ(16ビット) → 汎用レジスタ(ゼロ拡張)                     |
| ld    | %rd, %rs        | 汎用レジスタ(16ビット) → 汎用レジスタ                        |
|       | %rd, sign7      | 即値 → 汎用レジスタ(符号拡張)                             |
|       | %rd, [%rb]      | メモリ(16ビット) → 汎用レジスタ                           |
|       | %rd, [%rb] +    | メモリアドレスのポストインクリメント、ポストデクリメント、プリデクリメント機能を使用可能  |
|       | %rd, [%rb] -    |                                               |
|       | %rd, -[%rb]     |                                               |
|       | %rd, [%sp+imm7] | スタック(16ビット) → 汎用レジスタ                          |
|       | %rd, [imm7]     | メモリ(16ビット) → 汎用レジスタ                           |
|       | [%rb], %rs      | 汎用レジスタ(16ビット) → メモリ                           |
|       | [%rb] +, %rs    | メモリアドレスのポストインクリメント、ポストデクリメント、プリデクリメント機能を使用可能  |
| ld.a  | %rd, -[%rb]     |                                               |
|       | %rd, -[%rb]     |                                               |
|       | %rd, [%sp+imm7] | スタック(32ビット) → 汎用レジスタ (*1)                     |
|       | %rd, [imm7]     | メモリ(32ビット) → 汎用レジスタ (*1)                      |
|       | [%rb], %rs      | 汎用レジスタ(32ビット、ゼロ拡張) → メモリ (*1)                 |
|       | [%rb] +, %rs    | メモリアドレスのポストインクリメント、ポストデクリメント、プリデクリメント機能を使用可能  |
|       | [%rb] -, %rs    |                                               |
|       | -[%rb], %rs     |                                               |
|       | [%sp+imm7], %rs | 汎用レジスタ(32ビット、ゼロ拡張) → スタック (*1)                |
|       | [imm7], %rs     | 汎用レジスタ(32ビット、ゼロ拡張) → メモリ (*1)                 |
|       | %rd, %sp        | SP → 汎用レジスタ                                   |
|       | %rd, %pc        | PC → 汎用レジスタ                                   |
|       | %rd, [%sp]      | スタック(32ビット) → 汎用レジスタ (*1)                     |
|       | %rd, [%sp] +    | スタックポインタのポストインクリメント、ポストデクリメント、プリデクリメント機能を使用可能 |
|       | %rd, [%sp] -    |                                               |
|       | %rd, -[%sp]     |                                               |

| 種類     | ニーモニック          | 機能                                                                  |
|--------|-----------------|---------------------------------------------------------------------|
| データ転送  | ld.a [%sp], %rs | 汎用レジスタ(32ビット、ゼロ拡張)→スタック(*1)                                         |
|        | [%sp]+, %rs     | スタックポインタのポストインクリメント、ポストデクリメント、                                      |
|        | [%sp]-, %rs     | プリデクリメント機能を使用可能                                                     |
|        | -[%sp], %rs     |                                                                     |
|        | %sp, %rs        | 汎用レジスタ(24ビット)→SP                                                    |
|        | %sp, imm7       | 即値→SP                                                               |
| 整数算術演算 | add %rd, %rs    | 汎用レジスタ間の16ビット加算<br>条件実行に対応(/c: C = 1の場合に実行, /nc: C = 0の場合に実行)       |
|        | add/c           |                                                                     |
|        | add/nc          |                                                                     |
|        | add %rd, imm7   | 汎用レジスタと即値の16ビット加算                                                   |
|        | add.a %rd, %rs  | 汎用レジスタ間の24ビット加算<br>条件実行に対応(/c: C = 1の場合に実行, /nc: C = 0の場合に実行)       |
|        | add.a/c         |                                                                     |
|        | add.a/nc        |                                                                     |
|        | add.a %sp, %rs  | SPと汎用レジスタの24ビット加算                                                   |
|        | add.a %rd, imm7 | 汎用レジスタと即値の24ビット加算                                                   |
|        | add.a %sp, imm7 | SPと即値の24ビット加算                                                       |
|        | adc %rd, %rs    | 汎用レジスタ間のキャリー付き16ビット加算<br>条件実行に対応(/c: C = 1の場合に実行, /nc: C = 0の場合に実行) |
|        | adc/c           |                                                                     |
|        | adc/nc          |                                                                     |
|        | adc %rd, imm7   | 汎用レジスタと即値のキャリー付き16ビット加算                                             |
|        | sub %rd, %rs    | 汎用レジスタ間の16ビット減算<br>条件実行に対応(/c: C = 1の場合に実行, /nc: C = 0の場合に実行)       |
|        | sub/c           |                                                                     |
|        | sub/nc          |                                                                     |
|        | sub %rd, imm7   | 汎用レジスタと即値の16ビット減算                                                   |
|        | sub.a %rd, %rs  | 汎用レジスタ間の24ビット減算<br>条件実行に対応(/c: C = 1の場合に実行, /nc: C = 0の場合に実行)       |
|        | sub.a/c         |                                                                     |
|        | sub.a/nc        |                                                                     |
|        | sub.a %sp, %rs  | SPと汎用レジスタの24ビット減算                                                   |
|        | sub.a %rd, imm7 | 汎用レジスタと即値の24ビット減算                                                   |
|        | sub.a %sp, imm7 | SPと即値の24ビット減算                                                       |
|        | sbc %rd, %rs    | 汎用レジスタ間のキャリー付き16ビット減算<br>条件実行に対応(/c: C = 1の場合に実行, /nc: C = 0の場合に実行) |
|        | sbc/c           |                                                                     |
|        | sbc/nc          |                                                                     |
|        | sbc %rd, imm7   | 汎用レジスタと即値のキャリー付き16ビット減算                                             |
| 論理演算   | cmp %rd, %rs    | 汎用レジスタ間の16ビット比較<br>条件実行に対応(/c: C = 1の場合に実行, /nc: C = 0の場合に実行)       |
|        | cmp/c           |                                                                     |
|        | cmp/nc          |                                                                     |
|        | cmp %rd, sign7  | 汎用レジスタと即値の16ビット比較                                                   |
|        | cmp.a %rd, %rs  | 汎用レジスタ間の24ビット比較<br>条件実行に対応(/c: C = 1の場合に実行, /nc: C = 0の場合に実行)       |
|        | cmp.a/c         |                                                                     |
|        | cmp.a/nc        |                                                                     |
|        | cmp.a %rd, imm7 | 汎用レジスタと即値の24ビット比較                                                   |
|        | cmc %rd, %rs    | 汎用レジスタ間のキャリー付き16ビット比較<br>条件実行に対応(/c: C = 1の場合に実行, /nc: C = 0の場合に実行) |
|        | cmc/c           |                                                                     |
|        | cmc/nc          |                                                                     |
|        | cmc %rd, sign7  | 汎用レジスタと即値のキャリー付き16ビット比較                                             |
| 論理演算   | and %rd, %rs    | 汎用レジスタ間の論理積<br>条件実行に対応(/c: C = 1の場合に実行, /nc: C = 0の場合に実行)           |
|        | and/c           |                                                                     |
|        | and/nc          |                                                                     |
|        | and %rd, sign7  | 汎用レジスタと即値の論理積                                                       |
|        | or %rd, %rs     | 汎用レジスタ間の論理和<br>条件実行に対応(/c: C = 1の場合に実行, /nc: C = 0の場合に実行)           |
|        | or/c            |                                                                     |
|        | or/nc           |                                                                     |
|        | or %rd, sign7   | 汎用レジスタと即値の論理和                                                       |
|        | xor %rd, %rs    | 汎用レジスタ間の排他的論理和<br>条件実行に対応(/c: C = 1の場合に実行, /nc: C = 0の場合に実行)        |
|        | xor/c           |                                                                     |
|        | xor/nc          |                                                                     |
|        | xor %rd, sign7  | 汎用レジスタと即値の排他的論理和                                                    |
| 論理演算   | not %rd, %rs    | 汎用レジスタ間の論理否定(1の補数)<br>条件実行に対応(/c: C = 1の場合に実行, /nc: C = 0の場合に実行)    |
|        | not/c           |                                                                     |
|        | not/nc          |                                                                     |
|        | not %rd, sign7  | 汎用レジスタと即値の論理否定(1の補数)                                                |
|        |                 |                                                                     |

| 種類       | 二ーモニック  | 機能                                                 |
|----------|---------|----------------------------------------------------|
| シフト&スワップ | sr      | 右論理シフト(レジスタによるシフトビット数指定)<br>右論理シフト(即値によるシフトビット数指定) |
|          | sa      | 右算術シフト(レジスタによるシフトビット数指定)<br>右算術シフト(即値によるシフトビット数指定) |
|          | sl      | 左論理シフト(レジスタによるシフトビット数指定)<br>左論理シフト(即値によるシフトビット数指定) |
|          | swap    | 16ビット境界でバイト単位のスワップ                                 |
|          | ext     | 直後の命令のオペランドを拡張                                     |
| 即値拡張     | cv.ab   | 符号付き8ビットデータを24ビットに変換                               |
|          | cv.as   | 符号付き16ビットデータを24ビットに変換                              |
|          | cv.al   | 32ビットデータを24ビットに変換                                  |
|          | cv.la   | 24ビットデータを32ビットに変換                                  |
|          | cv.ls   | 16ビットデータを32ビットに変換                                  |
| 分岐       | jpr     | PC相対ジャンプ                                           |
|          | jpr.d   | ディレイド分岐可                                           |
|          | jpa     | 絶対ジャンプ                                             |
|          | jpa.d   | ディレイド分岐可                                           |
|          | jrgt    | PC相対条件ジャンプ 分岐条件: !Z & !(N ^ V)                     |
|          | jrgt.d  | ディレイド分岐可                                           |
|          | jrgt    | PC相対条件ジャンプ 分岐条件: !(N ^ V)                          |
|          | jrgt.d  | ディレイド分岐可                                           |
|          | jrlt    | PC相対条件ジャンプ 分岐条件: N ^ V                             |
|          | jrlt.d  | ディレイド分岐可                                           |
|          | jrlt    | PC相対条件ジャンプ 分岐条件: Z   N ^ V                         |
|          | jrlt.d  | ディレイド分岐可                                           |
|          | jrugt   | PC相対条件ジャンプ 分岐条件: !Z & !C                           |
|          | jrugt.d | ディレイド分岐可                                           |
|          | jruge   | PC相対条件ジャンプ 分岐条件: !C                                |
|          | jruge.d | ディレイド分岐可                                           |
|          | jrult   | PC相対条件ジャンプ 分岐条件: C                                 |
|          | jrult.d | ディレイド分岐可                                           |
|          | jrule   | PC相対条件ジャンプ 分岐条件: Z   C                             |
|          | jrule.d | ディレイド分岐可                                           |
|          | jreq    | PC相対条件ジャンプ 分岐条件: Z                                 |
|          | jreq.d  | ディレイド分岐可                                           |
|          | jrne    | PC相対条件ジャンプ 分岐条件: !Z                                |
|          | jrne.d  | ディレイド分岐可                                           |
| システム制御   | call    | PC相対サブルーチンコール                                      |
|          | call.d  | ディレイド分岐可                                           |
|          | calla   | 絶対サブルーチンコール                                        |
|          | calla.d | ディレイド分岐可                                           |
|          | ret     | サブルーチンからのリターン                                      |
|          | ret.d   | ディレイド分岐可                                           |
|          | int     | ソフトウェア割り込み                                         |
|          | intl    | 割り込みレベル指定付きソフトウェア割り込み                              |
|          | reti    | 割り込みからのリターン                                        |
|          | reti.d  | ディレイド分岐可                                           |
|          | brk     | デバッグ割り込み                                           |
|          | retd    | デバッグ処理からのリターン                                      |
|          | nop     | ノーオペレーション                                          |
|          | halt    | HALT                                               |
|          | slp     | SLEEP                                              |
|          | ei      | 割り込み許可                                             |
|          | di      | 割り込み禁止                                             |

\*1 l d. a命令は32ビットのメモリアクセスを行います。レジスタからメモリへのデータ転送では上位8ビットを0とした32ビットデータがメモリに書き込まれます。メモリからの読み出し時は、読み出しデータの上位8ビットが無視されます。

\*2 S1C17001はコプロセッサを内蔵していません。このため、コプロセッサ命令は予約命令となります。

表中の記号の意味は次のとおりです。

表2.3.2 記号の意味

| 記号                                   | 説明                                  |
|--------------------------------------|-------------------------------------|
| <code>%rs</code>                     | 汎用ソースレジスタ                           |
| <code>%rd</code>                     | 汎用デスティネーションレジスタ                     |
| <code>[%rb]</code>                   | 汎用レジスタで間接指定されるメモリ                   |
| <code>[%rb] +</code>                 | 汎用レジスタで間接指定されるメモリ(アドレスポストインクリメント付き) |
| <code>[%rb] -</code>                 | 汎用レジスタで間接指定されるメモリ(アドレスポストデクリメント付き)  |
| <code>-[%rb]</code>                  | 汎用レジスタで間接指定されるメモリ(アドレスプリデクリメント付き)   |
| <code>%sp</code>                     | スタックポインタ                            |
| <code>[%sp], [%sp+imm7]</code>       | スタック                                |
| <code>[%sp] +</code>                 | スタック(アドレスポストインクリメント付き)              |
| <code>[%sp] -</code>                 | スタック(アドレスポストデクリメント付き)               |
| <code>-[%sp]</code>                  | スタック(アドレスプリデクリメント付き)                |
| <code>imm3, imm5, imm7, imm13</code> | 符号なし即値(数値はビット長)                     |
| <code>sign7, sign10</code>           | 符号付き即値(数値はビット長)                     |

## 2.4 ベクターテーブル

ベクターテーブルは、割り込み処理ルーチンへのベクタ(処理ルーチン開始アドレス)を格納します。割り込みが発生すると、S1C17コアは割り込みに対応するベクタを読み出して、その処理ルーチンを実行します。ベクターテーブルの先頭には、リセット後にプログラムの実行を開始するブートアドレスを書き込んでおく必要があります。

S1C17001のベクターテーブルは、0x8000番地から配置されます。このベクターテーブルベースアドレスは0xfffff80番地のTTBR(ベクターテーブルベースレジスタ)から読み出すことができます。

表2.4.1にS1C17001のベクターテーブルを示します。

表2.4.1 ベクターテーブル

| ベクタNo./ソフトウェア割り込みNo.        | ベクタアドレス               | ハードウェア割り込み名          | ハードウェア割り込み要因                                           | 優先順位                  |
|-----------------------------|-----------------------|----------------------|--------------------------------------------------------|-----------------------|
| 0 (0x00)                    | 0x8000                | リセット                 | • #RESET端子へのLow入力<br>• ウオッチドッグタイマオーバーフロー <sup>*2</sup> | 1                     |
| 1 (0x01)                    | 0x8004                | アドレス不整割り込み           | メモリアクセス命令                                              | 2                     |
| -                           | (0xffffc00)           | デバッグ割り込み             | brk命令等                                                 | 3                     |
| 2 (0x02)                    | 0x8008                | NMI                  | ウォッチドッグタイマオーバーフロー <sup>*2</sup>                        | 4                     |
| 3 (0x03)                    | 0x800c                | reserved             | -                                                      | -                     |
| 4 (0x04)                    | 0x8010                | P0ポート割り込み            | P00~P07ポート入力                                           | 高い <sup>*1</sup><br>↑ |
| 5 (0x05)                    | 0x8014                | P1ポート割り込み            | P10~P17ポート入力                                           |                       |
| 6 (0x06)                    | 0x8018                | ストップウォッチタイマ割り込み      | • タイマ100Hz信号<br>• タイマ10Hz信号<br>• タイマ1Hz信号              |                       |
| 7 (0x07)                    | 0x801c                | 計時タイマ割り込み            | • タイマ32Hz信号<br>• タイマ8Hz信号<br>• タイマ2Hz信号<br>• タイマ1Hz信号  |                       |
| 8 (0x08)                    | 0x8020                | 8ビットOSC1タイマ割り込み      | コンペアマッチ                                                |                       |
| 9 (0x09)                    | 0x8024                | reserved             | -                                                      |                       |
| 10 (0x0a)                   | 0x8028                |                      | -                                                      |                       |
| 11 (0x0b)                   | 0x802c                | PWM&キャプチャタイマ割り込み     | • コンペアA<br>• コンペアB                                     |                       |
| 12 (0x0c)                   | 0x8030                | 8ビットタイマ割り込み          | タイマアンダーフロー                                             |                       |
| 13 (0x0d)                   | 0x8034                | 16ビットタイマCh.0割り込み     | タイマアンダーフロー                                             |                       |
| 14 (0x0e)                   | 0x8038                | 16ビットタイマCh.1割り込み     | タイマアンダーフロー                                             |                       |
| 15 (0x0f)                   | 0x803c                | 16ビットタイマCh.2割り込み     | タイマアンダーフロー                                             |                       |
| 16 (0x10)                   | 0x8040                | UART割り込み             | • 送信バッファエンブティ<br>• 受信バッファフル<br>• 受信エラー                 |                       |
| 17 (0x11)                   | 0x8044                | リモートコントローラ割り込み       | • データ長カウンタアンダーフロー<br>• 入力立ち上がりエッジ検出<br>• 入力立ち下がりエッジ検出  |                       |
| 18 (0x12)                   | 0x8048                | SPI割り込み              | • 送信バッファエンブティ<br>• 受信バッファフル                            |                       |
| 19 (0x13)                   | 0x804c                | I <sup>2</sup> C割り込み | • 送信バッファエンブティ<br>• 受信バッファフル                            |                       |
| 20 (0x14)<br>:<br>31 (0x1f) | 0x8050<br>:<br>0x807c | reserved             | -                                                      | ↓<br>低い <sup>*1</sup> |

\*1 同一の割り込みレベルが設定されている場合

\*2 ウオッチドッグタイマの割り込みは、ソフトウェアにてリセットまたはNMIのいずれかを選択

### 0xfffff80: Vector Table Base Register (TTBR)

| Register name                     | Address             | Bit    | Name       | Function                  | Setting | Init.  | R/W | Remarks |
|-----------------------------------|---------------------|--------|------------|---------------------------|---------|--------|-----|---------|
| Vector Table Base Register (TTBR) | 0xfffff80 (32 bits) | D31~24 | -          | Unused (fixed at 0)       | 0x0     | 0x0    | R   |         |
|                                   |                     | D23~0  | TTBR[23:0] | Vector table base address | 0x8000  | 0x8000 | R   |         |

## 2.5 プロセッサ情報

S1C17001はProcessor ID Register(0xffff84)を内蔵しており、アプリケーションソフトウェアからCPUコアの種類を特定することができます。

### 0xffff84: Processor ID Register (IDIR)

| Register name                | Address           | Bit  | Name      | Function                         | Setting | Init. | R/W | Remarks |
|------------------------------|-------------------|------|-----------|----------------------------------|---------|-------|-----|---------|
| Processor ID Register (IDIR) | 0xffff84 (8 bits) | D7–0 | IDIR[7:0] | Processor ID<br>0x10: S1C17 Core | 0x10    | 0x10  | R   |         |

プロセッサの機種を示すIDコードが格納されるリードオンリレジスタです。S1C17コアのIDコードは0x10です。

# 3 メモリマップ、バス制御

図3.1にS1C17001のメモリマップを示します。



図3.1 S1C17001メモリマップ

## 3.1 バスサイクル

CPUはCCLKを基準に動作します。CCLKについては、“8.2 CPUコアクロック(CCLK)の制御”を参照してください。

CCLKの立ち上がりから次の立ち上がりまでを1 CCLKとし、これを1バスサイクルとします。図3.1に示したとおり、1回のバスアクセスにかかるサイクル数は、周辺回路やメモリによって異なります。また、CPUの命令(アクセスサイズ)とデバイスサイズによりバスアクセス回数も変わります。

表3.1.1 バスアクセス回数

| デバイスサイズ | CPUアクセスサイズ | バスアクセス回数 |
|---------|------------|----------|
| 8ビット    | 8ビット       | 1        |
|         | 16ビット      | 2        |
|         | 32ビット*     | 4        |
| 16ビット   | 8ビット       | 1        |
|         | 16ビット      | 1        |
|         | 32ビット*     | 2        |
| 32ビット   | 8ビット       | 1        |
|         | 16ビット      | 1        |
|         | 32ビット*     | 1        |

\* 32ビットアクセス時の上位8ビットデータについて

32ビットデータは上位8ビットを0としてメモリに書き込まれます。メモリからの読み出し時は上位8ビットが無視されます。割り込み処理のスタック操作時は、PSRの値を上位8ビットに、戻アドレスを下位24ビットとした32ビットの書き込み/読み出しを行います。

### バスサイクル数の計算例

内蔵周辺回路エリア2(8ビットデバイス, 3サイクル)に、CPUから16ビットリード/ライト命令でアクセスする場合のバスサイクル数

$$3 \text{ [サイクル]} \times 2 \text{ [バスアクセス回数]} = 6 \text{ [CCLKサイクル]}$$

### 3.1.1 アクセスサイズ制限

以下に示すモジュールにはアクセスサイズに制限がありますので、プログラミングの際には使用する命令に注意してください。

#### SPI, I<sup>2</sup>C

SPIとI<sup>2</sup>Cのレジスタへのアクセスには、16ビットリード/ライト命令のみ使用可能です。

上記以外のモジュールは8ビット、16ビット、32ビットのいずれの命令でもアクセス可能です。ただし、必要のないレジスタの読み出しによって周辺回路の状態が変わり、問題が発生する場合もありますので、できるだけデバイスサイズに合わせてアクセスすることを推奨します。

### 3.1.2 命令実行サイクルの制限

以下のいずれかの条件下では命令のフェッチとデータアクセスが同時に行われず、データの存在するエリアのアクセスサイクル分、命令フェッチのサイクルが長くなります。

- 内蔵ROMエリアで命令を実行し、内蔵ROM、内蔵周辺回路エリア2(0x5000～)のデータにアクセスする場合
- 内蔵RAMエリアで命令を実行し、内蔵RAMエリアのデータにアクセスする場合

## 3.2 内蔵ROMエリア

### 3.2.1 内蔵ROM

0x8000番地から0xffff番地までの32Kバイトの領域にはROMが内蔵されており、アプリケーションプログラムやデータを書き込んでおくことができます。0x8000番地はベクターテーブルベースアドレスとして定義されていますので、この領域の先頭にベクターテーブル（“2.4 ベクターテーブル”参照）を置く必要があります。ROMの読み出しあは1～5サイクルで行われます。

### 3.2.2 ROMのリードアクセスサイクルの設定

S1C17701との互換性維持のため、IROMエリアのリードアクセスサイクルが、FLCYC[2:0](D[2:0]/MISC\_FLレジスタ)で設定できるようになっています。通常はFLCYC[2:0]を0x4に設定して使用してください。

#### 0x5320: ROM Control Register (MISC\_FL)

| Register name                  | Address         | Bit  | Name       | Function              | Setting    |            | Init. | R/W | Remarks            |
|--------------------------------|-----------------|------|------------|-----------------------|------------|------------|-------|-----|--------------------|
| ROM Control Register (MISC_FL) | 0x5320 (8 bits) | D7-3 | —          | reserved              | —          | —          | —     | —   | 0 when being read. |
|                                |                 | D2-0 | FLCYC[2:0] | ROM read access cycle | FLCYC[2:0] | Read cycle | 0x3   | R/W |                    |
|                                |                 |      |            |                       | 0x7-0x5    | reserved   |       |     |                    |
|                                |                 |      |            |                       | 0x4        | 1 cycle    |       |     |                    |
|                                |                 |      |            |                       | 0x3        | 5 cycles   |       |     |                    |
|                                |                 |      |            |                       | 0x2        | 4 cycles   |       |     |                    |
|                                |                 |      |            |                       | 0x1        | 3 cycles   |       |     |                    |
|                                |                 |      |            |                       | 0x0        | 2 cycles   |       |     |                    |

## 3.3 内蔵RAMエリア

---

### 3.3.1 内蔵RAM

0x0番地から0x7ff番地までの2Kバイトの領域にはRAMが内蔵されています。このRAMは1サイクルでアクセスされます。変数などの格納以外に、命令コードをコピーしてRAM上で高速に実行させることもできます。

注: 内蔵RAMの最後尾の64バイト(0x7c0～0x7ff)はオンチップデバッグ用に予約されています。アプリケーション開発中などデバッグ機能を使用する場合は、アプリケーションプログラムからはこの領域をアクセスしないでください。

デバッグの不要な量产品ではアプリケーション用に使用可能です。

## 3.4 内蔵周辺回路エリア

0x4000番地から始まる1Kバイトと、0x5000番地から始まる4Kバイトのエリアには、内蔵周辺回路のI/Oおよび制御レジスタが割り付けられています。

### 3.4.1 内蔵周辺回路エリア1(0x4000~)

0x4000番地から始まる内蔵周辺回路エリア1には以下の内蔵周辺機能用I/Oメモリが割り付けられており、1サイクルでアクセス可能です。

- プリスケーラ(PSC, 8ビットデバイス)
- UART(UART, 8ビットデバイス)
- 8ビットタイマ(T8F, 16ビットデバイス)
- 16ビットタイマ(T16, 16ビットデバイス)
- 割り込みコントローラ(ITC, 16ビットデバイス)
- SPI(SPI, 16ビットデバイス)
- I<sup>2</sup>C(I2C, 16ビットデバイス)

### 3.4.2 内蔵周辺回路エリア2(0x5000~)

0x5000番地から始まる内蔵周辺回路エリア2には以下の内蔵周辺機能用I/Oメモリが割り付けられており、3サイクルでアクセス可能です。

- 計時タイマ(CT, 8ビットデバイス)
- ストップウォッチタイマ(SWT, 8ビットデバイス)
- ウォッチドッグタイマ(WDT, 8ビットデバイス)
- 発振回路(OSC, 8ビットデバイス)
- クロックジェネレータ(CLG, 8ビットデバイス)
- 8ビットOSC1タイマ(T8OSC1, 8ビットデバイス)
- 入出力ポート&ポートMUX(P, 8ビットデバイス)
- PWM&キャプチャタイマ(T16E, 16ビットデバイス)
- MISCレジスタ(MISC, 8ビットデバイス)
- リモートコントローラ(REMC, 8ビットデバイス)

### 3.4.3 I/Oマップ<sup>9</sup>

内蔵周辺回路エリアのI/Oマップを以下に示します。各制御レジスタの詳細については、AppendixのI/Oレジスター一覧または各周辺回路の説明を参照してください。

注: 表中の“Reserved”で示されたアドレス、および表に記載のない周辺回路エリアの未使用領域は、アプリケーションプログラムからアクセスしないでください。

表3.4.3.1 I/Oマップ(内蔵周辺回路エリア1)

| 周辺回路                               | アドレス   | レジスタ名                 | 機能                                            |
|------------------------------------|--------|-----------------------|-----------------------------------------------|
| プリスケーラ<br>(8ビットデバイス)               | 0x4020 | PSC_CTL               | Prescaler Control Register                    |
|                                    | -      | -                     | Reserved                                      |
| UART(IrDA付き)<br>(8ビットデバイス)         | 0x4100 | UART_ST               | UART Status Register                          |
|                                    | 0x4101 | UART_TXD              | UART Transmit Data Register                   |
|                                    | 0x4102 | UART_RXD              | UART Receive Data Register                    |
|                                    | 0x4103 | UART_MOD              | UART Mode Register                            |
|                                    | 0x4104 | UART_CTL              | UART Control Register                         |
|                                    | 0x4105 | UART_EXP              | UART Expansion Register                       |
|                                    | -      | -                     | Reserved                                      |
| 8ビットタイマ<br>(Fモード付き)<br>(16ビットデバイス) | 0x4200 | T8F_CLK               | 8-bit Timer Input Clock Select Register       |
|                                    | 0x4202 | T8F_TR                | 8-bit Timer Reload Data Register              |
|                                    | 0x4204 | T8F_TC                | 8-bit Timer Counter Data Register             |
|                                    | 0x4206 | T8F_CTL               | 8-bit Timer Control Register                  |
|                                    | -      | -                     | Reserved                                      |
|                                    | -      | -                     | Reserved                                      |
|                                    | -      | -                     | Reserved                                      |
| 16ビットタイマ<br>Ch.0<br>(16ビットデバイス)    | 0x4220 | T16_CLK0              | 16-bit Timer Ch.0 Input Clock Select Register |
|                                    | 0x4222 | T16_TR0               | 16-bit Timer Ch.0 Reload Data Register        |
|                                    | 0x4224 | T16_TC0               | 16-bit Timer Ch.0 Counter Data Register       |
|                                    | 0x4226 | T16_CTL0              | 16-bit Timer Ch.0 Control Register            |
|                                    | -      | -                     | Reserved                                      |
| 16ビットタイマ<br>Ch.1<br>(16ビットデバイス)    | 0x4240 | T16_CLK1              | 16-bit Timer Ch.1 Input Clock Select Register |
|                                    | 0x4242 | T16_TR1               | 16-bit Timer Ch.1 Reload Data Register        |
|                                    | 0x4244 | T16_TC1               | 16-bit Timer Ch.1 Counter Data Register       |
|                                    | 0x4246 | T16_CTL1              | 16-bit Timer Ch.1 Control Register            |
|                                    | -      | -                     | Reserved                                      |
| 16ビットタイマ<br>Ch.2<br>(16ビットデバイス)    | 0x4260 | T16_CLK2              | 16-bit Timer Ch.2 Input Clock Select Register |
|                                    | 0x4262 | T16_TR2               | 16-bit Timer Ch.2 Reload Data Register        |
|                                    | 0x4264 | T16_TC2               | 16-bit Timer Ch.2 Counter Data Register       |
|                                    | 0x4266 | T16_CTL2              | 16-bit Timer Ch.2 Control Register            |
|                                    | -      | -                     | Reserved                                      |
| 割り込み<br>コントローラ<br>(16ビットデバイス)      | 0x4300 | ITC_IFLG              | Interrupt Flag Register                       |
|                                    | 0x4302 | ITC_EN                | Interrupt Enable Register                     |
|                                    | 0x4304 | ITC_CTL               | ITC Control Register                          |
|                                    | 0x4306 | ITC_ELV0              | External Interrupt Level Setup Register 0     |
|                                    | 0x4308 | ITC_ELV1              | External Interrupt Level Setup Register 1     |
|                                    | 0x430a | ITC_ELV2              | External Interrupt Level Setup Register 2     |
|                                    | 0x430c | ITC_ELV3              | External Interrupt Level Setup Register 3     |
|                                    | 0x430e | ITC_ILV0              | Internal Interrupt Level Setup Register 0     |
|                                    | 0x4310 | ITC_ILV1              | Internal Interrupt Level Setup Register 1     |
|                                    | 0x4312 | ITC_ILV2              | Internal Interrupt Level Setup Register 2     |
|                                    | 0x4314 | ITC_ILV3              | Internal Interrupt Level Setup Register 3     |
|                                    | -      | -                     | Reserved                                      |
|                                    | -      | -                     | Reserved                                      |
|                                    | -      | -                     | Reserved                                      |
| SPI<br>(16ビットデバイス)                 | 0x4320 | SPI_ST                | SPI Status Register                           |
|                                    | 0x4322 | SPI_TXD               | SPI Transmit Data Register                    |
|                                    | 0x4324 | SPI_RXD               | SPI Receive Data Register                     |
|                                    | 0x4326 | SPI_CTL               | SPI Control Register                          |
|                                    | -      | -                     | Reserved                                      |
| I <sup>2</sup> C<br>(16ビットデバイス)    | 0x4340 | I <sup>2</sup> C_EN   | I <sup>2</sup> C Enable Register              |
|                                    | 0x4342 | I <sup>2</sup> C_CTL  | I <sup>2</sup> C Control Register             |
|                                    | 0x4344 | I <sup>2</sup> C_DAT  | I <sup>2</sup> C Data Register                |
|                                    | 0x4346 | I <sup>2</sup> C_ICTL | I <sup>2</sup> C Interrupt Control Register   |
|                                    | -      | -                     | Reserved                                      |
|                                    | -      | -                     | Reserved                                      |

表3.4.3.2 I/Oマップ(内蔵周辺回路エリア2)

| 周辺回路                           | アドレス   | レジスタ名       | 機能                                             |
|--------------------------------|--------|-------------|------------------------------------------------|
| 計時タイマー<br>(8ビットデバイス)           | 0x5000 | CT_CTL      | Clock Timer Control Register                   |
|                                | 0x5001 | CT_CNT      | Clock Timer Counter Register                   |
|                                | 0x5002 | CT_IMSK     | Clock Timer Interrupt Mask Register            |
|                                | 0x5003 | CT_IFLG     | Clock Timer Interrupt Flag Register            |
|                                | -      | -           | Reserved                                       |
| ストップ<br>ウォッチタイマー<br>(8ビットデバイス) | 0x5020 | SWT_CTL     | Stopwatch Timer Control Register               |
|                                | 0x5021 | SWT_BCNT    | Stopwatch Timer BCD Counter Register           |
|                                | 0x5022 | SWT_IMSK    | Stopwatch Timer Interrupt Mask Register        |
|                                | 0x5023 | SWT_IFLG    | Stopwatch Timer Interrupt Flag Register        |
|                                | -      | -           | Reserved                                       |
| ウォッチドッグ<br>タイマー<br>(8ビットデバイス)  | 0x5040 | WDT_CTL     | Watchdog Timer Control Register                |
|                                | 0x5041 | WDT_ST      | Watchdog Timer Status Register                 |
|                                | -      | -           | Reserved                                       |
| 発振回路<br>(8ビットデバイス)             | 0x5060 | OSC_SRC     | Clock Source Select Register                   |
|                                | 0x5061 | OSC_CTL     | Oscillation Control Register                   |
|                                | 0x5062 | OSC_NFEN    | Noise Filter Enable Register                   |
|                                | 0x5063 | -           | Reserved                                       |
|                                | 0x5064 | OSC_FOUT    | FOUT Control Register                          |
|                                | 0x5065 | OSC_T8OSC1  | T8OSC1 Clock Control Register                  |
| クロック<br>ジェネレータ<br>(8ビットデバイス)   | 0x5080 | CLG_PCLK    | PCLK Control Register                          |
|                                | 0x5081 | CLG_CCLK    | CCLK Control Register                          |
|                                | -      | -           | Reserved                                       |
| 8ビットOSC1<br>タイマー<br>(8ビットデバイス) | 0x50c0 | T8OSC1_CTL  | 8-bit OSC1 Timer Control Register              |
|                                | 0x50c1 | T8OSC1_CNT  | 8-bit OSC1 Timer Counter Data Register         |
|                                | 0x50c2 | T8OSC1_CMP  | 8-bit OSC1 Timer Compare Data Register         |
|                                | 0x50c3 | T8OSC1_IMSK | 8-bit OSC1 Timer Interrupt Mask Register       |
|                                | 0x50c4 | T8OSC1_IFLG | 8-bit OSC1 Timer Interrupt Flag Register       |
| Pポート&<br>ポートMUX<br>(8ビットデバイス)  | -      | -           | Reserved                                       |
|                                | 0x5200 | P0_IN       | P0 Port Input Data Register                    |
|                                | 0x5201 | P0_OUT      | P0 Port Output Data Register                   |
|                                | 0x5202 | P0_IO       | P0 Port I/O Direction Control Register         |
|                                | 0x5203 | P0_PU       | P0 Port Pull-up Control Register               |
|                                | 0x5204 | -           | Reserved                                       |
|                                | 0x5205 | P0_IMSK     | P0 Port Interrupt Mask Register                |
|                                | 0x5206 | P0_EDGE     | P0 Port Interrupt Edge Select Register         |
|                                | 0x5207 | P0_IFLG     | P0 Port Interrupt Flag Register                |
|                                | 0x5208 | P0_CHAT     | P0 Port Chattering Filter Control Register     |
|                                | 0x5209 | P0_KRST     | P0 Port Key-Entry Reset Configuration Register |
|                                | -      | -           | Reserved                                       |
|                                | 0x5210 | P1_IN       | P1 Port Input Data Register                    |
|                                | 0x5211 | P1_OUT      | P1 Port Output Data Register                   |
|                                | 0x5212 | P1_IO       | P1 Port I/O Direction Control Register         |
|                                | 0x5213 | P1_PU       | P1 Port Pull-up Control Register               |
|                                | 0x5214 | -           | Reserved                                       |
|                                | 0x5215 | P1_IMSK     | P1 Port Interrupt Mask Register                |
|                                | 0x5216 | P1_EDGE     | P1 Port Interrupt Edge Select Register         |
|                                | 0x5217 | P1_IFLG     | P1 Port Interrupt Flag Register                |
|                                | -      | -           | Reserved                                       |
|                                | 0x5220 | P2_IN       | P2 Port Input Data Register                    |
|                                | 0x5221 | P2_OUT      | P2 Port Output Data Register                   |
|                                | 0x5222 | P2_IO       | P2 Port I/O Direction Control Register         |
|                                | 0x5223 | P2_PU       | P2 Port Pull-up Control Register               |
|                                | -      | -           | Reserved                                       |
|                                | 0x5230 | P3_IN       | P3 Port Input Data Register                    |
|                                | 0x5231 | P3_OUT      | P3 Port Output Data Register                   |
|                                | 0x5232 | P3_IO       | P3 Port I/O Direction Control Register         |
|                                | 0x5233 | P3_PU       | P3 Port Pull-up Control Register               |
|                                | -      | -           | Reserved                                       |
|                                | 0x52a0 | P0_PMUX     | P0 Port Function Select Register               |
|                                | 0x52a1 | P1_PMUX     | P1 Port Function Select Register               |
|                                | 0x52a2 | P2_PMUX     | P2 Port Function Select Register               |
|                                | 0x52a3 | P3_PMUX     | P3 Port Function Select Register               |
|                                | -      | -           | Reserved                                       |

| 周辺回路                            | アドレス   | レジスタ名     |                                       | 機能                     |
|---------------------------------|--------|-----------|---------------------------------------|------------------------|
| PWM&<br>キャプチャタイマ<br>(16ビットデバイス) | 0x5300 | T16E_CA   | PWM Timer Compare Data A Register     | コンペアデータAの設定            |
|                                 | 0x5302 | T16E_CB   | PWM Timer Compare Data B Register     | コンペアデータBの設定            |
|                                 | 0x5304 | T16E_TC   | PWM Timer Counter Data Register       | カウンタデータ                |
|                                 | 0x5306 | T16E_CTL  | PWM Timer Control Register            | タイマモードの設定とタイマのRUN/STOP |
|                                 | 0x5308 | T16E_CLK  | PWM Timer Input Clock Select Register | ブリスケーラ出力クロックの選択        |
|                                 | 0x530a | T16E_IMSK | PWM Timer Interrupt Mask Register     | 割り込みマスクの設定             |
|                                 | 0x530c | T16E_IFLG | PWM Timer Interrupt Flag Register     | 割り込み発生状態の表示/リセット       |
|                                 | —      | —         | —                                     | Reserved               |
| MISCレジスタ<br>(8ビットデバイス)          | 0x5320 | MISC_FL   | ROM Control Register                  | ROMアクセス条件設定            |
|                                 | 0x5321 | —         | —                                     | Reserved               |
|                                 | 0x5322 | MISC_OSC1 | OSC1 Peripheral Control Register      | デバッグ時のOSC1動作周辺機能の設定    |
|                                 | —      | —         | —                                     | Reserved               |
| リモート<br>コントローラ<br>(8ビットデバイス)    | 0x5340 | REMC_CFG  | REMC Configuration Register           | 送受信の選択と許可              |
|                                 | 0x5341 | REMC_PSC  | REMC Prescaler Clock Select Register  | ブリスケーラ出力クロックの選択        |
|                                 | 0x5342 | REMC_CARH | REMC H Carrier Length Setup Register  | キャリアのH区間長設定            |
|                                 | 0x5343 | REMC_CARL | REMC L Carrier Length Setup Register  | キャリアのL区間長設定            |
|                                 | 0x5344 | REMC_ST   | REMC Status Register                  | 送受信ビット                 |
|                                 | 0x5345 | REMC_LCNT | REMC Length Counter Register          | 送受信データ長の設定             |
|                                 | 0x5346 | REMC_IMSK | REMC Interrupt Mask Register          | 割り込みマスクの設定             |
|                                 | 0x5347 | REMC_IFLG | REMC Interrupt Flag Register          | 割り込み発生状態の表示/リセット       |
|                                 | —      | —         | —                                     | Reserved               |

## 3.5 コアI/O予約エリア

0xffffc00～0xffffffffの1K/バイトはCPUコアI/Oエリアとして使用され、以下のI/Oレジスタが割り付けられています。

表3.5.1 I/Oマップ(コアI/O予約エリア)

| 周辺回路       | アドレス      | レジスタ名 | 機能                |
|------------|-----------|-------|-------------------|
| S1C17コアI/O | 0xfffff80 | TTBR  | ベクタテーブルベースアドレスの表示 |
|            | 0xfffff84 | IDIR  | プロセッサIDの表示        |
|            | 0xfffff90 | DBRAM | デバッグRAMベースアドレスの表示 |

TTBRについては“2.4 ベクタテーブル”、IDIRについては“2.5 プロセッサ情報”を参照してください。  
DBRAMについては、“22 オンチップデバッガ(DBG)”を参照してください。

このページはブランクです。

# 4 電源電圧

S1C17001の動作電源電圧は次のとおりです。

コア電圧 (LV<sub>DD</sub>): 1.65~2.7V

I/O電圧 (HV<sub>DD</sub>): 1.65~3.6V

V<sub>SS</sub>端子をGNDとして、それぞれの範囲内の電圧をLV<sub>DD</sub>端子とHV<sub>DD</sub>端子に供給してください。

S1C17001には2本のLV<sub>DD</sub>端子、2本のHV<sub>DD</sub>端子、5本のV<sub>SS</sub>端子があります。いずれもオープンにせず、必ず+電源とGNDに接続してください。

このページはブランクです。

# 5 イニシャルリセット

## 5.1 イニシャルリセット要因

S1C17001の内部回路を初期化するイニシャルリセット要因は、以下の3種類です。

- (1) #RESET端子による外部イニシャルリセット
- (2) P0ポート(P00～P03端子)のキー入力による外部イニシャルリセット(ソフトウェアで設定)
- (3) ウオッチドッグタイマによる内部イニシャルリセット(ソフトウェアで設定)

図5.1.1にイニシャルリセット回路の構成を示します。



図5.1.1 イニシャルリセット回路の構成

イニシャルリセット要因によってCPUおよび周辺回路が初期化され、要因が解除されるとCPUはリセット処理を開始します。

これによって、ベクタテーブルの先頭からリセットベクタが読み出され、そのアドレスから始まるプログラム(初期化ルーチン)の実行を開始します。

### 5.1.1 #RESET端子

外部から#RESET端子にLowレベルを入力することでイニシャルリセットが行えます。

S1C17001を確実に初期化するため、電源電圧立ち上がり後、#RESET端子を規定の時間以上Lowレベルに保持してください。(“24.5 AC特性”参照)

#RESET入力がLowからHighになると、イニシャルリセットが解除され、CPUはリセット割り込み処理を開始します

#RESET端子には、プルアップ抵抗が内蔵されています。

## 5.1.2 P0ポートキー入力リセット

ソフトウェアで選択されたポート(P00～P03)に、外部から同時にLowレベルを入力することでイニシャルリセットが行えます。使用するポートはPOKRST[1:0](D[1:0]/P0\_KRSTレジスタ)で選択できます。

\* **POKRST[1:0]**: P0 Port Key-Entry Reset Configuration Bits in the P0 Port Key-Entry Reset Configuration (P0\_KRST) Register (D[1:0]/0x5209)

表5.1.2.1 P0ポートキー入力リセットの設定

| POKRST[1:0] | 使用するポート            |
|-------------|--------------------|
| 0x3         | P00, P01, P02, P03 |
| 0x2         | P00, P01, P02      |
| 0x1         | P00, P01           |
| 0x0         | 使用しない              |

たとえば、POKRST[1:0]を0x3に設定した場合、P00～P03の4ポートの入力が同時にLowレベルになったときにイニシャルリセットがかかります。

- 注: • P0ポートキー入力リセット機能を使用する場合、通常動作時に指定ポートが同時にLowレベルにならないように注意してください。
- P0ポートキー入力リセット機能はソフトウェアで有効にしますので、電源投入時のリセットには使用できません。
  - SLEEP状態では、P0ポートキー入力リセット機能は使用できません。

## 5.1.3 ウオッチドッグタイマによるリセット

S1C17001は、CPUの暴走を検出するためのウォッチドッグタイマを内蔵しています。ウォッチドッグタイマは4秒周期以内にソフトウェアによってリセットされない場合(CPUが暴走した場合)、タイマがオーバーフローし、このオーバーフロー信号によりNMIまたはリセットを発生するようになっています。リセットを発生させるにはWDTMD(D1/WDT\_STレジスタ)に1を書き込みます(WDTMDが0の場合はNMIを発生します)。

\* **WDTMD**: NMI/Reset Mode Select Bit in the Watchdog Timer Status (WDT\_ST) Register (D1/0x5041)

ウォッチドッグタイマの詳細については、“17 ウォッチドッグタイマ(WDT)”を参照してください。

- 注: • ウォッチドッグタイマによるリセット機能を使用する場合は、必ず4秒周期以内にウォッチドッグタイマをリセットし、不要なリセットが発生しないようにプログラムしてください。
- ウォッチドッグタイマによるリセット機能はソフトウェアで有効にしますので、電源投入時のリセットには使用できません。

## 5.2 イニシャルリセットシーケンス

電源投入時の#RESET端子によるリセット解除後、発振安定待ち時間( $1024/fosc3$ 秒\*)が経過するまでCPUの起動は待たれます。図5.2.1にイニシャルリセット解除後の動作シーケンスを示します。CPUはリセット解除後、OSC3クロックに同期して起動します。

\*  $fosc3$ : OSC3クロック周波数

注: 発振安定待ち時間には、発振開始時間は含まれていません。そのため、電源投入時やSLEEP解除後の命令実行までの時間は、下図よりも長くなる場合があります。



図5.2.1 イニシャルリセット解除後の動作シーケンス

## 5.3 イニシャルリセット時の初期設定

---

イニシャルリセットによりCPUの内部レジスタは以下のように初期化されます。

R0～R7: 0x0

PSR: 0x0(割り込みレベル = 0、割り込み禁止)

SP: 0x0

PC: リセット処理によりベクタテーブル先頭のリセットベクタがロードされます。

内蔵RAMおよび表示メモリはイニシャルリセット時に初期化されませんので、ソフトウェアで初期化してください。

内蔵の周辺回路については、それぞれ所定の初期化が行われます。必要に応じてソフトウェアで再設定してください。イニシャルリセット時の初期値については、AppendixのI/Oレジスター一覧または各周辺回路の説明を参照してください。

# 6 割り込みコントローラ (ITC)

## 6.1 ITCの構成

S1C17001には以下に示す14系統のハードウェア割り込みが用意されています。

1. P00～P07入力割り込み(8種類)
2. P10～P17入力割り込み(8種類)
3. ストップウォッチタイマ割り込み(3種類)
4. 計時タイマ割り込み(4種類)
5. 8ビットOSC1タイマ割り込み(1種類)
6. PWM&キャプチャタイマ割り込み(2種類)
7. 8ビットタイマ割り込み(1種類)
8. 16ビットタイマCh.0割り込み(1種類)
9. 16ビットタイマCh.1割り込み(1種類)
10. 16ビットタイマCh.2割り込み(1種類)
11. UART割り込み(3種類)
12. リモートコントローラ割り込み(3種類)
13. SPI割り込み(2種類)
14. I<sup>2</sup>C割り込み(2種類)

それぞれの割り込み系列には、周辺モジュールからの割り込み要求の発生を示す割り込みフラグと割り込みを許可/禁止する割り込みイネーブルビットが設けられています。また、複数の割り込みが同時に発生した場合に、処理する順序を決定する割り込みレベル(優先順位)を割り込み系列ごとに設定することができます。

各割り込み系列には上記の( )内に示した数の割り込み要因があります。どの割り込み要因でITCに対する割り込み要求を発生させるかについてはそれぞれの周辺モジュールのレジスタで制御します。割り込み要因とその制御の詳細については、各周辺モジュールの説明を参照してください。

図6.1.1に割り込みシステムの構成を示します。



図6.1.1 割り込みシステム

## 6.2 ベクタテーブル

ベクタテーブルは、割り込み処理ルーチンへのベクタ(処理ルーチン開始アドレス)を格納します。割り込みが発生すると、S1C17コアは割り込みに対応するベクタを読み出して、その処理ルーチンを実行します。S1C17001のベクタテーブルは、0x8000番地から配置されます。このベクタテーブルベースアドレスはTTBRレジスタ(0xfffff80)から読み出すことができます。

表6.2.1にS1C17001のベクタテーブルを示します。

表6.2.1 ベクタテーブル

| ベクタNo./ソフトウェア割り込みNo.     | ベクタアドレス            | ハードウェア割り込み名          | ハードウェア割り込み要因                                           | 優先順位                  |
|--------------------------|--------------------|----------------------|--------------------------------------------------------|-----------------------|
| 0 (0x00)                 | 0x8000             | リセット                 | • #RESET端子へのLow入力<br>• ウォッチドッグタイマオーバーフロー <sup>*2</sup> | 1                     |
| 1 (0x01)                 | 0x8004             | アドレス不整割り込み           | メモリアクセス命令                                              | 2                     |
| - (0xffffc00)            |                    | デバッグ割り込み             | brk命令等                                                 | 3                     |
| 2 (0x02)                 | 0x8008             | NMI                  | ウォッチドッグタイマオーバーフロー <sup>*2</sup>                        | 4                     |
| 3 (0x03)                 | 0x800c             | reserved             | -                                                      | -                     |
| 4 (0x04)                 | 0x8010             | P0ポート割り込み            | P00~P07ポート入力                                           | 高い <sup>*1</sup><br>↑ |
| 5 (0x05)                 | 0x8014             | P1ポート割り込み            | P10~P17ポート入力                                           |                       |
| 6 (0x06)                 | 0x8018             | ストップウォッチタイマ割り込み      | • タイマ100Hz信号<br>• タイマ10Hz信号<br>• タイマ1Hz信号              |                       |
| 7 (0x07)                 | 0x801c             | 計時タイマ割り込み            | • タイマ32Hz信号<br>• タイマ8Hz信号<br>• タイマ2Hz信号<br>• タイマ1Hz信号  |                       |
| 8 (0x08)                 | 0x8020             | 8ビットOSC1タイマ割り込み      | コンペアマッチ                                                |                       |
| 9 (0x09)                 | 0x8024             | reserved             | -                                                      |                       |
| 10 (0x0a)                | 0x8028             |                      |                                                        |                       |
| 11 (0x0b)                | 0x802c             | PWM&キャプチャタイマ割り込み     | • コンペアA<br>• コンペアB                                     |                       |
| 12 (0x0c)                | 0x8030             | 8ビットタイマ割り込み          | タイマアンダーフロー                                             |                       |
| 13 (0x0d)                | 0x8034             | 16ビットタイマCh.0割り込み     | タイマアンダーフロー                                             |                       |
| 14 (0x0e)                | 0x8038             | 16ビットタイマCh.1割り込み     | タイマアンダーフロー                                             |                       |
| 15 (0x0f)                | 0x803c             | 16ビットタイマCh.2割り込み     | タイマアンダーフロー                                             |                       |
| 16 (0x10)                | 0x8040             | UART割り込み             | • 送信バッファエンブティ<br>• 受信バッファフル<br>• 受信エラー                 |                       |
| 17 (0x11)                | 0x8044             | リモートコントローラ割り込み       | • データ長カウンタアンダーフロー<br>• 入力立ち上がりエッジ検出<br>• 入力立ち下がりエッジ検出  |                       |
| 18 (0x12)                | 0x8048             | SPI割り込み              | • 送信バッファエンブティ<br>• 受信バッファフル                            |                       |
| 19 (0x13)                | 0x804c             | I <sup>2</sup> C割り込み | • 送信バッファエンブティ<br>• 受信バッファフル                            |                       |
| 20 (0x14)<br>: 31 (0x1f) | 0x8050<br>: 0x807c | reserved             | -                                                      | ↓<br>低い <sup>*1</sup> |

\*1 同一の割り込みレベルが設定されている場合

\*2 ウォッチドッグタイマの割り込みは、ソフトウェアにてリセットまたはNMIのいずれかを選択

ベクタ番号4~19に、S1C17001が対応しているマスク可能な割り込みが割り当てられています。

## 6.3 マスク可能割り込みの制御

### 6.3.1 ITCイネーブル

ITCを使用するには、ITEN(DO/ITC\_CTLレジスタ)を1に設定します。

\* **ITEN:** ITC Enable Bit in the ITC Control (ITC\_CTL) Register (D0/0x4304)

ITENが0の場合、他のレジスタの設定にかかわらず、マスク可能な割り込みは発生しません。

### 6.3.2 周辺モジュールからの割り込み要求と割り込みフラグ

周辺モジュールで割り込みを許可した割り込み要因が発生すると、そのモジュールはITCに割り込み要求信号を送ります。この割り込み要求信号により、ITC内の対応する割り込みフラグが1にセットされます。割り込みフラグは0にリセットされるまで1を保持し、周辺モジュールからの割り込み要求が発生したことを示します。割り込みフラグの状態は、ITC\_IFLGレジスタ(0x4300)から読み出し可能です。表6.3.2.1に割り込み要因と割り込みフラグの対応を示します。

表6.3.2.1 ハードウェア割り込み要因と割り込みフラグ

| ベクタNo. | ハードウェア割り込み要求                                    | 割り込みフラグ                  |
|--------|-------------------------------------------------|--------------------------|
| 4      | P0ポート割り込み: P00～P07ポート入力                         | EIFT0 (D0/ITC_IFLGレジスタ)  |
| 5      | P1ポート割り込み: P10～P17ポート入力                         | EIFT1 (D1/ITC_IFLGレジスタ)  |
| 6      | ストップウォッチタイマ割り込み: 100Hz/10Hz/1Hz信号               | EIFT2 (D2/ITC_IFLGレジスタ)  |
| 7      | 計時タイマ割り込み: 32Hz/8Hz/2Hz/1Hz信号                   | EIFT3 (D3/ITC_IFLGレジスタ)  |
| 8      | 8ビットOSC1タイマ割り込み: コンペアマッチ                        | EIFT4 (D4/ITC_IFLGレジスタ)  |
| 11     | PWM&キャプチャタイマ割り込み: コンペアA/コンペアBマッチ                | EIFT7 (D7/ITC_IFLGレジスタ)  |
| 12     | 8ビットタイマ割り込み: タイマアンダーフロー                         | IIFT0 (D8/ITC_IFLGレジスタ)  |
| 13     | 16ビットタイマCh.0割り込み: タイマアンダーフロー                    | IIFT1 (D9/ITC_IFLGレジスタ)  |
| 14     | 16ビットタイマCh.1割り込み: タイマアンダーフロー                    | IIFT2 (D10/ITC_IFLGレジスタ) |
| 15     | 16ビットタイマCh.2割り込み: タイマアンダーフロー                    | IIFT3 (D11/ITC_IFLGレジスタ) |
| 16     | UART割り込み: 送信バッファエンプティ/受信バッファフル/受信エラー            | IIFT4 (D12/ITC_IFLGレジスタ) |
| 17     | リモートコントローラ割り込み: データ長カウンタアンダーフロー/入力立ち上がり/入力立ち下がり | IIFT5 (D13/ITC_IFLGレジスタ) |
| 18     | SPI割り込み: 送信バッファエンプティ/受信バッファフル                   | IIFT6 (D14/ITC_IFLGレジスタ) |
| 19     | I2C割り込み: 送信バッファエンプティ/受信バッファフル                   | IIFT7 (D15/ITC_IFLGレジスタ) |

ITCは割り込みフラグを使用してS1C17コアに割り込みを発生します。

割り込みが許可されている状態(次節参照)で割り込みフラグが1にセットされると、ITCは割り込み要求、割り込みレベルおよびベクタ番号の信号をS1C17コアに送ります。

1にセットされた割り込みフラグは1を書き込むことでリセットされます。割り込み処理ルーチンの中で割り込みフラグを0にリセットしてください。割り込み処理ルーチンが割り込みフラグをリセットしない場合、割り込み処理ルーチン終了後に同じ割り込みが再度発生してしまいます(割り込みは割り込み処理の間禁止され、割り込み処理の最後にreti命令を実行することで許可状態に戻ります)。

ただし、レベルトリガに設定した割り込み(6.3.5節参照)の割り込みフラグ(EIFT0～EIFT7)は1の書き込みでリセットされません。これらの割り込みフラグは、割り込み発生源が割り込み信号をインアクティブにすることによりリセットされます。

割り込み要因の発生条件やモジュール固有の割り込み設定については、割り込み発生源のモジュールの節を参照してください。

### 6.3.3 割り込みの許可/禁止

割り込み要求をS1C17コアに送るには、割り込みフラグに対応するITC\_ENレジスタ(0x4302)内の割り込みイネーブルビットを使用して、割り込みを個々に許可しておく必要があります。割り込みは割り込みイネーブルビットを1に設定すると許可され、0(デフォルト)に設定すると禁止されます。割り込みイネーブルビットは割り込みフラグには影響を与えません。割り込みイネーブルビットの設定にかかわらず、周辺モジュールからの割り込み要求の発生により割り込みフラグはセットされます。

表6.3.3.1に割り込みイネーブルビットと割り込みフラグの対応を示します。

表6.3.3.1 割り込みイネーブルビット一覧

| ペクタNo. | ハードウェア割り込み           | 割り込みフラグ                  | 割り込みイネーブルビット           |
|--------|----------------------|--------------------------|------------------------|
| 4      | P0ポート割り込み            | EIFT0 (D0/ITC_IFLGレジスタ)  | EIEN0 (D0/ITC_ENレジスタ)  |
| 5      | P1ポート割り込み            | EIFT1 (D1/ITC_IFLGレジスタ)  | EIEN1 (D1/ITC_ENレジスタ)  |
| 6      | ストップウォッチタイマ割り込み      | EIFT2 (D2/ITC_IFLGレジスタ)  | EIEN2 (D2/ITC_ENレジスタ)  |
| 7      | 計時タイマ割り込み            | EIFT3 (D3/ITC_IFLGレジスタ)  | EIEN3 (D3/ITC_ENレジスタ)  |
| 8      | 8ビットOSC1タイマ割り込み      | EIFT4 (D4/ITC_IFLGレジスタ)  | EIEN4 (D4/ITC_ENレジスタ)  |
| 11     | PWM&キャプチャタイマ割り込み     | EIFT7 (D7/ITC_IFLGレジスタ)  | EIEN7 (D7/ITC_ENレジスタ)  |
| 12     | 8ビットタイマ割り込み          | IIFT0 (D8/ITC_IFLGレジスタ)  | IIEN0 (D8/ITC_ENレジスタ)  |
| 13     | 16ビットタイマCh.0割り込み     | IIFT1 (D9/ITC_IFLGレジスタ)  | IIEN1 (D9/ITC_ENレジスタ)  |
| 14     | 16ビットタイマCh.1割り込み     | IIFT2 (D10/ITC_IFLGレジスタ) | IIEN2 (D10/ITC_ENレジスタ) |
| 15     | 16ビットタイマCh.2割り込み     | IIFT3 (D11/ITC_IFLGレジスタ) | IIEN3 (D11/ITC_ENレジスタ) |
| 16     | UART割り込み             | IIFT4 (D12/ITC_IFLGレジスタ) | IIEN4 (D12/ITC_ENレジスタ) |
| 17     | リモートコントローラ割り込み       | IIFT5 (D13/ITC_IFLGレジスタ) | IIEN5 (D13/ITC_ENレジスタ) |
| 18     | SPI割り込み              | IIFT6 (D14/ITC_IFLGレジスタ) | IIEN6 (D14/ITC_ENレジスタ) |
| 19     | I <sup>2</sup> C割り込み | IIFT7 (D15/ITC_IFLGレジスタ) | IIEN7 (D15/ITC_ENレジスタ) |

- 注: • 不要な割り込みの発生を避けるため、割り込みイネーブルビットへの1書き込みにより割り込みを許可する前に、必ず割り込みフラグをリセットしてください。
- 実際に割り込みを発生させるには、割り込みイネーブルビットに加え、S1C17コアのProcessor Status Register(PSR)にあるIEビットも1に設定する必要があります。IEビットが0に設定されている場合、S1C17コアはマスク可能な割り込み要求を受け付けません。この場合、ITCからの割り込み要求は保持され、IEビットが1に設定された後に受け付けられます。

### 6.3.4 複数の割り込み発生時の処理

ITCのITC\_ELVx、ITC\_ILVxレジスタ(0x4306～0x4314)は各割り込み要因の割り込みレベル(0～7)を設定します。

表6.3.4.1 割り込みレベル設定ビット

| ベクタNo. | ハードウェア割り込み       | 割り込みレベル設定ビット                      | レジスタアドレス |
|--------|------------------|-----------------------------------|----------|
| 4      | P0ポート割り込み        | EILV0[2:0] (D[2:0]/ITC_ELVOレジスタ)  | 0x4306   |
| 5      | P1ポート割り込み        | EILV1[2:0] (D[10:8]/ITC_ELVOレジスタ) | 0x4306   |
| 6      | ストップウォッチタイマ割り込み  | EILV2[2:0] (D[2:0]/ITC_ELV1レジスタ)  | 0x4308   |
| 7      | 計時タイマ割り込み        | EILV3[2:0] (D[10:8]/ITC_ELV1レジスタ) | 0x4308   |
| 8      | 8ビットOSC1タイマ割り込み  | EILV4[2:0] (D[2:0]/ITC_ELV2レジスタ)  | 0x430a   |
| 11     | PWM&キャプチャタイマ割り込み | EILV7[2:0] (D[10:8]/ITC_ELV3レジスタ) | 0x430c   |
| 12     | 8ビットタイマ割り込み      | ILV0[2:0] (D[2:0]/ITC_ILV0レジスタ)   | 0x430e   |
| 13     | 16ビットタイマCh.0割り込み | ILV1[2:0] (D[10:8]/ITC_ILV0レジスタ)  | 0x430e   |
| 14     | 16ビットタイマCh.1割り込み | ILV2[2:0] (D[2:0]/ITC_ILV1レジスタ)   | 0x4310   |
| 15     | 16ビットタイマCh.2割り込み | ILV3[2:0] (D[10:8]/ITC_ILV1レジスタ)  | 0x4310   |
| 16     | UART割り込み         | ILV4[2:0] (D[2:0]/ITC_ILV2レジスタ)   | 0x4312   |
| 17     | リモートコントローラ割り込み   | ILV5[2:0] (D[10:8]/ITC_ILV2レジスタ)  | 0x4312   |
| 18     | SPI割り込み          | ILV6[2:0] (D[2:0]/ITC_ILV3レジスタ)   | 0x4314   |
| 19     | I2C割り込み          | ILV7[2:0] (D[10:8]/ITC_ILV3レジスタ)  | 0x4314   |

割り込みレベルは、最高値が7、最低値が0です。

設定された割り込みレベルは、ITCが割り込み要求を出力する際に同時にS1C17コアに送られます。S1C17コアでは、この割り込みレベルを使用して、それ以降に発生する同一あるいはそれ以下のレベルの割り込みを禁止します(6.3.6節参照)。

イニシャルリセット時、割り込みレベルはすべて0に設定されます。割り込みレベルが0の場合、S1C17コアはその割り込み要求を受け付けません。

ITC内では、割り込みレベルを複数の割り込み要因が同時に発生した場合に使用します。

割り込みイネーブルビットにより許可されている複数の割り込みが同時に発生した場合、ITCはITC\_ELVx、ITC\_ILVxレジスタで設定されている最も高いレベルを持つ割り込みの要求をS1C17コアに送ります。

同一の割り込みレベルを持つ複数の割り込み要因が同時に発生した場合は、ベクタ番号の小さい割り込みが先に処理されます。

同時発生した他の割り込みは、より高い優先順位を持つ割り込みがすべてS1C17コアに受け付けられるまで保留されます。

ITCが割り込み要求信号をS1C17コアに出力中(S1C17コアに受け付けられる前に、より高い優先順位を持つ割り込み要因が発生した場合、ITCはベクタ番号および割り込みレベル信号を新たに発生した割り込みの設定内容に変更します。先に発生していた割り込みは保留されます。

### 6.3.5 割り込みのトリガモード

ITCにはパルストリガモードおよびレベルトリガモードの2つのトリガモードが用意されており、EIFTフラグをセットする割り込み要求をパルス信号またはレベル信号として受け付けることができます。

トリガモードはITC\_ELVxレジスタ(0x4306~0x4308)内のEITGxビットで選択できます。EITGxを1に設定するとレベルトリガモードが選択され、0(デフォルト)に設定するとパルストリガモードが選択されます。

注: S1C17001の場合、EITGxはすべて1(レベルトリガモード)に設定してください。

表6.3.5.1 トリガモード選択ビット

| ハードウェア割り込み       | トリガモード選択ビット              | レジスタアドレス |
|------------------|--------------------------|----------|
| P0ポート割り込み        | EITG0 (D4/ITC_ELV0レジスタ)  | 0x4306   |
| P1ポート割り込み        | EITG1 (D12/ITC_ELV0レジスタ) | 0x4306   |
| ストップウォッチタイマ割り込み  | EITG2 (D4/ITC_ELV1レジスタ)  | 0x4308   |
| 計時タイマ割り込み        | EITG3 (D12/ITC_ELV1レジスタ) | 0x4308   |
| 8ビットOSC1タイマ割り込み  | EITG4 (D4/ITC_ELV2レジスタ)  | 0x430a   |
| PWM&キャプチャタイマ割り込み | EITG7 (D12/ITC_ELV3レジスタ) | 0x430c   |

IIFTフラグをセットするモジュールはITCへの割り込み要求にパルス信号のみを出力します。したがって、トリガモード選択ビットは用意されていません。

#### パルストリガモード

パルストリガモードの場合、ITCは割り込み信号をシステムクロックの立ち上がりエッジでサンプリングします。パルスのHigh期間が検出されると、ITCは割り込みフラグ(IIFTx)を1にセットし、その割り込み信号のサンプリングを停止します。アプリケーションプログラム(割り込み処理ルーチン)が割り込みフラグ(IIFTx)を0にリセット後、ITCはこの割り込み信号のサンプリングを再開します。



図6.3.5.1 パルストリガモード

注: S1C17001の以下の割り込みはパルストリガモードです。割り込みが発生した際は、割り込み処理ルーチンの中で割り込みフラグIIFTxをリセット(1書き込み)してください。

- 8ビットタイマ割り込み
- 16ビットタイマCh.0割り込み
- 16ビットタイマCh.1割り込み
- 16ビットタイマCh.2割り込み
- UART割り込み
- リモートコントローラ割り込み
- SPI割り込み
- I<sup>2</sup>C割り込み

## レベルトリガモード

レベルトリガモードの場合、ITCは割り込み信号をシステムクロックの立ち上がりエッジで連続的にサンプリングします。割り込みフラグ(EIFTx)はHighレベルが検出されると1に設定され、その後Lowレベルが検出されると0にリセットされます。このモードでは1の書き込みで割り込みフラグ(EIFTx)をリセットすることはできません。したがって、割り込み発生源モジュールがS1C17コアに受け付けられるまで割り込み信号をHighに保持し、その後割り込み信号をクリアする必要があります。



割り込み発生源が割り込み信号をインアクティブに設定

図6.3.5.2 レベルトリガモード

注: S1C17001の以下の割り込みはレベルトリガモードです。割り込み処理ルーチンの中では、EIFTxではなく、周辺モジュール内の割り込みフラグをリセット(1書き込み)する必要があります。

- P0ポート割り込み
- P1ポート割り込み
- ストップウォッチタイマ割り込み
- 計時タイマ割り込み
- 8ビットOSC1タイマ割り込み
- PWM&キャプチャタイマ割り込み

リセットする割り込みフラグについては、各周辺モジュールの説明を参照してください。

### 6.3.6 S1C17コアの割り込み処理

S1C17コアに対するマスク可能な割り込みは、以下のすべての条件が成立している場合に発生します。

- ITEN(DO/ITC\_CTLレジスタ)が1に設定されている。

\* **ITEN:** ITC Enable Bit in the ITC Control (ITC\_CTL) Register (D0/0x4304)

- 発生した割り込み要因に対応する割り込みイネーブルビットが1にセットされている。
- PSR(S1C17コア内のプロセッサステータスレジスタ)のIE(割り込みイネーブル)ビットが1にセットされている。
- 発生した割り込み要因が、PSRのIL(割り込みレベル)に設定されている値よりも高い割り込みレベルに設定されている。
- NMIなど、他の優先順位の高い割り込み要因が発生していない。

割り込み要因が発生すると対応する割り込みフラグが1にセットされ、プログラムまたはハードウェア(レベルトリガモードに設定されている割り込みの場合)でリセットするまではその状態を保持します。したがって、割り込み要因の発生時点で上記の条件が満たされていない場合でも発生した割り込み要因がクリアされることはありません。上記の条件が満たされた時点で割り込みが発生します。

同時に複数のマスク可能な割り込み要因が発生した場合は、その中で最も高いレベルを持つ割り込み要因がその時点でのS1C17コアへの割り込み要求の対象となります。レベルの低い割り込みは、その後、上記の条件が成立するまで保留されます。

S1C17コアは毎サイクル、割り込み要求のサンプリングを行っています。S1C17コアは割り込み要求を受け付けるとその時点の命令の実行終了後、割り込み処理に移行します。

割り込み処理で実行される内容は以下のとおりです。

- PSRおよび現在のプログラムカウンタ(PC)値をスタックに退避
- PSRのIEビットを0にリセット(以降のマスク可能な割り込みを禁止)
- PSRのILを受け付けた割り込みのレベルにセット(NMIは割り込みレベルを変更しない)
- 発生した割り込み要因のベクタをPCにロードして割り込み処理ルーチンを実行

したがって、割り込みを受け付けると、(2)によって以降のマスク可能な割り込みは禁止されます。

割り込み処理ルーチン内でIEビットを1にセットすることで、多重割り込みにも対応できます。その場合、(3)によってILが変更されていますので、現在処理中の割り込みより高いレベルの割り込みのみが受け付けられます。

割り込み処理ルーチンをreti命令で終了すると、PSRが割り込み発生前の状態に戻ります。プログラムは割り込み発生時に実行していた命令の次の命令に分岐して処理を再開します。

## 6.4 NMI

S1C17001では、ウォッチドッグタイマでNMI(ノンマスカブル割り込み)を発生させることができます。NMIのベクタ番号は2で、ベクタアドレスはベクタテーブル先頭アドレス + 8バイトに設定されています。この割り込みは他の割り込み要因に優先して、無条件にS1C17コアに受け付けられます。

NMIを発生させる方法については、“17 ウォッチドッグタイマ(WDT)”を参照してください。

## 6.5 ソフトウェア割り込み

S1C17コアのint *imm5*またはint1 *imm5, imm3*命令を使用することによって、ソフトウェアで任意の割り込みを発生させることができます。オペランドの即値*imm5*でベクターテーブルのベクタ番号(0~31)を指定します。int1命令では、*imm3*でPSRのILフィールドに設定する割り込みレベル(0~7)を指定することもできます。

プロセッサの割り込み処理の内容は、ハードウェアによる割り込み発生時と同様です。

## 6.6 割り込み要因によるHALT, SLEEPモードの解除

HALT, SLEEPモードは割り込み要因によって解除され、CPUが起動します。

HALT, SLEEPモード時の各クロックの状態によって、CPUを起動可能な割り込み要因とCPU起動後のプログラム実行内容(割り込み処理ルーチンに分岐するか否か)が異なります。

詳細は、Appendix Bの“B.1 クロック制御によるパワーセーブ”を参照してください。

## 6.7 制御レジスタ詳細

表6.7.1 ITCレジスター一覧

| アドレス   | レジスタ名    |                                           | 機能                                  |
|--------|----------|-------------------------------------------|-------------------------------------|
| 0x4300 | ITC_IFLG | Interrupt Flag Register                   | 割り込み発生状態の表示/リセット                    |
| 0x4302 | ITC_EN   | Interrupt Enable Register                 | 各マスク可能割り込みの許可/禁止                    |
| 0x4304 | ITC_CTL  | ITC Control Register                      | ITC動作の許可/禁止                         |
| 0x4306 | ITC_ELV0 | External Interrupt Level Setup Register 0 | P0、P1ポート割り込みレベルとトリガモードの設定           |
| 0x4308 | ITC_ELV1 | External Interrupt Level Setup Register 1 | ストップウォッチタイマ、計時タイマ割り込みレベルとトリガモードの設定  |
| 0x430a | ITC_ELV2 | External Interrupt Level Setup Register 2 | 8ビットOSC1タイマ割り込みレベルとトリガモードの設定        |
| 0x430c | ITC_ELV3 | External Interrupt Level Setup Register 3 | PWM&キャプチャタイマ割り込みレベルとトリガモードの設定       |
| 0x430e | ITC_ILV0 | Internal Interrupt Level Setup Register 0 | 8ビットタイマ、16ビットタイマCh.0割り込みレベルの設定      |
| 0x4310 | ITC_ILV1 | Internal Interrupt Level Setup Register 1 | 16ビットタイマCh.1、16ビットタイマCh.2割り込みレベルの設定 |
| 0x4312 | ITC_ILV2 | Internal Interrupt Level Setup Register 2 | UART、リモートコントローラ割り込みレベルの設定           |
| 0x4314 | ITC_ILV3 | Internal Interrupt Level Setup Register 3 | SPI、I <sup>2</sup> C割り込みレベルの設定      |

以下、ITCのレジスタを個々に説明します。これらはすべて16ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

## 0x4300: Interrupt Flag Register (ITC\_IFLG)

| Register name                      | Address          | Bit | Name  | Function                         | Setting                       |                                   | Init. | R/W | Remarks                                            |
|------------------------------------|------------------|-----|-------|----------------------------------|-------------------------------|-----------------------------------|-------|-----|----------------------------------------------------|
| Interrupt Flag Register (ITC_IFLG) | 0x4300 (16 bits) | D15 | IIFT7 | I <sup>2</sup> C interrupt flag  | 1 Cause of interrupt occurred | 0 Cause of interrupt not occurred | 0     | R/W | Reset by writing 1.                                |
|                                    |                  | D14 | IIFT6 | SPI interrupt flag               |                               |                                   | 0     | R/W |                                                    |
|                                    |                  | D13 | IIFT5 | Remote controller interrupt flag |                               |                                   | 0     | R/W |                                                    |
|                                    |                  | D12 | IIFT4 | UART interrupt flag              |                               |                                   | 0     | R/W |                                                    |
|                                    |                  | D11 | IIFT3 | 16-bit timer Ch.2 interrupt flag |                               |                                   | 0     | R/W |                                                    |
|                                    |                  | D10 | IIFT2 | 16-bit timer Ch.1 interrupt flag |                               |                                   | 0     | R/W |                                                    |
|                                    |                  | D9  | IIFT1 | 16-bit timer Ch.0 interrupt flag |                               |                                   | 0     | R/W |                                                    |
|                                    |                  | D8  | IIFT0 | 8-bit timer interrupt flag       |                               |                                   | 0     | R/W |                                                    |
|                                    |                  | D7  | EIFT7 | PWM&capture timer interrupt flag | 1 Cause of interrupt occurred | 0 Cause of interrupt not occurred | 0     | R/W | Reset by writing 1 in pulse trigger mode.          |
|                                    |                  | D6  | EIFT6 | reserved                         |                               |                                   | 0     | R/W |                                                    |
|                                    |                  | D5  | EIFT5 | reserved                         |                               |                                   | 0     | R/W | Cannot be reset by software in level trigger mode. |
|                                    |                  | D4  | EIFT4 | 8-bit OSC1 timer interrupt flag  |                               |                                   | 0     | R/W |                                                    |
|                                    |                  | D3  | EIFT3 | Clock timer interrupt flag       |                               |                                   | 0     | R/W |                                                    |
|                                    |                  | D2  | EIFT2 | Stopwatch timer interrupt flag   |                               |                                   | 0     | R/W |                                                    |
|                                    |                  | D1  | EIFT1 | P1 port interrupt flag           |                               |                                   | 0     | R/W |                                                    |
|                                    |                  | D0  | EIFT0 | P0 port interrupt flag           |                               |                                   | 0     | R/W |                                                    |

### D[15:8] IIFT[7:0]: Interrupt Flags (for Pulse Trigger)

割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり
- 0(R): 割り込み要因なし(デフォルト)
- 1(W): フラグをリセット
- 0(W): 無効

割り込みフラグは各周辺モジュールで割り込み要因が発生すると1にセットされます。

このとき、以下の条件が成立していれば、S1C17コアに対し割り込みが発生します。

1. 対応する割り込みイネーブルビットが1に設定されている。
2. 他の優先レベルの高い割り込み要求が発生していない。
3. PSRのIEビットが1(割り込み許可)に設定されている。
4. 対応する割り込みレベル設定ビットがS1C17コアの割り込みレベル(IL)より高いレベルに設定されている。

割り込みフラグは割り込みイネーブルビットや割り込みレベル設定ビットの状態にかかわらず、割り込み要因の発生により1にセットされます。

割り込み発生後、次の割り込みを受け付けるには、割り込みフラグのリセットとPSRの再設定(IEビットを1にセットするか、reti命令を実行する)が必要です。

1にセットされた割り込み要因フラグは、1の書き込みによってリセットされます。

表6.7.2 ハードウェア割り込み要因と割り込みフラグ

| 割り込みフラグ     | ハードウェア割り込み要因                                        |
|-------------|-----------------------------------------------------|
| IIFT0 (D8)  | 8ビットタイマ割り込み: タイマアンダーフロー                             |
| IIFT1 (D9)  | 16ビットタイマCh.0割り込み: タイマアンダーフロー                        |
| IIFT2 (D10) | 16ビットタイマCh.1割り込み: タイマアンダーフロー                        |
| IIFT3 (D11) | 16ビットタイマCh.2割り込み: タイマアンダーフロー                        |
| IIFT4 (D12) | UART割り込み: 送信バッファエンブティ / 受信バッファフル / 受信エラー            |
| IIFT5 (D13) | リモートコントローラ割り込み: データ長カウンタアンダーフロー / 入力立ち上がり / 入力立ち下がり |
| IIFT6 (D14) | SPI割り込み: 送信バッファエンブティ / 受信バッファフル                     |
| IIFT7 (D15) | I <sup>2</sup> C割り込み: 送信バッファエンブティ / 受信バッファフル        |

**D[7:0] EIFT[7:0]: Interrupt Flags (for Level Trigger)**

割り込み要因の発生状態を示す割り込みフラグです。

1(R): 割り込み要因あり

0(R): 割り込み要因なし(デフォルト)

1(W): 無効

0(W): 無効

IIFT[7:0]の説明を参照してください。

ただし、これらの割り込みはITC\_ELVxレジスタ(0x4306~0x430c)でレベルトリガモードに設定する必要があります。そのため、本ビットへの1書き込みではリセットされません。割り込みフラグをリセットするには、周辺モジュール内の割り込みフラグに1を書き込みます。

表6.7.3 ハードウェア割り込み要因と割り込みフラグ

| 割り込みフラグ    | ハードウェア割り込み要因                     |
|------------|----------------------------------|
| EIFT0 (D0) | P0ポート割り込み: P00~P07ポート入力          |
| EIFT1 (D1) | P1ポート割り込み: P10~P17ポート入力          |
| EIFT2 (D2) | トップウォッチタイマ割り込み: 100Hz/10Hz/1Hz信号 |
| EIFT3 (D3) | 計時タイマ割り込み: 32Hz/8Hz/2Hz/1Hz信号    |
| EIFT4 (D4) | 8ビットOSC1タイマ割り込み: コンペアマッチ         |
| EIFT7 (D7) | PWM&キャプチャタイマ割り込み: コンペアA/コンペアBマッチ |

注: マスク可能な割り込み要求がS1C17コアに受け付けられ、割り込み処理ルーチンに分岐しても、割り込みフラグはリセットされません。プログラムで割り込みフラグをリセットせずにreti命令で割り込み処理ルーチンからリターンすると、再度同一の割り込みが発生しますので注意してください。レベルトリガに設定された割り込みフラグは周辺モジュール内の制御レジスタでリセットする必要があります。

## 0x4302: Interrupt Enable Register (ITC\_EN)

| Register name                            | Address             | Bit | Name  | Function                           | Setting |        | Init. | R/W | Remarks |
|------------------------------------------|---------------------|-----|-------|------------------------------------|---------|--------|-------|-----|---------|
| Interrupt<br>Enable Register<br>(ITC_EN) | 0x4302<br>(16 bits) | D15 | IIEN7 | I <sup>2</sup> C interrupt enable  | 1       | Enable | 0     | R/W |         |
|                                          |                     | D14 | IIEN6 | SPI interrupt enable               |         |        | 0     | R/W |         |
|                                          |                     | D13 | IIEN5 | Remote controller interrupt enable |         |        | 0     | R/W |         |
|                                          |                     | D12 | IIEN4 | UART interrupt enable              |         |        | 0     | R/W |         |
|                                          |                     | D11 | IIEN3 | 16-bit timer Ch.2 interrupt enable |         |        | 0     | R/W |         |
|                                          |                     | D10 | IIEN2 | 16-bit timer Ch.1 interrupt enable |         |        | 0     | R/W |         |
|                                          |                     | D9  | IIEN1 | 16-bit timer Ch.0 interrupt enable |         |        | 0     | R/W |         |
|                                          |                     | D8  | IIENO | 8-bit timer interrupt enable       |         |        | 0     | R/W |         |
|                                          |                     | D7  | EIEN7 | PWM&capture timer interrupt enable |         |        | 0     | R/W |         |
|                                          |                     | D6  | EIEN6 | reserved                           |         |        | 0     | R/W |         |
|                                          |                     | D5  | EIEN5 | reserved                           |         |        | 0     | R/W |         |
|                                          |                     | D4  | EIEN4 | 8-bit OSC1 timer interrupt enable  |         |        | 0     | R/W |         |
|                                          |                     | D3  | EIEN3 | Clock timer interrupt enable       |         |        | 0     | R/W |         |
|                                          |                     | D2  | EIEN2 | Stopwatch timer interrupt enable   |         |        | 0     | R/W |         |
|                                          |                     | D1  | EIEN1 | P1 port interrupt enable           |         |        | 0     | R/W |         |
|                                          |                     | D0  | EIENO | P0 port interrupt enable           |         |        | 0     | R/W |         |

### D[15:0] IIEN[7:0], EIEN[7:0]: Interrupt Enable Bits

これらのビットは、割り込みの発生を許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

割り込みイネーブルビットを1に設定すると対応する割り込みが許可され、0に設定すると割り込みが禁止されます。

割り込み禁止に設定した場合でも、対応する割り込みをスタンバイモードの解除に使用することができます。

表6.7.4 ハードウェア割り込み要因と割り込みイネーブルビット

| 割り込み<br>イネーブルビット | ハードウェア割り込み要因                                         |
|------------------|------------------------------------------------------|
| EIENO (D0)       | P0ポート割り込み: P00～P07ポート入力                              |
| EIEN1 (D1)       | P1ポート割り込み: P10～P17ポート入力                              |
| EIEN2 (D2)       | ストップウォッチタイマ割り込み: 100Hz/10Hz/1Hz信号                    |
| EIEN3 (D3)       | 計時タイマ割り込み: 32Hz/8Hz/2Hz/1Hz信号                        |
| EIEN4 (D4)       | 8ビットOSC1タイマ割り込み: コンペアマッチ                             |
| EIEN7 (D7)       | PWM&キャプチャタイマ割り込み: コンペアA/コンペアBマッチ                     |
| IIENO (D8)       | 8ビットタイマ割り込み: タイマアンダーフロー                              |
| IIEN1 (D9)       | 16ビットタイマCh.0割り込み: タイマアンダーフロー                         |
| IIEN2 (D10)      | 16ビットタイマCh.1割り込み: タイマアンダーフロー                         |
| IIEN3 (D11)      | 16ビットタイマCh.2割り込み: タイマアンダーフロー                         |
| IIEN4 (D12)      | UART割り込み: 送信バッファエンブティ /受信バッファフル/受信エラー                |
| IIEN5 (D13)      | リモートコントローラ割り込み: データ長カウンタアンダーフロー /入力立ち上がり<br>/入力立ち下がり |
| IIEN6 (D14)      | SPI割り込み: 送信バッファエンブティ /受信バッファフル                       |
| IIEN7 (D15)      | I <sup>2</sup> C割り込み: 送信バッファエンブティ /受信バッファフル          |

**0x4304: ITC Control Register (ITC\_CTL)**

| Register name                  | Address          | Bit   | Name | Function | Setting | Init. | R/W | Remarks            |
|--------------------------------|------------------|-------|------|----------|---------|-------|-----|--------------------|
| ITC Control Register (ITC_CTL) | 0x4304 (16 bits) | D15-1 | —    | reserved | —       | —     | R/W | 0 when being read. |

**D[15:1] Reserved****D0 ITEN: ITC Enable Bit**

ITCによる割り込みの制御を許可します。

1 (R/W): 許可

0 (R/W): 禁止(デフォルト)

ITCを使用する前に、1に設定してください。

## 0x4306: External Interrupt Level Setup Register 0 (ITC\_ELVO)

| Register name                                                 | Address             | Bit    | Name       | Function                  | Setting               | Init. | R/W | Remarks              |
|---------------------------------------------------------------|---------------------|--------|------------|---------------------------|-----------------------|-------|-----|----------------------|
| External<br>Interrupt Level<br>Setup Register 0<br>(ITC_ELVO) | 0x4306<br>(16 bits) | D15~13 | —          | reserved                  | —                     | —     | —   | 0 when being read.   |
|                                                               |                     | D12    | EITG1      | P1 interrupt trigger mode | 1   Level   0   Pulse | 0     | R/W | Be sure to set to 1. |
|                                                               |                     | D11    | —          | reserved                  | —                     | —     | —   | 0 when being read.   |
|                                                               |                     | D10~8  | EILV1[2:0] | P1 interrupt level        | 0 to 7                | 0x0   | R/W |                      |
|                                                               |                     | D7~5   | —          | reserved                  | —                     | —     | —   | 0 when being read.   |
|                                                               |                     | D4     | EITG0      | P0 interrupt trigger mode | 1   Level   0   Pulse | 0     | R/W | Be sure to set to 1. |
|                                                               |                     | D3     | —          | reserved                  | —                     | —     | —   | 0 when being read.   |
|                                                               |                     | D2~0   | EILV0[2:0] | P0 interrupt level        | 0 to 7                | 0x0   | R/W |                      |

### D[15:13] Reserved

#### D12 EITG1: P1 Port Interrupt Trigger Mode Select Bit

P1ポート割り込みのトリガモードを選択します。S1C17001では1に設定してください。

1(R/W): レベルトリガモード

0(R/W): パルストリガモード(デフォルト)

パルストリガモードの場合、ITCは割り込み信号をシステムクロックの立ち上がりエッジでサンプリングします。パルスのHigh期間が検出されると、ITCは割り込みフラグ(EIFTx)を1にセットし、その割り込み信号のサンプリングを停止します。アプリケーションプログラム(割り込み処理ルーチン)が割り込みフラグ(EIFTx)を0にリセット後、ITCはこの割り込み信号のサンプリングを再開します。

レベルトリガモードの場合、ITCは割り込み信号をシステムクロックの立ち上がりエッジで連続的にサンプリングします。割り込みフラグ(EIFTx)はHighレベルが検出されると1に設定され、その後Lowレベルが検出されると0にリセットされます。このモードでは1の書き込みで割り込みフラグ(EIFTx)をリセットすることはできません。したがって、割り込み発生源モジュールが、S1C17コアに受け付けられるまで割り込み信号をHighに保持し、その後割り込み信号をクリアする必要があります。

### D11 Reserved

#### D[10:8] EILV1[2:0]: P1 Port Interrupt Level Bits

P1ポート割り込みの割り込みレベル(0~7)を設定します。(デフォルト: 0)

S1C17コアは、PSRのILの値より低いレベルに設定された割り込みを受け付けません。

ITC内では、割り込みレベルを複数の割り込み要因が同時に発生した場合に使用します。

割り込みイネーブルビットにより許可されている複数の割り込みが同時に発生した場合、ITCはITC\_ELVx、ITC\_ILVxレジスタ(0x4306~0x4314)で設定されている最も高いレベルを持つ割り込みの要求をS1C17コアに送ります。同一の割り込みレベルを持つ複数の割り込み要因が同時に発生した場合は、ベクタ番号の小さい割り込みが先に処理されます。

同時発生したその他の割り込みは、より高い優先順位を持つ割り込みがすべてS1C17コアに受け付けられるまで保留されます。

ITCが割り込み要求信号をS1C17コアに出力中(S1C17コアに受け付けられる前)に、より高い優先順位を持つ割り込み要因が発生した場合、ITCはベクタ番号および割り込みレベル信号を新たに発生した割り込みの設定内容に変更します。先に発生していた割り込みは保留されます。

### D[7:5] Reserved

#### D4 EITG0: P0 Port Interrupt Trigger Mode Select Bit

P0ポート割り込みのトリガモードを選択します。S1C17001では1に設定してください。

1(R/W): レベルトリガモード

0(R/W): パルストリガモード(デフォルト)

EITG1(D12)の説明を参照してください。

### D3 Reserved

#### D[2:0] EILV0[2:0]: P0 Port Interrupt Level Bits

P0ポート割り込みの割り込みレベル(0~7)を設定します。(デフォルト: 0)

EILV1[2:0](D[10:8])の説明を参照してください。

**0x4308: External Interrupt Level Setup Register 1 (ITC\_ELV1)**

| Register name                                        | Address | Bit    | Name       | Function                   | Setting               | Init. | R/W | Remarks              |
|------------------------------------------------------|---------|--------|------------|----------------------------|-----------------------|-------|-----|----------------------|
| External Interrupt Level Setup Register 1 (ITC_ELV1) | 0x4308  | D15-13 | —          | reserved                   | —                     | —     | —   | 0 when being read.   |
|                                                      |         | D12    | EITG3      | CT interrupt trigger mode  | 1   Level   0   Pulse | 0     | R/W | Be sure to set to 1. |
|                                                      |         | D11    | —          | reserved                   | —                     | —     | —   | 0 when being read.   |
|                                                      |         | D10-8  | EILV3[2:0] | CT interrupt level         | 0 to 7                | 0x0   | R/W |                      |
|                                                      |         | D7-5   | —          | reserved                   | —                     | —     | —   | 0 when being read.   |
|                                                      |         | D4     | EITG2      | SWT interrupt trigger mode | 1   Level   0   Pulse | 0     | R/W | Be sure to set to 1. |
|                                                      |         | D3     | —          | reserved                   | —                     | —     | —   | 0 when being read.   |
|                                                      |         | D2-0   | EILV2[2:0] | SWT interrupt level        | 0 to 7                | 0x0   | R/W |                      |

**D[15:13] Reserved****D12 EITG3: Clock Timer Interrupt Trigger Mode Select Bit**

計時タイマ割り込みのトリガモードを選択します。[S1C17001](#)では1に設定してください。

1(R/W): レベルトリガモード

0(R/W): パルストリガモード(デフォルト)

ITC\_ELV0レジスタ(0x4306)のEITG1(D12)の説明を参照してください。

**D11 Reserved****D[10:8] EILV3[2:0]: Clock Timer Interrupt Level Bits**

計時タイマ割り込みの割り込みレベル(0~7)を設定します。(デフォルト:0)

ITC\_ELV0レジスタ(0x4306)のEILV1[2:0](D[10:8])の説明を参照してください。

**D[7:5] Reserved****D4 EITG2: Stopwatch Timer Interrupt Trigger Mode Select Bit**

ストップウォッチタイマ割り込みのトリガモードを選択します。[S1C17001](#)では1に設定してください。

1(R/W): レベルトリガモード

0(R/W): パルストリガモード(デフォルト)

ITC\_ELV0レジスタ(0x4306)のEITG1(D12)の説明を参照してください。

**D3 Reserved****D[2:0] EILV2[2:0]: Stopwatch Timer Interrupt Level Bits**

ストップウォッチタイマ割り込みの割り込みレベル(0~7)を設定します。(デフォルト:0)

ITC\_ELV0レジスタ(0x4306)のEILV1[2:0](D[10:8])の説明を参照してください。

**0x430a: External Interrupt Level Setup Register 2 (ITC\_ELV2)**

| Register name                                                 | Address             | Bit   | Name       | Function                      | Setting               | Init. | R/W | Remarks              |
|---------------------------------------------------------------|---------------------|-------|------------|-------------------------------|-----------------------|-------|-----|----------------------|
| External<br>Interrupt Level<br>Setup Register 2<br>(ITC_ELV2) | 0x430a<br>(16 bits) | D15-5 | —          | reserved                      | —                     | —     | —   | 0 when being read.   |
|                                                               |                     | D4    | EITG4      | T8OSC1 interrupt trigger mode | 1   Level   0   Pulse | 0     | R/W | Be sure to set to 1. |
|                                                               |                     | D3    | —          | reserved                      | —                     | —     | —   | 0 when being read.   |
|                                                               |                     | D2-0  | EILV4[2:0] | T8OSC1 interrupt level        | 0 to 7                | 0x0   | R/W |                      |

**D[15:5] Reserved****D4 EITG4: 8-bit OSC1 Timer Interrupt Trigger Mode Select Bit**

8ビットOSC1タイマ割り込みのトリガモードを選択します。S1C17001では1に設定してください。

1(R/W): レベルトリガモード

0(R/W): パルストリガモード(デフォルト)

ITC\_ELV0レジスタ(0x4306)のEITG1(D12)の説明を参照してください。

**D3 Reserved****D[2:0] EILV4[2:0]: 8-bit OSC1 Timer Interrupt Level Bits**

8ビットOSC1タイマ割り込みの割り込みレベル(0~7)を設定します。(デフォルト: 0)

ITC\_ELV0レジスタ(0x4306)のEILV1[2:0](D[10:8])の説明を参照してください。

**0x430c: External Interrupt Level Setup Register 3 (ITC\_ELV3)**

| Register name                                        | Address | Bit    | Name       | Function                    | Setting               | Init. | R/W | Remarks              |
|------------------------------------------------------|---------|--------|------------|-----------------------------|-----------------------|-------|-----|----------------------|
| External Interrupt Level Setup Register 3 (ITC_ELV3) | 0x430c  | D15-13 | —          | reserved                    | —                     | —     | —   | 0 when being read.   |
|                                                      |         | D12    | EITG7      | T16E interrupt trigger mode | 1   Level   0   Pulse | 0     | R/W | Be sure to set to 1. |
|                                                      |         | D11    | —          | reserved                    | —                     | —     | —   | 0 when being read.   |
|                                                      |         | D10-8  | EILV7[2:0] | T16E interrupt level        | 0 to 7                | 0x0   | R/W |                      |
|                                                      |         | D7-0   | —          | reserved                    | —                     | —     | —   | 0 when being read.   |

**D[15:13] Reserved****D12 EITG7: PWM & Capture Timer Interrupt Trigger Mode Select Bit**

PWM&キャプチャタイム割り込みのトリガモードを選択します。S1C17001では1に設定してください。

1(R/W): レベルトリガモード

0(R/W): パルストリガモード(デフォルト)

ITC\_ELV0レジスタ(0x4306)のEITG1(D12)の説明を参照してください。

**D11 Reserved****D[10:8] EILV7[2:0]: PWM & Capture Timer Interrupt Level Bits**

PWM&キャプチャタイム割り込みの割り込みレベル(0~7)を設定します。(デフォルト: 0)

ITC\_ELV0レジスタ(0x4306)のEILV1[2:0](D[10:8])の説明を参照してください。

**D[7:0] Reserved**

## 0x430e: Internal Interrupt Level Setup Register 0 (ITC\_ILV0)

| Register name                                                 | Address | Bit    | Name       | Function                 | Setting | Init. | R/W | Remarks            |
|---------------------------------------------------------------|---------|--------|------------|--------------------------|---------|-------|-----|--------------------|
| Internal<br>Interrupt Level<br>Setup Register 0<br>(ITC_ILV0) | 0x430e  | D15–11 | –          | reserved                 | –       | –     | –   | 0 when being read. |
|                                                               |         | D10–8  | IILV1[2:0] | T16 Ch.0 interrupt level | 0 to 7  | 0x0   | R/W |                    |
|                                                               |         | D7–3   | –          | reserved                 | –       | –     | –   | 0 when being read. |
|                                                               |         | D2–0   | IILV0[2:0] | T8 interrupt level       | 0 to 7  | 0x0   | R/W |                    |

### D[15:11] Reserved

### D[10:8] IILV1[2:0]: 16-bit Timer Ch.0 Interrupt Level Bits

16ビットタイマCh.0割り込みの割り込みレベル(0～7)を設定します。(デフォルト: 0)

S1C17コアは、PSRのILの値より低いレベルに設定された割り込みを受け付けません。

ITC内では、割り込みレベルを複数の割り込み要因が同時に発生した場合に使用します。

割り込みイネーブルビットにより許可されている複数の割り込みが同時に発生した場合、ITCはITC\_ELVx、ITCILVxレジスタ(0x4306～0x4314)で設定されている最も高いレベルを持つ割り込みの要求をS1C17コアに送ります。

同一の割り込みレベルを持つ複数の割り込み要因が同時に発生した場合は、ベクタ番号の小さい割り込みが先に処理されます。

同時発生したその他の割り込みは、より高い優先順位を持つ割り込みがすべてS1C17コアに受け付けられるまで保留されます。

ITCが割り込み要求信号をS1C17コアに出力中(S1C17コアに受け付けられる前)に、より高い優先順位を持つ割り込み要因が発生した場合、ITCはベクタ番号および割り込みレベル信号を新たに発生した割り込みの設定内容に変更します。先に発生していた割り込みは保留されます。

### D[7:3] Reserved

### D[2:0] IILV0[2:0]: 8-bit Timer Interrupt Level Bits

8ビットタイマ割り込みの割り込みレベル(0～7)を設定します。(デフォルト: 0)

IILV1[2:0](D[10:8])の説明を参照してください。

**0x4310: Internal Interrupt Level Setup Register 1 (ITC\_ILV1)**

| Register name                                                 | Address | Bit    | Name       | Function                 | Setting | Init. | R/W | Remarks            |
|---------------------------------------------------------------|---------|--------|------------|--------------------------|---------|-------|-----|--------------------|
| Internal<br>Interrupt Level<br>Setup Register 1<br>(ITC_ILV1) | 0x4310  | D15-11 | —          | reserved                 | —       | —     | —   | 0 when being read. |
|                                                               |         | D10-8  | IILV3[2:0] | T16 Ch.2 interrupt level | 0 to 7  | 0x0   | R/W |                    |
|                                                               |         | D7-3   | —          | reserved                 | —       | —     | —   | 0 when being read. |
|                                                               |         | D2-0   | IILV2[2:0] | T16 Ch.1 interrupt level | 0 to 7  | 0x0   | R/W |                    |

**D[15:11] Reserved****D[10:8] IILV3[2:0]: 16-bit Timer Ch.2 Interrupt Level Bits**

16ビットタイマCh.2割り込みの割り込みレベル(0～7)を設定します。(デフォルト: 0)  
ITC\_ILV0レジスタ(0x430e)のIILV1[2:0](D[10:8])の説明を参照してください。

**D[7:3] Reserved****D[2:0] IILV2[2:0]: 16-bit Timer Ch.1 Interrupt Level Bits**

16ビットタイマCh.1割り込みの割り込みレベル(0～7)を設定します。(デフォルト: 0)  
ITC\_ILV0レジスタ(0x430e)のIILV1[2:0](D[10:8])の説明を参照してください。

## 0x4312: Internal Interrupt Level Setup Register 2 (ITC\_ILV2)

| Register name                                                 | Address | Bit    | Name       | Function             | Setting | Init. | R/W | Remarks            |
|---------------------------------------------------------------|---------|--------|------------|----------------------|---------|-------|-----|--------------------|
| Internal<br>Interrupt Level<br>Setup Register 2<br>(ITC_ILV2) | 0x4312  | D15–11 | –          | reserved             | –       | –     | –   | 0 when being read. |
|                                                               |         | D10–8  | IILV5[2:0] | REMC interrupt level | 0 to 7  | 0x0   | R/W |                    |
|                                                               |         | D7–3   | –          | reserved             | –       | –     | –   | 0 when being read. |
|                                                               |         | D2–0   | IILV4[2:0] | UART interrupt level | 0 to 7  | 0x0   | R/W |                    |

### D[15:11] Reserved

### D[10:8] IILV5[2:0]: Remote Controller Interrupt Level Bits

リモートコントローラ割り込みの割り込みレベル(0～7)を設定します。(デフォルト: 0)  
ITC\_ILV0レジスタ(0x430e)のIILV1[2:0](D[10:8])の説明を参照してください。

### D[7:3] Reserved

### D[2:0] IILV4[2:0]: UART Interrupt Level Bits

UART割り込みの割り込みレベル(0～7)を設定します。(デフォルト: 0)  
ITC\_ILV0レジスタ(0x430e)のIILV1[2:0](D[10:8])の説明を参照してください。

**0x4314: Internal Interrupt Level Setup Register 3 (ITC\_ILV3)**

| Register name                                                 | Address | Bit    | Name       | Function                         | Setting | Init. | R/W | Remarks            |
|---------------------------------------------------------------|---------|--------|------------|----------------------------------|---------|-------|-----|--------------------|
| Internal<br>Interrupt Level<br>Setup Register 3<br>(ITC_ILV3) | 0x4314  | D15-11 | —          | reserved                         | —       | —     | —   | 0 when being read. |
|                                                               |         | D10-8  | IILV7[2:0] | I <sup>2</sup> C interrupt level | 0 to 7  | 0x0   | R/W |                    |
|                                                               |         | D7-3   | —          | reserved                         | —       | —     | —   | 0 when being read. |
|                                                               |         | D2-0   | IILV6[2:0] | SPI interrupt level              | 0 to 7  | 0x0   | R/W |                    |

**D[15:11] Reserved****D[10:8] IILV7[2:0]: I<sup>2</sup>C Interrupt Level Bits**

I<sup>2</sup>C割り込みの割り込みレベル(0～7)を設定します。(デフォルト:0)

ITC\_ILV0レジスタ(0x430e)のIILV1[2:0](D[10:8])の説明を参照してください。

**D[7:3] Reserved****D[2:0] IILV6[2:0]: SPI Interrupt Level Bits**

SPI割り込みの割り込みレベル(0～7)を設定します。(デフォルト:0)

ITC\_ILV0レジスタ(0x430e)のIILV1[2:0](D[10:8])の説明を参照してください。

## 6.8 注意事項

- 割り込み発生後は、同じ要因による割り込みの再発生を防止するため、割り込みを許可、PSRを再設定またはreti命令を実行する前に必ず割り込みフラグをリセットしてください。
- S1C17001の以下の割り込みはレベルトリガモードです。
  - P0ポート割り込み
  - P1ポート割り込み
  - ストップウォッチタイマ割り込み
  - 計時タイマ割り込み
  - 8ビットOSC1タイマ割り込み
  - PWM&キャプチャタイマ割り込み

ITC\_ELVxレジスタ(0x4306～0x430c)内のEITG $x$ ビットはすべて1(レベルトリガモード)に設定してください。

また、割り込み処理ルーチンの中では、EIFT $x$ ではなく、周辺モジュール内の割り込みフラグをリセット(1書き込み)する必要があります。リセットする割り込みフラグについては、各周辺モジュールの説明を参照してください。

このページはブランクです。

# 7 発振回路(OSC)

## 7.1 OSCモジュールの構成

S1C17001は2種類の発振回路(OSC3およびOSC1)を内蔵しています。OSC3発振回路はS1C17コアや周辺回路を高速動作させるためのメインクロック(Max. 8.2MHz)を、OSC1発振回路はタイマ動作や低電力動作用のサブクロック(Typ. 32.768kHz)を発生します。

イニシャルリセット時、システムクロックにはOSC3クロックが選択されます。

発振回路のOn/Offとシステムクロックの切り換え(OSC3↔OSC1)はソフトウェアによって制御できます。

また、外部へのクロック出力も可能となっています。

図7.1.1にクロックシステムとOSCモジュールの構成を示します。



図7.1.1 OSCモジュールの構成

処理に合わせてクロックを制御し、さらにスタンバイモードを組み合わせることで消費電流を抑えることができます。消費電流を抑える手法については、“Appendix B パワーセーブ”を参照してください。

## 7.2 OSC3発振回路

OSC3発振回路はS1C17コアと周辺回路を高速動作させるメインクロック(Max. 8.2MHz)を発生します。発振回路の種類は水晶またはセラミック発振です。外部クロック入力にも対応しています。図7.2.1にOSC3発振回路の構造を示します。



図7.2.1 OSC3発振回路

水晶またはセラミック発振回路として使用する場合は、OSC3端子とOSC4端子間に水晶振動子(X'tal3)またはセラミック振動子(Ceramic)と帰還抵抗( $R_f$ )を、OSC3、OSC4端子とVss間にキャパシタを2個( $C_{G3}$ 、 $C_{D3}$ )接続します。また、必要に応じてドレン抵抗( $R_d$ )をOSC4端子と $C_{D3}$ の間に接続してください。外部クロックを使用する場合はOSC4端子を開放し、LV<sub>DD</sub>レベルでデューティ比が50%のクロックをOSC3端子に入力してください。

### OSC3発振のOn/Off

OSC3発振回路はOSC3EN(D0/OSC\_CTLレジスタ)を0に設定すると発振を停止し、1に設定すると発振を開始します。OSC3発振回路はSLEEPモードでも発振を停止します。

\* **OSC3EN: OSC3 Enable Bit in the Oscillation Control (OSC\_CTL) Register (D0/0x5061)**

イニシャルリセット時はOSC3ENが1に設定され、OSC3発振回路はOnします。また、OSC3クロックがシステムクロックとなりますので、S1C17コアはOSC3クロックで動作を開始します。

## OSC3発振開始時の安定待ち時間

電源投入時、SLEEPからの起床時、ソフトウェアでOSC3発振回路をOnにした場合など、OSC3発振開始時の不安定なクロックによる誤動作を防止するため、OSC3発振回路には発振安定待ちタイムが設けられています。このタイムで設定した時間が経過するまで、OSC3クロックはシステムに供給されません。

この発振安定待ち時間はOSC3WT[1:0](D[5:4]/OSC\_CTLレジスタ)で4種類から選択します。

\* **OSC3WT[1:0]**: OSC3 Wait Cycle Select Bits in the Oscillation Control (OSC\_CTL) Register (D[5:4]/0x5061)

表7.2.2 OSC3発振安定待ち時間の設定

| OSC3WT[1:0] | 発振安定待ち時間 |
|-------------|----------|
| 0x3         | 128サイクル  |
| 0x2         | 256サイクル  |
| 0x1         | 512サイクル  |
| 0x0         | 1024サイクル |

(デフォルト: 0x0)

イニシャルリセット時は1024サイクル(OSC3クロック)に設定されますので、リセット解除後はこの時間が経過するまでCPUは動作を開始しません。

注: OSC3発振開始時間は振動子、外付け部品によって変動します。発振安定待ち時間は余裕を持って設定してください。“24 電気的特性”に発振開始時間の一例を示しますので参考にしてください。

## 7.3 OSC1発振回路

OSC1発振回路は32.768kHz(Typ.)のサブクロックを発生します。

通常、OSC1クロックはタイマ(計時タイマ、ストップウォッチタイマ、ウォッチドッグタイマ、8ビットOSC1タイマ)の動作クロックとして使用します。また、高速な処理が不要な場合は、消費電流を低減するため、OSC3クロックの代わりにシステムクロックとしても使用可能です。

発振回路の種類は水晶発振です。外部クロック入力にも対応しています。

図7.3.1にOSC1発振回路の構造を示します。



図7.3.1 OSC1発振回路

水晶発振回路として使用する場合は、OSC1端子とOSC2端子間に水晶振動子X'tal1(Typ. 32.768kHz)と帰還抵抗(Rf)を、OSC1、OSC2端子とVss間にキャパシタを2個(Cg1、Cd1)接続します。また、必要に応じてドレイン抵抗(Rd)をOSC2端子とCd1の間に接続してください。

外部クロック(100kHz Max.)を使用する場合はOSC2端子を開放し、LVDDレベルでデューティ比が50%のクロックをOSC1端子に入力してください。

OSC1発振回路を使用しない場合はOSC1端子をVssに接続し、OSC2端子を開放してください。

### OSC1発振のOn/Off

OSC1発振回路はOSC1EN(D1/OSC\_CTLレジスタ)を0に設定すると発振を停止し、1に設定すると発振を開始します。OSC1発振回路はSLEEPモードでも発振を停止します。

\* **OSC1EN:** OSC1 Enable Bit in the Oscillation Control (OSC\_CTL) Register (D1/0x5061)

### OSC1発振開始時の安定待ち時間

電源投入時、SLEEPからの起床時、ソフトウェアでOSC1発振回路をOnにした場合など、OSC1発振開始時の不安定なクロックによる誤動作を防止するため、OSC1発振回路には発振安定待ちタイマが設けられています。発振開始後、OSC1クロックは256サイクルの期間、システムに供給されません。

## 7.4 システムクロックの切り換え

OSC3とOSC1クロックのどちらをシステムクロックとして使用するか、ソフトウェアによって切り換えることができます。可能であれば、システムクロックをOSC1に切り換え後にOSC3発振を停止させることで、消費電流を低減できます。

この制御手順を以下に示します。

### OSC3→OSC1

1. OSC1発振が停止している場合は、OSC1EN(D1/OSC\_CTLレジスタ)を1に設定して発振を開始させます。

\* **OSC1EN**: OSC1 Enable Bit in the Oscillation Control (OSC\_CTL) Register (D1/0x5061)

2. CLKSRC(D0/OSC\_SRCレジスタ)を1に設定して、システムクロックをOSC3からOSC1に切り換えます。

\* **CLKSRC**: System Clock Source Select Bit in the Clock Source Select (OSC\_SRC) Register (D0/0x5060)

3. OSC3を原振とする周辺モジュールの動作が不要な場合は、OSC3EN(D0/OSC\_CTLレジスタ)を0に設定してOSC3発振を停止させます。

\* **OSC3EN**: OSC3 Enable Bit in the Oscillation Control (OSC\_CTL) Register (D0/0x5061)

- 注: • OSC1発振開始直後に、システムクロックをOSC3からOSC1に切り換えると、OSC1クロックが立ち上がるまで(OSC1クロックの256サイクルの期間)、システムクロックは停止します。
- システムクロックをOSC1に切り換える前にOSC3発振を停止することはできません。

### OSC1→OSC3

1. OSC3WT[1:0](D[5:4]/OSC\_CTLレジスタ)を、OSC3発振開始時間以上の発振安定待ち時間(表7.2.2 参照)に設定します(すでに設定済みの場合は不要)。

\* **OSC3WT[1:0]**: OSC3 Wait Cycle Select Bits in the Oscillation Control (OSC\_CTL) Register (D[5:4]/0x5061)

2. OSC3発振が停止している場合は、OSC3EN(D0/OSC\_CTLレジスタ)を1に設定して発振を開始させます。OSC3発振開始直後は、OSC3WT[1:0](D[5:4]/OSC\_CTLレジスタ)による設定時間が経過するまで、OSC3クロックは供給されません。

3. CLKSRC(D0/OSC\_SRCレジスタ)を0に設定して、システムクロックをOSC1からOSC3に切り換えます。

4. OSC1を原振とする周辺モジュールの動作が不要な場合は、OSC1EN(D1/OSC\_CTLレジスタ)を0に設定してOSC1発振を停止させます。

- 注: • OSC3発振回路がすでに動作中の場合、1と2の操作は不要です。
- OSC3発振開始時間は振動子、外付け部品によって変動します。発振安定待ち時間は余裕を持って設定してください。“24 電気的特性”に発振開始時間の一例を示しますので参考にしてください。
- システムクロックをOSC3に切り換える前にOSC1発振を停止することはできません。

## 7.5 8ビットOSC1タイマクロックの制御

OSCモジュールには、8ビットOSC1タイマの動作クロックを生成する分周回路と供給を制御する機構が組み込まれています。8ビットOSC1タイマはOSC1分周クロックのみで動作するプログラマブルタイマです。詳細については、“14 8ビットOSC1タイマ(T8OSC1)”を参照してください。



図7.5.1 8ビットOSC1タイマクロック制御回路

### クロック分周比の選択

T8O1CK[2:0](D[3:1]/OSC\_T8OSC1レジスタ)でOSC1クロックの分周比を選択します。

\* **T8O1CK[2:0]: T8OSC1 Clock Division Ratio Select Bits in the T8OSC1 Clock Control (OSC\_T8OSC1) Register (D[3:1]/0x5065)**

表7.5.1 T8OSC1クロック分周比の選択

| T8O1CK[2:0] | 分周比       |
|-------------|-----------|
| 0x7~0x6     | Reserved  |
| 0x5         | OSC1•1/32 |
| 0x4         | OSC1•1/16 |
| 0x3         | OSC1•1/8  |
| 0x2         | OSC1•1/4  |
| 0x1         | OSC1•1/2  |
| 0x0         | OSC1•1/1  |

(デフォルト: 0x0)

### クロック供給の制御

8ビットOSC1タイマへのクロック供給は、T8O1CE(D0/OSC\_T8OSC1レジスタ)で制御します。T8O1CEのデフォルト設定は0で、クロックの供給は停止しています。T8O1CEを1に設定すると、上記のとおり生成されたクロックが8ビットOSC1タイマに送られます。8ビットOSC1タイマの動作が不要な場合は、消費電流を抑えるため、クロック供給を停止してください。

\* **T8O1CE: T8OSC1 Clock Enable Bit in the T8OSC1 Clock Control (OSC\_T8OSC1) Register (D0/0x5065)**

## 7.6 クロック外部出力(FOUT3, FOUT1)

OSC3の分周クロック(FOUT3)、OSC1クロック(FOUT1)をチップ外部へ出力することができます。



図7.6.1 クロック出力回路

### FOUT3出力

FOUT3はOSC3の分周クロックです。

#### 出力端子の設定

FOUT3出力端子はP30ポート端子を兼ねています。デフォルト設定ではP30ポート端子として機能しますので、FOUT3出力として使用する場合はP30MUX(D0/P3\_PMUXレジスタ)に1を書き込み、端子機能を変更してください。

\* **P30MUX**: P30 Port Function Select Bit in the P3 Port Function Select (P3\_PMUX) Register (D0/0x52a3)

#### FOUT3クロック周波数の選択

出力するクロック周波数は3種類から選択できます。FOUT3D[1:0](D[3:2]/OSC\_FOUTレジスタ)でOSC3クロックの分周比を選択してください。

\* **FOUT3D[1:0]**: FOUT3 Clock Division Ratio Select Bits in the FOUT Control (OSC\_FOUT) Register (D[3:2]/0x5064)

表7.6.1 FOUT3クロック分周比の選択

| FOUT3D[1:0] | 分周比      |
|-------------|----------|
| 0x3         | Reserved |
| 0x2         | OSC3·1/4 |
| 0x1         | OSC3·1/2 |
| 0x0         | OSC3·1/1 |

(デフォルト: 0x0)

#### クロック出力の制御

クロック出力は、FOUT3E(D1/OSC\_FOUTレジスタ)で制御します。FOUT3Eを1に設定するとFOUT3クロックがFOUT3端子から出力され、FOUT3Eを0に設定すると出力は停止します。

\* **FOUT3E**: FOUT3 Output Enable Bit in the FOUT Control (OSC\_FOUT) Register (D1/0x5064)



図7.6.2 FOUT3出力

注: FOUT3信号はFOUT3Eの書き込みとは非同期に生成されますので、出力のOn/Off時にはハザードを生じます。

## FOUT1出力

FOUT1はOSC1クロックです。

### 出力端子の設定

FOUT1出力端子はP13ポート端子を兼ねています。デフォルト設定ではP13ポート端子として機能しますので、FOUT1出力として使用する場合はP13MUX(D3/P1\_PMUXレジスタ)に1を書き込み、端子機能を変更してください。

\* **P13MUX**: P13 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D3/0x52a1)

### クロック出力の制御

クロック出力は、FOUT1E(D0/OSC\_FOUTレジスタ)で制御します。FOUT1Eを1に設定するとFOUT1クロックがFOUT1端子から出力され、FOUT1Eを0に設定すると出力は停止します。

\* **FOUT1E**: FOUT1 Output Enable Bit in the FOUT Control (OSC\_FOUT) Register (D0/0x5064)



図7.6.3 FOUT1出力

注: FOUT1信号はFOUT1Eの書き込みとは非同期に生成されますので、出力のOn/Off時にはハザードを生じます。

## 7.7 RESET, NMI入力ノイズフィルタ

S1C17コアの入力信号の中で、RESET、NMIがノイズの影響により誤まってアクティブになると、不要なリセット、NMI処理を実行してしまいます。

これを防ぐため、OSCモジュールにはシステムクロックで動作するノイズフィルタが組み込まれており、これらの信号がS1C17コアに入力される前にノイズを除去できるようになっています。

ノイズフィルタは信号ごとに独立しており、個別に有効とするかバイパスさせるか選択できます。イニシャルリセット時はすべて有効となります。

RESET入力ノイズフィルタ: RSTFE(D1/OSC\_NFENレジスタ) = 1でノイズ除去、RSTFE = 0でバイパス  
NMI入力ノイズフィルタ: NMIFE(D0/OSC\_NFENレジスタ) = 1でノイズ除去、NMIFE = 0でバイパス

\* **RSTFE**: Reset Noise Filter Enable Bit in the Noise Filter Enable (OSC\_NFEN) Register (D1/0x5062)

\* **NMIFE**: NMI Noise Filter Enable Bit in the Noise Filter Enable (OSC\_NFEN) Register (D0/0x5062)

ノイズフィルタはシステムクロック(OSC3クロックまたはOSC1クロック)を1/8に分周したクロックで動作します。有効にすると、このクロックの2サイクル以下のパルスはノイズとして除去されます。

したがって、有効な信号として入力するためには、システムクロックの16サイクル以上のパルス幅が必要です。

注: • 通常は、すべてのノイズフィルタを有効に設定してください。

- S1C17001には外部NMI入力端子はありませんが、ウォッチャドッグタイマのNMI要求信号がこのノイズフィルタを通ります。

## 7.8 制御レジスタ詳細

表7.8.1 OSCレジスター一覧

| アドレス   | レジスタ名      | 機能                                                  |
|--------|------------|-----------------------------------------------------|
| 0x5060 | OSC_SRC    | Clock Source Select Register<br>クロック源の選択            |
| 0x5061 | OSC_CTL    | Oscillation Control Register<br>発振制御                |
| 0x5062 | OSC_NFEN   | Noise Filter Enable Register<br>ノイズフィルタのON/OFF      |
| 0x5064 | OSC_FOUT   | FOUT Control Register<br>クロック外部出力の制御                |
| 0x5065 | OSC_T8OSC1 | T8OSC1 Clock Control Register<br>8ビットOSC1タイマクロックの設定 |

以下、OSCモジュールのレジスタを個々に説明します。これらはすべて8ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

## 0x5060: Clock Source Select Register (OSC\_SRC)

| Register name                          | Address         | Bit  | Name | Function | Setting | Init. | R/W | Remarks            |
|----------------------------------------|-----------------|------|------|----------|---------|-------|-----|--------------------|
| Clock Source Select Register (OSC_SRC) | 0x5060 (8 bits) | D7–1 | –    | reserved | –       | –     | –   | 0 when being read. |

### D[7:1] Reserved

#### D0 CLKSRC: System Clock Source Select Bit

システムのクロックソースを選択します。

1(R/W): OSC1

0(R/W): OSC3(デフォルト)

通常(高速)動作時はOSC3を選択します。OSC3クロックが不要な場合は、OSC1をシステムクロックに設定し、OSC3発振を停止することで消費電流を低減できます。

注: OSC1発振開始直後に、システムクロックをOSC3からOSC1に切り換えると、OSC1クロックが立ち上がるまで(OSC1クロックの256サイクルの期間)、システムクロックは停止します。

## 0x5061: Oscillation Control Register (OSC\_CTL)

| Register name                          | Address         | Bit  | Name        | Function               | Setting     |             | Init. | R/W     | Remarks            |
|----------------------------------------|-----------------|------|-------------|------------------------|-------------|-------------|-------|---------|--------------------|
| Oscillation Control Register (OSC_CTL) | 0x5061 (8 bits) | D7-6 | —           | reserved               | —           | —           | —     | —       | 0 when being read. |
|                                        |                 | D5-4 | OSC3WT[1:0] | OSC3 wait cycle select | OSC3WT[1:0] | Wait cycle  | 0x0   | R/W     |                    |
|                                        |                 |      |             |                        | 0x3         | 128 cycles  |       |         |                    |
|                                        |                 |      |             |                        | 0x2         | 256 cycles  |       |         |                    |
|                                        |                 | D3-2 | —           | reserved               | 0x1         | 512 cycles  |       |         | 0 when being read. |
|                                        |                 | D1   | OSC1EN      | OSC1 enable            | 0x0         | 1024 cycles | 1     | R/W     |                    |
|                                        |                 | D0   | OSC3EN      | OSC3 enable            | 1           | Enable      | 0     | Disable | 1                  |
|                                        |                 |      |             |                        | 0           | Disable     | 1     | R/W     |                    |

### D[7:6] Reserved

### D[5:4] OSC3WT[1:0]: OSC3 Wait Cycle Select Bits

OSC3発振開始時の不安定なクロックによる誤動作を防止するための、発振安定待ち時間設定します。

電源投入時、SLEEPからの起床時、ソフトウェアでOSC3発振回路をOnにした場合など、OSC3発振開始直後は、ここで設定した時間が経過するまで、OSC3クロックはシステムに供給されません。

表7.8.2 OSC3発振安定待ち時間の設定

| OSC3WT[1:0] | 発振安定待ち時間 |
|-------------|----------|
| 0x3         | 128サイクル  |
| 0x2         | 256サイクル  |
| 0x1         | 512サイクル  |
| 0x0         | 1024サイクル |

(デフォルト: 0x0)

イニシャルリセット時は1024サイクル(OSC3クロック)に設定されますので、リセット解除後はこの時間が経過するまでCPUは動作を開始しません。

注: OSC3発振開始時間は振動子、外付け部品によって変動します。発振安定待ち時間は余裕を持って設定してください。“24 電気的特性”に発振開始時間の一例を示しますので参考にしてください。

### D[3:2] Reserved

### D1 OSC1EN: OSC1 Enable Bit

OSC1発振回路の動作を許可/禁止します。

1(R/W): 許可(On) (デフォルト)

0(R/W): 禁止(Off)

注: • OSC1クロックをシステムクロックとして使用している場合、OSC1発振回路を停止することはできません。  
 • OSC1ENを0から1に設定してOSC1発振を開始させた直後は誤動作を防ぐため、OSC1クロックは256サイクルの期間、システムに供給されません。

### D0 OSC3EN: OSC3 Enable Bit

OSC3発振回路の動作を許可/禁止します。

1(R/W): 許可(On) (デフォルト)

0(R/W): 禁止(Off)

注: OSC3クロックをシステムクロックとして使用している場合、OSC3発振回路を停止することはできません。

## 0x5062: Noise Filter Enable Register (OSC\_NFEN)

| Register name                                 | Address | Bit  | Name         | Function                  | Setting |        | Init. | R/W     | Remarks            |     |
|-----------------------------------------------|---------|------|--------------|---------------------------|---------|--------|-------|---------|--------------------|-----|
| Noise Filter<br>Enable Register<br>(OSC_NFEN) | 0x5062  | D7-2 | —            | reserved                  | —       | —      | —     | —       | 0 when being read. |     |
|                                               |         | D1   | <b>RSTFE</b> | Reset noise filter enable | 1       | Enable | 0     | Disable | 1                  | R/W |
|                                               |         | D0   | <b>NMIFE</b> | NMI noise filter enable   | 1       | Enable | 0     | Disable | 1                  | R/W |

### D[7:2] Reserved

#### D1 RSTFE: Reset Noise Filter Enable Bit

RESET入力用ノイズフィルタの動作を有効/無効にします。

1(R/W): 有効(ノイズ除去) (デフォルト)

0(R/W): 無効(バイパス)

このノイズフィルタは、システムクロック(OSC3クロックまたはOSC1クロック)16サイクル以上の幅のRESETパルスのみをS1C17コアに入力します。パルス幅が16サイクル未満の場合はノイズとして除去されます。通常は有効に設定してください。

#### D0 NMIFE: NMI Noise Filter Enable Bit

NMI入力用ノイズフィルタの動作を有効/無効にします。

1(R/W): 有効(ノイズ除去) (デフォルト)

0(R/W): 無効(バイパス)

このノイズフィルタは、システムクロック(OSC3クロックまたはOSC1クロック)16サイクル以上の幅のNMIパルスのみをS1C17コアに入力します。パルス幅が16サイクル未満の場合はノイズとして除去されます。通常は有効に設定してください。

注: S1C17001には外部NMI入力端子はありませんが、ウォッチドッグタイマのNMI要求信号がこのノイズフィルタを通ります。

**0x5064: FOUT Control Register (OSC\_FOUT)**

| Register name                    | Address         | Bit  | Name        | Function                          | Setting     |                | Init. | R/W     | Remarks            |
|----------------------------------|-----------------|------|-------------|-----------------------------------|-------------|----------------|-------|---------|--------------------|
| FOUT Control Register (OSC_FOUT) | 0x5064 (8 bits) | D7–4 | –           | reserved                          | –           | –              | –     | –       | 0 when being read. |
|                                  |                 | D3–2 | FOUT3D[1:0] | FOUT3 clock division ratio select | FOUT3D[1:0] | Division ratio | 0x0   | R/W     |                    |
|                                  |                 |      |             |                                   | 0x3         | reserved       |       |         |                    |
|                                  |                 |      |             |                                   | 0x2         | OSC3•1/4       |       |         |                    |
|                                  |                 | D1   | FOUT3E      | FOUT3 output enable               | 1           | Enable         | 0     | Disable | 0                  |
|                                  |                 | D0   | FOUT1E      | FOUT1 output enable               | 1           | Enable         | 0     | Disable | 0                  |

**D[7:4] Reserved****D[3:2] FOUT3D[1:0]: FOUT3 Clock Division Ratio Select Bits**

OSC3クロックの分周比を選択し、FOUT3クロック周波数を設定します。

表7.8.3 FOUT3クロック分周比の選択

| FOUT3D[1:0] | 分周比      |
|-------------|----------|
| 0x3         | Reserved |
| 0x2         | OSC3•1/4 |
| 0x1         | OSC3•1/2 |
| 0x0         | OSC3•1/1 |

(デフォルト: 0x0)

**D1 FOUT3E: FOUT3 Output Enable Bit**

FOUT3クロック(OSC3分周クロック)の外部出力を許可/禁止します。

1(R/W): 許可(On)

0(R/W): 禁止(Off) (デフォルト)

FOUT3Eを1に設定するとFOUT3クロックがFOUT3端子から出力され、FOUT3Eを0に設定すると出力は停止します。

FOUT3出力端子はP30ポート端子を兼ねています。デフォルト設定ではP30ポート端子として機能しますので、FOUT3出力として使用する場合はP30MUX(D0/P3\_PMUXレジスタ)に1を書き込み、端子機能を変更してください。

\* **P30MUX:** P30 Port Function Select Bit in the P3 Port Function Select (P3\_PMUX) Register (D0/0x52a3)**D0 FOUT1E: FOUT1 Output Enable Bit**

FOUT1クロック(OSC1クロック)の外部出力を許可/禁止します。

1(R/W): 許可(On)

0(R/W): 禁止(Off) (デフォルト)

FOUT1Eを1に設定するとFOUT1クロックがFOUT1端子から出力され、FOUT1Eを0に設定すると出力は停止します。

FOUT1出力端子はP13ポート端子を兼ねています。デフォルト設定ではP13ポート端子として機能しますので、FOUT1出力として使用する場合はP13MUX(D3/P1\_PMUXレジスタ)に1を書き込み、端子機能を変更してください。

\* **P13MUX:** P13 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D3/0x52a1)

**0x5065: T8OSC1 Clock Control Register (OSC\_T8OSC1)**

| Register name                              | Address            | Bit  | Name        | Function                           | Setting     |                | Init. | R/W     | Remarks            |
|--------------------------------------------|--------------------|------|-------------|------------------------------------|-------------|----------------|-------|---------|--------------------|
| T8OSC1 Clock Control Register (OSC_T8OSC1) | 0x5065<br>(8 bits) | D7-4 | —           | reserved                           | —           | —              | —     | —       | 0 when being read. |
|                                            |                    | D3-1 | T8O1CK[2:0] | T8OSC1 clock division ratio select | T8O1CK[2:0] | Division ratio | 0x0   | R/W     |                    |
|                                            |                    |      |             |                                    | 0x7~0x6     | reserved       |       |         |                    |
|                                            |                    |      |             |                                    | 0x5         | OSC1•1/32      |       |         |                    |
|                                            |                    |      |             |                                    | 0x4         | OSC1•1/16      |       |         |                    |
|                                            |                    |      |             |                                    | 0x3         | OSC1•1/8       |       |         |                    |
|                                            |                    |      |             |                                    | 0x2         | OSC1•1/4       |       |         |                    |
|                                            |                    |      |             |                                    | 0x1         | OSC1•1/2       |       |         |                    |
|                                            |                    |      |             |                                    | 0x0         | OSC1•1/1       |       |         |                    |
|                                            |                    | D0   | T8O1CE      | T8OSC1 clock output enable         | 1           | Enable         | 0     | Disable | 0 R/W              |

**D[7:4] Reserved****D[3:1] T8O1CK[2:0]: T8OSC1 Clock Division Ratio Select Bits**

OSC1クロックの分周比を選択し、8ビットOSC1タイマの動作クロックを設定します。

表7.8.4 T8OSC1クロック分周比の選択

| T8O1CK[2:0] | 分周比       |
|-------------|-----------|
| 0x7~0x6     | Reserved  |
| 0x5         | OSC1•1/32 |
| 0x4         | OSC1•1/16 |
| 0x3         | OSC1•1/8  |
| 0x2         | OSC1•1/4  |
| 0x1         | OSC1•1/2  |
| 0x0         | OSC1•1/1  |

(デフォルト:0x0)

**D0 T8O1CE: T8OSC1 Clock Output Enable Bit**

8ビットOSC1タイマへのクロック供給を許可/禁止します。

1(R/W): 許可(On)

0(R/W): 禁止(Off) (デフォルト)

T8O1CEのデフォルト設定は0で、クロックの供給は停止しています。T8O1CEを1に設定すると、上記のビットで選択されたクロックが8ビットOSC1タイマに送られます。8ビットOSC1タイマの動作が不要な場合は、消費電流を抑えるため、クロック供給を停止してください。

## 7.9 注意事項

- ・発振開始時間は振動子、外付け部品によって変動します。OSC3発振安定待ち時間は余裕を持って設定してください。“24 電気的特性”に発振開始時間の一例を示しますので参考にしてください。
- ・OSC1発振開始直後に、システムクロックをOSC3からOSC1に切り換えると、OSC1クロックが立ち上がるまで(OSC1クロックの256サイクルの期間)、システムクロックは停止します。
- ・OSC3クロックをシステムクロックとして使用している場合、OSC3発振回路を停止することはできません。
- ・OSC1クロックをシステムクロックとして使用している場合、OSC1発振回路を停止することはできません。
- ・FOUT3/FOUT1信号はFOUT3E/FOUT1Eの書き込みとは非同期に生成されますので、出力のOn/Off時にはハザードを生じます。

# 8 クロックジェネレータ(CLG)

## 8.1 クロックジェネレータの構成

クロックジェネレータは、S1C17コアや周辺モジュールへのシステムクロックの供給を制御します。

図8.1.1にクロックシステムとCLGモジュールの構成を示します。



図8.1.1 CLGモジュールの構成

処理に合わせてクロックを制御し、さらにスタンバイモードを組み合わせることで消費電流を抑えることができます。消費電流を抑える手法については、“Appendix B パワーセーブ”を参照してください。

## 8.2 CPUコアクロック(CCLK)の制御

CLGモジュールには、システムクロックを減速させてS1C17コアに送るためのクロックギアが組み込まれています。できるだけ低速なクロックでS1C17コアを動作させることで消費電流を抑えることができます。また、halt命令が実行されると、CLGはS1C17コアへのクロック供給を停止してパワーセーブを図ります。



図8.2.1 CCLK供給システム

### クロックギアの設定

CCLKGR[1:0](D[1:0]/CLG\_CCLKレジスタ)でシステムクロックを減速するギア比を選択します。

\* **CCLKGR[1:0]**: CCLK Clock Gear Ratio Select Bits in the CCLK Control (CLG\_CCLK) Register (D[1:0]/0x5081)

表8.2.1 CCLKギア比の選択

| CCLKGR[1:0] | ギア比 |
|-------------|-----|
| 0x3         | 1/8 |
| 0x2         | 1/4 |
| 0x1         | 1/2 |
| 0x0         | 1/1 |

(デフォルト: 0x0)

### クロック供給の制御

CCLKクロックの供給を停止するには、halt命令を実行します。システムクロックは停止しませんので、周辺モジュールは動作します。

HALTモードはリセット、NMI、その他の割り込みで解除され、それと同時にCCLKの供給も再開します。

slp命令を実行した場合はCLGへのシステムクロックの供給が停止しますので、CCLKの供給は停止します。SLEEPモードが外部割り込み等で解除されるとシステムクロックの供給が再開され、CCLKの供給も再開します。

システムクロックの制御については、“7 発振回路(OSC)”を参照してください。

## 8.3 周辺モジュールクロック(PCLK)の制御

CLGモジュールは、周辺モジュールへのクロック供給も制御します。

周辺モジュールクロック(PCLK)にはシステムクロックがそのまま使用されます。



図8.3.1 周辺モジュールクロック制御回路

### クロック供給の制御

PCLKの供給はPCKEN[1:0](D[1:0]/CLG\_PCLKレジスタ)で制御します。

\* **PCKEN[1:0]: PCLK Enable Bits in the PCLK Control (CLG\_PCLK) Register (D[1:0]/0x5080)**

表8.3.1 PCLKの制御

| PCKEN[1:0] | PCLKの供給 |
|------------|---------|
| 0x3        | 許可(On)  |
| 0x2        | 設定禁止    |
| 0x1        | 設定禁止    |
| 0x0        | 禁止(Off) |

(デフォルト: 0x3)

デフォルト設定は0x3で、クロックが供給されるようになっています。内部周辺回路エリア内の全周辺モジュール(上記のリストにあるモジュール)の動作が不要な場合は、消費電流を抑えるため、クロックの供給を停止してください。

注: 一部の周辺モジュールが動作を停止しますので、PCKEN[1:0](D[1:0]/CLG\_PCLKレジスタ)を0x2または0x1には設定しないでください。

### PCLK以外で動作する周辺モジュール

計時タイマ、ストップウォッチタイマ、ウォッチドッグタイマ、8ビットOSC1タイマは制御レジスタへのアクセスを除き、OSC1分周クロックで動作します。PCLKを停止すると制御レジスタは読み出し、書き込み共にできなくなりますが、動作は継続します。

## 8.4 制御レジスタ詳細

表8.4.1 CLGレジスター一覧

| アドレス   | レジスタ名    |                       | 機能         |
|--------|----------|-----------------------|------------|
| 0x5080 | CLG_PCLK | PCLK Control Register | PCLK供給制御   |
| 0x5081 | CLG_CCLK | CCLK Control Register | CCLK分周比の設定 |

以下、CLGモジュールのレジスタを個々に説明します。これらはすべて8ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

## 0x5080: PCLK Control Register (CLG\_PCLK)

| Register name                    | Address            | Bit  | Name       | Function    | Setting    |             | Init. | R/W | Remarks            |
|----------------------------------|--------------------|------|------------|-------------|------------|-------------|-------|-----|--------------------|
| PCLK Control Register (CLG_PCLK) | 0x5080<br>(8 bits) | D7-2 | —          | reserved    | —          | —           | —     | —   | 0 when being read. |
|                                  |                    | D1-0 | PCKEN[1:0] | PCLK enable | PCKEN[1:0] | PCLK supply | 0x3   | R/W |                    |
|                                  |                    |      |            |             | 0x3        | Enable      |       |     |                    |
|                                  |                    |      |            |             | 0x2        | Not allowed |       |     |                    |
|                                  |                    |      |            |             | 0x1        | Not allowed |       |     |                    |
|                                  |                    |      |            |             | 0x0        | Disable     |       |     |                    |

**D[7:2]** Reserved

**D[1:0]** PCKEN[1:0]: PCLK Enable Bits

内部周辺モジュールへのクロック(PCLK)の供給を許可/禁止します。

表8.4.2 PCLKの制御

| PCKEN[1:0] | PCLKの供給 |
|------------|---------|
| 0x3        | 許可(On)  |
| 0x2        | 設定禁止    |
| 0x1        | 設定禁止    |
| 0x0        | 禁止(Off) |

(デフォルト:0x3)

PCKEN[1:0]のデフォルト設定は0x3で、クロックは供給されるようになっています。下記の周辺モジュールを使用しない場合は、消費電流を抑えるため、クロック供給を停止してください。

PCLKで動作する周辺モジュール

- プリスケーラ(PWM&キャプチャタイマ、リモートコントローラ、Pポート)
- UART
- 8ビットタイマ
- 16ビットタイマ Ch.0～2
- 割り込みコントローラ
- SPI
- I<sup>2</sup>C
- Pポート&ポートMUX
- PWM&キャプチャタイマ
- MISCレジスタ
- リモートコントローラ

以下の周辺モジュールは制御レジスタへのアクセスを除き、PCLK以外のクロックで動作します。したがって、制御レジスタを設定して動作を開始後はPCLKは必要ありません。

- 計時タイマ
- ストップウォッチタイマ
- ウオッチドッグタイマ
- 8ビットOSC1タイマ

注: 一部の周辺モジュールが動作を停止しますので、PCKEN[1:0]を0x2または0x1には設定しないでください。

**0x5081: CCLK Control Register (CLG\_CCLK)**

| Register name                    | Address         | Bit  | Name        | Function                     | Setting     |            | Init. | R/W | Remarks            |  |  |  |
|----------------------------------|-----------------|------|-------------|------------------------------|-------------|------------|-------|-----|--------------------|--|--|--|
| CCLK Control Register (CLG_CCLK) | 0x5081 (8 bits) | D7-2 | –           | reserved                     | –           |            | –     | –   | 0 when being read. |  |  |  |
|                                  |                 | D1-0 | CCLKGR[1:0] | CCLK clock gear ratio select | CCLKGR[1:0] | Gear ratio | 0x0   | R/W |                    |  |  |  |
|                                  |                 |      |             |                              | 0x3         | 1/8        |       |     |                    |  |  |  |
|                                  |                 |      |             |                              | 0x2         | 1/4        |       |     |                    |  |  |  |
|                                  |                 |      |             |                              | 0x1         | 1/2        |       |     |                    |  |  |  |
|                                  |                 |      |             |                              | 0x0         | 1/1        |       |     |                    |  |  |  |

**D[7:2] Reserved****D[1:0] CCLKGR[1:0]: CCLK Clock Gear Ratio Select Bits**

システムクロックを減速するギア比を選択し、S1C17コアを動作させるCCLKクロックの速度を設定します。できるだけ低速なクロックでS1C17コアを動作させることで消費電流を抑えることができます。

表8.4.3 CCLKギア比の選択

| CCLKGR[1:0] | ギア比 |
|-------------|-----|
| 0x3         | 1/8 |
| 0x2         | 1/4 |
| 0x1         | 1/2 |
| 0x0         | 1/1 |

(デフォルト: 0x0)

## 8.5 注意事項

(1) デフォルト設定では、周辺モジュールにPCLKが供給されるようになっています。下記の周辺モジュールを使用しない場合は、消費電流を抑えるため、クロック供給を停止してください。

PCLKで動作する周辺モジュール

- プリスケーラ(PWM&キャプチャタイマ、リモートコントローラ、Pポート)
- UART
- 8ビットタイマ
- 16ビットタイマ Ch.0~2
- 割り込みコントローラ
- SPI
- I<sup>2</sup>C
- Pポート&ポートMUX
- PWM&キャプチャタイマ
- MISCレジスタ
- リモートコントローラ

以下の周辺モジュールは制御レジスタへのアクセスを除き、PCLK以外のクロックで動作します。したがって、制御レジスタを設定して動作を開始後はPCLKは必要ありません。

- 計時タイマ
- ストップウォッチタイマ
- ウォッチドッグタイマ
- 8ビットOSC1タイマ

(2) 一部の周辺モジュールが動作を停止しますので、PCKEN[1:0](D[1:0]/CLG\_PCLKレジスタ)を0x2または0x1には設定しないでください。

\* **PCKEN[1:0]**: PCLK Enable Bits in the PCLK Control (CLG\_PCLK) Register (D[1:0]/0x5080)

このページはブランクです。

# 9 プリスケーラ(PSC)

## 9.1 プリスケーラの構成

S1C17001はタイマなどの動作クロックを生成するプリスケーラを内蔵しています。プリスケーラはクロックジェネレータから供給されるPCLKクロックを1/1～1/16Kに分周し、15種類の周波数を生成します。クロック供給先の周辺モジュールにはクロック選択レジスタが設けられており、この中の1つをカウントクロックや動作クロックとして選択できるようになっています。



図9.1.1 プリスケーラ

プリスケーラはPRUNビット(D0/PSC\_CTLレジスタ)で制御します。プリスケーラを動作させるにはPRUNに1を書き込みます。0を書き込むとプリスケーラは停止します。タイマやインターフェースモジュールが停止中は、プリスケーラを停止させることで消費電流を低減できます。イニシャルリセット後、プリスケーラは停止しています。

\* **PRUN:** Prescaler Run/Stop Control Bit in the Prescaler Control (PSC\_CTL) Register (D0/0x4020)

注: プリスケーラを使用するには、クロックジェネレータからPCLKが供給されている必要があります。

プリスケーラにはもう一つの制御ビット、PRUND(D1/PSC\_CTLレジスタ)が用意されています。このビットはデバッグモード時のプリスケーラの動作を指定します。PRUNDを1に設定すると、プリスケーラはデバッグモード時も動作します。PRUNDを0に設定すると、S1C17コアがデバッグモードになった時点でのプリスケーラは停止します。デバッグ中にタイマやインターフェースモジュールを使用する場合は、PRUNDを1に設定してください。

\* **PRUND:** Prescaler Run/Stop Setting Bit in Debug Mode in the Prescaler Control (PSC\_CTL) Register (D1/0x4020)

## 9.2 制御レジスタ詳細

表9.2.1 プリスケーラレジスタ

| アドレス   | レジスタ名   |                            | 機能                 |
|--------|---------|----------------------------|--------------------|
| 0x4020 | PSC_CTL | Prescaler Control Register | プリスケーラのスタート/ストップ制御 |

プリスケーラのレジスタは8ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

### 0x4020: Prescaler Control Register (PSC\_CTL)

| Register name                        | Address         | Bit  | Name     | Function | Setting | Init. | R/W | Remarks            |
|--------------------------------------|-----------------|------|----------|----------|---------|-------|-----|--------------------|
| Prescaler Control Register (PSC_CTL) | 0x4020 (8 bits) | D7-2 | reserved |          | -       | -     | -   | 0 when being read. |

#### D[7:2] Reserved

#### D1 PRUND: Prescaler Run/Stop Setting Bit for Debug Mode

デバッグモード時のプリスケーラの動作を選択します。

1(R/W):動作

0(R/W):停止(デフォルト)

PRUNDを1に設定すると、プリスケーラはデバッグモード時も動作します。PRUNDを0に設定すると、S1C17コアがデバッグモードになった時点でプリスケーラは停止します。デバッグ中にタイマやインターフェースモジュールを使用する場合は、PRUNDを1に設定してください。

#### D0 PRUN: Prescaler Run/Stop Control Bit

プリスケーラの動作を開始/停止させます。

1(R/W):動作開始

0(R/W):停止(デフォルト)

プリスケーラを動作させるにはPRUNに1を書き込みます。0を書き込むとプリスケーラは停止します。タイマやインターフェースモジュールが停止中は、プリスケーラを停止させることで消費電流を低減できます。

### 9.3 注意事項

プリスケーラを使用するには、クロックジェネレータからPCLKが供給されている必要があります。

このページはブランクです。

# 10 入出力ポート(P)

## 10.1 入出力ポートの構成

S1C17001は、ソフトウェアによって入出力方向の切り換えが可能な28の入出力ポート(P0[7:0]、P1[7:0]、P2[7:0]、P3[3:0])を内蔵しています。一部を除き内部周辺モジュールの入出力端子を兼ねていますが、周辺モジュール用に使用しない端子については、汎用の入出力ポートとして使用することができます。

図10.1.1に入出力ポートの構造を示します。



図10.1.1 入出力ポートの構造

P0およびP1ポートは入力割り込みを発生可能です。

また、P0[3:0]ポートはキー入力リセットに使用することもできます(詳細は“5.1.2 P0ポートキー入力リセット”を参照)。

注: 入出力ポートをアクセスするためには、クロックジェネレータからPCLKクロックが供給されている必要があります。

また、P0ポートのチャタリングフィルタの動作にはプリスケーラ出力クロックも必要です。この機能を使用する場合は、プリスケーラもOnにしてください。

## 10.2 入出力端子機能の選択(ポートMUX)

入出力ポート端子は一部を除いて周辺モジュール用の入出力端子を兼ねており、入出力ポートとして使用するか、周辺モジュール用に使用するかを各ポートに対応するポート機能選択ビットによって設定できるようになっています。周辺モジュール用に使用しない端子は、すべて汎用入出力ポート端子として使用できます。

表10.2.1 入出力端子機能の選択

| 端子機能1<br>Px <sub>x</sub> MUX = 0 | 端子機能2<br>Px <sub>x</sub> MUX = 1 | ポート機能<br>選択ビット | 制御レジスタ                                              |
|----------------------------------|----------------------------------|----------------|-----------------------------------------------------|
| <b>P00</b>                       | —                                | —              | —                                                   |
| <b>P01</b>                       | —                                | —              | —                                                   |
| <b>P02</b>                       | —                                | —              | —                                                   |
| <b>P03</b>                       | —                                | —              | —                                                   |
| <b>P04</b>                       | REMI (REMC)                      | P04MUX (D4)    | P0 Port Function Select (P0_PMUX) Register (0x52a0) |
| <b>P05</b>                       | REMO (REMC)                      | P05MUX (D5)    |                                                     |
| <b>P06/EXCL2 (T16CH2)</b>        | —                                | —              | —                                                   |
| <b>P07/EXCL1 (T16CH1)</b>        | —                                | —              | —                                                   |
| <b>P10</b>                       | —                                | —              | —                                                   |
| <b>P11</b>                       | —                                | —              | —                                                   |
| <b>P12</b>                       | —                                | —              | —                                                   |
| <b>P13</b>                       | FOUT1 (OSC)                      | P13MUX (D3)    | P1 Port Function Select (P1_PMUX) Register (0x52a1) |
| <b>P14</b>                       | SDA (I2C)                        | P14MUX (D4)    |                                                     |
| <b>P15</b>                       | SCL (I2C)                        | P15MUX (D5)    |                                                     |
| <b>P16/EXCL0 (T16CH0)</b>        | —                                | —              | —                                                   |
| <b>P17</b>                       | #SPISS (SPI)                     | P17MUX (D7)    | P1 Port Function Select (P1_PMUX) Register (0x52a1) |
| <b>P20</b>                       | SDI (SPI)                        | P20MUX (D0)    | P2 Port Function Select (P2_PMUX) Register (0x52a2) |
| <b>P21</b>                       | SDO (SPI)                        | P21MUX (D1)    |                                                     |
| <b>P22</b>                       | SPICLK (SPI)                     | P22MUX (D2)    |                                                     |
| <b>P23</b>                       | SIN (UART)                       | P23MUX (D3)    |                                                     |
| <b>P24</b>                       | SOUT (UART)                      | P24MUX (D4)    |                                                     |
| <b>P25</b>                       | SCLK (UART)                      | P25MUX (D5)    |                                                     |
| <b>P26</b>                       | TOUT (T16E)                      | P26MUX (D6)    |                                                     |
| <b>P27</b>                       | EXCL3 (T16E)                     | P27MUX (D7)    |                                                     |
| <b>P30</b>                       | FOUT3 (OSC)                      | P30MUX (D0)    | P3 Port Function Select (P3_PMUX) Register (0x52a3) |
| <b>DCLK (DBG)</b>                | P31                              | P31MUX (D1)    |                                                     |
| <b>DST2 (DBG)</b>                | P32                              | P32MUX (D2)    |                                                     |
| <b>DSIO (DBG)</b>                | P33                              | P33MUX (D3)    |                                                     |

イニシャルリセットにより、各入出力ポート端子(P<sub>xx</sub>)はデフォルト(表10.2.1の端子機能1)の機能に初期化されます。

P06、P07、P16端子は入力モードに設定することで16ビットタイマの外部クロック入力端子としても使用できます。ただし、汎用入力ポートとしての機能も同時に有効なため、ポート機能選択ビットは設けられていません。

入出力ポート以外の機能については、()で示した周辺モジュールの説明を参照してください。

以下の節は、端子が汎用入出力ポートに設定されているものとしてポート機能を説明します。

## 10.3 データの入出力

入出力ポートは、PxIO[7:0](Px\_IOレジスタ)によってビットごとにデータの入出力方向を選択できるようになっています。

- \* **P0IO[7:0]**: P0[7:0] Port I/O Direction Select Bits in the P0 Port I/O Direction Control (P0\_IO) Register (D[7:0]/0x5202)
- \* **P1IO[7:0]**: P1[7:0] Port I/O Direction Select Bits in the P1 Port I/O Direction Control (P1\_IO) Register (D[7:0]/0x5212)
- \* **P2IO[7:0]**: P2[7:0] Port I/O Direction Select Bits in the P2 Port I/O Direction Control (P2\_IO) Register (D[7:0]/0x5222)
- \* **P3IO[3:0]**: P3[3:0] Port I/O Direction Select Bits in the P3 Port I/O Direction Control (P3\_IO) Register (D[3:0]/0x5232)

周辺モジュール用の機能を選択したポートの入出力方向は周辺モジュールによって制御され、PxIO[7:0]の設定は無視されます。

### データ入力

入力モードに設定する場合はPxIO[7:0]を0(デフォルト)に設定します。入力モードに設定された入出力ポートは、ハイインピーダンス状態となり入力ポートとして機能します。Px\_PUレジスタでプルアップを有効にしている場合は、ポートがプルアップされます。

入力モード時は、入力端子の状態をPxIN[7:0](Px\_INレジスタ)から直接読み出すことができます。読み出し値は入力端子がHigh(HVDD)レベルのときに1、Low(Vss)レベルのときに0となります。

- \* **P0IN[7:0]**: P0[7:0] Port Input Data Bits in the P0 Port Input Data (P0\_IN) Register (D[7:0]/0x5200)
- \* **P1IN[7:0]**: P1[7:0] Port Input Data Bits in the P1 Port Input Data (P1\_IN) Register (D[7:0]/0x5210)
- \* **P2IN[7:0]**: P2[7:0] Port Input Data Bits in the P2 Port Input Data (P2\_IN) Register (D[7:0]/0x5220)
- \* **P3IN[3:0]**: P3[3:0] Port Input Data Bits in the P3 Port Input Data (P3\_IN) Register (D[3:0]/0x5230)

### データ出力

出力モードに設定する場合はPxIO[7:0]を1に設定します。出力モードに設定された入出力ポートは出力ポートとして機能し、PxOUT[7:0](Px\_OUTレジスタ)に1を書き込むとポート端子はHigh(HVDD)レベル、0を書き込むとLow(Vss)レベルを出力します。なお、Px\_PUレジスタでプルアップを有効にした場合でも、ポートが出力モード時はプルアップされません。

- \* **P0OUT[7:0]**: P0[7:0] Port Output Data Bits in the P0 Port Output Data (P0\_OUT) Register (D[7:0]/0x5201)
- \* **P1OUT[7:0]**: P1[7:0] Port Output Data Bits in the P1 Port Output Data (P1\_OUT) Register (D[7:0]/0x5211)
- \* **P2OUT[7:0]**: P2[7:0] Port Output Data Bits in the P2 Port Output Data (P2\_OUT) Register (D[7:0]/0x5221)
- \* **P3OUT[3:0]**: P3[3:0] Port Output Data Bits in the P3 Port Output Data (P3\_OUT) Register (D[3:0]/0x5231)

入力モード時も、端子の状態に影響を与えることなくPxOUT[7:0]に対して書き込みは行えます。

## 10.4 プルアップ制御

入出力ポートはプルアップ抵抗を内蔵しており、これを使用するかしないか、PxPU[7:0](Px\_PUレジスタ)によってビットごとに選択できるようになっています。

- \* **P0PU[7:0]**: P0[7:0] Port Pull-up Enable Bits in the P0 Port Pull-up Control (P0\_PU) Register (D[7:0]/0x5203)
- \* **P1PU[7:0]**: P1[7:0] Port Pull-up Enable Bits in the P1 Port Pull-up Control (P1\_PU) Register (D[7:0]/0x5213)
- \* **P2PU[7:0]**: P2[7:0] Port Pull-up Enable Bits in the P2 Port Pull-up Control (P2\_PU) Register (D[7:0]/0x5223)
- \* **P3PU[3:0]**: P3[3:0] Port Pull-up Enable Bits in the P3 Port Pull-up Control (P3\_PU) Register (D[3:0]/0x5233)

PxPU[7:0]を1(デフォルト)に設定することによりプルアップ抵抗が有効になり、入力モード時にポート端子がプルアップされます。0に設定するとプルアップされません。

出力モード時には、PxPU[7:0]の設定は無効となり、プルアップされません。

使用しない入出力ポートについてはプルアップを有効に設定してください。

周辺モジュール用の機能を選択したポートも、このプルアップ設定は有効です。

内蔵プルアップ抵抗によって、ポート端子をLowレベルからHighレベルに変化させる場合、プルアップ抵抗と端子の負荷容量等の時定数によって波形立ち上がりに遅延が生じます。このため、入出力ポートの取り込みには適切な待ち時間の設定が必要となります。待ち時間は以下の式で求められる値以上を設定してください。

$$\text{待ち時間} = R_{IN} \times (C_{IN} + \text{基板上の負荷容量}) \times 1.6 \text{ [秒]}$$

$R_{IN}$ : プルアップ抵抗Max.値

$C_{IN}$ : 端子容量Max.値

## 10.5 入力インターフェースレベル

S1C17001の入力インターフェースレベルは、CMOSシグミットレベルに固定されています。

## 10.6 P0ポートのチャタリング除去機能

P0ポートにはキー入力用のチャタリング除去回路が設けられています。この機能を使用するか否か、また、使用する場合は検定時間を、P0CFx[2:0](P0\_CHATレジスタ)によってP0[3:0]、P0[7:4]の4ポートごとに選択します。

\* **P0CF1[2:0]**: P0[3:0] Chattering Filter Time Select Bits in the P0 Port Chattering Filter Control (P0\_CHAT) Register (D[2:0]/0x5208)

\* **P0CF2[2:0]**: P0[7:4] Chattering Filter Time Select Bits in the P0 Port Chattering Filter Control (P0\_CHAT) Register (D[6:4]/0x5208)

表10.6.1 チャタリング除去機能の設定

| P0CFx[2:0] | 検定時間 *             |
|------------|--------------------|
| 0x7        | 16384/fPCLK (8ms)  |
| 0x6        | 8192/fPCLK (4ms)   |
| 0x5        | 4096/fPCLK (2ms)   |
| 0x4        | 2048/fPCLK (1ms)   |
| 0x3        | 1024/fPCLK (512μs) |
| 0x2        | 512/fPCLK (256μs)  |
| 0x1        | 256/fPCLK (128μs)  |
| 0x0        | なし(Off)            |

(デフォルト:0x0, \* OSC3=2MHz, PCLK=OSC3の場合)

- 注: • チャタリング除去の検定時間は、除去できる最大パルス幅のことを指します。入力割り込みを発生させるには、最小で検定時間、最大で検定時間の2倍の入力時間が必要になります。
- チャタリング除去がOnに設定されたままSLEEPモードに入ると、入力割り込みを受け付けません。slp命令実行前に、チャタリング除去をOff(時間検定なし)に設定してください。
- P0\_CHATレジスタ(0x5208)の設定変更は、必ずP0ポート割り込みが禁止されている状態で行ってください。割り込みが許可されている状態で設定を変更すると、P0ポート割り込みが誤って発生する場合があります。
- 入力信号の立ち上がり/立ち下がり時間が遅い場合、信号がしきい値を通過するまでに時間がかかり、内部信号が発振する現象が起こる可能性があります。この場合、入力割り込みは誤動作しますので、入力信号の立ち上がり/立ち下がり時間は25ns以下を目安に設定してください。

## 10.7 ポート入力割り込み

P0およびP1ポートは入力割り込み機能を持っています。

16ポートの中から割り込みに使用するポートを任意に選択可能です。また、割り込み発生条件についても、入力信号の立ち上がりエッジまたは立ち下がりエッジのどちらで割り込みを発生させるか選択可能です。図10.7.1にポート入力割り込み回路の構成を示します。



図10.7.1 ポート入力割り込み回路の構成

### 割り込みポートの選択

割り込みを発生させるポートをPxIE[7:0](Px\_IMSKレジスタ)によって選択します。

- \* **P0IE[7:0]:** P0[7:0] Port Interrupt Enable Bits in the P0 Port Interrupt Mask (P0\_IMSK) Register (D[7:0]/0x5205)
- \* **P1IE[7:0]:** P1[7:0] Port Interrupt Enable Bits in the P1 Port Interrupt Mask (P1\_IMSK) Register (D[7:0]/0x5215)

PxIE[7:0]を1に設定すると、対応するポートが割り込みを発生可能となります。0(デフォルト)に設定すると割り込みを発生しません。

実際に割り込みを発生させるためには、割り込みコントローラの設定も必要です。割り込みコントローラの設定方法については、“6 割り込みコントローラ(ITC)”を参照してください。

### 割り込みエッジの選択

ポート入力割り込みは、入力信号の立ち上がりエッジまたは立ち下がりエッジで発生させることができます。どちらのエッジで発生させるかを、PxEDGE[7:0](Px\_EDGEレジスタ)によって選択します。

- \* **P0EDGE[7:0]:** P0[7:0] Port Interrupt Edge Select Bits in the P0 Port Interrupt Edge Select (P0\_EDGE) Register (D[7:0]/0x5206)
- \* **P1EDGE[7:0]:** P1[7:0] Port Interrupt Edge Select Bits in the P1 Port Interrupt Edge Select (P1\_EDGE) Register (D[7:0]/0x5216)

PxEDGE[7:0]を1に設定するとポート入力割り込みは入力信号の立ち下がりエッジで発生し、0(デフォルト)に設定すると立ち上がりエッジで発生します。

## Pポートモジュール内の割り込みフラグ

ITCはP0ポート割り込みとP1ポート割り込みの2系統の割り込み要求を受け付け可能ですが、P0[7:0]とP1[7:0]の16ポートの割り込みを個々に制御できるよう、Pポートモジュール内には、16ポートに個々に対応する割り込みフラグPxIF[7:0]が用意されています。対応するPxIE[7:0]を1に設定しておくことにより、PxIF[7:0]は入力信号の指定エッジ(立ち上がりエッジまたは立ち下がりエッジ)で1にセットされます。同時に、ITCに対してP0またはP1ポート割り込み要求信号が出力されます。この割り込み要求信号により、ITC内のP0/P1ポート割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

\* **P0IF[7:0]**: P0[7:0] Port Interrupt Flags in the P0 Port Interrupt Flag (P0\_IFLG) Register (D[7:0]/0x5207)

\* **P1IF[7:0]**: P1[7:0] Port Interrupt Flags in the P1 Port Interrupt Flag (P1\_IFLG) Register (D[7:0]/0x5217)

割り込み要因の発生状態をPポートモジュールの割り込みフラグで管理するため、以下の処理が必要です。

1. ITCのP0およびP1割り込みのトリガモードをレベルトリガモードに設定
2. 割り込み発生後は、割り込み処理ルーチン内で、Pポートモジュール内の割り込みフラグ PxIF[7:0]をリセット(これによりITCの割り込みフラグもリセットされます)

PxIF[7:0]は1の書き込みによりリセットされます。

**注:** 不要な割り込みの発生を防止するため、PxIE[7:0](Px\_IMSKレジスタ)によって必要なポートの割り込みを許可する前に、対応するPxIF[7:0]をリセットしてください。

## ポート割り込み用ITCレジスタ

前述の設定により、割り込みを許可されたポートが入力信号の指定のエッジを検出すると、P0またはP1ポート割り込み信号をITCに出力します。

ポート割り込みを発生させるには、ITCレジスタで割り込みレベルと割り込み許可の設定を行ってください。

表10.7.1に、ポート割り込み用のITC制御ビットを示します。

表10.7.1 ITCの制御ビット

| ポート | 割り込みフラグ             | 割り込みイネーブル         | 割り込みレベル設定                     | トリガモード設定             |
|-----|---------------------|-------------------|-------------------------------|----------------------|
| P0  | EIFT0 (D0/ITC_IFLG) | EIEN0 (D0/ITC_EN) | EILV0[2:0] (D[2:0]/ITC_ELV0)  | EITG0 (D4/ITC_ELV0)  |
| P1  | EIFT1 (D1/ITC_IFLG) | EIEN1 (D1/ITC_EN) | EILV1[2:0] (D[10:8]/ITC_ELV0) | EITG1 (D12/ITC_ELV0) |

ITC\_IFLGレジスタ (0x4300)

ITC\_ENレジスタ (0x4302)

ITC\_ELV0レジスタ (0x4306)

P0またはP1ポート割り込み信号がアクティブになると、対応するITCの割り込みフラグが1にセットされます。その割り込みフラグに対応する割り込みイネーブルビットが1に設定されていると、ITCは割り込み要求をS1C17コアに送ります。ポート割り込みを禁止するには、割り込みイネーブルビットを0に設定しておきます。割り込みフラグは、割り込みイネーブルビットの設定にかかわらず(0に設定されていても)、P0またはP1ポート割り込み信号によって1にセットされます。

割り込みレベル設定ビットは、ポート割り込みのレベル(0~7)を設定します。同一の割り込みレベルに設定した場合、P0ポートの優先順位が高くなっています。

前述のとおり、ポート割り込みのトリガモード設定ビットは必ず1(レベルトリガ)に設定してください。

S1C17コアは、以下のすべての条件が成立している場合に割り込みを受け付けます。

- 割り込みイネーブルビットが1にセットされている。
- PSR(S1C17コア内のプロセッサステータスレジスタ)のIE(割り込みイネーブル)ビットが1にセットされている。
- ポート割り込みが、PSRのIL(割り込みレベル)に設定されている値よりも高い割り込みレベルに設定されている。
- NMIなど、他の優先順位の高い割り込み要因が発生していない。

これらの割り込み制御レジスタの詳細と割り込み発生時の動作については、“6 割り込みコントローラ(ITC)”を参照してください。

## 割り込みベクタ

ポート割り込みのベクタ番号とベクタアドレスは以下のとおりです。

表10.7.2 ポート割り込みベクタ

| ポート | ベクタ番号   | ベクタアドレス |
|-----|---------|---------|
| P0  | 4(0x04) | 0x8010  |
| P1  | 5(0x05) | 0x8014  |

## 10.8 制御レジスタ詳細

表10.8.1 入出力ポート制御レジスター一覧

| アドレス   | レジスタ名   | 機能                                             |
|--------|---------|------------------------------------------------|
| 0x5200 | P0_IN   | P0 Port Input Data Register                    |
| 0x5201 | P0_OUT  | P0 Port Output Data Register                   |
| 0x5202 | P0_IO   | P0 Port I/O Direction Control Register         |
| 0x5203 | P0_PU   | P0 Port Pull-up Control Register               |
| 0x5205 | P0_IMSK | P0 Port Interrupt Mask Register                |
| 0x5206 | P0_EDGE | P0 Port Interrupt Edge Select Register         |
| 0x5207 | P0_IFLG | P0 Port Interrupt Flag Register                |
| 0x5208 | P0_CHAT | P0 Port Chattering Filter Control Register     |
| 0x5209 | P0_KRST | P0 Port Key-Entry Reset Configuration Register |
| 0x5210 | P1_IN   | P1 Port Input Data Register                    |
| 0x5211 | P1_OUT  | P1 Port Output Data Register                   |
| 0x5212 | P1_IO   | P1 Port I/O Direction Control Register         |
| 0x5213 | P1_PU   | P1 Port Pull-up Control Register               |
| 0x5215 | P1_IMSK | P1 Port Interrupt Mask Register                |
| 0x5216 | P1_EDGE | P1 Port Interrupt Edge Select Register         |
| 0x5217 | P1_IFLG | P1 Port Interrupt Flag Register                |
| 0x5220 | P2_IN   | P2 Port Input Data Register                    |
| 0x5221 | P2_OUT  | P2 Port Output Data Register                   |
| 0x5222 | P2_IO   | P2 Port I/O Direction Control Register         |
| 0x5223 | P2_PU   | P2 Port Pull-up Control Register               |
| 0x5230 | P3_IN   | P3 Port Input Data Register                    |
| 0x5231 | P3_OUT  | P3 Port Output Data Register                   |
| 0x5232 | P3_IO   | P3 Port I/O Direction Control Register         |
| 0x5233 | P3_PU   | P3 Port Pull-up Control Register               |
| 0x52a0 | P0_PMUX | P0 Port Function Select Register               |
| 0x52a1 | P1_PMUX | P1 Port Function Select Register               |
| 0x52a2 | P2_PMUX | P2 Port Function Select Register               |
| 0x52a3 | P3_PMUX | P3 Port Function Select Register               |

以下、入出力ポートのレジスタを個々に説明します。これらはすべて8ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

**0x5200/0x5210/0x5220/0x5230: Px Port Input Data Registers (Px\_IN)**

| Register name                       | Address | Bit  | Name      | Function                | Setting |       |   | Init. | R/W | Remarks            |
|-------------------------------------|---------|------|-----------|-------------------------|---------|-------|---|-------|-----|--------------------|
| P0 Port Input Data Register (P0_IN) | 0x5200  | D7-0 | P0IN[7:0] | P0[7:0] port input data | 1       | 1 (H) | 0 | 0 (L) | ×   | R                  |
| P1 Port Input Data Register (P1_IN) | 0x5210  | D7-0 | P1IN[7:0] | P1[7:0] port input data | 1       | 1 (H) | 0 | 0 (L) | ×   | R                  |
| P2 Port Input Data Register (P2_IN) | 0x5220  | D7-0 | P2IN[7:0] | P2[7:0] port input data | 1       | 1 (H) | 0 | 0 (L) | ×   | R                  |
| P3 Port Input Data Register (P3_IN) | 0x5230  | D7-4 | —         | reserved                | —       | —     | — | —     | —   | 0 when being read. |
|                                     |         | D3-0 | P3IN[3:0] | P3[3:0] port input data | 1       | 1 (H) | 0 | 0 (L) | ×   | R                  |

注: ビット名などの'x'はポート番号の0~3を示します。

**D[7:0] PxIN[7:0]: Px[7:0] Port Input Data Bits (P3ポートはP3IN[3:0])**

Pポート端子の状態が読み出せます。(デフォルト: 外部端子の状態)

1(R): Highレベル

0(R): Lowレベル

PxIN[7:0]はPx[7:0]端子と1対1に対応し、入力/出力モードにかかわらず端子の電圧レベルが読み出せます。端子電圧がHighの場合の読み出し値は1、Lowの場合の読み出し値は0です。PxIN[7:0]は読み出し専用のため、書き込み操作は無効です。

**0x5201/0x5211/0x5221/0x5231: Px Port Output Data Registers (Px\_OUT)**

| Register name                         | Address         | Bit  | Name       | Function                 | Setting |       | Init. | R/W   | Remarks            |     |
|---------------------------------------|-----------------|------|------------|--------------------------|---------|-------|-------|-------|--------------------|-----|
| P0 Port Output Data Register (P0_OUT) | 0x5201 (8 bits) | D7-0 | P0OUT[7:0] | P0[7:0] port output data | 1       | 1 (H) | 0     | 0 (L) | 0                  | R/W |
| P1 Port Output Data Register (P1_OUT) | 0x5211 (8 bits) | D7-0 | P1OUT[7:0] | P1[7:0] port output data | 1       | 1 (H) | 0     | 0 (L) | 0                  | R/W |
| P2 Port Output Data Register (P2_OUT) | 0x5221 (8 bits) | D7-0 | P2OUT[7:0] | P2[7:0] port output data | 1       | 1 (H) | 0     | 0 (L) | 0                  | R/W |
| P3 Port Output Data Register (P3_OUT) | 0x5231 (8 bits) | D7-4 | —          | reserved                 | —       | —     | —     | —     | 0 when being read. |     |
|                                       |                 | D3-0 | P3OUT[3:0] | P3[3:0] port output data | 1       | 1 (H) | 0     | 0 (L) | 0                  | R/W |

注: ビット名などの'x'はポート番号の0~3を示します。

**D[7:0] PxOUT[7:0]: Px[7:0] Port Output Data Bits (P3ポートはP3OUT[3:0])**

ポート端子から出力するデータを設定します。

1(R/W): Highレベル

0(R/W): Lowレベル(デフォルト)

PxOUT[7:0]はPx[7:0]端子と1対1に対応し、書き込んだデータがそのままポート端子から出力されます。データビットを1に設定するとポート端子はHighとなり、0に設定するとLowになります。

入力モードの場合もポートデータの書き込みは行えます。

## 0x5202/0x5212/0x5222/0x5232: Px Port I/O Direction Control Registers (Px\_IO)

| Register name                                  | Address            | Bit  | Name      | Function                          | Setting |        |   | Init. | R/W | Remarks            |
|------------------------------------------------|--------------------|------|-----------|-----------------------------------|---------|--------|---|-------|-----|--------------------|
| P0 Port I/O Direction Control Register (P0_IO) | 0x5202<br>(8 bits) | D7–0 | P0IO[7:0] | P0[7:0] port I/O direction select | 1       | Output | 0 | Input | 0   | R/W                |
| P1 Port I/O Direction Control Register (P1_IO) | 0x5212<br>(8 bits) | D7–0 | P1IO[7:0] | P1[7:0] port I/O direction select | 1       | Output | 0 | Input | 0   | R/W                |
| P2 Port I/O Direction Control Register (P2_IO) | 0x5222<br>(8 bits) | D7–0 | P2IO[7:0] | P2[7:0] port I/O direction select | 1       | Output | 0 | Input | 0   | R/W                |
| P3 Port I/O Direction Control Register (P3_IO) | 0x5232<br>(8 bits) | D7–4 | –         | reserved                          | –       | –      | – | –     | –   | 0 when being read. |
|                                                |                    | D3–0 | P3IO[3:0] | P3[3:0] port I/O direction select | 1       | Output | 0 | Input | 0   | R/W                |

注: ビット名などの'x'はポート番号の0~3を示します。

### D[7:0] PxIO[7:0]: Px[7:0] Port I/O Direction Select Bits (P3ポートはP3IO[3:0])

入出力ポートの入力/出力モードを設定します。

1(R/W): 出力モード

0(R/W): 入力モード(デフォルト)

PxIO[7:0]はPx[7:0]ポートと1対1に対応する入出力方向選択ビットで、1に設定するとポートが出力モードに、0に設定すると入力モードになります。端子を周辺モジュール用に使用する場合の入出力方向は、周辺モジュールの機能により決まります。

**0x5203/0x5213/0x5223/0x5233: Px Port Pull-up Control Registers (Px\_PU)**

| Register name                            | Address         | Bit  | Name      | Function                    | Setting |        | Init. | R/W     | Remarks            |     |
|------------------------------------------|-----------------|------|-----------|-----------------------------|---------|--------|-------|---------|--------------------|-----|
| P0 Port Pull-up Control Register (P0_PU) | 0x5203 (8 bits) | D7-0 | P0PU[7:0] | P0[7:0] port pull-up enable | 1       | Enable | 0     | Disable | 1                  | R/W |
| P1 Port Pull-up Control Register (P1_PU) | 0x5213 (8 bits) | D7-0 | P1PU[7:0] | P1[7:0] port pull-up enable | 1       | Enable | 0     | Disable | 1                  | R/W |
| P2 Port Pull-up Control Register (P2_PU) | 0x5223 (8 bits) | D7-0 | P2PU[7:0] | P2[7:0] port pull-up enable | 1       | Enable | 0     | Disable | 1                  | R/W |
| P3 Port Pull-up Control Register (P3_PU) | 0x5233 (8 bits) | D7-4 | —         | reserved                    | —       | —      | —     | —       | 0 when being read. |     |
|                                          |                 | D3-0 | P3PU[3:0] | P3[3:0] port pull-up enable | 1       | Enable | 0     | Disable | 1                  | R/W |

注: ビット名などの'x'はポート番号の0~3を示します。

**D[7:0] PxPU[7:0]: Px[7:0] Port Pull-up Enable Bits (P3ポートはP3PU[3:0])**

各ポートに内蔵されているプルアップ抵抗を有効/無効に設定します。

1(R/W): 有効(デフォルト)

0(R/W): 無効

PxPU[7:0]はPx[7:0]ポートと1対1に対応するプルアップ制御ビットで、1に設定するとプルアップ抵抗が有効になり、入力モード時にポート端子がプルアップされます。0に設定するとプルアップされません。

出力モード時には、PxPU[7:0]の設定は無効となり、プルアップされません。

使用しない入出力ポートについてはプルアップを有効に設定してください。

周辺モジュール用の機能を選択したポートも、このプルアップ設定は有効です。

内蔵プルアップ抵抗によって、ポート端子をLowレベルからHighレベルに変化させる場合、プルアップ抵抗と端子の負荷容量等の時定数によって波形立ち上がりに遅延が生じます。このため、入出力ポートの取り込みには適切な待ち時間の設定が必要となります。待ち時間は以下の式で求められる値以上を設定してください。

$$\text{待ち時間} = R_{IN} \times (C_{IN} + \text{基板上の負荷容量}) \times 1.6 \text{ [秒]}$$

R<sub>IN</sub>: プルアップ抵抗Max.値

C<sub>IN</sub>: 端子容量Max.値

## 0x5205/5215: Px Port Interrupt Mask Registers (Px\_IMSK)

| Register name                             | Address         | Bit  | Name      | Function                      | Setting |        | Init. | R/W     | Remarks |
|-------------------------------------------|-----------------|------|-----------|-------------------------------|---------|--------|-------|---------|---------|
| P0 Port Interrupt Mask Register (P0_IMSK) | 0x5205 (8 bits) | D7-0 | P0IE[7:0] | P0[7:0] port interrupt enable | 1       | Enable | 0     | Disable | 0 R/W   |
| P1 Port Interrupt Mask Register (P1_IMSK) | 0x5215 (8 bits) | D7-0 | P1IE[7:0] | P1[7:0] port interrupt enable | 1       | Enable | 0     | Disable | 0 R/W   |

注: ビット名などの'x'はポート番号の0と1を示します。

### D[7:0] PxIE[7:0]: Px[7:0] Port Interrupt Enable Bits

P0[7:0]とP1[7:0]の各ポートによる割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

PxIE[7:0]を1に設定すると対応する割り込みが許可され、0に設定すると割り込みが禁止されます。割り込み禁止に設定した入力端子の状態変化は、割り込みの発生に影響を与えません。

なお、割り込みを発生させるには、ITCのP0、P1ポート割り込みイネーブルビットも割り込み許可に設定する必要があります。

**0x5206/5216: Px Port Interrupt Edge Select Registers (Px\_EDGE)**

| Register name                                             | Address            | Bit  | Name        | Function                           | Setting |                 | Init. | R/W         | Remarks |     |
|-----------------------------------------------------------|--------------------|------|-------------|------------------------------------|---------|-----------------|-------|-------------|---------|-----|
| P0 Port<br>Interrupt Edge<br>Select Register<br>(P0_EDGE) | 0x5206<br>(8 bits) | D7–0 | P0EDGE[7:0] | P0[7:0] port interrupt edge select | 1       | Falling<br>edge | 0     | Rising edge | 0       | R/W |
| P1 Port<br>Interrupt Edge<br>Select Register<br>(P1_EDGE) | 0x5216<br>(8 bits) | D7–0 | P1EDGE[7:0] | P1[7:0] port interrupt edge select | 1       | Falling<br>edge | 0     | Rising edge | 0       | R/W |

注: ビット名などの'x'はポート番号の0と1を示します。

**D[7:0] PxEDGE[7:0]: Px[7:0] Port Interrupt Edge Select Bits**

P0[7:0]とP1[7:0]の各ポートの割り込みを発生させる入力信号のエッジを選択します。

1(R/W): 立ち下がりエッジ

0(R/W): 立ち上がりエッジ(デフォルト)

PxEDGE[7:0]を1に設定したポートの割り込みは入力信号の立ち下がりエッジで発生し、0に設定すると立ち上がりエッジで発生します。

## 0x5207/5217: Px Port Interrupt Flag Registers (Px\_IFLG)

| Register name                             | Address         | Bit  | Name      | Function                    | Setting |                             | Init. | R/W                             | Remarks                   |
|-------------------------------------------|-----------------|------|-----------|-----------------------------|---------|-----------------------------|-------|---------------------------------|---------------------------|
| P0 Port Interrupt Flag Register (P0_IFLG) | 0x5207 (8 bits) | D7-0 | P0IF[7:0] | P0[7:0] port interrupt flag | 1       | Cause of interrupt occurred | 0     | Cause of interrupt not occurred | 0 R/W Reset by writing 1. |
| P1 Port Interrupt Flag Register (P1_IFLG) | 0x5217 (8 bits) | D7-0 | P1IF[7:0] | P1[7:0] port interrupt flag | 1       | Cause of interrupt occurred | 0     | Cause of interrupt not occurred | 0 R/W Reset by writing 1. |

注: ビット名などの'x'はポート番号の0と1を示します。

### D[7:0] PxIF[7:0]: Px[7:0] Port Interrupt Flags

割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり
- 0(R): 割り込み要因なし(デフォルト)
- 1(W): フラグをリセット
- 0(W): 無効

PxIF[7:0]はP0[7:0]とP1[7:0]の16ポートに個々に対応する割り込みフラグです。対応するPxIE[7:0](Px\_IMSKレジスタ)を1に設定しておくことにより、入力信号の指定エッジ(立ち上がりエッジまたは立ち下がりエッジ)で1にセットされます。同時に、ITCに対してP0またはP1ポート割り込み要求信号が outputされます。この割り込み要求信号により、ITC内のP0/P1ポート割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

割り込み要因の発生状態をPxIF[7:0]で管理するため、以下の処理が必要です。

1. ITCのP0およびP1割り込みのトリガモードをレベルトリガモードに設定
2. 割り込み発生後は、割り込み処理ルーチン内で、Pポートモジュール内の割り込みフラグ PxIF[7:0]をリセット(これによりITCの割り込みフラグもリセットされます)

PxIF[7:0]は1の書き込みによりリセットされます。

注: 不要な割り込みの発生を防止するため、PxIE[7:0](Px\_IMSKレジスタ)によって必要なポートの割り込みを許可する前に、対応するPxIF[7:0]をリセットしてください。

- \* **P0IE[7:0]: P0[7:0] Port Interrupt Enable Bits in the P0 Port Interrupt Mask (P0\_IMSK) Register (D[7:0]/0x5205)**
- \* **P1IE[7:0]: P1[7:0] Port Interrupt Enable Bits in the P1 Port Interrupt Mask (P1\_IMSK) Register (D[7:0]/0x5215)**

## 0x5208: P0 Port Chattering Filter Control Register (P0\_CHAT)

| Register name                                        | Address         | Bit  | Name       | Function                       | Setting    |                    | Init. | R/W | Remarks            |
|------------------------------------------------------|-----------------|------|------------|--------------------------------|------------|--------------------|-------|-----|--------------------|
| P0 Port Chattering Filter Control Register (P0_CHAT) | 0x5208 (8 bits) | D7   | —          | reserved                       | —          | —                  | —     | —   | 0 when being read. |
|                                                      |                 | D6-4 | P0CF2[2:0] | P0[7:4] chattering filter time | P0CF2[2:0] | Filter time        | 0     | R/W |                    |
|                                                      |                 |      |            |                                | 0x7        | 16384/fPCLK        | 0x0   | R/W |                    |
|                                                      |                 |      |            |                                | 0x6        | 8192/fPCLK (4ms)   |       |     |                    |
|                                                      |                 |      |            |                                | 0x5        | 4096/fPCLK (2ms)   |       |     |                    |
|                                                      |                 |      |            |                                | 0x4        | 2048/fPCLK (1ms)   |       |     |                    |
|                                                      |                 |      |            |                                | 0x3        | 1024/fPCLK (512μs) |       |     |                    |
|                                                      |                 |      |            |                                | 0x2        | 512/fPCLK (256μs)  |       |     |                    |
|                                                      |                 |      |            |                                | 0x1        | 256/fPCLK (128μs)  |       |     |                    |
|                                                      |                 |      |            |                                | 0x0        | なし(Off)            |       |     |                    |
|                                                      | D3              | —    | reserved   | —                              | —          | —                  | —     | —   | 0 when being read. |
|                                                      |                 | D2-0 | P0CF1[2:0] | P0[3:0] chattering filter time | P0CF1[2:0] | Filter time        | 0x0   | R/W |                    |
|                                                      |                 |      |            |                                | 0x7        | 16384/fPCLK        |       |     |                    |
|                                                      |                 |      |            |                                | 0x6        | 8192/fPCLK         |       |     |                    |
|                                                      |                 |      |            |                                | 0x5        | 4096/fPCLK         |       |     |                    |

### D7 Reserved

### D[6:4] P0CF2[2:0]: P0[7:4] Chattering Filter Time Select Bits

P0[7:4]ポートに組み込まれているチャタリング除去回路を設定します。

### D3 Reserved

### D[2:0] P0CF1[2:0]: P0[3:0] Chattering Filter Time Select Bits

P0[3:0]ポートに組み込まれているチャタリング除去回路を設定します。

P0ポートにはキー入力用のチャタリング除去回路が設けられています。この機能を使用するか否か、また、使用する場合は検定時間を、P0CFx[2:0]によってP0[3:0]、P0[7:4]の4ポートごとに選択します。

表10.8.2 チャタリング除去機能の設定

| P0CFx[2:0] | 検定時間 *             |
|------------|--------------------|
| 0x7        | 16384/fPCLK (8ms)  |
| 0x6        | 8192/fPCLK (4ms)   |
| 0x5        | 4096/fPCLK (2ms)   |
| 0x4        | 2048/fPCLK (1ms)   |
| 0x3        | 1024/fPCLK (512μs) |
| 0x2        | 512/fPCLK (256μs)  |
| 0x1        | 256/fPCLK (128μs)  |
| 0x0        | なし(Off)            |

(デフォルト: 0x0, \* OSC3=2MHz, PCLK=OSC3の場合)

- 注:
- チャタリング除去の検定時間は、除去できる最大パルス幅のことを指します。入力割り込みを発生させるには、最小で検定時間、最大で検定時間の2倍の入力時間が必要になります。
  - チャタリング除去がOnに設定されたままSLEEPモードに入ると、入力割り込みを受け付けません。slp命令実行前に、チャタリング除去をOff(時間検定なし)に設定してください。
  - P0\_CHATレジスタの設定変更は、必ずP0ポート割り込みが禁止されている状態で行ってください。割り込みが許可されている状態で設定を変更すると、P0ポート割り込みが誤って発生する場合があります。
  - 入力信号の立ち上がり/立ち下がり時間が遅い場合、信号がしきい値を通過するまでに時間がかかり、内部信号が発振する現象が起こる可能性があります。この場合、入力割り込みは誤動作しますので、入力信号の立ち上がり/立ち下がり時間は25ns以下を目安に設定してください。

## 0x5209: P0 Port Key-Entry Reset Configuration Register (P0\_KRST)

| Register name                                            | Address            | Bit  | Name        | Function                              | Setting     |               | Init. | R/W | Remarks            |
|----------------------------------------------------------|--------------------|------|-------------|---------------------------------------|-------------|---------------|-------|-----|--------------------|
| P0 Port Key-Entry Reset Configuration Register (P0_KRST) | 0x5209<br>(8 bits) | D7-2 | -           | reserved                              | -           | -             | -     | -   | 0 when being read. |
|                                                          |                    | D1-0 | P0KRST[1:0] | P0 port key-entry reset configuration | P0KRST[1:0] | Configuration | 0x0   | R/W |                    |
|                                                          |                    |      |             |                                       | 0x3         | P0[3:0] = 0   |       |     |                    |
|                                                          |                    |      |             |                                       | 0x2         | P0[2:0] = 0   |       |     |                    |
|                                                          |                    |      |             |                                       | 0x1         | P0[1:0] = 0   |       |     |                    |
|                                                          |                    |      |             |                                       | 0x0         | Disable       |       |     |                    |

D[7:2] Reserved

D[1:0] P0KRST[1:0]: P0 Port Key-Entry Reset Configuration Bits

P0ポートキー入力リセットに使用するポートの組み合わせを選択します。

表10.8.3 P0ポートキー入力リセットの設定

| P0KRST[1:0] | 使用するポート            |
|-------------|--------------------|
| 0x3         | P00, P01, P02, P03 |
| 0x2         | P00, P01, P02      |
| 0x1         | P00, P01           |
| 0x0         | 使用しない              |

(デフォルト: 0x0)

キー入力リセットは、ここで選択されたポートに、外部から同時にLowレベルを入力することでイニシャルリセットを行う機能です。

たとえば、P0KRST[1:0]を0x3に設定した場合、P00～P03の4ポートの入力が同時にLowレベルになったときにイニシャルリセットがかかります。

このリセット機能を使用しない場合はP0KRST[1:0]を0x0に設定します。

- 注:
- P0ポートキー入力リセット機能を使用する場合、通常動作時に指定ポートが同時にLowレベルにならないように注意してください。
  - P0ポートキー入力リセット機能はイニシャルリセット時に無効となりますので、電源投入時のリセットには使用できません。
  - SLEEP状態では、P0ポートキー入力リセット機能は使用できません。

**0x52a0: P0 Port Function Select Register (P0\_PMUX)**

| Register name                              | Address | Bit  | Name   | Function                 | Setting            | Init. | R/W | Remarks            |
|--------------------------------------------|---------|------|--------|--------------------------|--------------------|-------|-----|--------------------|
| P0 Port Function Select Register (P0_PMUX) | 0x52a0  | D7-6 | —      | reserved                 | —                  | —     | —   | 0 when being read. |
|                                            |         | D5   | P05MUX | P05 port function select | 1   REMO   0   P05 | 0     | R/W |                    |
|                                            |         | D4   | P04MUX | P04 port function select | 1   REMI   0   P04 | 0     | R/W |                    |
|                                            |         | D3-0 | —      | reserved                 | —                  | —     | —   | 0 when being read. |

P04とP05入出力ポート端子は周辺モジュール用端子を兼ねています。このレジスタで、どちらの端子として使用するか選択します。

**D[7:6] Reserved****D5 P05MUX: P05 Port Function Select Bit**

1(R/W): REMO(REMC)

0(R/W): P05ポート(デフォルト)

**D4 P04MUX: P04 Port Function Select Bit**

1(R/W): REMI(REMC)

0(R/W): P04ポート(デフォルト)

**D[3:0] Reserved**

## 0x52a1: P1 Port Function Select Register (P1\_PMUX)

| Register name                                       | Address            | Bit  | Name   | Function                 | Setting |        | Init. | R/W | Remarks            |
|-----------------------------------------------------|--------------------|------|--------|--------------------------|---------|--------|-------|-----|--------------------|
| P1 Port<br>Function Select<br>Register<br>(P1_PMUX) | 0x52a1<br>(8 bits) | D7   | P17MUX | P17 port function select | 1       | #SPISS | 0     | P17 | 0 R/W              |
|                                                     |                    | D6   | -      | reserved                 | -       | -      | -     | -   | 0 when being read. |
|                                                     |                    | D5   | P15MUX | P15 port function select | 1       | SCL    | 0     | P15 | 0 R/W              |
|                                                     |                    | D4   | P14MUX | P14 port function select | 1       | SDA    | 0     | P14 | 0 R/W              |
|                                                     |                    | D3   | P13MUX | P13 port function select | 1       | FOUT1  | 0     | P13 | 0 R/W              |
|                                                     |                    | D2-0 | -      | reserved                 | -       | -      | -     | -   | 0 when being read. |
|                                                     |                    |      |        |                          |         |        |       |     |                    |

P13～P15とP17入出力ポート端子は周辺モジュール用端子を兼ねています。このレジスタで、どちらの端子として使用するか選択します。

### D7 P17MUX: P17 Port Function Select Bit

1(R/W): #SPISS(SPI)

0(R/W): P17ポート(デフォルト)

### D6 Reserved

### D5 P15MUX: P15 Port Function Select Bit

1(R/W): SCL(I2C)

0(R/W): P15ポート(デフォルト)

### D4 P14MUX: P14 Port Function Select Bit

1(R/W): SDA(I2C)

0(R/W): P14ポート(デフォルト)

### D3 P13MUX: P13 Port Function Select Bit

1(R/W): FOUT1(OSC)

0(R/W): P13ポート(デフォルト)

### D[2:0] Reserved

**0x52a2: P2 Port Function Select Register (P2\_PMUX)**

| Register name                              | Address | Bit | Name   | Function                 | Setting |        | Init. | R/W | Remarks |
|--------------------------------------------|---------|-----|--------|--------------------------|---------|--------|-------|-----|---------|
| P2 Port Function Select Register (P2_PMUX) | 0x52a2  | D7  | P27MUX | P27 port function select | 1       | EXCL3  | 0     | P27 | 0 R/W   |
|                                            |         | D6  | P26MUX | P26 port function select | 1       | TOUT   | 0     | P26 | 0 R/W   |
|                                            |         | D5  | P25MUX | P25 port function select | 1       | SCLK   | 0     | P25 | 0 R/W   |
|                                            |         | D4  | P24MUX | P24 port function select | 1       | SOUT   | 0     | P24 | 0 R/W   |
|                                            |         | D3  | P23MUX | P23 port function select | 1       | SIN    | 0     | P23 | 0 R/W   |
|                                            |         | D2  | P22MUX | P22 port function select | 1       | SPICLK | 0     | P22 | 0 R/W   |
|                                            |         | D1  | P21MUX | P21 port function select | 1       | SDO    | 0     | P21 | 0 R/W   |
|                                            |         | D0  | P20MUX | P20 port function select | 1       | SDI    | 0     | P20 | 0 R/W   |

P20～P27入出力ポート端子は周辺モジュール用端子を兼ねています。このレジスタで、どちらの端子として使用するか選択します。

**D7 P27MUX: P27 Port Function Select Bit**

1(R/W): EXCL3(T16E)

0(R/W): P27ポート(デフォルト)

**D6 P26MUX: P26 Port Function Select Bit**

1(R/W): TOUT(T16E)

0(R/W): P26ポート(デフォルト)

**D5 P25MUX: P25 Port Function Select Bit**

1(R/W): SCLK(UART)

0(R/W): P25ポート(デフォルト)

**D4 P24MUX: P24 Port Function Select Bit**

1(R/W): SOUT(UART)

0(R/W): P24ポート(デフォルト)

**D3 P23MUX: P23 Port Function Select Bit**

1(R/W): SIN(UART)

0(R/W): P23ポート(デフォルト)

**D2 P22MUX: P22 Port Function Select Bit**

1(R/W): SPICLK(SPI)

0(R/W): P22ポート(デフォルト)

**D1 P21MUX: P21 Port Function Select Bit**

1(R/W): SDO(SPI)

0(R/W): P21ポート(デフォルト)

**D0 P20MUX: P20 Port Function Select Bit**

1(R/W): SDI(SPI)

0(R/W): P20ポート(デフォルト)

## 0x52a3: P3 Port Function Select Register (P3\_PMUX)

| Register name                                       | Address | Bit  | Name   | Function                 | Setting |       | Init. | R/W  | Remarks            |
|-----------------------------------------------------|---------|------|--------|--------------------------|---------|-------|-------|------|--------------------|
| P3 Port<br>Function Select<br>Register<br>(P3_PMUX) | 0x52a3  | D7-4 | —      | reserved                 | —       | —     | —     | —    | 0 when being read. |
|                                                     |         | D3   | P33MUX | P33 port function select | 1       | P33   | 0     | DSIO | 0 R/W              |
|                                                     |         | D2   | P32MUX | P32 port function select | 1       | P32   | 0     | DST2 | 0 R/W              |
|                                                     |         | D1   | P31MUX | P31 port function select | 1       | P31   | 0     | DCLK | 0 R/W              |
|                                                     |         | D0   | P30MUX | P30 port function select | 1       | FOUT3 | 0     | P30  | 0 R/W              |

P30～P33入出力ポート端子は周辺モジュール用端子を兼ねています。このレジスタで、どちらの端子として使用するか選択します。

### D[7:4] Reserved

#### D3 P33MUX: P33 Port Function Select Bit

1(R/W): P33ポート  
0(R/W): DSIO(DBG) (デフォルト)

#### D2 P32MUX: P32 Port Function Select Bit

1(R/W): P32ポート  
0(R/W): DST2(DBG) (デフォルト)

#### D1 P31MUX: P31 Port Function Select Bit

1(R/W): P31ポート  
0(R/W): DCLK(DBG) (デフォルト)

#### D0 P30MUX: P30 Port Function Select Bit

1(R/W): FOUT3(OSC)  
0(R/W): P30ポート(デフォルト)

## 10.9 注意事項

### 動作クロック

- 入出力ポートをアクセスするためには、クロックジェネレータからPCLKクロックが供給されている必要があります。
- また、P0ポートのチャタリングフィルタの動作にはプリスケーラ出力クロックも必要です。この機能を使用する場合は、プリスケーラもOnにしてください。

### プルアップ

- 内蔵プルアップ抵抗によって、ポート端子をLowレベルからHighレベルに変化させる場合、プルアップ抵抗と端子の負荷容量等の時定数によって波形立ち上がりに遅延が生じます。このため、入出力ポートの取り込みには適切な待ち時間の設定が必要となります。待ち時間は以下の式で求められる値以上を設定してください。

$$\text{待ち時間} = R_{IN} \times (C_{IN} + \text{基板上の負荷容量}) \times 1.6 \text{ [秒]}$$

R<sub>IN</sub>: プルアップ抵抗Max.値

C<sub>IN</sub>: 端子容量Max.値

- 使用しない入出力ポートについてはプルアップ抵抗を有効に設定してください。

### P0、P1ポート割り込み

- 不要な割り込みの発生を防止するため、P0\_IMSKレジスタ(0x5205)、P1\_IMSKレジスタ(0x5215)によって必要なポートの割り込みを許可する前に、対応する割り込みフラグPOIF[7:0](0x5207)、P1IF[7:0](0x5217)をリセットしてください。
- ITCのP0およびP1ポート割り込みのトリガモードをレベルトリガモードに設定してください。割り込み発生後は、割り込み処理ルーチン内で、Pポートモジュール内の割り込みフラグPOIF[7:0](0x5207)、P1IF[7:0](0x5217)をリセットします。(これによりITCの割り込みフラグもリセットされます。)

### P0ポートチャタリング除去回路

- チャタリング除去がOnに設定されたままSLEEPモードに入ると、入力割り込みを受け付けません。slp命令実行前に、チャタリング除去をOff(時間検定なし)に設定してください。
- P0\_CHATレジスタ(0x5208)の設定変更は、必ずP0ポート割り込みが禁止されている状態で行ってください。割り込みが許可されている状態で設定を変更すると、P0ポート割り込みが誤って発生する場合があります。
- チャタリング除去の検定時間は、除去できる最大パルス幅のことを指します。入力割り込みを発生させるには、最小で検定時間、最大で検定時間の2倍の入力時間が必要になります。
- 入力信号の立ち上がり/立ち下がり時間が遅い場合、信号がしきい値を通過するまでに時間がかかり、内部信号が発振する現象が起こる可能性があります。この場合、入力割り込みは誤動作しますので、入力信号の立ち上がり/立ち下がり時間は25ns以下を目安に設定してください。

### P0ポートキー入力リセット

- P0ポートキー入力リセット機能を使用する場合、通常動作時に指定ポートが同時にLowレベルにならないように注意してください。
- P0ポートキー入力リセット機能はイニシャルリセット時に無効となりますので、電源投入時のリセットには使用できません。
- SLEEP状態では、P0ポートキー入力リセット機能は使用できません。

# 11 16ビットタイマ(T16)

## 11.1 16ビットタイマの概要

S1C17001には3チャネルの16ビットタイマ(T16)が内蔵されています。

16ビットタイマは16ビットプリセッタブルダウンカウンタとプリセット値を保持する16ビットリロードデータレジスタで構成されます。タイマはリロードデータレジスタに設定した初期値からカウントダウンを行い、カウンタのアンダーフローによってアンダーフロー信号を出力します。アンダーフロー信号は、割り込みの発生や内部シリアルインターフェース用のクロック生成に使用されます。アンダーフロー周期はプリスケーラクロックとリロードデータの選択によりプログラム可能なため、アプリケーションプログラムは任意の時間間隔やシリアル転送速度を得ることができます。

また、入出力ポート端子を使用したイベントカウンタ機能と外部入力信号のパルス幅測定機能も合わせ持っています。

図11.1.1に16ビットタイマの構造を示します。



図11.1.1 16ビットタイマの構造(1チャネル)

注: 3チャネルの16ビットタイマモジュールは、制御レジスタのアドレスを除きすべて同じ機能をっていますので、本節内の説明は16ビットタイマの全チャネルに適用されます。レジスタ名の'x'はチャネル番号(0~2)を表します。また、レジスタのアドレスは(Ch.0/Ch.1/Ch.2)のように記述されています。

例: T16\_CTLxレジスタ (0x4226/0x4246/0x4266)

Ch.0: T16\_CTL0レジスタ (0x4226)

Ch.1: T16\_CTL1レジスタ (0x4246)

Ch.2: T16\_CTL2レジスタ (0x4266)

## 11.2 16ビットタイマの動作モード

16ビットタイマには3つの動作モードがあります。

1. 内部クロックモード(内部クロックをカウントする通常のタイマ)
2. 外部クロックモード(イベントカウンタとして機能)
3. パルス幅測定モード(外部入力パルス幅を内部クロックでカウント)

この中の1つをCKSL[1:0](D[9:8]/T16\_CTLxレジスタ)で選択します。

\* **CKSL[1:0]**: Input Clock and Pulse Width Count Mode Select Bits in the 16-bit Timer Ch.x Control (T16\_CTLx) Register (D[9:8]/0x4226/0x4246/0x4266)

表11.2.1 動作モードの選択

| CKSL[1:0] | 動作モード     |
|-----------|-----------|
| 0x3       | Reserved  |
| 0x2       | パルス幅測定モード |
| 0x1       | 外部クロックモード |
| 0x0       | 内部クロックモード |

(デフォルト:0x0)

### 11.2.1 内部クロックモード

内部クロックモードでは、プリスケーラ出力クロックをカウントクロックとして使用します。

タイマはリロードデータレジスタに設定した初期値からカウントダウンを行い、カウンタのアンダーフローによってアンダーフロー信号を出力します。アンダーフロー信号は、割り込みの発生や内部シリアルインターフェース用のクロック生成に使用されます。プリスケーラクロックとカウンタ初期値の選択によってアンダーフロー発生までの時間を細かくプログラム可能なため、シリアル転送クロックの生成や単発的な時間計測等に有効です。

#### カウントクロックの選択

カウントクロックは、プリスケーラがPCLKクロックを1/1~1/16Kに分周して生成した15種類の中から1つをDF[3:0](D[3:0]/T16\_CLKxレジスタ)で選択します。

\* **DF[3:0]**: Timer Input Clock Select Bits in the 16-bit Timer Ch.x Input Clock Select (T16\_CLKx) Register (D[3:0]/0x4220/0x4240/0x4260)

表11.2.1.1 カウントクロックの選択

| DF[3:0] | プリスケーラ出力クロック | DF[3:0] | プリスケーラ出力クロック |
|---------|--------------|---------|--------------|
| 0xf     | Reserved     | 0x7     | PCLK・1/128   |
| 0xe     | PCLK・1/16384 | 0x6     | PCLK・1/64    |
| 0xd     | PCLK・1/8192  | 0x5     | PCLK・1/32    |
| 0xc     | PCLK・1/4096  | 0x4     | PCLK・1/16    |
| 0xb     | PCLK・1/2048  | 0x3     | PCLK・1/8     |
| 0xa     | PCLK・1/1024  | 0x2     | PCLK・1/4     |
| 0x9     | PCLK・1/512   | 0x1     | PCLK・1/2     |
| 0x8     | PCLK・1/256   | 0x0     | PCLK・1/1     |

(デフォルト:0x0)

注: • 16ビットタイマを内部クロックモードで動作させるには、その前にプリスケーラを動作させておく必要があります。

- カウントクロックの設定は、16ビットタイマがカウント停止中に行ってください。

プリスケーラの制御については、“9 プリスケーラ(PSC)”を参照してください。

## 11.2.2 外部クロックモード

外部クロックモードでは、入出力ポートから入力したクロックやパルスをカウントクロックとして使用します。したがって、イベントカウンタとして使用可能です。入力クロック以外のタイマの動作は内部クロックモードと同じです。

### 外部クロック入力ポート

外部クロック/パルス入力に使用する入力ポートは次のとおりです。

表11.2.2.1 外部クロック入力ポート

| タイマチャネル | 入力信号名 | 入出力ポート端子 |
|---------|-------|----------|
| Ch.0    | EXCL0 | P16      |
| Ch.1    | EXCL1 | P07      |
| Ch.2    | EXCL2 | P06      |

外部クロック/パルス入力に使用する入出力ポートは入力モード(デフォルト)に設定してください。端子機能選択の操作は不要です。入出力ポートは汎用入力として機能しますが、入力信号は16ビットタイマにも送られます。

16ビットタイマCh.1とCh.2が使用するP07とP06ポートにはチャタリング除去回路が組み込まれており、EXCLx入力として使用する場合も有効です。チャタリング除去回路の制御方法については、“10.6 P0ポートのチャタリング除去機能”を参照してください。

### 信号極性の選択

このモードでは、カウントを入力信号の立ち下がりエッジで行うか、立ち上がりエッジで行うかをCKACTV(D10/T16\_CTLxレジスタ)で選択できます。

\* **CKACTV:** External Clock Active Level Select Bit in the 16-bit Timer Ch.x Control (T16\_CTLx) Register (D10/0x4226/0x4246/0x4266)

CKACTVが1(デフォルト)の場合は立ち上がりエッジでカウントダウン、0に設定すると立ち下がりエッジでカウントダウンします。



図11.2.2.1 外部クロックモードのカウント

16ビットタイマは、このモードではプリスケーラを使用しません。ほかにプリスケーラクロックを使用する周辺モジュールがない場合はプリスケーラを停止して消費電流を低減できます。(P0ポートのチャタリング除去にはプリスケーラクロックが使用されます。)

### 11.2.3 パルス幅測定モード

パルス幅測定モードでは、指定極性のパルスが外部クロックポートから入力されると、その信号がアクティブな期間のみ内部クロックが供給され、カウントを行います。これにより、指定幅以上のパルス入力で割り込みを発生させたり、入力パルス幅を測定したりすることができます。

#### パルス入力ポート

外部パルスの入力に使用する入出力ポートは、外部クロックモードと同様です(表11.2.2.1参照)。使用するタイマチャネルに対応する入出力ポートを入力モードにして、パルスを入力してください。

#### カウントクロックの選択

内部クロックモードと同様に、DF[3:0](D[3:0]/T16\_CLKxレジスタ)で選択したプリスケーラ出力クロックでカウントを行います。入力パルスのおよその幅や測定精度に合わせてクロックを選択してください(表11.2.1.1参照)。

#### 信号極性の選択

CKACTV(D10/T16\_CTLxレジスタ)で測定するパルスのアクティブルーレベルを選択します。CKACTVが1(デフォルト)の場合はHigh期間を測定、0に設定するとLow期間を測定します。

##### 例1) パルス幅を測定



##### 例2) 指定幅以上のパルスを検出



図11.2.3.1 パルス幅測定モードのカウント動作

## 11.3 カウントモード

16ビットタイマはリピートモードとワンショットモードの2つのカウントモードを持っています。この選択は、TRMD(D4/T16\_CTLxレジスタ)で行います。

\* **TRMD**: Count Mode Select Bit in the 16-bit Timer Ch.x Control (T16\_CTLx) Register (D4/0x4226/0x4246/0x4266)

### リピートモード( TRMD = 0、デフォルト)

TRMDを0に設定すると、16ビットタイマはリピートモードに設定されます。

このモードでは、カウントを開始するとアプリケーションプログラムで停止するまで16ビットタイマは停止しません。カウンタがアンダーフローすると、タイマはリロードデータレジスタの値をカウンタにプリセットし、カウントを継続します。これにより、タイマは周期的にアンダーフローパルスを出力します。任意の間隔で周期的な割り込みを発生させる場合や、シリアル転送クロックを生成する場合は、16ビットタイマをこのモードに設定してください。

### ワンショットモード( TRMD = 1)

TRMDを1に設定すると、16ビットタイマはワンショットモードに設定されます。

このモードでは、カウンタがアンダーフローした時点で16ビットタイマは自動的に停止します。したがって、タイマをスタート後、割り込みを1回のみ発生可能です。なお、アンダーフロー発生時に、タイマはリロードデータレジスタの値をカウンタにプリセットしてから停止します。特定の待ち時間を作りたい場合やパルス幅測定時などに、16ビットタイマをこのモードに設定してください。

## 11.4 16ビットタイマリロードレジスタとアンダーフロー周期

リロードデータレジスタT16\_TRx(0x4222/0x4242/0x4262)は、ダウンカウンタに初期値をセットするため使用します。

リロードデータレジスタに設定したカウンタ初期値は、16ビットタイマがリセットされるか、カウンタがアンダーフローした時点でダウンカウンタにプリセットされます。16ビットタイマをリセット後にスタートさせると、タイマはリロード値(初期値)からカウントダウンを行います。したがって、このリロード値と入力クロック周波数により、タイマスタートからアンダーフローが発生するまで(またはアンダーフロー間)の時間が決まります。これにより、特定の待ち時間、周期的な割り込みの発生間隔、あるいはプログラマブルなシリアルインターフェースの転送クロックが得られます。



図11.4.1 プリセットタイミング

アンダーフロー周期は次のように計算できます。

$$\text{アンダーフロー期間} = \frac{\text{TR} + 1}{\text{clk\_in}} \text{ [s]} \quad \text{アンダーフローサイクル} = \frac{\text{clk\_in}}{\text{TR} + 1} \text{ [Hz]}$$

clk\_in: カウントクロック(プリスケーラ出力クロック)周波数 [Hz]

TR: リロードデータ(0~65535)

## 11.5 16ビットタイマのリセット

16ビットタイマをリセットするには、PRESER(D1/T16\_CTLxレジスタ)に1を書き込みます。リロードデータがプリセットされ、カウンタが初期化されます。

\* **PRESER**: Timer Reset Bit in the 16-bit Timer Ch.x Control (T16\_CTLx) Register (D1/0x4226/0x4246/0x4266)

## 11.6 16ビットタイマRUN/STOP制御

16ビットタイマの動作を開始させる前に、以下の設定を行ってください。

- (1) 動作モード(内部クロック、外部クロック、パルス幅測定)を選択します。11.2節を参照してください。
- (2) 内部クロックまたはパルス幅測定モードの場合はカウントクロック(プリスケーラ出力クロック)を選択します。11.2.1節を参照してください。
- (3) カウントモード(ワンショットまたはリピート)を設定します。11.3節を参照してください。
- (4) カウンタ初期値を計算してリロードデータレジスタに設定します。11.4節を参照してください。
- (5) タイマをリセットして初期値をカウンタにプリセットします。11.5節を参照してください。
- (6) タイマ割り込みを使用する場合は、割り込みレベルを設定し、該当タイマチャネルの割り込みを許可します。11.8節を参照してください。

16ビットタイマの動作を開始させるには、PRUN(D0/T16\_CTLxレジスタ)に1を書き込みます。

\* **PRUN:** Timer Run/Stop Control Bit in the 16-bit Timer Ch.x Control (T16\_CTLx) Register (D0/0x4226/0x4246/0x4266)

タイマは初期値から、あるいは初期値をプリセットしなかった場合は現在のカウンタ値からカウントダウンを開始します。カウンタがアンダーフローすると、タイマはアンダーフローパルスを出力し、初期値を再びカウンタにプリセットします。これと同時に、割り込み要求が割り込みコントローラ(ITC)に送られます。

ワンショットモードに設定されている場合、タイマはカウントを停止します。

リピートモードに設定されている場合、タイマはリロードされた初期値からカウントを継続します。

アプリケーションプログラムから16ビットタイマを停止させるには、PRUNに0を書き込みます。カウンタはカウント動作を停止し、タイマのリセットまたは再スタートまで、現在のカウンタ値を保持します。初期値からカウントを再スタートさせる場合は、PRUNに1を書き込む前にタイマをリセットしてください。

### ワンショットモード



### リピートモード



図11.6.1 カウント動作

パルス幅測定モードの場合は、PRUNが1に設定され、かつ外部入力信号が指定したアクティブルレベルの間のみカウントを行います。外部入力信号がインアクティブになると、16ビットタイマはカウントを停止し、次のアクティブルレベルの入力までカウンタ値を保持します。(図11.2.3.1参照)

## 11.7 16ビットタイマ出力信号

16ビットタイマはカウンタがアンダーフローするとアンダーフローパルスを出力します。

このパルスは、タイマ割り込み要求に使用されます。

また、内部シリアルインターフェース用のシリアル転送クロックの生成にも使用されます。



図11.7.1 タイマ出力クロック

生成されたクロックは以下のとおり、内部シリアルインターフェースに送られます。

16ビットタイマCh.1出力クロック → SPI

16ビットタイマCh.2出力クロック → I<sup>2</sup>C

希望の転送レートを得るためのリロードデータレジスタ値は次の式で計算できます。

$$\text{SPI} \quad \text{TR} = \frac{\text{clk\_in}}{\text{bps} \times 2} - 1$$

$$\text{I}^2\text{C} \quad \text{TR} = \frac{\text{clk\_in}}{\text{bps} \times 4} - 1$$

clk\_in: カウントクロック(プリスケーラ出力クロック)周波数 [Hz]

TR: リロードデータ(0~65535)

bps: 転送レート(ビット/秒)

## 11.8 16ビットタイマ割り込み

16ビットタイマは、カウンタのアンダーフローにより、割り込み要求を割り込みコントローラ(ITC)に出力します。

タイマアンダーフロー割り込みを発生させるには、ITCレジスタで割り込みレベルと割り込み許可の設定を行ってください。

### タイマ割り込み用ITCレジスタ

表11.8.1に、各タイマチャネル用のITC制御レジスタを示します。

表11.8.1 ITCレジスタ

| タイマチャネル | 割り込みフラグ              | 割り込みイネーブルビット       | 割り込みレベル設定ビット                 |
|---------|----------------------|--------------------|------------------------------|
| Ch.0    | IIFT1 (D9/ITC_IFLG)  | IIEN1 (D9/ITC_EN)  | ILV1[2:0] (D[10:8]/ITC_ILV0) |
| Ch.1    | IIFT2 (D10/ITC_IFLG) | IIEN2 (D10/ITC_EN) | ILV2[2:0] (D[2:0]/ITC_ILV1)  |
| Ch.2    | IIFT3 (D11/ITC_IFLG) | IIEN3 (D11/ITC_EN) | ILV3[2:0] (D[10:8]/ITC_ILV1) |

ITC\_IFLGレジスタ (0x4300)

ITC\_ENレジスタ (0x4302)

ITC\_ILV0レジスタ (0x430e)

ITC\_ILV1レジスタ (0x4310)

タイマにアンダーフローが発生すると、対応する割り込みフラグが1にセットされます。

その割り込みフラグに対応する割り込みイネーブルビットが1に設定されていると、ITCは割り込み要求をS1C17コアに送ります。タイマによる割り込みを禁止するには、割り込みイネーブルビットを0に設定しておきます。割り込みフラグは、割り込みイネーブルビットの設定にかかわらず(0に設定されていても)、タイマのアンダーフローパルスによって1にセットされます。

割り込みレベル設定ビットは、タイマ割り込みのレベル(0~7)を設定します。同一の割り込みレベルに設定した場合、16ビットタイマCh.0の優先順位が最も高く、16ビットタイマCh.2が最も低い順位となります。

S1C17コアは、以下のすべての条件が成立している場合に割り込みを受け付けます。

- ・割り込みイネーブルビットが1にセットされている。
- ・PSR(S1C17コア内のプロセッサステータスレジスタ)のIE(割り込みイネーブル)ビットが1にセットされている。
- ・タイマ割り込みが、PSRのIL(割り込みレベル)に設定されている値よりも高い割り込みレベルに設定されている。
- ・NMIなど、他の優先順位の高い割り込み要因が発生していない。

これらの割り込み制御レジスタの詳細と割り込み発生時の動作については、“6 割り込みコントローラ(ITC)”を参照してください。

### 割り込みベクタ

タイマ割り込みのベクタ番号とベクタアドレスは以下のとおりです。

表11.8.2 タイマ割り込みベクタ

| タイマチャネル | ベクタ番号   | ベクタアドレス |
|---------|---------|---------|
| タイマCh.0 | 13(0xd) | 0x8034  |
| タイマCh.1 | 14(0xe) | 0x8038  |
| タイマCh.2 | 15(0xf) | 0x803c  |

## 11.9 制御レジスタ詳細

表11.9.1 16ビットタイマレジスター観

| アドレス   | レジスタ名    | 機能                                                               |
|--------|----------|------------------------------------------------------------------|
| 0x4220 | T16_CLK0 | 16-bit Timer Ch.0 Input Clock Select Register<br>ブリスケーラ出力クロックの選択 |
| 0x4222 | T16_TR0  | 16-bit Timer Ch.0 Reload Data Register<br>リロードデータの設定             |
| 0x4224 | T16_TC0  | 16-bit Timer Ch.0 Counter Data Register<br>カウンタデータ               |
| 0x4226 | T16_CTL0 | 16-bit Timer Ch.0 Control Register<br>タイマモードの設定とタイマのRUN/STOP     |
| 0x4240 | T16_CLK1 | 16-bit Timer Ch.1 Input Clock Select Register<br>ブリスケーラ出力クロックの選択 |
| 0x4242 | T16_TR1  | 16-bit Timer Ch.1 Reload Data Register<br>リロードデータの設定             |
| 0x4244 | T16_TC1  | 16-bit Timer Ch.1 Counter Data Register<br>カウンタデータ               |
| 0x4246 | T16_CTL1 | 16-bit Timer Ch.1 Control Register<br>タイマモードの設定とタイマのRUN/STOP     |
| 0x4260 | T16_CLK2 | 16-bit Timer Ch.2 Input Clock Select Register<br>ブリスケーラ出力クロックの選択 |
| 0x4262 | T16_TR2  | 16-bit Timer Ch.2 Reload Data Register<br>リロードデータの設定             |
| 0x4264 | T16_TC2  | 16-bit Timer Ch.2 Counter Data Register<br>カウンタデータ               |
| 0x4266 | T16_CTL2 | 16-bit Timer Ch.2 Control Register<br>タイマモードの設定とタイマのRUN/STOP     |

以下、16ビットタイマのレジスタを個々に説明します。これらはすべて16ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

## 0x4220/0x4240/0x4260: 16-bit Timer Ch.x Input Clock Select Registers (T16\_CLKx)

| Register name                                                        | Address                                 | Bit           | Name         | Function                                                         | Setting |              | Init. | R/W | Remarks            |  |
|----------------------------------------------------------------------|-----------------------------------------|---------------|--------------|------------------------------------------------------------------|---------|--------------|-------|-----|--------------------|--|
| 16-bit Timer<br>Ch.x Input<br>Clock Select<br>Register<br>(T16_CLKx) | 0x4220<br>0x4240<br>0x4260<br>(16 bits) | D15-4<br>D3-0 | —<br>DF[3:0] | reserved<br>Timer input clock select<br>(Prescaler output clock) | —       |              | —     |     | 0 when being read. |  |
|                                                                      |                                         |               |              |                                                                  | DF[3:0] | Clock        | 0x0   | R/W |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0xf     | reserved     |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0xe     | PCLK-1/16384 |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0xd     | PCLK-1/8192  |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0xc     | PCLK-1/4096  |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0xb     | PCLK-1/2048  |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0xa     | PCLK-1/1024  |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0x9     | PCLK-1/512   |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0x8     | PCLK-1/256   |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0x7     | PCLK-1/128   |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0x6     | PCLK-1/64    |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0x5     | PCLK-1/32    |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0x4     | PCLK-1/16    |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0x3     | PCLK-1/8     |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0x2     | PCLK-1/4     |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0x1     | PCLK-1/2     |       |     |                    |  |
|                                                                      |                                         |               |              |                                                                  | 0x0     | PCLK-1/1     |       |     |                    |  |

注: レジスタ名などの'x'はチャネル番号の0~2を表します。

0x4220: 16-bit Timer Ch.0 Input Clock Select Register (T16\_CLK0)

0x4240: 16-bit Timer Ch.1 Input Clock Select Register (T16\_CLK1)

0x4260: 16-bit Timer Ch.2 Input Clock Select Register (T16\_CLK2)

D[15:4] Reserved

D[3:0] DF[3:0]: Timer Input Clock Select Bits

15種類のプリスケーラ出力クロックから、16ビットタイマのカウントクロックを選択します。

表11.9.2 カウントクロックの選択

| DF[3:0] | プリスケーラ出力クロック | DF[3:0] | プリスケーラ出力クロック |
|---------|--------------|---------|--------------|
| 0xf     | Reserved     | 0x7     | PCLK-1/128   |
| 0xe     | PCLK-1/16384 | 0x6     | PCLK-1/64    |
| 0xd     | PCLK-1/8192  | 0x5     | PCLK-1/32    |
| 0xc     | PCLK-1/4096  | 0x4     | PCLK-1/16    |
| 0xb     | PCLK-1/2048  | 0x3     | PCLK-1/8     |
| 0xa     | PCLK-1/1024  | 0x2     | PCLK-1/4     |
| 0x9     | PCLK-1/512   | 0x1     | PCLK-1/2     |
| 0x8     | PCLK-1/256   | 0x0     | PCLK-1/1     |

(デフォルト: 0x0)

注: カウントクロックの設定は、16ビットタイマがカウント停止中に行ってください。

## 0x4222/0x4242/0x4262: 16-bit Timer Ch.x Reload Data Registers (T16\_TRx)

| Register name                                    | Address                                 | Bit   | Name     | Function                                            | Setting       | Init. | R/W | Remarks |
|--------------------------------------------------|-----------------------------------------|-------|----------|-----------------------------------------------------|---------------|-------|-----|---------|
| 16-bit Timer Ch.x Reload Data Register (T16_TRx) | 0x4222<br>0x4242<br>0x4262<br>(16 bits) | D15-0 | TR[15:0] | 16-bit timer reload data<br>TR15 = MSB<br>TR0 = LSB | 0x0 to 0xffff | 0x0   | R/W |         |

注: レジスタ名などの'x'はチャネル番号の0~2を表します。

0x4222: 16-bit Timer Ch.0 Reload Data Register (T16\_TR0)

0x4242: 16-bit Timer Ch.1 Reload Data Register (T16\_TR1)

0x4262: 16-bit Timer Ch.2 Reload Data Register (T16\_TR2)

### D[15:0] TR[15:0]: 16-bit Timer Reload Data

カウンタの初期値を設定します。(デフォルト: 0x0)

このレジスタに設定したリロードデータは、タイマがリセットされるか、カウンタがアンダーフローした時点でカウンタにプリセットされます。

16ビットタイマをリセット後にスタートさせると、タイマはリロード値(初期値)からカウントダウンを行います。したがって、このリロード値と入力クロック周波数により、タイマスタートからアンダーフローが発生するまで(またはアンダーフロー間)の時間が決まります。これにより、任意の待ち時間、周期的な割り込みの発生間隔、あるいはプログラマブルなシリアルインターフェースの転送クロックが得られます。

## 0x4224/0x4244/0x4264: 16-bit Timer Ch.x Counter Data Registers (T16\_TCx)

| Register name                                     | Address                                 | Bit   | Name     | Function                                             | Setting       | Init. | R/W | Remarks |
|---------------------------------------------------|-----------------------------------------|-------|----------|------------------------------------------------------|---------------|-------|-----|---------|
| 16-bit Timer Ch.x Counter Data Register (T16_TCx) | 0x4224<br>0x4244<br>0x4264<br>(16 bits) | D15–0 | TC[15:0] | 16-bit timer counter data<br>TC15 = MSB<br>TC0 = LSB | 0x0 to 0xffff | 0x0   | R   |         |

注: レジスタ名などの'x'はチャネル番号の0~2を表します。

0x4224: 16-bit Timer Ch.0 Counter Data Register (T16\_TC0)

0x4244: 16-bit Timer Ch.1 Counter Data Register (T16\_TC1)

0x4264: 16-bit Timer Ch.2 Counter Data Register (T16\_TC2)

### D[15:0] TC[15:0]: 16-bit Timer Counter Data

カウンタデータが読み出せます。(デフォルト: 0x0)

このレジスタはリードオンリのため、データの書き込みはできません。

**0x4226/0x4246/0x4266: 16-bit Timer Ch.x Control Registers (T16\_CTLx)**

| Register name                                          | Address             | Bit    | Name      | Function                                            | Setting      |                | Init. | R/W | Remarks            |
|--------------------------------------------------------|---------------------|--------|-----------|-----------------------------------------------------|--------------|----------------|-------|-----|--------------------|
| 16-bit Timer<br>Ch.x Control<br>Register<br>(T16_CTLx) | 0x4226              | D15-11 | —         | reserved                                            | —            | —              | —     | —   | 0 when being read. |
|                                                        | 0x4246              | D10    | CKACTV    | External clock active level select                  | 1   High     | 0   Low        | 1     | R/W |                    |
|                                                        | 0x4266<br>(16 bits) | D9-8   | CKSL[1:0] | Input clock and pulse width measurement mode select | CKSL[1:0]    | Mode           | 0x0   | R/W |                    |
|                                                        |                     |        |           |                                                     | 0x3          | reserved       |       |     |                    |
|                                                        |                     |        |           |                                                     | 0x2          | Pulse width    |       |     |                    |
|                                                        |                     |        |           |                                                     | 0x1          | External clock |       |     |                    |
|                                                        |                     |        |           |                                                     | 0x0          | Internal clock |       |     |                    |
|                                                        |                     | D7-5   | —         | reserved                                            | —            | —              | —     | —   | 0 when being read. |
|                                                        |                     | D4     | TRMD      | Count mode select                                   | 1   One shot | 0   Repeat     | 0     | R/W |                    |
|                                                        |                     | D3-2   | —         | reserved                                            | —            | —              | —     | —   | 0 when being read. |
|                                                        |                     | D1     | PRESER    | Timer reset                                         | 1   Reset    | 0   Ignored    | 0     | W   |                    |
|                                                        |                     | D0     | PRUN      | Timer run/stop control                              | 1   Run      | 0   Stop       | 0     | R/W |                    |

注: レジスタ名などの'x'はチャネル番号の0~2を表します。

0x4226: 16-bit Timer Ch.0 Control Register (T16\_CTL0)

0x4246: 16-bit Timer Ch.1 Control Register (T16\_CTL1)

0x4266: 16-bit Timer Ch.2 Control Register (T16\_CTL2)

**D[15:11] Reserved****D10 CKACTV: External Clock Active Level Select Bit**

外部入力パルスの極性、または外部クロックのカウントエッジを選択します。

1(R/W): アクティブHigh/立ち上がりエッジ(デフォルト)

0(R/W): アクティブLow/立ち下がりエッジ

外部クロックモード時(CKSL[1:0] = 0x1)は、外部入力クロックの立ち上がりエッジまたは立ち下がりエッジのどちらでカウントを行うか選択します。パルス幅測定モード時(CKSL[1:0] = 0x2)は、外部入力パルスの極性を選択します。

**D[9:8] CKSL[1:0]: Input Clock and Pulse Width Measurement Mode Select Bits**

16ビットタイマの動作モードを選択します。

表11.9.3 動作モードの選択

| CKSL[1:0] | 動作モード     |
|-----------|-----------|
| 0x3       | Reserved  |
| 0x2       | パルス幅測定モード |
| 0x1       | 外部クロックモード |
| 0x0       | 内部クロックモード |

(デフォルト:0x0)

内部クロックモードでは、プリスケーラ出力クロックをカウントクロックとして使用します。タイマはリロードデータレジスタに設定した初期値からカウントダウンを行い、カウンタのアンダーフローによってアンダーフロー信号を出力します。アンダーフロー信号は、割り込みの発生や内部シリアルインターフェース用のクロック生成に使用されます。プリスケーラクロックとカウンタ初期値の選択によってアンダーフロー発生までの時間を細かくプログラム可能なため、シリアル転送クロックの生成や単発的な時間計測等に有効です。

外部クロックモードでは、入出力ポート(Ch.0: P16, Ch.1: P07, Ch.2: P06)から入力したクロックやパルスをカウントクロックとして使用します。したがって、イベントカウンタとして使用可能です。入力クロック以外のタイマの動作は内部クロックモードと同じです。

パルス幅測定モードでは、指定極性のパルスが外部クロックポートから入力されると、その信号がアクティブな期間のみ内部クロックが供給され、カウントを行います。これにより、指定幅以上のパルス入力で割り込みを発生させたり、入力パルス幅を測定したりすることができます。

**D[7:5] Reserved**

**D4 TRMD: Count Mode Select Bit**

16ビットタイマのカウントモードを選択します。

1(R/W): ワンショットモード

0(R/W): リピートモード(デフォルト)

TRMDを0に設定すると、16ビットタイマはリピートモードに設定されます。このモードでは、カウントを開始するとアプリケーションプログラムで停止するまで16ビットタイマは停止しません。カウンタがアンダーフローすると、タイマはリロードデータレジスタの値をカウンタにプリセットし、カウントを継続します。これにより、タイマは周期的にアンダーフロー パルスを出力します。任意の間隔で周期的な割り込みを発生させる場合や、シリアル転送クロックを生成する場合は、16ビットタイマをこのモードに設定してください。

TRMDを1に設定すると、16ビットタイマはワンショットモードに設定されます。このモードでは、カウンタがアンダーフローした時点で16ビットタイマは自動的に停止します。したがって、タイマをスタート後、割り込みを1回のみ発生可能です。なお、アンダーフロー発生時に、タイマはリロードデータレジスタの値をカウンタにプリセットしてから停止します。特定の待ち時間を作りたい場合やパルス幅測定時などに、16ビットタイマをこのモードに設定してください。

**D[3:2] Reserved****D1 PRESER: Timer Reset Bit**

16ビットタイマをリセットします。

1(W): リセット

0(W): 無効

0(R): 読み出し時は常時0(デフォルト)

このビットに1を書き込むことによって、リロードデータがカウンタにプリセットされます。

**D0 PRUN: Timer Run/Stop Control Bit**

タイマのRUN/STOPを制御します。

1(R/W): RUN

0(R/W): STOP(デフォルト)

タイマはPRUNに1を書き込むことによってカウントを開始し、0の書き込みにより停止します。STOP状態ではリセットか次にRUN状態にするまで、カウンタのデータは保持されます。

## 11.10 注意事項

- 16ビットタイマを動作させるには、その前にプリスケーラを動作させておく必要があります。
- カウントクロックとカウントモードの設定は、16ビットタイマがカウント停止中に行ってください。

このページはブランクです。

# 12 8ビットタイマ(T8F)

## 12.1 8ビットタイマの概要

S1C17001はファインモード付き8ビットタイマを1チャネル内蔵しています。

8ビットタイマは8ビットプリセッタブルダウンカウンタとプリセット値を保持する8ビットリロードデータレジスタで構成されます。タイマはリロードデータレジスタに設定した初期値からカウントダウンを行い、カウンタのアンダーフローによってアンダーフロー信号を出力します。アンダーフロー信号は、割り込みの発生やUART用のクロック生成に使用されます。アンダーフロー周期はプリスケーラクロックとリロードデータの選択によりプログラム可能なため、アプリケーションプログラムは任意の時間間隔やシリアル転送速度を得ることができます。ファインモードは、転送レートの誤差を最小限に抑える機能を提供します。

図12.1.1に8ビットタイマの構造を示します。



図12.1.1 8ビットタイマの構造

## 12.2 8ビットタイマのカウントモード

8ビットタイマはリピートモードとワンショットモードの2つのカウントモードを持っています。この選択は、TRMDビット(D4/T8F\_CTLレジスタ)で行います。

\* **TRMD**: Count Mode Select Bit in the 8-bit Timer Control (T8F\_CTL) Register (D4/0x4206)

### リピートモード(TRMD = 0、デフォルト)

TRMDを0に設定すると、8ビットタイマはリピートモードに設定されます。

このモードでは、カウントを開始するとアプリケーションプログラムで停止するまで8ビットタイマは停止しません。カウンタがアンダーフローすると、タイマはリロードデータレジスタの値をカウンタにプリセットし、カウントを継続します。これにより、タイマは周期的にアンダーフローパルスを出力します。任意の間隔で周期的な割り込みを発生させる場合や、シリアル転送クロックを生成する場合は、8ビットタイマをこのモードに設定してください。

### ワンショットモード(TRMD = 1)

TRMDを1に設定すると、8ビットタイマはワンショットモードに設定されます。

このモードでは、カウンタがアンダーフローした時点で8ビットタイマは自動的に停止します。したがって、タイマをスタート後、割り込みを1回のみ発生可能です。なお、アンダーフロー発生時に、タイマはリロードデータレジスタの値をカウンタにプリセットしてから停止します。特定の待ち時間を作りたい場合などに、8ビットタイマをこのモードに設定してください。

注: カウントモードの設定は、8ビットタイマがカウント停止中に行ってください。

## 12.3 カウントクロック

8ビットタイマはプリスケーラ出力クロックをカウントクロックとして使用します。プリスケーラはPCLKクロックを1/1~1/16Kに分周して15種類のクロックを生成します。この中の1つをDF[3:0]ビット(D[3:0]/T8F\_CLKレジスタ)で選択します。

\* **DF[3:0]**: Timer Input Clock Select Bits in the 8-bit Timer Input Clock Select (T8F\_CLK) Register (D[3:0]/0x4200)

表12.3.1 カウントクロックの選択

| DF[3:0] | プリスケーラ出力クロック | DF[3:0] | プリスケーラ出力クロック |
|---------|--------------|---------|--------------|
| 0xf     | Reserved     | 0x7     | PCLK•1/128   |
| 0xe     | PCLK•1/16384 | 0x6     | PCLK•1/64    |
| 0xd     | PCLK•1/8192  | 0x5     | PCLK•1/32    |
| 0xc     | PCLK•1/4096  | 0x4     | PCLK•1/16    |
| 0xb     | PCLK•1/2048  | 0x3     | PCLK•1/8     |
| 0xa     | PCLK•1/1024  | 0x2     | PCLK•1/4     |
| 0x9     | PCLK•1/512   | 0x1     | PCLK•1/2     |
| 0x8     | PCLK•1/256   | 0x0     | PCLK•1/1     |

(デフォルト: 0x0)

- 注: • 8ビットタイマを動作させるには、その前にプリスケーラを動作させておく必要があります。  
• カウントクロックの設定は、8ビットタイマがカウント停止中に行ってください。

プリスケーラの制御については、“9 プリスケーラ(PSC)”を参照してください。

## 12.4 8ビットタイマリロードレジスタとアンダーフロー周期

リロードデータレジスタT8F\_TR(0x4202)は、ダウンカウンタに初期値をセットするために使用します。リロードデータレジスタに設定したカウンタ初期値は、8ビットタイマがリセットされるか、カウンタがアンダーフローした時点でダウンカウンタにプリセットされます。8ビットタイマをリセット後にスタートさせると、タイマはリロード値(初期値)からカウントダウンを行います。したがって、このリロード値と入力クロック周波数により、タイマスタートからアンダーフローが発生するまで(またはアンダーフロー間)の時間が決まります。これにより、特定の待ち時間、周期的な割り込みの発生間隔、あるいはプログラマブルなシリアルインターフェースの転送クロックが得られます。



図12.4.1 プリセットタイミング

アンダーフロー周期は次のように計算できます。

$$\text{アンダーフロー期間} = \frac{\text{T8F\_TR} + 1}{\text{clk\_in}} [\text{s}] \quad \text{アンダーフローサイクル} = \frac{\text{clk\_in}}{\text{T8F\_TR} + 1} [\text{Hz}]$$

clk\_in: カウントクロック(プリスケーラ出力クロック)周波数 [Hz]

T8F\_TR: リロードデータ(0~255)

注: UARTは8ビットタイマの出力を1/16に分周してサンプリングクロックを生成します。転送レートを設定する際には注意してください。

## 12.5 8ビットタイマのリセット

8ビットタイマをリセットするには、PRESERビット(D1/T8F\_CTLレジスタ)に1を書き込みます。リロードデータがプリセットされ、カウンタが初期化されます。

\* **PRESER**: Timer Reset Bit in the 8-bit Timer Control (T8F\_CTL) Register (D1/0x4206)

## 12.6 8ビットタイマRUN/STOP制御

8ビットタイマの動作を開始させる前に、以下の設定を行ってください。

- (1) カウントモード(ワンショットまたはリピート)を設定します。12.2節を参照してください。
- (2) カウントクロック(プリスケーラ出力クロック)を選択します。12.3節を参照してください。
- (3) カウンタ初期値を計算してリロードデータレジスタに設定します。12.4節を参照してください。
- (4) タイマをリセットして初期値をカウンタにプリセットします。12.5節を参照してください。
- (5) タイマ割り込みを使用する場合は、割り込みレベルを設定し、割り込みを許可します。12.9節を参照してください。

8ビットタイマの動作を開始させるには、PRUNビット(D0/T8F\_CTLレジスタ)に1を書き込みます。

\* **PRUN: Timer Run/Stop Control Bit in the 8-bit Timer Control (T8F\_CTL) Register (D0/0x4206)**

タイマは初期値から、あるいは初期値をプリセットしなかった場合は現在のカウンタ値からカウントダウンを開始します。カウンタがアンダーフローすると、タイマはアンダーフローパルスを出力し、初期値を再びカウンタにプリセットします。これと同時に、割り込み要求が割り込みコントローラ(ITC)に送られます。

ワンショットモードに設定されている場合、タイマはカウントを停止します。

リピートモードに設定されている場合、タイマはリロードされた初期値からカウントを継続します。

アプリケーションプログラムから8ビットタイマを停止させるには、PRUNビットに0を書き込みます。カウンタはカウント動作を停止し、タイマのリセットまたは再スタートまで、現在のカウンタ値を保持します。初期値からカウントを再スタートさせる場合は、PRUNビットに1を書き込む前にタイマをリセットしてください。

カウント中にタイマのリセットを行うと、リロードレジスタ値がカウンタにロードされ、カウントが継続します。



図12.6.1 カウント動作

## 12.7 8ビットタイマ出力信号

8ビットタイマはカウンタがアンダーフローするとアンダーフローパルスを出力します。このパルスは、タイマ割り込み要求に使用されます。



図12.7.1 タイマ出力クロック

また、アンダーフローパルスはシリアル転送クロックの生成にも使用され、UARTに送られます。希望の転送レートを得るためのリロードデータレジスタ値は次の式で計算できます。

$$\text{bps} = \frac{\text{clk\_in}}{\{(T8F\_TR + 1) \times 16 + \text{TFMD}\}}$$

$$T8F\_TR = \left( \frac{\text{clk\_in}}{\text{bps}} - \text{TFMD} - 16 \right) \div 16$$

clk\_in: カウントクロック(プリスケーラ出力クロック)周波数 [Hz]

T8F\_TR: リロードデータ(0~255)

bps: 転送レート(ビット/秒)

TFMD: フайнモード設定値(0~15)

## 12.8 ファインモード

ファインモードは、転送レートの誤差を最小限に抑える機能を提供します。

8ビットタイマはプログラマブルなクロックを出力可能で、その信号はUARTのシリアル転送クロックとして使用されます。プリスケーラ出力クロックとリロードデータの適切な選択により、タイマ出力クロックを希望の周波数に設定することができます。ただし、転送レートによっては誤差を生じます。ファインモードでは、カウンタによるアンダーフローパルスの出力を遅らせ、出力クロック周期を延ばします。この遅延量はTFMD[3:0]ビット(D[11:8]/T8F\_CTLレジスタ)で指定できます。

\* **TFMD[3:0]**: Fine Mode Setup Bits in the 8-bit Timer Control (T8F\_CTL) Register (D[11:8]/0x4206)

TFMD[3:0]ビットは16アンダーフロー期間に挿入する遅延パターンを指定します。遅延の挿入1回につき、出力クロック周期はカウントクロック1サイクル分延長されます。この設定により、割り込みタイミングも同様に遅延します。

表12.8.1 TFMD[3:0]で指定する遅延パターン

| TFMD[3:0] | アンダーフロー一番号 |   |   |   |   |   |   |   |   |    |    |    |    |    |    |    |
|-----------|------------|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|
|           | 1          | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 |
| 0x0       | -          | - | - | - | - | - | - | - | - | -  | -  | -  | -  | -  | -  | -  |
| 0x1       | -          | - | - | - | - | - | - | - | - | -  | -  | -  | -  | -  | -  | D  |
| 0x2       | -          | - | - | - | - | - | - | D | - | -  | -  | -  | -  | -  | -  | D  |
| 0x3       | -          | - | - | - | - | - | - | D | - | -  | -  | D  | -  | -  | -  | D  |
| 0x4       | -          | - | - | D | - | - | - | D | - | -  | -  | D  | -  | -  | -  | D  |
| 0x5       | -          | - | - | D | - | - | - | D | - | -  | -  | D  | -  | D  | -  | D  |
| 0x6       | -          | - | - | D | - | D | - | D | - | -  | -  | D  | -  | D  | -  | D  |
| 0x7       | -          | - | - | D | - | D | - | D | - | D  | -  | D  | -  | D  | -  | D  |
| 0x8       | -          | D | - | D | - | D | - | D | - | D  | -  | D  | -  | D  | -  | D  |
| 0x9       | -          | D | - | D | - | D | - | D | - | D  | -  | D  | -  | D  | D  | D  |
| 0xa       | -          | D | - | D | - | D | D | D | - | D  | -  | D  | -  | D  | D  | D  |
| 0xb       | -          | D | - | D | - | D | D | D | - | D  | D  | D  | -  | D  | D  | D  |
| 0xc       | -          | D | D | D | - | D | D | D | - | D  | D  | D  | -  | D  | D  | D  |
| 0xd       | -          | D | D | D | D | D | D | D | - | D  | D  | D  | D  | D  | D  | D  |
| 0xe       | -          | D | D | D | D | D | D | D | - | D  | D  | D  | D  | D  | D  | D  |
| 0xf       | -          | D | D | D | D | D | D | D | D | D  | D  | D  | D  | D  | D  | D  |

D: 遅延サイクルが挿入されることを示します。



図12.8.1 ファインモードでの遅延サイクルの挿入

イニシャルリセット時、TFMD[3:0]は0x0に設定され、遅延サイクルは挿入されません。

## 12.9 8ビットタイマ割り込み

8ビットタイマは、カウンタのアンダーフローにより、割り込み要求を割り込みコントローラ(ITC)に出力します。

タイマアンダーフロー割り込みを発生させるには、ITCレジスタで割り込みレベルと割り込み許可の設定を行ってください。

### タイマ割り込み用ITCレジスタ

以下に、8ビットタイマ用のITC制御ビットを示します。

#### 割り込みフラグ IIFT0

\* **IIFT0**: 8-bit Timer Interrupt Flag in the Interrupt Flag (ITC\_IFLG) Register (D8/0x4300)

#### 割り込みイネーブルビット IIENO

\* **IIENO**: 8-bit Timer Interrupt Enable Bit in the Interrupt Enable (ITC\_EN) Register (D8/0x4302)

#### 割り込みレベル設定ビット IILV0

\* **IILV0[2:0]**: 8-bit Timer Interrupt Level Bits in the Internal Interrupt Level Setup (ITC\_ILV0) Register 0 (D[2:0]/0x430e)

タイマにアンダーフローが発生すると、対応する割り込みフラグが1にセットされます。

その割り込みフラグに対応する割り込みイネーブルビットが1に設定されていると、ITCは割り込み要求をS1C17コアに送ります。タイマによる割り込みを禁止するには、割り込みイネーブルビットを0に設定しておきます。割り込みフラグは、割り込みイネーブルビットの設定にかかわらず(0に設定されていても)、タイマのアンダーフローパルスによって1にセットされます。

割り込みレベル設定ビットは、タイマ割り込みのレベル(0~7)を設定します。

S1C17コアは、以下のすべての条件が成立している場合に割り込みを受け付けます。

- 割り込みイネーブルビットが1にセットされている。
- PSR(S1C17コア内のプロセッサステータスレジスタ)のIE(割り込みイネーブル)ビットが1にセットされている。
- タイマ割り込みが、PSRのIL(割り込みレベル)に設定されている値よりも高い割り込みレベルに設定されている。
- NMIなど、他の優先順位の高い割り込み要因が発生していない。

これらの割り込み制御レジスタの詳細と割り込み発生時の動作については、“6 割り込みコントローラ(ITC)”を参照してください。

### 割り込みベクタ

8ビットタイマ割り込みのベクタ番号とベクタアドレスは以下のとおりです。

ベクタ番号: 12(0x0c)

ベクタアドレス: 0x8030

## 12.10 制御レジスタ詳細

表12.10.1 8ビットタイマレジスター一覧

| アドレス   | レジスタ名   |                                         | 機能                     |
|--------|---------|-----------------------------------------|------------------------|
| 0x4200 | T8F_CLK | 8-bit Timer Input Clock Select Register | プリスケーラ出力クロックの選択        |
| 0x4202 | T8F_TR  | 8-bit Timer Reload Data Register        | リロードデータの設定             |
| 0x4204 | T8F_TC  | 8-bit Timer Counter Data Register       | カウンタデータ                |
| 0x4206 | T8F_CTL | 8-bit Timer Control Register            | タイマモードの設定とタイマのRUN/STOP |

以下、8ビットタイマのレジスタを個々に説明します。これらはすべて16ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

## 0x4200: 8-bit Timer Input Clock Select Register (T8F\_CLK)

| Register name                                              | Address             | Bit           | Name         | Function                                                         | Setting |              | Init. | R/W | Remarks            |
|------------------------------------------------------------|---------------------|---------------|--------------|------------------------------------------------------------------|---------|--------------|-------|-----|--------------------|
| 8-bit Timer<br>Input Clock<br>Select Register<br>(T8F_CLK) | 0x4200<br>(16 bits) | D15-4<br>D3-0 | —<br>DF[3:0] | reserved<br>Timer input clock select<br>(Prescaler output clock) | —       | —            | —     | —   | 0 when being read. |
|                                                            |                     |               |              |                                                                  | DF[3:0] | Clock        | 0x0   | R/W |                    |
|                                                            |                     |               |              |                                                                  | 0xf     | reserved     |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0xe     | PCLK-1/16384 |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0xd     | PCLK-1/8192  |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0xc     | PCLK-1/4096  |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0xb     | PCLK-1/2048  |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0xa     | PCLK-1/1024  |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0x9     | PCLK-1/512   |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0x8     | PCLK-1/256   |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0x7     | PCLK-1/128   |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0x6     | PCLK-1/64    |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0x5     | PCLK-1/32    |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0x4     | PCLK-1/16    |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0x3     | PCLK-1/8     |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0x2     | PCLK-1/4     |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0x1     | PCLK-1/2     |       |     |                    |
|                                                            |                     |               |              |                                                                  | 0x0     | PCLK-1/1     |       |     |                    |

## D[15:4] Reserved

## D[3:0] DF[3:0]: Timer Input Clock Select Bits

15種類のプリスケーラ出力クロックから、8ビットタイマのカウントクロックを選択します。

表12.10.2 カウントクロックの選択

| DF[3:0] | プリスケーラ出力クロック | DF[3:0] | プリスケーラ出力クロック |
|---------|--------------|---------|--------------|
| 0xf     | Reserved     | 0x7     | PCLK-1/128   |
| 0xe     | PCLK-1/16384 | 0x6     | PCLK-1/64    |
| 0xd     | PCLK-1/8192  | 0x5     | PCLK-1/32    |
| 0xc     | PCLK-1/4096  | 0x4     | PCLK-1/16    |
| 0xb     | PCLK-1/2048  | 0x3     | PCLK-1/8     |
| 0xa     | PCLK-1/1024  | 0x2     | PCLK-1/4     |
| 0x9     | PCLK-1/512   | 0x1     | PCLK-1/2     |
| 0x8     | PCLK-1/256   | 0x0     | PCLK-1/1     |

(デフォルト: 0x0)

注: カウントクロックの設定は、8ビットタイマがカウント停止中に行ってください。

## 0x4202: 8-bit Timer Reload Data Register (T8F\_TR)

| Register name                             | Address          | Bit           | Name         | Function                                                      | Setting          | Init.    | R/W      | Remarks            |
|-------------------------------------------|------------------|---------------|--------------|---------------------------------------------------------------|------------------|----------|----------|--------------------|
| 8-bit Timer Reload Data Register (T8F_TR) | 0x4202 (16 bits) | D15-8<br>D7-0 | —<br>TR[7:0] | reserved<br>8-bit timer reload data<br>TR7 = MSB<br>TR0 = LSB | —<br>0x0 to 0xff | —<br>0x0 | —<br>R/W | 0 when being read. |

### D[15:8] Reserved

### D[7:0] TR[7:0]: 8-bit Timer Reload Data

カウンタの初期値を設定します。(デフォルト: 0x0)

このレジスタに設定したリロードデータは、タイマがリセットされるか、カウンタがアンダーフローした時点でカウンタにプリセットされます。

8ビットタイマをリセット後にスタートさせると、タイマはリロード値(初期値)からカウントダウンを行います。したがって、このリロード値と入力クロック周波数により、タイマスタートからアンダーフローが発生するまで(またはアンダーフロー間)の時間が決まります。これにより、任意の待ち時間、周期的な割り込みの発生間隔、あるいはプログラマブルなシリアルインターフェースの転送クロックが得られます。

**0x4204: 8-bit Timer Counter Data Register (T8F\_TC)**

| Register name                              | Address          | Bit           | Name         | Function                                                       | Setting          | Init.    | R/W    | Remarks            |
|--------------------------------------------|------------------|---------------|--------------|----------------------------------------------------------------|------------------|----------|--------|--------------------|
| 8-bit Timer Counter Data Register (T8F_TC) | 0x4204 (16 bits) | D15–8<br>D7–0 | —<br>TC[7:0] | reserved<br>8-bit timer counter data<br>TC7 = MSB<br>TC0 = LSB | —<br>0x0 to 0xff | —<br>0x0 | —<br>R | 0 when being read. |

**D[15:8] Reserved****D[7:0] TC[7:0]: 8-bit Timer Counter Data**

カウンタデータが読み出せます。(デフォルト: 0x0)

このレジスタはリードオンリのため、データの書き込みはできません。

## 0x4206: 8-bit Timer Control Register (T8F\_CTL)

| Register name                          | Address          | Bit    | Name      | Function               | Setting             | Init. | R/W | Remarks                                                   |
|----------------------------------------|------------------|--------|-----------|------------------------|---------------------|-------|-----|-----------------------------------------------------------|
| 8-bit Timer Control Register (T8F_CTL) | 0x4206 (16 bits) | D15-12 | —         | reserved               | —                   | —     | —   | 0 when being read.                                        |
|                                        |                  | D11-8  | TFMD[3:0] | Fine mode setup        | 0x0 to 0xf          | 0x0   | R/W | Set a number of times to insert delay into a 16-underflow |
|                                        |                  | D7-5   | —         | reserved               | —                   | —     | —   | 0 when being read.                                        |
|                                        |                  | D4     | TRMD      | Count mode select      | 1 One shot 0 Repeat | 0     | R/W |                                                           |
|                                        |                  | D3-2   | —         | reserved               | —                   | —     | —   | 0 when being read.                                        |
|                                        |                  | D1     | PRESER    | Timer reset            | 1 Reset 0 Ignored   | 0     | W   |                                                           |
|                                        |                  | D0     | PRUN      | Timer run/stop control | 1 Run 0 Stop        | 0     | R/W |                                                           |

### D[15:12] Reserved

### D[11:8] TFMD[3:0]: Fine Mode Setup Bits

転送レートの誤差を補正します。(デフォルト: 0x0)

TFMD[3:0]ビットは16アンダーフロー期間に挿入する遅延パターンを指定します。遅延の挿入1回につき、出力クロック周期はカウントクロック1サイクル分延長されます。この設定により、割り込みタイミングも同様に遅延します。

表12.10.3 TFMD[3:0]で指定する遅延パターン

| TFMD[3:0] | アンダーフロー番号 |   |   |   |   |   |   |   |   |    |    |    |    |    |    |    |
|-----------|-----------|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|
|           | 1         | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 |
| 0x0       | —         | — | — | — | — | — | — | — | — | —  | —  | —  | —  | —  | —  | —  |
| 0x1       | —         | — | — | — | — | — | — | — | — | —  | —  | —  | —  | —  | —  | D  |
| 0x2       | —         | — | — | — | — | — | — | D | — | —  | —  | —  | —  | —  | —  | D  |
| 0x3       | —         | — | — | — | — | — | — | D | — | —  | —  | D  | —  | —  | —  | D  |
| 0x4       | —         | — | — | D | — | — | D | — | — | —  | D  | —  | —  | —  | —  | D  |
| 0x5       | —         | — | — | D | — | — | D | — | — | —  | D  | —  | D  | —  | D  | D  |
| 0x6       | —         | — | — | D | — | D | — | D | — | —  | D  | —  | D  | —  | D  | D  |
| 0x7       | —         | — | — | D | — | D | — | D | — | D  | —  | D  | —  | D  | —  | D  |
| 0x8       | —         | D | — | D | — | D | — | D | — | D  | —  | D  | —  | D  | —  | D  |
| 0x9       | —         | D | — | D | — | D | — | D | — | D  | —  | D  | —  | D  | D  | D  |
| 0xa       | —         | D | — | D | — | D | D | D | — | D  | —  | D  | —  | D  | D  | D  |
| 0xb       | —         | D | — | D | — | D | D | D | — | D  | D  | D  | —  | D  | D  | D  |
| 0xc       | —         | D | D | D | — | D | D | D | — | D  | D  | D  | —  | D  | D  | D  |
| 0xd       | —         | D | D | D | — | D | D | D | — | D  | D  | D  | D  | D  | D  | D  |
| 0xe       | —         | D | D | D | D | D | D | D | — | D  | D  | D  | D  | D  | D  | D  |
| 0xf       | —         | D | D | D | D | D | D | D | D | D  | D  | D  | D  | D  | D  | D  |

D: 遅延サイクルが挿入されることを示します。



図12.10.1 ファインモードでの遅延サイクルの挿入

### D[7:5] Reserved

**D4 TRMD: Count Mode Select Bit**

8ビットタイマのカウントモードを選択します。  
 1(R/W): ワンショットモード  
 0(R/W): リピートモード(デフォルト)

TRMDを0に設定すると、8ビットタイマはリピートモードに設定されます。このモードでは、カウントを開始するとアプリケーションプログラムで停止するまで8ビットタイマは停止しません。カウンタがアンダーフローすると、タイマはリロードデータレジスタの値をカウンタにプリセットし、カウントを継続します。これにより、タイマは周期的にアンダーフローパルスを出力します。任意の間隔で周期的な割り込みを発生させる場合や、シリアル転送クロックを生成する場合は、8ビットタイマをこのモードに設定してください。

TRMDを1に設定すると、8ビットタイマはワンショットモードに設定されます。このモードでは、カウンタがアンダーフローした時点で8ビットタイマは自動的に停止します。したがって、タイマをスタート後、割り込みを1回のみ発生可能です。なお、アンダーフロー発生時に、タイマはリロードデータレジスタの値をカウンタにプリセットしてから停止します。特定の待ち時間を作りたい場合などに、8ビットタイマをこのモードに設定してください。

注: カウントモードの設定は、8ビットタイマがカウント停止中に行ってください。

**D[3:2] Reserved****D1 PRESER: Timer Reset Bit**

8ビットタイマをリセットします。  
 1(W): リセット  
 0(W): 無効  
 0(R): 読み出し時は常時0(デフォルト)

このビットに1を書き込むことによって、リロードデータがカウンタにプリセットされます。

**D0 PRUN: Timer Run/Stop Control Bit**

タイマのRUN/STOPを制御します。  
 1(R/W): RUN  
 0(R/W): STOP(デフォルト)

タイマはPRUNに1を書き込むことによってカウントを開始し、0の書き込みにより停止します。STOP状態ではリセットか次にRUN状態にするまで、カウンタのデータは保持されます。

## 12.11 注意事項

---

- 8ビットタイマを動作させるには、その前にプリスケーラを動作させておく必要があります。
- カウントクロックとカウントモードの設定は、8ビットタイマがカウント停止中に行ってください。

# 13 PWM&キャプチャタイマ(T16E)

## 13.1 PWM&キャプチャタイマの概要

S1C17001はPWM&キャプチャタイマを1チャネル内蔵しています。

図13.1.1にPWM&キャプチャタイマの構造を示します。



図13.1.1 PWM&キャプチャタイマの構造

PWM&キャプチャタイマには、16ビットのアップカウンタ(T16E\_TCレジスタ)と、2つの16ビットコンペアデータレジスタ(T16E\_CAレジスタ、T16E\_CBレジスタ)とそのバッファが設けられています。

16ビットカウンタはソフトウェアで0にリセットおよびカウンタ値のセットが可能で、プリスケーラ出力クロックまたはP27ポート端子からの外部信号でカウントアップを行います。カウント値はソフトウェアで読み出すことができます。

コンペアデータAおよびBレジスタはアップカウンタの内容と比較するためのデータを格納するレジスタです。コンペアデータレジスタは、直接データの書き込み/読み出しが可能です。また、コンペアデータバッファを使用すると、カウンタがソフトウェアまたはコンペアBマッチ信号によってリセットされた時点で設定した比較値をコンペアデータレジスタにロードすることができます。比較値をコンペアデータレジスタとバッファのどちらに書き込むかについては、ソフトウェアで設定可能です。

カウンタ値が各コンペアデータレジスタの内容に一致すると比較器によって信号が出力され、割り込みや出力信号を制御します。したがって、これらのレジスタにより割り込みの発生周期や出力クロックの周波数とデューティ比をプログラマブルに設定することができます。

## 13.2 PWM&キャプチャタイマの動作モード

PWM&キャプチャタイマには2つの動作モードがあります。

- 内部クロックモード(内部クロックをカウントするタイマ)
- 外部クロックモード(イベントカウンタとして機能)

いずれか1つをCLKSEL(D3/T16E\_CTLレジスタ)で選択します。

\* **CLKSEL**: Input Clock Select Bit in the PWM Timer Control (T16E\_CTL) Register (D3/0x5306)

CLKSELが0(デフォルト)の場合は内部クロックモード、1に設定すると外部クロックモードになります。

### 内部クロックモード

内部クロックモードでは、プリスケーラ出力クロックをカウントクロックとして使用します。

カウントクロックは、プリスケーラがPCLKクロックを1/1～1/16Kに分周して生成した15種類の中から1つをT16EDF[3:0](D[3:0]/T16E\_CLKレジスタ)で選択します。

\* **T16EDF[3:0]**: Timer Input Clock Select Bits in the PWM Timer Input Clock Select (T16E\_CLK) Register (D[3:0]/0x5308)

表13.2.1 プリスケーラクロックの選択

| T16EDF[3:0] | プリスケーラ出力クロック | T16EDF[3:0] | プリスケーラ出力クロック |
|-------------|--------------|-------------|--------------|
| 0xf         | Reserved     | 0x7         | PCLK・1/128   |
| 0xe         | PCLK・1/16384 | 0x6         | PCLK・1/64    |
| 0xd         | PCLK・1/8192  | 0x5         | PCLK・1/32    |
| 0xc         | PCLK・1/4096  | 0x4         | PCLK・1/16    |
| 0xb         | PCLK・1/2048  | 0x3         | PCLK・1/8     |
| 0xa         | PCLK・1/1024  | 0x2         | PCLK・1/4     |
| 0x9         | PCLK・1/512   | 0x1         | PCLK・1/2     |
| 0x8         | PCLK・1/256   | 0x0         | PCLK・1/1     |

(デフォルト:0x0)

注: • PWM&キャプチャタイマを内部クロックモードで動作させるには、その前にプリスケーラを動作させておく必要があります。

• カウントクロックの設定は、PWM&キャプチャタイマがカウント停止中に行ってください。

プリスケーラの制御については“9 プリスケーラ(PSC)”を参照してください。

### 外部クロックモード

外部クロックモードでは、P27(EXCL3)ポートから入力したクロックやパルスをカウントクロックとして使用します。したがって、イベントカウンタとして使用可能です。入力クロック以外のタイマの動作は内部クロックモードと同じです。

P27ポートからEXCL3クロックを入力するには、P27MUX(D7/P2\_PMUXレジスタ)に1を書き込み、P27端子の機能を変更しておく必要があります。

\* **P27MUX**: P27 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register

PWM&キャプチャタイマは入力信号の立ち上がりエッジでカウントアップします。

PWM&キャプチャタイマは、このモードではプリスケーラを使用しません。ほかにプリスケーラクロックを使用する周辺モジュールがない場合はプリスケーラを停止して消費電流を低減できます。

### 13.3 カウンタ値のセット/リセット

PWM&キャプチャタイマのカウンタをリセットするには、T16ERSTビット(D1/T16E\_CTLレジスタ)に1を書き込みます。カウンタが0に初期化されます。

\* **T16ERST**: Timer Reset Bit in the PWM Timer Control (T16E\_CTL) Register (D1/0x5306)

通常は、カウントアップを開始する前に、このビットに1を書き込みカウンタをリセットします。カウント開始後は、カウンタがコンペアデータBに一致するとハードウェアによってリセットされます。

また、T16ETC[15:0](D[15:0]/T16E\_TCレジスタ)にデータを書き込むことにより、カウンタに任意の値をセットすることもできます。

\* **T16ETC[15:0]**: Counter Data in the PWM Timer Counter Data (T16E\_TC) Register (D[15:0]/0x5304)

## 13.4 コンペアデータの設定

### コンペアデータレジスタ/バッファの選択

PWM&キャプチャタイマにはデータの比較器が内蔵されており、カウントデータを任意の値と比較することができます。この比較データを格納するレジスタがコンペアデータAレジスタとコンペアデータBレジスタです。コンペアデータレジスタは直接データの書き込み/読み出しが可能です。また、コンペアデータバッファを使用すると、カウンタがソフトウェア(T16ERSTへの1書き込み)またはコンペアBマッチ信号によってリセットされた時点で、バッファに設定した比較値を自動的にコンペアデータレジスタにロードすることができます。比較値をコンペアデータレジスタとバッファのどちらに書き込むかについては、CBUFEN(D5/0x5306)で設定します。

\* **CBUFEN**: Comparison Buffer Enable Bit in the PWM Timer Control (T16E\_CTL) Register (D5/0x5306)

CBUFENに1を書き込むとコンペアデータバッファ、0を書き込むとコンペアデータレジスタが選択されます。イニシャルリセット時は、コンペアデータレジスタが選択されます。

### コンペアデータの書き込み

コンペアデータAはT16ECA[15:0](D[15:0]/T16E\_CAレジスタ)に、コンペアデータBはT16ECB[15:0](D[15:0]/T16E\_CBレジスタ)に書き込みます。

\* **T16ECA[15:0]**: Compare Data A in the PWM Timer Compare Data A (T16E\_CA) Register (D[15:0]/0x5300)

\* **T16ECB[15:0]**: Compare Data B in the PWM Timer Compare Data B (T16E\_CB) Register (D[15:0]/0x5302)

CBUFENが0に設定されている場合、これらのレジスタによりコンペアデータレジスタ値が直接読み出し/書き込み可能です。

CBUFENが1に設定されている場合、これらのレジスタへのデータ書き込み/読み出しはコンペアデータバッファに対して行われます。バッファの内容はカウンタがリセットされた時点でコンペアデータレジスタにロードされます。

イニシャルリセット時、コンペアデータレジスタ/バッファは0x0に設定されます。

タイマはコンペアデータレジスタとカウントデータを比較し、同じ値になったところでコンペアマッチ信号を発生します。このコンペアマッチ信号は割り込みを発生するとともに外部へのクロック(TOUT信号)出力を制御します。

コンペアデータBはカウンタのリセット周期も決定します。

カウンタのリセット周期は次のように計算できます。

$$\text{カウンタリセット期間} = \frac{CB + 1}{clk\_in} [\text{s}]$$

$$\text{カウンタリセット周期} = \frac{clk\_in}{CB + 1} [\text{Hz}]$$

CB: コンペアデータB(T16E\_CBレジスタ値)

clk\_in: プリスケーラ出力クロック周波数

## 13.5 PWM&キャプチャタイマRUN/STOP制御

PWM&キャプチャタイマの動作を開始させる前に、以下の設定を行ってください。

- (1) 動作モード(入力クロック)を設定します。13.2節を参照してください。
- (2) クロック出力の設定を行います。13.6節を参照してください。
- (3) 割り込みを使用する場合は、割り込みレベルを設定し、PWM&キャプチャタイマの割り込みを許可します。13.7節を参照してください。
- (4) カウンタに値をセット、または0にリセットします。13.3節を参照してください。
- (5) コンペアデータを設定します。13.4節を参照してください。

PWM&キャプチャタイマには、Run/Stopを制御するT16ERUN(D0/T16E\_CTLレジスタ)が設けられています。

\* **T16ERUN:** Timer Run/Stop Control Bit in the PWM Timer Control (T16E\_CTL) Register (D0/0x5306)

タイマはT16ERUNに1を書き込むことによってカウントを開始します。T16ERUNに0を書き込むとクロックの入力が禁止され、カウントは停止します。

この制御はカウンタのデータには影響を与えません。カウントの停止中もカウンタのデータは保持されており、そのデータから継続してカウントを開始することができます。

T16ERUNとT16ERSTに同時に1を書き込んだ場合、タイマはカウンタをリセット後にカウントを開始します。

カウント中にカウンタがコンペアデータAレジスタの設定値と一致すると、コンペアAマッチ信号が出力され、コンペアA割り込み要因が発生します。

また、カウンタがコンペアデータBレジスタの設定値と一致すると、コンペアBマッチ信号が出力され、コンペアB割り込み要因が発生します。同時にカウンタが0にリセットされます。CBUFENが1に設定されている場合は、コンペアデータバッファに設定してある値がコンペアデータレジスタにロードされます。割り込みを許可している場合は、割り込み要求が割り込みコントローラ(ITC)に送られます。

どちらの場合もカウント動作はそのまま継続します。コンペアBの場合はカウンタ値0からのカウントとなります。



図13.5.1 カウンタの基本動作タイミング

## 13.6 クロック出力の制御

PWM&キャプチャタイマは、コンペアマッチ信号によってTOUT信号を発生させることができます。

図13.6.1にPWM&キャプチャタイマのクロック出力回路を示します。



図13.6.1 PWM&キャプチャタイマのクロック出力回路

### 初期出力レベルの設定

クロック出力がOffの状態でのデフォルト出力レベルは0(Lowレベル)です。これをINITOL(D8/T16E\_CTLレジスタ)で1(Highレベル)に変更することができます。

\* **INITOL**: Initial Output Level Select Bit in the PWM Timer Control (T16E\_CTL) Register (D8/0x5306)

INITOLが0(デフォルト)の場合、初期出力レベルはLowです。1に設定すると、初期出力レベルはHighになります。

T16ERSTへの1書き込みによりタイマをリセットした場合も、タイマ出力はここで設定した初期出力レベルになります。

### 出力信号の極性選択

デフォルトでは、アクティブHigh(ノーマルLow)の出力信号が生成されます。この論理をINVOUT(D4/T16E\_CTLレジスタ)で反転することができます。INVOUTに1を書き込むと、タイマはアクティブLow(ノーマルHigh)の信号を生成します。

\* **INVOUT**: Inverse Output Control Bit in the PWM Timer Control (T16E\_CTL) Register (D4/0x5306)

INVOUTを1に設定すると、INITOLで設定した初期出力レベルも反転します。

出力波形については図13.6.2を参照してください。

### 出力端子の設定

ここで発生したTOUT信号は、TOUT(P26)端子から出力可能で、外部デバイス等に対してプログラマブルなクロックやPWM信号を供給することができます。

イニシャルリセット時、出力に使用するP26端子は入出力ポート用に設定され、入力モードとなります。このときの端子の状態はハイインピーダンスとなります。

端子機能をTOUT出力に切り換えると、INITOLおよびINVOUTの設定に従ったレベルの出力を行います。タイマ出力を開始後、カウンタ値によって変化するまで出力はこのレベルに保たれます。

表13.6.1 初期出力レベル

| INITOL | INVOUT | 初期出力レベル |
|--------|--------|---------|
| 1      | 1      | Low     |
| 1      | 0      | High    |
| 0      | 1      | High    |
| 0      | 0      | Low     |

## クロック出力の開始

TOUTクロックを出力するには、OUTEN(D2/T16E\_CTLレジスタ)に1を書き込みます。OUTENに0を書き込むと、出力はINITOLおよびINVOUTの設定値に従った初期出力レベルとなります。

\* **OUTEN**: Clock Output Enable Bit in the PWM Timer Control (T16E\_CTL) Register (D2/0x5306)

図13.6.2に出力波形を示します。



(T16E\_CA = 3、T16E\_CB = 5の場合)

図13.6.2 PWM&キャプチャタイマの出力波形

### INVOUT = 0(アクティブHigh)の場合

タイマは、カウンタがT16E\_CAレジスタ(0x5300)に設定したコンペアデータAに一致するまでLowレベル(出力開始時は初期出力レベル)を出力します。カウンタがコンペアデータAの次の値になると、出力端子はHighレベルとなりコンペアA割り込み要因が発生します。その後、カウンタがT16E\_CBレジスタ(0x5302)に設定したコンペアデータBまでカウントアップされると、カウンタがリセットされ、出力端子はLowレベルに戻ります。同時にコンペアB割り込み要因も発生します。

### INVOUT = 1(アクティブLow)の場合

タイマは、カウンタがT16E\_CAレジスタ(0x5300)に設定したコンペアデータAに一致するまでHighレベル(出力開始時は初期出力レベルの反転値)を出力します。カウンタがコンペアデータAの次の値になると、出力端子はLowレベルとなりコンペアA割り込み要因が発生します。その後、カウンタがT16E\_CBレジスタ(0x5302)に設定したコンペアデータBまでカウントアップされると、カウンタがリセットされ、出力端子はHighレベルに戻ります。同時にコンペアB割り込み要因も発生します。

## クロック出力ファインモードの設定

デフォルト設定では、コンペアデータAとカウンタ値が一致した場合、入力クロックの立ち上がりでクロック出力が変化します。

ファインモードのクロック出力は、コンペアデータAレジスタT16ECA0[15:1]とカウンタデータレジスタT16ETC[14:0]が一致した場合に、コンペアデータAのビット0(T16ECA0)の値に従って変化します。

T16ECA0が0の場合: 入力クロックの立ち上がりで変化

T16ECA0が1の場合: 半周期遅れの入力クロックの立ち下がりで変化



図13.6.3 ファインモードのクロック出力

このように、ファインモードでは入力クロックの半周期きざみで出力デューティを調節することができます。ただし、コンペアデータA = 0の場合は、入力クロックの1周期幅のパルスが出力されます(デフォルトの場合と同様)。ファインモードでのコンペアデータBの最大値は $2^{15} - 1 = 32,767$ 、コンペアデータAの設定範囲は0~(2 × コンペアデータB - 1)となります。

ファインモードはSELMF(D6/T16E\_CTLレジスタ)で設定します。

\* **SELMF:** Fine Mode Select Bit in the PWM Timer Control (T16E\_CTL) Register (D6/0x5306)

SELMFに1を書き込むと、ファインモードが設定されます。イニシャルリセット時はファインモードがディセーブル状態となります。

## 注意事項

- (1) タイマ出力を使用する場合、コンペアデータはA $\geq 0$ 、B $\geq 1$ を設定してください。最小設定はA = 0、B = 1で、タイマ出力サイクルは入力クロックの1/2となります。
- (2) コンペアデータをA > B(ファインモードの場合はA > B × 2)に設定するとコンペアBマッチ信号のみ発生し、コンペアAマッチ信号は発生しません。この場合、タイマ出力はLow(INVOUT = 1)の場合はHigh)に固定されます。

## 13.7 PWM&キャプチャタイマ割り込み

T16Eモジュールには、以下の2種類の割り込みを発生させる機能があります。

- ・コンペアAマッチ割り込み
- ・コンペアBマッチ割り込み

T16Eモジュールは、上記2種類の割り込み要因が共有する1本の割り込み信号を割り込みコントローラ(ITC)に対して出力します。発生した割り込み要因を特定するには、T16Eモジュール内の割り込みフラグを読み出してください。

### コンペアAマッチ割り込み

この割り込み要求は、カウント中にカウンタがコンペアデータAレジスタの設定値に一致すると発生し、T16Eモジュール内の割り込みフラグCAIF(D0/T16E\_IFLGレジスタ)を1にセットします。

\* **CAIF:** Compare A Interrupt Flag in the PWM Timer Interrupt Flag (T16E\_IFLG) Register (D0/0x530c)

この割り込みを使用するには、CAIE(D0/T16E\_IMSKレジスタ)を1に設定します。CAIEが0(デフォルト)に設定されているとCAIFが1にセットされず、この要因による割り込み要求はITCに送られません。

\* **CAIE:** Compare A Interrupt Enable Bit in the PWM Timer Interrupt Mask (T16E\_IMSK) Register (D0/0x530a)

CAIFが1にセットされるとT16Eモジュールは割り込み要求をITCに出力します。この割り込み要求信号により、ITC内のPWM&キャプチャタイマ割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

PWM&キャプチャタイマ割り込みがコンペアAマッチによるものかどうかについては、PWM&キャプチャタイマ割り込み処理ルーチンでCAIFを読み出して確認してください。

また、割り込み処理ルーチン内では、ITCのPWM&キャプチャタイマ割り込みフラグではなくT16EモジュールのCAIFをリセット(1を書き込み)して割り込み要因をクリアしてください。

### コンペアBマッチ割り込み

この割り込み要求は、カウント中にカウンタがコンペアデータBレジスタの設定値に一致すると発生し、T16Eモジュール内の割り込みフラグCBIF(D1/T16E\_IFLGレジスタ)を1にセットします。

\* **CBIF:** Compare B Interrupt Flag in the PWM Timer Interrupt Flag (T16E\_IFLG) Register (D1/0x530c)

この割り込みを使用するには、CBIE(D1/T16E\_IMSKレジスタ)を1に設定します。CBIEが0(デフォルト)に設定されているとCBIFが1にセットされず、この要因による割り込み要求はITCに送られません。

\* **CBIE:** Compare B Interrupt Enable Bit in the PWM Timer Interrupt Mask (T16E\_IMSK) Register (D1/0x530a)

CBIFが1にセットされるとT16Eモジュールは割り込み要求をITCに出力します。この割り込み要求信号により、ITC内のPWM&キャプチャタイマ割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

PWM&キャプチャタイマ割り込みがコンペアBマッチによるものかどうかについては、PWM&キャプチャタイマ割り込み処理ルーチンでCBIFを読み出して確認してください。

また、割り込み処理ルーチン内では、ITCのPWM&キャプチャタイマ割り込みフラグではなくT16EモジュールのCBIFをリセット(1を書き込み)して割り込み要因をクリアしてください。

注: 不要な割り込みの発生を防止するため、CAIEまたはCBIEによってコンペアAまたはコンペアB割り込みを許可する前に、対応するCAIFまたはCBIFをリセットしてください。

## PWM&キャプチャタイマ割り込み用ITCレジスタ

前述の設定により、割り込みを許可されたコンペアマッチが発生すると、T16Eモジュールは割り込み信号をITCに出力します。PWM&キャプチャタイマ割り込みを発生させるには、ITCレジスタで割り込みレベルと割り込み許可の設定を行ってください。

以下に、PWM&キャプチャタイマ用のITC制御ビットを示します。

### ITC内の割り込みフラグ

\* **EIFT7**: PWM & Capture Timer Interrupt Flag in the Interrupt Flag (ITC\_IFLG) Register (D7/0x4300)

### ITC内の割り込みイネーブルビット

\* **ELEN7**: PWM & Capture Timer Interrupt Enable Bit in the Interrupt Enable (ITC\_EN) Register (D7/0x4302)

### ITC内の割り込みレベル設定ビット

\* **EILV7[2:0]**: T16E Interrupt Level Bits in the External Interrupt Level Setup (ITC\_ELV3) Register 3 (D[10:8]/0x430c)

### ITC内の割り込みトリガモード選択ビット(1に固定してください)

\* **EITG7**: T16E Interrupt Trigger Mode Select Bit in the External Interrupt Level Setup (ITC\_ELV3) Register 3 (D12/0x430c)

T16Eモジュールで割り込みが許可されたコンペアマッチが発生すると、EIFT7が1にセットされます。このとき、ELEN7が1に設定されていると、ITCは割り込み要求をS1C17コアに送ります。PWM&キャプチャタイマによる割り込みを禁止するには、ELEN7を0に設定しておきます。EIFT7は、ELEN7の設定にかかわらず(0に設定していても)、T16Eモジュールからの割り込み信号によって1にセットされます。

EILV7[2:0]は、PWM&キャプチャタイマ割り込みのレベル(0~7)を設定します。

S1C17コアは、以下のすべての条件が成立している場合に割り込みを受け付けます。

- ・割り込みイネーブルビットが1にセットされている。
- ・PSR(S1C17コア内のプロセッサステータスレジスタ)のIE(割り込みイネーブル)ビットが1にセットされている。
- ・PWM&キャプチャタイマ割り込みが、PSRのIL(割り込みレベル)に設定されている値よりも高い割り込みレベルに設定されている。
- ・NMIなど、他の優先順位の高い割り込み要因が発生していない。

これらの割り込み制御レジスタの詳細と割り込み発生時の動作については、“6 割り込みコントローラ(ITC)”を参照してください。

注: 割り込み要因の発生状態をT16Eモジュールの割り込みフラグで管理するため、以下の処理が必要です。

1. ITCのPWM&キャプチャタイマ割り込みのトリガモードをレベルトリガモードに設定
2. 割り込み発生後は、割り込み処理ルーチン内で、T16Eモジュール内の割り込みフラグCAIF、CBIFをリセット(これによりITCの割り込みフラグもリセットされます)

### 割り込みベクタ

PWM&キャプチャタイマ割り込みのベクタ番号とベクタアドレスは以下のとおりです。

ベクタ番号: 11(0x0b)

ベクタアドレス: 0x802c

## 13.8 制御レジスタ詳細

表13.8.1 PWM&amp;キャプチャタイマレジスター一覧

| アドレス   | レジスタ名     | 機能                                                       |
|--------|-----------|----------------------------------------------------------|
| 0x5300 | T16E_CA   | PWM Timer Compare Data A Register<br>コンペアデータAの設定         |
| 0x5302 | T16E_CB   | PWM Timer Compare Data B Register<br>コンペアデータBの設定         |
| 0x5304 | T16E_TC   | PWM Timer Counter Data Register<br>カウンタデータ               |
| 0x5306 | T16E_CTL  | PWM Timer Control Register<br>タイマモードの設定とタイマのRUN/STOP     |
| 0x5308 | T16E_CLK  | PWM Timer Input Clock Select Register<br>プリスケーラ出力クロックの選択 |
| 0x530a | T16E_IMSK | PWM Timer Interrupt Mask Register<br>割り込みマスクの設定          |
| 0x530c | T16E_IFLG | PWM Timer Interrupt Flag Register<br>割り込み発生状態の表示/リセット    |

以下、PWM&キャプチャタイマのレジスタを個々に説明します。これらはすべて16ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

**0x5300: PWM Timer Compare Data A Register (T16E\_CA)**

| Register name                               | Address          | Bit   | Name         | Function                                          | Setting       | Init. | R/W | Remarks |
|---------------------------------------------|------------------|-------|--------------|---------------------------------------------------|---------------|-------|-----|---------|
| PWM Timer Compare Data A Register (T16E_CA) | 0x5300 (16 bits) | D15-0 | T16ECA[15:0] | Compare data A<br>T16ECA15 = MSB<br>T16ECA0 = LSB | 0x0 to 0xffff | 0x0   | R/W |         |

**D[15:0] T16ECA[15:0]: Compare Data A**

PWM&キャプチャタイマのコンペアデータAを設定します。(デフォルト: 0x0)

CBUFEN(D5/T16E\_CTLレジスタ)が0に設定されている場合、このレジスタによりコンペアデータAレジスタが直接読み出し/書き込み可能です。

CBUFENが1に設定されている場合、これらのレジスタへのデータ書き込み/読み出しがコンペアデータAバッファに対して行われます。バッファの内容はカウンタがリセットされた時点でのコンペアデータAレジスタにロードされます。

設定したデータがカウンタデータと比較され、内容が一致したところでコンペアA割り込み要因が発生します。同時に、タイマ出力波形が変化します(INVOUT(D4/T16E\_CTLレジスタ) = 0の場合は立ち上がり、INVOUT = 1の場合は立ち下がります)。これらの処理は、カウンタのデータやカウントアップ動作には影響を与えません。

## 0x5302: PWM Timer Compare Data B Register (T16E\_CB)

| Register name                               | Address | Bit   | Name         | Function                                          | Setting       | Init. | R/W | Remarks |
|---------------------------------------------|---------|-------|--------------|---------------------------------------------------|---------------|-------|-----|---------|
| PWM Timer Compare Data B Register (T16E_CB) | 0x5302  | D15-0 | T16ECB[15:0] | Compare data B<br>T16ECB15 = MSB<br>T16ECB0 = LSB | 0x0 to 0xffff | 0x0   | R/W |         |

### D[15:0] T16ECB[15:0]: Compare Data B

PWM&キャプチャタイマのコンペアデータBを設定します。(デフォルト: 0x0)

CBUFEN(D5/T16E\_CTLレジスタ)が0に設定されている場合、このレジスタによりコンペアデータBレジスタが直接読み出し/書き込み可能です。

CBUFENが1に設定されている場合、これらのレジスタへのデータ書き込み/読み出しあはコンペアデータBバッファに対して行われます。バッファの内容はカウンタがリセットされた時点でコンペアデータBレジスタにロードされます。

設定したデータがカウンタデータと比較され、内容が一致したところでコンペアB割り込み要因が発生します。同時に、タイマ出力波形が変化し(INVOUT(D4/T16E\_CTLレジスタ) = 0の場合は立ち上がり、INVOUT = 1の場合は立ち下がります)、カウンタが0にリセットされます。

**0x5304: PWM Timer Counter Data Register (T16E\_TC)**

| Register name                             | Address             | Bit   | Name         | Function                                        | Setting       | Init. | R/W | Remarks |
|-------------------------------------------|---------------------|-------|--------------|-------------------------------------------------|---------------|-------|-----|---------|
| PWM Timer Counter Data Register (T16E_TC) | 0x5304<br>(16 bits) | D15–0 | T16ETC[15:0] | Counter data<br>T16ETC15 = MSB<br>T16ETC0 = LSB | 0x0 to 0xffff | 0x0   | R/W |         |

**D[15:0] T16ETC[15:0]: Counter Data**

カウンタデータが読み出せます。(デフォルト: 0x0)

また、このレジスタにデータを書き込むことにより、カウンタ値をセットすることもできます。

## 0x5306: PWM Timer Control Register (T16E\_CTL)

| Register name                         | Address          | Bit   | Name    | Function                 | Setting |           | Init. | R/W         | Remarks                |
|---------------------------------------|------------------|-------|---------|--------------------------|---------|-----------|-------|-------------|------------------------|
| PWM Timer Control Register (T16E_CTL) | 0x5306 (16 bits) | D15~9 | —       | reserved                 | —       | —         | —     | —           | 0 when being read.     |
|                                       |                  | D8    | INITOL  | Initial output level     | 1       | High      | 0     | Low         | 0 R/W                  |
|                                       |                  | D7    | —       | reserved                 | —       | —         | —     | —           | 0 when being read.     |
|                                       |                  | D6    | SELMF   | Fine mode select         | 1       | Fine mode | 0     | Normal mode | 0 R/W                  |
|                                       |                  | D5    | CBUFEN  | Comparison buffer enable | 1       | Enable    | 0     | Disable     | 0 R/W                  |
|                                       |                  | D4    | INVOUT  | Inverse output           | 1       | Invert    | 0     | Normal      | 0 R/W                  |
|                                       |                  | D3    | CLKSEL  | Input clock select       | 1       | External  | 0     | Internal    | 0 R/W                  |
|                                       |                  | D2    | OUTEN   | Clock output enable      | 1       | Enable    | 0     | Disable     | 0 R/W                  |
|                                       |                  | D1    | T16ERST | Timer reset              | 1       | Reset     | 0     | Ignored     | 0 W 0 when being read. |
|                                       |                  | D0    | T16ERUN | Timer run/stop control   | 1       | Run       | 0     | Stop        | 0 R/W                  |

### D[15:9] Reserved

#### D8 INITOL: Initial Output Level Bit

タイマ出力の初期出力レベルを設定します。

1(R/W): High

0(R/W): Low(デフォルト)

クロック出力をOUTEN(D2)への0書き込みによりOffした場合、またはタイマをT16ERST(D1)への1書き込みによりリセットした場合、タイマ出力端子はここで設定した初期出力レベルになります。ただし、INVOUT(D4)が1の場合、このレベルは反転します。

#### D7 Reserved

#### D6 SELMF: Fine Mode Select Bit

クロック出力をファインモードに設定します。

1(R/W): ファインモード

0(R/W): 通常出力(デフォルト)

SELMFが1に設定されていると、クロック出力がファインモードに設定され、出力クロックのデューティを入力クロックの半周期単位で調整可能となります。

SELMFが0に設定されている場合は、通常のクロック出力が行われます。

#### D5 CBUFEN: Comparison Buffer Enable Bit

コンペアデータバッファへの書き込みを許可/禁止します。

1(R/W): 許可

0(R/W): 禁止(デフォルト)

CBUFENが1に設定されていると、コンペアデータの書き込み/読み出しがコンペアデータバッファに対して行われます。バッファの内容は、カウンタがソフトウェアまたはコンペアB信号によってリセットされた時点でコンペアデータレジスタにロードされます。

CBUFENが0に設定されている場合は、コンペアデータの書き込み/読み出しがコンペアデータレジスタに対して直接行われます。

#### D4 INVOUT: Inverse Output Control Bit

タイマ出力信号の極性を選択します。

1(R/W): 反転(アクティブLow)

0(R/W): 通常(アクティブHigh) (デフォルト)

INVOUTに1を書き込むと、TOUT出力用にアクティブLowの信号(Offレベル = High)が生成されます。INVOUTが0の場合は、アクティブHighの信号(Offレベル = Low)が生成されます。

本ビットへの1書き込みはINITOL(D8)で設定した初期出力レベルも反転します。

**D3 CLKSEL: Input Clock Select Bit**

タイマの入力クロックを選択します。

1(R/W): 外部クロック

0(R/W): 内部クロック(デフォルト)

CLKSELに0を書き込んだ場合は、タイマの入力クロックとして内部クロック(プリスケーラ出力)が選択されます。1を書き込んだ場合は外部クロック(EXCL3(P27)端子から入力するクロック)が選択され、イベントカウンタとして機能します。

注: P27ポートからEXCL3クロックを入力するには、P27MUX(D7/P2\_PMUXレジスタ)に1を書き込み、P27端子の機能を変更しておく必要があります。

\* **P27MUX**: P27 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register

**D2 OUTEN: Clock Output Enable Bit**

TOUT信号(タイマ出力クロック)の出力制御を行います。

1(R/W): 許可

0(R/W): 禁止(デフォルト)

OUTENに1を書き込むと、TOUT信号がTOUT(P26)出力端子から出力されます。OUTENに0を書き込むことによって出力は停止し、INVOUT(D4)およびINITOL(D8)の設定値に従ったOffレベルとなります。TOUT信号を出力する前に、P26ポート機能選択レジスタでP26をTOUT端子に設定しておく必要があります。

**D1 T16ERST: Timer Reset Bit**

カウンタをリセットします。

1(W): リセット

0(W): 無効

0(R): 読み出し時は常時0(デフォルト)

T16ERSTに1を書き込むことによって、PWM&キャプチャタイマのカウンタがリセットされます。

**D0 T16ERUN: Timer Run/Stop Control Bit**

タイマのRun/Stopを制御します。

1(R/W): Run

0(R/W): Stop(デフォルト)

PWM&キャプチャタイマはT16ERUNに1を書き込むことによってカウントアップを開始し、0の書き込みにより停止します。Stop状態ではリセットか次にRun状態にするまで、カウンタのデータは保持されます。また、Stop状態からRun状態にすることによって、保持していたデータから継続してカウントを進めることができます。

## 0x5308: PWM Timer Input Clock Select Register (T16E\_CLK)

| Register name                                             | Address             | Bit           | Name             | Function                                                         | Setting          | Init.                                                                                                                                                                                                                                                                                          | R/W             | Remarks                 |
|-----------------------------------------------------------|---------------------|---------------|------------------|------------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------------------|
| PWM Timer<br>Input Clock<br>Select Register<br>(T16E_CLK) | 0x5308<br>(16 bits) | D15–4<br>D3–0 | —<br>T16EDF[3:0] | reserved<br>Timer input clock select<br>(Prescaler output clock) | —<br>T16EDF[3:0] | Clock<br>0xf reserved<br>0xe PCLK-1/16384<br>0xd PCLK-1/8192<br>0xc PCLK-1/4096<br>0xb PCLK-1/2048<br>0xa PCLK-1/1024<br>0x9 PCLK-1/512<br>0x8 PCLK-1/256<br>0x7 PCLK-1/128<br>0x6 PCLK-1/64<br>0x5 PCLK-1/32<br>0x4 PCLK-1/16<br>0x3 PCLK-1/8<br>0x2 PCLK-1/4<br>0x1 PCLK-1/2<br>0x0 PCLK-1/1 | —<br>0x0<br>R/W | —<br>0 when being read. |

**D[15:4] Reserved**

**D[3:0] T16EDF[3:0]: Timer Input Clock Select Bits**

15種類のプリスケーラ出力クロックから、PWM&キャプチャタイマのカウントクロックを選択します。

表13.8.2 カウントクロックの選択

| T16EDF[3:0] | プリスケーラ出力クロック | T16EDF[3:0] | プリスケーラ出力クロック |
|-------------|--------------|-------------|--------------|
| 0xf         | Reserved     | 0x7         | PCLK-1/128   |
| 0xe         | PCLK-1/16384 | 0x6         | PCLK-1/64    |
| 0xd         | PCLK-1/8192  | 0x5         | PCLK-1/32    |
| 0xc         | PCLK-1/4096  | 0x4         | PCLK-1/16    |
| 0xb         | PCLK-1/2048  | 0x3         | PCLK-1/8     |
| 0xa         | PCLK-1/1024  | 0x2         | PCLK-1/4     |
| 0x9         | PCLK-1/512   | 0x1         | PCLK-1/2     |
| 0x8         | PCLK-1/256   | 0x0         | PCLK-1/1     |

(デフォルト:0x0)

注: カウントクロックの設定は、PWM&キャプチャタイマがカウント停止中に行ってください。

**0x530a: PWM Timer Interrupt Mask Register (T16E\_IMSK)**

| Register name                                          | Address             | Bit   | Name | Function                   | Setting               | Init. | R/W | Remarks            |
|--------------------------------------------------------|---------------------|-------|------|----------------------------|-----------------------|-------|-----|--------------------|
| PWM Timer<br>Interrupt<br>Mask Register<br>(T16E_IMSK) | 0x530a<br>(16 bits) | D15-2 | —    | reserved                   | —                     | —     | —   | 0 when being read. |
|                                                        |                     | D1    | CBIE | Compare B interrupt enable | 1 Enable<br>0 Disable | 0     | R/W |                    |
|                                                        |                     | D0    | CAIE | Compare A interrupt enable | 1 Enable<br>0 Disable | 0     | R/W |                    |

**D[15:2] Reserved****D1 CBIE: Compare B Interrupt Enable Bit**

コンペアBマッチによる割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

CBIEを1に設定するとITCへのコンペアB割り込み要求が許可され、0に設定すると割り込みが禁止されます。

なお、割り込みを発生させるには、ITCのPWM&キャプチャタイマ割り込みイネーブルビットも割り込み許可に設定する必要があります。

**D0 CAIE: Compare A Interrupt Enable Bit**

コンペアAマッチによる割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

CAIEを1に設定するとITCへのコンペアA割り込み要求が許可され、0に設定すると割り込みが禁止されます。

なお、割り込みを発生させるには、ITCのPWM&キャプチャタイマ割り込みイネーブルビットも割り込み許可に設定する必要があります。

## 0x530c: PWM Timer Interrupt Flag Register (T16E\_IFLG)

| Register name                                          | Address             | Bit   | Name        | Function                 | Setting |                             | Init. | R/W | Remarks                                   |
|--------------------------------------------------------|---------------------|-------|-------------|--------------------------|---------|-----------------------------|-------|-----|-------------------------------------------|
| PWM Timer<br>Interrupt<br>Flag Register<br>(T16E_IFLG) | 0x530c<br>(16 bits) | D15-2 | —           | reserved                 | 1       | Cause of interrupt occurred | —     | —   | 0 when being read.<br>Reset by writing 1. |
|                                                        |                     | D1    | <b>CBIF</b> | Compare B interrupt flag |         |                             |       |     |                                           |
|                                                        |                     | D0    | <b>CAIF</b> | Compare A interrupt flag |         |                             |       |     |                                           |

### D[15:2] Reserved

#### D1 CBIF: Compare B Interrupt Flag

コンペアB割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり
- 0(R): 割り込み要因なし(デフォルト)
- 1(W): フラグをリセット
- 0(W): 無効

CBIFはコンペアB割り込みに対応する割り込みフラグです。CBIE(D1/T16E\_IMSK)を1に設定しておくことにより、カウント中にカウンタがコンペアデータBレジスタの設定値に一致すると1にセットされます。同時に、ITCに対してPWM&キャプチャタイマ割り込み要求信号が出力されます。この割り込み要求信号により、ITC内のPWM&キャプチャタイマ割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

#### D0 CAIF: Compare A Interrupt Flag

コンペアA割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり
- 0(R): 割り込み要因なし(デフォルト)
- 1(W): フラグをリセット
- 0(W): 無効

CAIFはコンペアA割り込みに対応する割り込みフラグです。CAIE(D0/T16E\_IMSK)を1に設定しておくことにより、カウント中にカウンタがコンペアデータAレジスタの設定値に一致すると1にセットされます。同時に、ITCに対してPWM&キャプチャタイマ割り込み要求信号が出力されます。この割り込み要求信号により、ITC内のPWM&キャプチャタイマ割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

割り込み要因の発生状態を本レジスタで管理するため、以下の処理が必要です。

1. ITCのPWM&キャプチャタイマ割り込みのトリガモードをレベルトリガモードに設定
2. 割り込み発生後は、割り込み処理ルーチン内で、T16Eモジュール内の割り込みフラグ CAIF, CBIFをリセット(これによりITCの割り込みフラグもリセットされます)

CAIF, CBIFは1の書き込みによりリセットされます。

注: 不要な割り込みの発生を防止するため、CAIE(D0/T16E\_IMSK)またはCBIE(D1/T16E\_IMSK)によってコンペアAまたはコンペアB割り込みを許可する前に、対応するCAIFまたはCBIFをリセットしてください。

## 13.9 注意事項

- PWM&キャプチャタイマを動作させるには、その前にプリスケーラを動作させておく必要があります。
- カウントクロックの設定は、PWM&キャプチャタイマがカウント停止中に行ってください。
- タイマ出力を使用する場合、コンペアデータは $A \geq 0$ 、 $B \geq 1$ を設定してください。最小設定は $A = 0$ 、 $B = 1$ で、タイマ出力サイクルは入力クロックの1/2となります。
- コンペアデータを $A > B$ (ファインモードの場合は $A > B \times 2$ )に設定するとコンペアBマッチ信号のみ発生し、コンペアAマッチ信号は発生しません。この場合、タイマ出力はLow(INVOUT = 1の場合はHigh)に固定されます。
- 不要な割り込みの発生を防止するため、CAIE(D0/T16E\_IMSKレジスタ)またはCBIE(D1/T16E\_IMSKレジスタ)によってコンペアAまたはコンペアB割り込みを許可する前に、対応するCAIF(D0/T16E\_IFLGレジスタ)またはCBIF(D1/T16E\_IFLGレジスタ)をリセットしてください。

# 14 8ビットOSC1タイマ(T8OSC1)

## 14.1 8ビットOSC1タイマの概要

S1C17001はOSC1クロックを源振とする8ビットOSC1タイマを1チャネル内蔵しています。

図14.1.1に8ビットOSC1タイマの構造を示します。



図14.1.1 8ビットOSC1タイマの構造

8ビットOSC1タイマには、8ビットのアップカウンタ(T8OSC1\_CNTレジスタ)と8ビットのコンペアデータレジスタ(T8OSC1\_CMPレジスタ)が設けられています。

8ビットカウンタはソフトウェアで0にリセット可能で、OSC1分周クロック(OSC1•1/1～OSC1•1/32)でカウントアップを行います。カウント値はソフトウェアで読み出すことができます。

コンペアデータレジスタはアップカウンタの内容と比較するためのデータを格納するレジスタです。カウンタ値がコンペアデータレジスタの内容に一致すると比較器によって信号が outputされ、割り込みを制御します。したがって、コンペアデータレジスタにより割り込みの発生周期をプログラマブルに設定することができます。

## 14.2 8ビットOSC1タイマのカウントモード

8ビットOSC1タイマはリピートモードとワンショットモードの2つのカウントモードを持っています。この選択は、T8ORMD(D1/T8OSC1\_CTLレジスタ)で行います。

\* **T8ORMD**: Count Mode Select Bit in the 8-bit OSC1 Timer Control (T8OSC1\_CTL) Register (D1/0x50c0)

### リピートモード(T8ORMD = 0、デフォルト)

T8ORMDを0に設定すると、8ビットOSC1タイマはリピートモードに設定されます。

このモードでは、カウントを開始するとアプリケーションプログラムで停止するまで8ビットOSC1タイマは停止しません。カウンタがコンペアデータに一致すると、タイマはカウンタをリセットしてカウントを継続します。同時に割り込み信号を出力しますので、任意の間隔で周期的な割り込みを発生させる場合に、8ビットOSC1タイマをこのモードに設定してください。

### ワンショットモード(T8ORMD = 1)

T8ORMDを1に設定すると、8ビットOSC1タイマはワンショットモードに設定されます。

このモードでは、カウンタがコンペアデータに一致した時点で8ビットOSC1タイマは自動的に停止します。したがって、タイマをスタート後、割り込みを1回のみ発生可能です。なお、コンペアマッチ発生時に、タイマはカウンタをリセットしてから停止します。特定の待ち時間を作りたい場合などに、8ビットOSC1タイマをこのモードに設定してください。

注: カウントモードの設定は、8ビットOSC1タイマがカウント停止中に行ってください。

## 14.3 カウントクロック

8ビットOSC1タイマは、OSCモジュールが outputするOSC1分周クロックをカウントクロックとして使用します。OSCモジュールはOSC1クロックを1/1~1/32に分周して6種類のクロックを生成します。この中の1つをT8O1CK[2:0](D[3:1]/OSC\_T8OSC1レジスタ)で選択します。

\* **T8O1CK[2:0]**: T8OSC1 Clock Division Ratio Select Bits in the T8OSC1 Clock Control (OSC\_T8OSC1) Register (D[3:1]/0x5065)

表14.3.1 カウントクロックの選択

| T8O1CK[2:0] | 分周比       |
|-------------|-----------|
| 0x7~0x6     | Reserved  |
| 0x5         | OSC1・1/32 |
| 0x4         | OSC1・1/16 |
| 0x3         | OSC1・1/8  |
| 0x2         | OSC1・1/4  |
| 0x1         | OSC1・1/2  |
| 0x0         | OSC1・1/1  |

(デフォルト:0x0)

8ビットOSC1タイマへのクロック供給は、T8O1CE(D0/OSC\_T8OSC1レジスタ)で制御します。T8O1CEのデフォルト設定は0で、クロックの供給は停止しています。T8O1CEを1に設定すると、上記の中から選択されたクロックが8ビットOSC1タイマに送られます。8ビットOSC1タイマの動作が不要な場合は、消費電流を抑えるため、クロック供給を停止してください。

\* **T8O1CE**: T8OSC1 Clock Enable Bit in the T8OSC1 Clock Control (OSC\_T8OSC1) Register (D0/0x5065)

注: カウントクロックの設定は、8ビットOSC1タイマがカウント停止中に行ってください。

クロック制御の詳細については、“7 発振回路(OSC)”を参照してください。

## 14.4 8ビットOSC1タイマのリセット

8ビットOSC1タイマをリセットするには、T8ORSTビット(D4/T8OSC1\_CTLレジスタ)に1を書き込みます。カウンタが0に初期化されます。

\* **T8ORST**: Timer Reset Bit in the 8-bit OSC1 Timer Control (T8OSC1\_CTL) Register (D4/0x50c0)

通常は、カウントアップを開始する前に、このビットに1を書き込みカウンタをリセットします。カウント開始後は、カウンタがコンペアデータに一致するとハードウェアによってリセットされます。

## 14.5 コンペアデータの設定

コンペアデータはT8OCMP[7:0](D[7:0]/T8OSC1\_CMPレジスタ)に書き込みます。

\* **T8OCMP[7:0]: Compare Data Bits in the 8-bit OSC1 Timer Compare Data (T8OSC1\_CMP) Register (D[7:0]/0x50c2)**  
イニシャルリセット時、コンペアデータレジスタは0x0に設定されます。

タイマはコンペアデータレジスタとカウントデータを比較し、同じ値になったところでカウンタをリセットすると共にコンペアマッチ信号を発生します。このコンペアマッチ信号により割り込みを発生可能です。

コンペアマッチ周期は次のように計算できます。

$$\text{コンペアマッチ期間} = \frac{\text{CMP} + 1}{\text{clk\_in}} \text{ [s]}$$

$$\text{コンペアマッチ周期} = \frac{\text{clk\_in}}{\text{CMP} + 1} \text{ [Hz]}$$

CMP: コンペアデータ(T8OSC1\_CMPレジスタ値)  
clk\_in:8ビットOSC1タイマカウントクロック周波数

## 14.6 8ビットOSC1タイマRUN/STOP制御

8ビットOSC1タイマの動作を開始させる前に、以下の設定を行ってください。

- (1) カウントモード(ワンショットまたはリピート)を設定します。14.2節を参照してください。
- (2) 動作クロックを選択します。14.3節を参照してください。
- (3) 割り込みを使用する場合は、割り込みレベルを設定し、8ビットOSC1タイマの割り込みを許可します。14.7節を参照してください。
- (4) タイマをリセットします。14.4節を参照してください。
- (5) コンペアデータを設定します。14.5節を参照してください。

8ビットOSC1タイマには、Run/Stopを制御するT8ORUN(D0/T8OSC1\_CTLレジスタ)が設けられています。

\* **T8ORUN**: Timer Run/Stop Control Bit in the 8-bit OSC1 Timer Control (T8OSC1\_CTL) Register (D0/0x50c0)

タイマはT8ORUNに1を書き込むことによってカウントを開始します。T8ORUNに0を書き込むとクロックの入力が禁止され、カウントは停止します。

この制御はカウンタのデータには影響を与えません。カウントの停止中もカウンタのデータは保持されており、そのデータから継続してカウントを開始することができます。

T8ORUNとT8ORSTに同時に1を書き込んだ場合、タイマはカウンタをリセット後にカウントを開始します。

カウント中にカウンタがコンペアデータレジスタの設定値と一致すると、コンペアマッチ信号が出力され、コンペアマッチ割り込み要因が発生します。同時にカウンタが0にリセットされます。割り込みを許可している場合は、割り込み要求が割り込みコントローラ(ITC)に送られます。

ワンショットモードに設定されている場合、タイマはカウントを停止します。

リピートモードに設定されている場合、タイマは0からカウントを継続します。

### ワンショットモード



### リピートモード



図14.6.1 カウンタの基本動作タイミング

## 14.7 8ビットOSC1タイマ割り込み

T8OSC1モジュールは、コンペアマッチにより割り込み要求を割り込みコントローラ(ITC)に出力可能です。

### コンペアマッチ割り込み

この割り込み要求は、カウント中にカウンタがコンペアデータレジスタの設定値に一致すると発生し、T8OSC1モジュール内の割り込みフラグT8OIF(D0/T8OSC1\_IFLGレジスタ)を1にセットします。

\* **T8OIF**: 8-bit OSC1 Timer Interrupt Flag in the 8-bit OSC1 Timer Interrupt Flag (T8OSC1\_IFLG) Register (D0/0x50c4)

この割り込みを使用するには、T8OIE(D0/T8OSC1\_IMSKレジスタ)を1に設定します。T8OIEが0(デフォルト)に設定されているとT8OIFは1にセットされず、この要因による割り込み要求はITCに送られません。

\* **T8OIE**: 8-bit OSC1 Timer Interrupt Enable Bit in the 8-bit OSC1 Timer Interrupt Mask (T8OSC1\_IMSK) Register (D0/0x50c3)

T8OIFが1にセットされるとT8OSC1モジュールは割り込み要求をITCに出力します。この割り込み要求信号により、ITC内の8ビットOSC1タイマ割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

割り込み処理ルーチン内では、ITCの8ビットOSC1タイマ割り込みフラグではなくT8OSC1モジュールのT8OIFをリセット(1を書き込み)して割り込み要因をクリアしてください。

注: 不要な割り込みの発生を防止するため、T8OIEによって8ビットOSC1タイマ割り込みを許可する前に、T8OIFをリセットしてください。

### 8ビットOSC1タイマ割り込み用ITCレジスタ

前述の設定により、コンペアマッチが発生すると、8ビットOSC1タイマは割り込み信号をITCに出力します。

8ビットOSC1タイマ割り込みを発生させるには、ITCレジスタで割り込みレベルと割り込み許可の設定を行ってください。

以下に、8ビットOSC1タイマ用のITC制御ビットを示します。

#### ITC内の割り込みフラグ

\* **EIFT4**: 8-bit OSC1 Timer Interrupt Flag in the Interrupt Flag (ITC\_IFLG) Register (D4/0x4300)

#### ITC内の割り込みイネーブルビット

\* **EIEN4**: 8-bit OSC1 Timer Interrupt Enable Bit in the Interrupt Enable (ITC\_EN) Register (D4/0x4302)

#### ITC内の割り込みレベル設定ビット

\* **EILV4[2:0]**: T8OSC1 Interrupt Level Bits in the External Interrupt Level Setup (ITC\_ELV2) Register 2 (D[2:0]/0x430a)

#### ITC内の割り込みトリガモード選択ビット(1に固定してください)

\* **EITG4**: T8OSC1 Interrupt Trigger Mode Select Bit in the External Interrupt Level Setup (ITC\_ELV2) Register 2 (D4/0x430a)

T8OSC1モジュールで割り込みが許可されたコンペアマッチが発生すると、EIFT4が1にセットされます。

このとき、EIEN4が1に設定されていると、ITCは割り込み要求をS1C17コアに送ります。8ビットOSC1タイマによる割り込みを禁止するには、EIEN4を0に設定しておきます。EIFT4は、EIEN4の設定にかかわらず(0に設定されていても)、T8OSC1モジュールからの割り込み信号によって1にセットされます。

EILV4[2:0]は、8ビットOSC1タイマ割り込みのレベル(0~7)を設定します。

S1C17コアは、以下のすべての条件が成立している場合に割り込みを受け付けます。

- 割り込みイネーブルビットが1にセットされている。
- PSR(S1C17コア内のプロセッサステータスレジスタ)のIE(割り込みイネーブル)ビットが1にセットされている。
- 8ビットOSC1タイマ割り込みが、PSRのIL(割り込みレベル)に設定されている値よりも高い割り込みレベルに設定されている。
- NMIなど、他の優先順位の高い割り込み要因が発生していない。

これらの割り込み制御レジスタの詳細と割り込み発生時の動作については、“6 割り込みコントローラ(ITC)”を参照してください。

注: 割り込み要因の発生状態をT8OSC1モジュールの割り込みフラグで管理するため、以下の処理が必要です。

1. ITCの8ビットOSC1タイマ割り込みのトリガモードをレベルトリガモードに設定
2. 割り込み発生後は、割り込み処理ルーチン内で、T8OSC1モジュール内の割り込みフラグT8OIFをリセット(これによりITCの割り込みフラグもリセットされます)

### 割り込みベクタ

8ビットOSC1タイマ割り込みのベクタ番号とベクタアドレスは以下のとおりです。

ベクタ番号: 8(0x08)

ベクタアドレス: 0x8020

## 14.8 制御レジスタ詳細

表14.8.1 8ビットOSC1タイマレジスター一覧

| アドレス   | レジスタ名       | 機能                                                           |
|--------|-------------|--------------------------------------------------------------|
| 0x50c0 | T8OSC1_CTL  | 8-bit OSC1 Timer Control Register<br>タイマモードの設定とタイマのRUN/STOP  |
| 0x50c1 | T8OSC1_CNT  | 8-bit OSC1 Timer Counter Data Register<br>カウンタデータ            |
| 0x50c2 | T8OSC1_CMP  | 8-bit OSC1 Timer Compare Data Register<br>コンペアデータの設定         |
| 0x50c3 | T8OSC1_IMSK | 8-bit OSC1 Timer Interrupt Mask Register<br>割り込みマスクの設定       |
| 0x50c4 | T8OSC1_IFLG | 8-bit OSC1 Timer Interrupt Flag Register<br>割り込み発生状態の表示/リセット |

以下、8ビットOSC1タイマのレジスタを個々に説明します。これらはすべて8ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

**0x50c0: 8-bit OSC1 Timer Control Register (T8OSC1\_CTL)**

| Register name                                           | Address            | Bit  | Name   | Function               | Setting             | Init. | R/W | Remarks            |
|---------------------------------------------------------|--------------------|------|--------|------------------------|---------------------|-------|-----|--------------------|
| 8-bit OSC1<br>Timer Control<br>Register<br>(T8OSC1_CTL) | 0x50c0<br>(8 bits) | D7-5 | —      | reserved               | —                   | —     | —   | 0 when being read. |
|                                                         |                    | D4   | T8ORST | Timer reset            | 1 Reset 0 Ignored   | 0     | W   |                    |
|                                                         |                    | D3-2 | —      | reserved               | —                   | —     | —   |                    |
|                                                         |                    | D1   | T8ORMD | Count mode select      | 1 One shot 0 Repeat | 0     | R/W |                    |
|                                                         |                    | D0   | T8ORUN | Timer run/stop control | 1 Run 0 Stop        | 0     | R/W |                    |

**D[7:5] Reserved****D4 T8ORST: Timer Reset Bit**

8ビットOSC1タイマをリセットします。

1(W): リセット

0(W): 無効

0(R): 読み出し時は常時0(デフォルト)

このビットに1を書き込むことによって、カウンタが0にリセットされます。

**D[3:2] Reserved****D1 T8ORMD: Count Mode Select Bit**

8ビットOSC1タイマのカウントモードを選択します。

1(R/W): ワンショットモード

0(R/W): リピートモード(デフォルト)

T8ORMDを0に設定すると、8ビットOSC1タイマはリピートモードに設定されます。このモードでは、カウントを開始するとアプリケーションプログラムで停止するまで8ビットタイマは停止しません。カウンタがコンペアデータレジスタの値に一致すると、タイマはカウンタをリセットし、カウントを継続します。これにより、タイマは周期的にコンペアマッチ信号を出力します。任意の間隔で周期的な割り込みを発生させる場合は、8ビットOSC1タイマをこのモードに設定してください。

T8ORMDを1に設定すると、8ビットOSC1タイマはワンショットモードに設定されます。このモードでは、カウンタがコンペアデータレジスタの値に一致した時点で8ビットOSC1タイマは自動的に停止します。したがって、タイマをスタート後、割り込みを1回のみ発生可能です。なお、コンペアマッチ発生時に、タイマはカウンタをリセットしてから停止します。特定の待ち時間を作りたい場合などに、8ビットOSC1タイマをこのモードに設定してください。

注: カウントモードの設定は、8ビットOSC1タイマがカウント停止中に行ってください。

**D0 T8ORUN: Timer Run/Stop Control Bit**

タイマのRun/Stopを制御します。

1(R/W): Run

0(R/W): Stop(デフォルト)

タイマはT8ORUNに1を書き込むことによってカウントを開始し、0の書き込みにより停止します。Stop状態ではリセットか次にRun状態にするまで、カウンタのデータは保持されます。

## 0x50c1: 8-bit OSC1 Timer Counter Data Register (T8OSC1\_CNT)

| Register name                                                | Address            | Bit  | Name        | Function                                             | Setting     | Init. | R/W | Remarks |
|--------------------------------------------------------------|--------------------|------|-------------|------------------------------------------------------|-------------|-------|-----|---------|
| 8-bit OSC1<br>Timer Counter<br>Data Register<br>(T8OSC1_CNT) | 0x50c1<br>(8 bits) | D7-0 | T8OCNT[7:0] | Timer counter data<br>T8OCNT7 = MSB<br>T8OCNT0 = LSB | 0x0 to 0xff | 0xff  | R   |         |

### D[7:0] T8OCNT[7:0]: Counter Data

カウンタデータが読み出せます。(デフォルト: 0xff)

このレジスタはリードオンリのため、データの書き込みはできません。

**0x50c2: 8-bit OSC1 Timer Compare Data Register (T8OSC1\_CMP)**

| Register name                                                | Address | Bit  | Name        | Function                                       | Setting     | Init. | R/W | Remarks |
|--------------------------------------------------------------|---------|------|-------------|------------------------------------------------|-------------|-------|-----|---------|
| 8-bit OSC1<br>Timer Compare<br>Data Register<br>(T8OSC1_CMP) | 0x50c2  | D7-0 | T8OCMP[7:0] | Compare data<br>T8OCMP7 = MSB<br>T8OCMP0 = LSB | 0x0 to 0xff | 0x0   | R/W |         |

**D[7:0] T8OCMP[7:0]: Compare Data**

8ビットOSC1タイマのコンペアデータを設定します。(デフォルト: 0x0)

設定したデータがカウンタデータと比較され、内容が一致したところでコンペアマッチ割り込み要因が発生します。同時に、カウンタが0にリセットされます。

**0x50c3: 8-bit OSC1 Timer Interrupt Mask Register (T8OSC1\_IMSK)**

| Register name                                          | Address         | Bit  | Name | Function | Setting |   | Init. | R/W | Remarks            |
|--------------------------------------------------------|-----------------|------|------|----------|---------|---|-------|-----|--------------------|
| 8-bit OSC1 Timer Interrupt Mask Register (T8OSC1_IMSK) | 0x50c3 (8 bits) | D7–1 | –    | reserved | –       | – | –     | –   | 0 when being read. |

**D[7:1] Reserved****D0 T8OIE: 8-bit OSC1 Timer Interrupt Enable Bit**

コンペアマッチによる割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

T8OIEを1に設定するとITCへの8ビットOSC1タイマ割り込み要求が許可され、0に設定すると割り込みが禁止されます。

なお、割り込みを発生させるには、ITCの8ビットOSC1タイマ割り込みイネーブルビットも割り込み許可に設定する必要があります。

**0x50c4: 8-bit OSC1 Timer Interrupt Flag Register (T8OSC1\_IFLG)**

| Register name                                          | Address | Bit  | Name | Function | Setting |   | Init. | R/W | Remarks            |
|--------------------------------------------------------|---------|------|------|----------|---------|---|-------|-----|--------------------|
| 8-bit OSC1 Timer Interrupt Flag Register (T8OSC1_IFLG) | 0x50c4  | D7-1 | —    | reserved | —       | — | —     | —   | 0 when being read. |

**D[7:1] Reserved****D0 T8OIF: 8-bit OSC1 Timer Interrupt Flag**

コンペアマッチ割り込み要因の発生状態を示す割り込みフラグです。

1(R): 割り込み要因あり

0(R): 割り込み要因なし(デフォルト)

1(W): フラグをリセット

0(W): 無効

T8OIFはT8OSC1モジュールの割り込みフラグです。T8OIE(D0/T8OSC1\_IMSKレジスタ)を1に設定しておくことにより、カウント中にカウンタがコンペアデータレジスタの設定値に一致すると1にセットされます。同時に、ITCに対して8ビットOSC1タイマ割り込み要求信号が outputされます。この割り込み要求信号により、ITC内の8ビットOSC1タイマ割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

割り込み要因の発生状態を本レジスタで管理するため、以下の処理が必要です。

1. ITCの8ビットOSC1タイマ割り込みのトリガモードをレベルトリガモードに設定
2. 割り込み発生後は、割り込み処理ルーチン内で、T8OSC1モジュール内の割り込みフラグ T8OIFをリセット(これによりITCの割り込みフラグもリセットされます)

T8OIFは1の書き込みによりリセットされます。

注: 不要な割り込みの発生を防止するため、T8OIE(D0/T8OSC1\_IMSKレジスタ)によってコンペアマッチ割り込みを許可する前に、T8OIFをリセットしてください。

## 14.9 注意事項

- 8ビットOSC1タイマを動作させるには、その前にOSCモジュールから8ビットOSC1タイマ用クロックを出力させておく必要があります。
- カウントクロックとカウントモードの設定は、8ビットOSC1タイマがカウント停止中に行ってください。
- 不要な割り込みの発生を防止するため、T8OIE(D0/T8OSC1\_IMSKレジスタ)によってコンペアマッチ割り込みを許可する前に、T8OIF(D0/T8OSC1\_IFLGレジスタ)をリセットしてください。

このページはブランクです。

# 15 計時タイマ(CT)

## 15.1 計時タイマの概要

S1C17001はOSC1クロックを源振とする計時タイマを1チャネル内蔵しています。

計時タイマはOSC1クロックを分周した256Hz信号を入力クロックとする8ビットのバイナリカウンタで構成され、各ビット(128~1Hz)のデータをソフトウェアによって読み出すことができます。

また、計時タイマは32Hz、8Hz、2Hz、1Hzの各信号によって割り込みを発生させることができます。

通常はこの計時タイマを、時計などのような各種の計時機能に使用します。

図15.1.1に計時タイマの構造を示します。



図15.1.1 計時タイマの構造

## 15.2 動作クロック

計時タイマは、OSCモジュールが output する 256Hz クロックを動作クロックとして使用します。OSCモジュールはOSC1クロックを1/128に分周してこの動作クロックを生成します。したがって、OSC1クロック周波数が32.768kHzの場合に256Hzとなります。それ以外のOSC1クロック周波数では、本節に記載の周波数が変わります。OSCモジュールに256Hzクロックの出力制御ビットは設けられていません。OSC1発振がOnの場合は、常に256Hzクロックが計時タイマに供給されます。OSC1発振回路の制御については、“7 発振回路(OSC)”を参照してください。

## 15.3 計時タイマのリセット

計時タイマをリセットするには、CTRSTビット(D4/CT\_CTLレジスタ)に1を書き込みます。カウンタが0にクリアされます。

\* **CTRST:** Clock Timer Reset Bit in the Clock Timer Control (CT\_CTL) Register (D4/0x5000)

この操作以外では、イニシャルリセットによりカウンタがクリアされます。

## 15.4 計時タイマRUN/STOP制御

計時タイマの動作を開始させる前に、以下の設定を行ってください。

- (1) 割り込みを使用する場合は、割り込みレベルを設定し、計時タイマの割り込みを許可します。  
15.5節を参照してください。
- (2) タイマをリセットします。15.3節を参照してください。

計時タイマには、Run/Stopを制御するCTRUN(D0/CT\_CTLレジスタ)が設けられています。

\* **CTRUN**: Clock Timer Run/Stop Control Bit in the Clock Timer Control (CT\_CTL) Register (D0/0x5000)

計時タイマはCTRUNに1を書き込むことによって動作を開始します。CTRUNに0を書き込むとクロックの入力が禁止され、動作は停止します。

この制御はカウンタ(CT\_CNTレジスタ)のデータには影響を与えません。カウントの停止中もカウンタのデータは保持されており、そのデータから継続してカウントを開始することができます。CTRUNとCTRSTに同時に1を書き込んだ場合、計時タイマはカウンタをリセット後にカウントを開始します。

カウント中は32Hz、8Hz、2Hz、1Hz信号の立ち下がりエッジでそれぞれの割り込み要因が発生します。割り込みを許可している場合は、割り込み要求が割り込みコントローラ(ITC)に送られます。



図15.4.1 計時タイマのタイミングチャート

注: 計時タイマはCTRUNへの書き込みに対して、256Hz信号の立ち下がりエッジに同期して実際にRun/Stop状態となります。したがって、CTRUNに0を書き込んだ場合は、“+1”余分にカウントしたところでタイマが停止状態となります。また、このときCTRUNは実際にタイマがStop状態となるまで、読み出しに対して1を保持します。

図15.4.2にRun/Stop制御のタイミングチャートを示します。



図15.4.2 Run/Stop制御のタイミングチャート

## 15.5 計時タイマ割り込み

CTモジュールには、以下の4種類の割り込みを発生させる機能があります。

- 32Hz割り込み
- 8Hz割り込み
- 2Hz割り込み
- 1Hz割り込み

CTモジュールは、上記4種類の割り込み要因が共有する1本の割り込み信号を割り込みコントローラ(ITC)に対して出力します。発生した割り込み要因を特定するには、CTモジュール内の割り込みフラグを読み出してください。

### 32Hz、8Hz、2Hz、1Hz割り込み

これらの割り込み要求は、32Hz、8Hz、2Hz、1Hz信号の立ち下がりエッジで発生し、CTモジュール内の以下の割り込みフラグを1にセットします。

- \* **CTIF32:** 32 Hz Interrupt Flag in the Clock Timer Interrupt Flag (CT\_IFLG) Register (D3/0x5003)
- \* **CTIF8:** 8 Hz Interrupt Flag in the Clock Timer Interrupt Flag (CT\_IFLG) Register (D2/0x5003)
- \* **CTIF2:** 2 Hz Interrupt Flag in the Clock Timer Interrupt Flag (CT\_IFLG) Register (D1/0x5003)
- \* **CTIF1:** 1 Hz Interrupt Flag in the Clock Timer Interrupt Flag (CT\_IFLG) Register (D0/0x5003)

これらの割り込みを使用するには、割り込みフラグに対応する以下の割り込みイネーブルビットを1に設定します。割り込みイネーブルビットが0(デフォルト)に設定されていると割り込みフラグは1にセットされず、その要因による割り込み要求はITCに送られません。

- \* **CTIE32:** 32 Hz Interrupt Enable Bit in the Clock Timer Interrupt Mask (CT\_IMSK) Register (D3/0x5002)
- \* **CTIE8:** 8 Hz Interrupt Enable Bit in the Clock Timer Interrupt Mask (CT\_IMSK) Register (D2/0x5002)
- \* **CTIE2:** 2 Hz Interrupt Enable Bit in the Clock Timer Interrupt Mask (CT\_IMSK) Register (D1/0x5002)
- \* **CTIE1:** 1 Hz Interrupt Enable Bit in the Clock Timer Interrupt Mask (CT\_IMSK) Register (D0/0x5002)

CTIF\*が1にセットされるとCTモジュールは割り込み要求をITCに出力します。この割り込み要求信号により、ITC内の計時タイマ割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

計時タイマ割り込みがどの周波数によるものかについては、計時タイマ割り込み処理ルーチンでCTIF\*を読み出して確認してください。

また、割り込み処理ルーチン内では、ITCの計時タイマ割り込みフラグではなくCTモジュールのCTIF\*をリセット(1を書き込み)して割り込み要因をクリアしてください。

**注:** 不要な割り込みの発生を防止するため、CTIE\*によって計時タイマ割り込みを許可する前に、CTIF\*をリセットしてください。

### 計時タイマ割り込み用ITCレジスタ

前述の設定により、割り込みを許可した周波数の立ち下がりエッジで計時タイマは割り込み信号をITCに出力します。計時タイマ割り込みを発生させるには、ITCレジスタで割り込みレベルと割り込み許可の設定を行ってください。

以下に、計時タイマ用のITC制御ビットを示します。

#### ITC内の割り込みフラグ

- \* **EIFT3:** Clock Timer Interrupt Flag in the Interrupt Flag (ITC\_IFLG) Register (D3/0x4300)

#### ITC内の割り込みイネーブルビット

- \* **EIEN3:** Clock Timer Interrupt Enable Bit in the Interrupt Enable (ITC\_EN) Register (D3/0x4302)

#### ITC内の割り込みレベル設定ビット

- \* **EILV3[2:0]:** CT Interrupt Level Bits in the External Interrupt Level Setup (ITC\_ELV1) Register 1 (D[10:8]/0x4308)

#### ITC内の割り込みトリガモード選択ビット(1に固定してください)

- \* **EITG3:** CT Interrupt Trigger Mode Select Bit in the External Interrupt Level Setup (ITC\_ELV1) Register 1 (D12/0x4308)

CTモジュールで割り込みが許可された32/8/2/1Hz信号の立ち下がりエッジで、EIFT3が1にセットされます。このとき、EIEN3が1に設定されていると、ITCは割り込み要求をS1C17コアに送ります。計時タイマによる割り込みを禁止するには、EIEN3を0に設定しておきます。EIFT3は、EIEN3の設定にかかわらず(0に設定していても)、CTモジュールからの割り込み信号によって1にセットされます。EILV3[2:0]は、計時タイマ割り込みのレベル(0~7)を設定します。

S1C17コアは、以下のすべての条件が成立している場合に割り込みを受け付けます。

- 割り込みイネーブルビットが1にセットされている。
- PSR(S1C17コア内のプロセッサステータスレジスタ)のIE(割り込みイネーブル)ビットが1にセットされている。
- 計時タイマ割り込みが、PSRのIL(割り込みレベル)に設定されている値よりも高い割り込みレベルに設定されている。
- NMIなど、他の優先順位の高い割り込み要因が発生していない。

これらの割り込み制御レジスタの詳細と割り込み発生時の動作については、“6 割り込みコントローラ(ITC)”を参照してください。

注: 割り込み要因の発生状態をCTモジュールの割り込みフラグで管理するため、以下の処理が必要です。

1. ITCの計時タイマ割り込みのトリガモードをレベルトリガモードに設定
2. 割り込み発生後は、割り込み処理ルーチン内で、CTモジュール内の割り込みフラグCTIF\*をリセット(これによりITCの割り込みフラグもリセットされます)

### 割り込みベクタ

計時タイマ割り込みのベクタ番号とベクタアドレスは以下のとおりです。

ベクタ番号: 7(0x07)

ベクタアドレス: 0x801c

## 15.6 制御レジスタ詳細

表15.6.1 計時タイマレジスター一覧

| アドレス   | レジスタ名   | 機能                                                      |
|--------|---------|---------------------------------------------------------|
| 0x5000 | CT_CTL  | Clock Timer Control Register<br>タイマのリセットとRUN/STOP制御     |
| 0x5001 | CT_CNT  | Clock Timer Counter Register<br>カウンタデータ                 |
| 0x5002 | CT_IMSK | Clock Timer Interrupt Mask Register<br>割り込みマスクの設定       |
| 0x5003 | CT_IFLG | Clock Timer Interrupt Flag Register<br>割り込み発生状態の表示/リセット |

以下、計時タイマのレジスタを個々に説明します。これらはすべて8ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

**0x5000: Clock Timer Control Register (CT\_CTL)**

| Register name                         | Address         | Bit  | Name  | Function                     | Setting                 | Init. | R/W | Remarks            |
|---------------------------------------|-----------------|------|-------|------------------------------|-------------------------|-------|-----|--------------------|
| Clock Timer Control Register (CT_CTL) | 0x5000 (8 bits) | D7-5 | —     | reserved                     | —                       | —     | —   | 0 when being read. |
|                                       |                 | D4   | CTRST | Clock timer reset            | 1   Reset   0   Ignored | 0     | W   |                    |
|                                       |                 | D3-1 | —     | reserved                     | —                       | —     | —   |                    |
|                                       |                 | D0   | CTRUN | Clock timer run/stop control | 1   Run   0   Stop      | 0     | R/W |                    |

**D[7:5] Reserved****D4 CTRST: Clock Timer Reset Bit**

計時タイマをリセットします。

1(W): リセット

0(W): 無効

0(R): 読み出し時は常時0(デフォルト)

このビットに1を書き込むことによって、カウンタが0x0にリセットされます。計時タイマがRun状態でリセットを行うとリセット直後にリスタートします。また、Stop状態の場合はリセットデータ0x0が保持されます。

**D[3:1] Reserved****D0 CTRUN: Clock Timer Run/Stop Control Bit**

計時タイマのRun/Stopを制御します。

1(R/W): Run

0(R/W): Stop(デフォルト)

計時タイマはCTRUNに1を書き込むことによってカウントを開始し、0の書き込みにより停止します。Stop状態ではリセットか次にRun状態にするまで、カウンタのデータは保持されます。

## 0x5001: Clock Timer Counter Register (CT\_CNT)

| Register name                         | Address         | Bit  | Name       | Function                  | Setting     | Init. | R/W | Remarks |
|---------------------------------------|-----------------|------|------------|---------------------------|-------------|-------|-----|---------|
| Clock Timer Counter Register (CT_CNT) | 0x5001 (8 bits) | D7-0 | CTCNT[7:0] | Clock timer counter value | 0x0 to 0xff | 0     | R   |         |

### D[7:0] CTCNT[7:0]: Clock Timer Counter Value

カウンタデータが読み出せます。(デフォルト: 0xff)

このレジスタはリードオンリのため、データの書き込みはできません。

各ビットと周波数の対応は以下のとおりです。

D7: 1Hz

D6: 2Hz

D5: 4Hz

D4: 8Hz

D3: 16Hz

D2: 32Hz

D1: 64Hz

D0: 128Hz

**0x5002: Clock Timer Interrupt Mask Register (CT\_IMSK)**

| Register name                                          | Address            | Bit  | Name   | Function               | Setting |        | Init. | R/W     | Remarks            |
|--------------------------------------------------------|--------------------|------|--------|------------------------|---------|--------|-------|---------|--------------------|
| Clock Timer<br>Interrupt Mask<br>Register<br>(CT_IMSK) | 0x5002<br>(8 bits) | D7–4 | –      | reserved               | –       | –      | –     | –       | 0 when being read. |
|                                                        |                    | D3   | CTIE32 | 32 Hz interrupt enable | 1       | Enable | 0     | Disable | 0 R/W              |
|                                                        |                    | D2   | CTIE8  | 8 Hz interrupt enable  | 1       | Enable | 0     | Disable | 0 R/W              |
|                                                        |                    | D1   | CTIE2  | 2 Hz interrupt enable  | 1       | Enable | 0     | Disable | 0 R/W              |
|                                                        |                    | D0   | CTIE1  | 1 Hz interrupt enable  | 1       | Enable | 0     | Disable | 0 R/W              |

本レジスタは、計時タイマの32Hz、8Hz、2Hz、1Hz信号による割り込み要求を個々に許可または禁止します。CTIE\*ビットを1に設定すると、対応する周波数の信号の立ち下がりエッジによる計時タイマ割り込み要求が許可され、0に設定すると割り込みが禁止されます。

なお、割り込みを発生させるには、ITCの計時タイマ割り込みイネーブルビットも割り込み許可に設定する必要があります。

**D[7:4] Reserved****D3 CTIE32: 32 Hz Interrupt Enable Bit**

32Hz信号による割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

**D2 CTIE8: 8 Hz Interrupt Enable Bit**

8Hz信号による割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

**D1 CTIE2: 2 Hz Interrupt Enable Bit**

2Hz信号による割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

**D0 CTIE1: 1 Hz Interrupt Enable Bit**

1Hz信号による割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

## 0x5003: Clock Timer Interrupt Flag Register (CT\_IFLG)

| Register name                                          | Address            | Bit  | Name   | Function             | Setting |                             | Init. | R/W                             | Remarks            |
|--------------------------------------------------------|--------------------|------|--------|----------------------|---------|-----------------------------|-------|---------------------------------|--------------------|
| Clock Timer<br>Interrupt Flag<br>Register<br>(CT_IFLG) | 0x5003<br>(8 bits) | D7-4 | —      | reserved             | —       | —                           | —     | —                               | 0 when being read. |
|                                                        |                    | D3   | CTIF32 | 32 Hz interrupt flag | 1       | Cause of interrupt occurred | 0     | Cause of interrupt not occurred | 0 R/W              |
|                                                        |                    | D2   | CTIF8  | 8 Hz interrupt flag  |         |                             |       |                                 | 0 R/W              |
|                                                        |                    | D1   | CTIF2  | 2 Hz interrupt flag  |         |                             |       |                                 | 0 R/W              |
|                                                        |                    | D0   | CTIF1  | 1 Hz interrupt flag  |         |                             |       |                                 | 0 R/W              |

本レジスタは、計時タイマの32Hz、8Hz、2Hz、1Hz信号による割り込み要因の発生状態を示します。計時タイマ割り込みが発生した場合は、本レジスタの割り込みフラグを読み出して発生した割り込み要因(周波数)を特定してください。CTIF\*は32Hz、8Hz、2Hz、1Hz割り込みに個々に対応するCTモジュールの割り込みフラグです。CTIE\*(CT\_IMSKレジスタ)を1に設定しておくことにより、各信号の立ち下がりエッジで1にセットされます。同時に、ITCに対して計時タイマ割り込み要求信号が送出されます。この割り込み要求信号により、ITC内の計時タイマ割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

割り込み要因の発生状態を本レジスタで管理するため、以下の処理が必要です。

1. ITCの計時タイマ割り込みのトリガモードをレベルトリガモードに設定
2. 割り込み発生後は、割り込み処理ルーチン内で、CTモジュール内の割り込みフラグをリセット  
(これによりITCの割り込みフラグもリセットされます)

CTIF\*は1の書き込みによりリセットされます。

注: 不要な割り込みの発生を防止するため、CTIE\*によって計時タイマ割り込みを許可する前に、CTIF\*をリセットしてください。

### D[7:4] Reserved

#### D3 CTIF32: 32 Hz Interrupt Flag

32Hz割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり  
0(R): 割り込み要因なし(デフォルト)  
1(W): フラグをリセット  
0(W): 無効

CTIF32はCTIE32(D3/CT\_IMSKレジスタ)を1に設定しておくことにより、32Hz信号の立ち下がりエッジで1にセットされます。

#### D2 CTIF8: 8 Hz Interrupt Flag

8Hz割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり  
0(R): 割り込み要因なし(デフォルト)  
1(W): フラグをリセット  
0(W): 無効

CTIF8はCTIE8(D2/CT\_IMSKレジスタ)を1に設定しておくことにより、8Hz信号の立ち下がりエッジで1にセットされます。

#### D1 CTIF2: 2 Hz Interrupt Flag

2Hz割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり  
0(R): 割り込み要因なし(デフォルト)  
1(W): フラグをリセット  
0(W): 無効

CTIF2はCTIE2(D1/CT\_IMSKレジスタ)を1に設定しておくことにより、2Hz信号の立ち下がりエッジで1にセットされます。

#### D0 CTIF1: 1 Hz Interrupt Flag

1Hz割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり  
0(R): 割り込み要因なし(デフォルト)  
1(W): フラグをリセット  
0(W): 無効

CTIF1はCTIE1(D0/CT\_IMSKレジスタ)を1に設定しておくことにより、1Hz信号の立ち下がりエッジで1にセットされます。

## 15.7 注意事項

- ・計時タイマを動作させるには、その前にOSC1発振回路をOnさせておく必要があります。
- ・不要な割り込みの発生を防止するため、CT\_IMSKレジスタによって計時タイマ割り込みを許可する前に、CT\_IFLGレジスタの割り込みフラグをリセットしてください。
- ・計時タイマはCTRUN(DO/CT\_CTLレジスタ)への書き込みに対して、256Hz信号の立ち下がりエッジに同期して実際にRun/Stop状態となります。したがって、CTRUNに0を書き込んだ場合は、“+1”余分にカウントしたところでタイマが停止状態となります。また、このときCTRUNは実際にタイマがStop状態となるまで、読み出しに対して1を保持します。

図15.7.1にRun/Stop制御のタイミングチャートを示します。



図15.7.1 Run/Stop制御のタイミングチャート

- ・計時タイマがRunしている状態(CTRUN = 1)でslp命令を実行した場合は、SLEEP状態からの復帰時に計時タイマが不安定な動作となります。したがって、SLEEP状態へ移行する場合は、slp命令の実行以前に計時タイマをSTOP状態(CTRUN = 0)に設定してください。

# 16 ストップウォッチタイマ(SWT)

## 16.1 ストップウォッチタイマの概要

S1C17001は1/100秒と1/10秒のストップウォッチタイマを内蔵しています。ストップウォッチタイマはOSC1クロックを分周した256Hz信号を入力クロックとする4ビット2段のBCDカウンタ(1/100秒単位、1/10秒単位)で構成され、カウントデータをソフトウェアによって読み出すことができます。また、ストップウォッチタイマは100Hz(近似100Hz)、10Hz(近似10Hz)、1Hzの各信号によって割り込みを発生させることができます。

図16.1.1にストップウォッチタイマの構造を示します。



図16.1.1 ストップウォッチタイマの構造

## 16.2 BCDカウンタ

ストップウォッチタイマは、1/100秒と1/10秒の2個の4ビットBCDカウンタで構成されています。カウント値はSWT\_BCNTレジスタから読み出し可能です。

### 1/100秒カウンタ

\* **BCD10[3:0]**: 1/100 Sec. BCD Counter Value in the Stopwatch Timer BCD Counter (SWT\_BCNT) Register (D[3:0]/0x5021)

### 1/10秒カウンタ

\* **BCD10[3:0]**: 1/10 Sec. BCD Counter Value in the Stopwatch Timer BCD Counter (SWT\_BCNT) Register (D[7:4]/0x5021)

### カウントアップパターン

256Hzクロックから100Hz信号、10Hz信号、1Hz信号を生成するため、帰還分周回路を使用して図16.2.1のようにカウンタのカウントアップパターンを変化させています。



図16.2.1 ストップウォッチタイマのカウントアップパターン

帰還分周回路はOSCモジュールから供給される256Hz信号から2/256秒と3/256秒間隔の近似100Hz信号を発生します。

1/100秒カウンタは帰還分周回路が出力する近似100Hz信号をカウントして、25/256秒と26/256秒間隔の近似10Hz信号を発生します。

カウントアップは、2/256秒と3/256秒間隔による擬似的な1/100秒カウントとなります。

1/10秒カウンタは、1/100秒カウンタが発生する近似10Hz信号を4:6の割合でカウントして、1Hz信号を発生します。

カウントアップは、25/256秒と26/256秒間隔による擬似的な1/10秒カウントとなります。

## 16.3 動作クロック

ストップウォッチタイマは、OSCモジュールが出力する256Hzクロックを動作クロックとして使用します。

OSCモジュールはOSC1クロックを1/128に分周してこの動作クロックを生成します。したがって、OSC1クロック周波数が32.768kHzの場合に256Hzとなります。それ以外のOSC1クロック周波数では、本節に記載の周波数が変わります。

OSCモジュールに256Hzクロックの出力制御ビットは設けられていません。OSC1発振がOnの場合は、常に256Hzクロックがストップウォッチタイマに供給されます。

OSC1発振回路の制御については、“7 発振回路(OSC)”を参照してください。

## 16.4 ストップウォッチタイマのリセット

---

ストップウォッチタイマをリセットするには、SWTRSTビット(D4/SWT\_CTLレジスタ)に1を書き込みます。カウンタが0にクリアされます。

\* **SWTRST**: Stopwatch Timer Reset Bit in the Stopwatch Timer Control (SWT\_CTL) Register (D4/0x5020)  
この操作以外では、イニシャルリセットによりカウンタがクリアされます。

## 16.5 ストップウォッチタイマRUN/STOP制御

ストップウォッチタイマの動作を開始させる前に、以下の設定を行ってください。

- (1) 割り込みを使用する場合は、割り込みレベルを設定し、ストップウォッチタイマの割り込みを許可します。16.6節を参照してください。
- (2) タイマをリセットします。16.4節を参照してください。

ストップウォッチタイマには、Run/Stopを制御するSWTRUN(D0/SWT\_CTLレジスタ)が設けられています。

\* **SWTRUN:** Stopwatch Timer Run/Stop Control Bit in the Stopwatch Timer Control (SWT\_CTL) Register (D0/0x5020)

ストップウォッチタイマはSWTRUNに1を書き込むことによって動作を開始します。SWTRUNに0を書き込むとクロックの入力が禁止され、動作は停止します。

この制御はカウンタ(SWT\_BCNTレジスタ)のデータには影響を与えません。カウントの停止中もカウンタのデータは保持されており、そのデータから継続してカウントを開始させることができます。SWTRUNとSWTRSTに同時に1を書き込んだ場合、ストップウォッチタイマはカウンタをリセット後にカウントを開始します。

カウント中は100Hz(近似100Hz)、10Hz(近似10Hz)、1Hz信号の立ち下がりエッジでそれぞれの割り込み要因が発生します。割り込みを許可している場合は、割り込み要求が割り込みコントローラ(ITC)に送られます。



図16.5.1 ストップウォッチタイマのタイミングチャート

注: ストップウォッチタイマはSWTRUNへの書き込みに対して、256Hz信号の立ち下がりエッジに同期して実際にRun/Stop状態となる場合があります。したがって、SWTRUNに0を書き込んだ場合は、“+1”余分にカウントしたところでタイマが停止状態となります。また、このときSWTRUNは実際にタイマがStop状態となるまで、読み出しに対して1を保持します。

図16.5.2にRun/Stop制御のタイミングチャートを示します。



図16.5.2 Run/Stop制御のタイミングチャート

## 16.6 ストップウォッチタイマ割り込み

SWTモジュールには、以下の3種類の割り込みを発生させる機能があります。

- 100Hz割り込み
- 10Hz割り込み
- 1Hz割り込み

SWTモジュールは、上記3種類の割り込み要因が共有する1本の割り込み信号を割り込みコントローラ(ITC)に対して出力します。発生した割り込み要因を特定するには、SWTモジュール内の割り込みフラグを読み出してください。

### 100Hz、10Hz、1Hz割り込み

これらの割り込み要求は、100Hz(近似100Hz)、10Hz(近似10Hz)、1Hz信号の立ち下がりエッジで発生し、SWTモジュール内の以下の割り込みフラグを1にセットします。

- \* **SIF1:** 1 Hz Interrupt Flag in the Stopwatch Timer Interrupt Flag (SWT\_IFLG) Register (D2/0x5023)
- \* **SIF10:** 10 Hz Interrupt Flag in the Stopwatch Timer Interrupt Flag (SWT\_IFLG) Register (D1/0x5023)
- \* **SIF100:** 100 Hz Interrupt Flag in the Stopwatch Timer Interrupt Flag (SWT\_IFLG) Register (D0/0x5023)

これらの割り込みを使用するには、割り込みフラグに対応する以下の割り込みイネーブルビットを1に設定します。割り込みイネーブルビットが0(デフォルト)に設定されていると割り込みフラグが1にセットされず、その要因による割り込み要求はITCに送られません。

- \* **SIE1:** 1 Hz Interrupt Enable Bit in the Stopwatch Timer Interrupt Mask (SWT\_IMSK) Register (D2/0x5022)
- \* **SIE10:** 10 Hz Interrupt Enable Bit in the Stopwatch Timer Interrupt Mask (SWT\_IMSK) Register (D1/0x5022)
- \* **SIE100:** 100 Hz Interrupt Enable Bit in the Stopwatch Timer Interrupt Mask (SWT\_IMSK) Register (D0/0x5022)

SIF\*が1にセットされるとSWTモジュールは割り込み要求をITCに出力します。この割り込み要求信号により、ITC内のストップウォッチタイマ割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

ストップウォッチタイマ割り込みがどの周波数によるものかについては、ストップウォッチタイマ割り込み処理ルーチンでSIF\*を読み出して確認してください。

また、割り込み処理ルーチン内では、ITCのストップウォッチタイマ割り込みフラグではなくSWTモジュールのSIF\*をリセット(1を書き込み)して割り込み要因をクリアしてください。

**注:** 不要な割り込みの発生を防止するため、SIE\*によってストップウォッチタイマ割り込みを許可する前に、SIF\*をリセットしてください。

### ストップウォッチタイマ割り込み用ITCレジスタ

前述の設定により、割り込みを許可した周波数の立ち下がりエッジでストップウォッチタイマは割り込み信号をITCに出力します。ストップウォッチタイマ割り込みを発生させるには、ITCレジスタで割り込みレベルと割り込み許可の設定を行ってください。

以下に、ストップウォッチタイマ用のITC制御ビットを示します。

#### ITC内の割り込みフラグ

- \* **EIFT2:** Stopwatch Timer Interrupt Flag in the Interrupt Flag (ITC\_IFLG) Register (D2/0x4300)

#### ITC内の割り込みイネーブルビット

- \* **EIEN2:** Stopwatch Timer Interrupt Enable Bit in the Interrupt Enable (ITC\_EN) Register (D2/0x4302)

#### ITC内の割り込みレベル設定ビット

- \* **EILV2[2:0]:** SWT Interrupt Level Bits in the External Interrupt Level Setup (ITC\_ELV1) Register 1 (D[2:0]/0x4308)

#### ITC内の割り込みトリガモード選択ビット(1に固定してください)

- \* **ETG2:** SWT Interrupt Trigger Mode Select Bit in the External Interrupt Level Setup (ITC\_ELV1) Register 1 (D4/0x4308)

SWTモジュールで割り込みが許可された100/10/1Hz信号の立ち下がりエッジで、EIFT2が1にセットされます。このとき、EIEN2が1に設定されていると、ITCは割り込み要求をS1C17コアに送ります。ストップウォッチタイマによる割り込みを禁止するには、EIEN2を0に設定しておきます。EIFT2は、EIEN2の設定にかかわらず(0に設定されていても)、SWTモジュールからの割り込み信号によって1にセットされます。

EILV2[2:0]は、ストップウォッチタイマ割り込みのレベル(0~7)を設定します。

S1C17コアは、以下のすべての条件が成立している場合に割り込みを受け付けます。

- 割り込みイネーブルビットが1にセットされている。
- PSR(S1C17コア内のプロセッサステータスレジスタ)のIE(割り込みイネーブル)ビットが1にセットされている。
- ストップウォッチタイマ割り込みが、PSRのIL(割り込みレベル)に設定されている値よりも高い割り込みレベルに設定されている。
- NMIなど、他の優先順位の高い割り込み要因が発生していない。

これらの割り込み制御レジスタの詳細と割り込み発生時の動作については、“6 割り込みコントローラ(ITC)”を参照してください。

注: 割り込み要因の発生状態をSWTモジュールの割り込みフラグで管理するため、以下の処理が必要です。

1. ITCのストップウォッチタイマ割り込みのトリガモードをレベルトリガモードに設定
2. 割り込み発生後は、割り込み処理ルーチン内で、SWTモジュール内の割り込みフラグSIF\*をリセット(これによりITCの割り込みフラグもリセットされます)

### 割り込みベクタ

ストップウォッチタイマ割り込みのベクタ番号とベクタアドレスは以下のとおりです。

ベクタ番号: 6(0x06)

ベクタアドレス: 0x8018

## 16.7 制御レジスタ詳細

表16.7.1 ストップウォッチタイマレジスター一覧

| アドレス   | レジスタ名    | 機能                                                          |
|--------|----------|-------------------------------------------------------------|
| 0x5020 | SWT_CTL  | Stopwatch Timer Control Register<br>タイマのリセットとRUN/STOP制御     |
| 0x5021 | SWT_BCNT | Stopwatch Timer BCD Counter Register<br>BCDカウンタデータ          |
| 0x5022 | SWT_IMSK | Stopwatch Timer Interrupt Mask Register<br>割り込みマスクの設定       |
| 0x5023 | SWT_IFLG | Stopwatch Timer Interrupt Flag Register<br>割り込み発生状態の表示/リセット |

以下、ストップウォッチタイマのレジスタを個々に説明します。これらはすべて8ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

**0x5020: Stopwatch Timer Control Register (SWT\_CTL)**

| Register name                                       | Address            | Bit  | Name   | Function                         | Setting   | Init.       | R/W     | Remarks            |
|-----------------------------------------------------|--------------------|------|--------|----------------------------------|-----------|-------------|---------|--------------------|
| Stopwatch<br>Timer Control<br>Register<br>(SWT_CTL) | 0x5020<br>(8 bits) | D7-5 | —      | reserved                         | —         | —           | —       | 0 when being read. |
|                                                     |                    | D4   | SWTRST | Stopwatch timer reset            | 1   Reset | 0   Ignored | 0   W   |                    |
|                                                     |                    | D3-1 | —      | reserved                         | —         | —           | —       |                    |
|                                                     |                    | D0   | SWTRUN | Stopwatch timer run/stop control | 1   Run   | 0   Stop    | 0   R/W |                    |

**D[7:5] Reserved****D4 SWTRST: Stopwatch Timer Reset Bit**

ストップウォッチタイマをリセットします。

1(W): リセット

0(W): 無効

0(R): 読み出し時は常時0(デフォルト)

このビットに1を書き込むことによって、カウンタが0x0にリセットされます。ストップウォッチタイマがRun状態でリセットを行うとリセット直後にリスタートします。また、Stop状態の場合はリセットデータ0x0が保持されます。

**D[3:1] Reserved****D0 SWTRUN: Stopwatch Timer Run/Stop Control Bit**

ストップウォッチタイマのRun/Stopを制御します。

1(R/W): Run

0(R/W): Stop(デフォルト)

ストップウォッチタイマはSWTRUNに1を書き込むことによってカウントを開始し、0の書き込みにより停止します。Stop状態ではリセットか次にRun状態にするまで、カウンタのデータは保持されます。

**0x5021: Stopwatch Timer BCD Counter Register (SWT\_BCNT)**

| Register name                                            | Address            | Bit  | Name        | Function                     | Setting | Init. | R/W | Remarks |
|----------------------------------------------------------|--------------------|------|-------------|------------------------------|---------|-------|-----|---------|
| Stopwatch<br>Timer BCD<br>Counter Register<br>(SWT_BCNT) | 0x5021<br>(8 bits) | D7–4 | BCD10[3:0]  | 1/10 sec. BCD counter value  | 0 to 9  | 0     | R   |         |
|                                                          |                    | D3–0 | BCD100[3:0] | 1/100 sec. BCD counter value | 0 to 9  | 0     | R   |         |

**D[7:4] BCD10[3:0]: 1/10 Sec. BCD Counter Value**

1/10秒カウンタのBCDデータが読み出せます。(デフォルト: 0)

このレジスタはリードオンリのため、データの書き込みはできません。

**D[3:0] BCD100[3:0]: 1/100 Sec. BCD Counter Value**

1/100秒カウンタのBCDデータが読み出せます。(デフォルト: 0)

このレジスタはリードオンリのため、データの書き込みはできません。

## 0x5022: Stopwatch Timer Interrupt Mask Register (SWT\_IMSK)

| Register name                                               | Address            | Bit  | Name   | Function                | Setting |        | Init. | R/W     | Remarks            |
|-------------------------------------------------------------|--------------------|------|--------|-------------------------|---------|--------|-------|---------|--------------------|
| Stopwatch<br>Timer Interrupt<br>Mask Register<br>(SWT_IMSK) | 0x5022<br>(8 bits) | D7–3 | –      | reserved                | –       | –      | –     | –       | 0 when being read. |
|                                                             |                    | D2   | SIE1   | 1 Hz interrupt enable   | 1       | Enable | 0     | Disable | 0 R/W              |
|                                                             |                    | D1   | SIE10  | 10 Hz interrupt enable  | 1       | Enable | 0     | Disable | 0 R/W              |
|                                                             |                    | D0   | SIE100 | 100 Hz interrupt enable | 1       | Enable | 0     | Disable | 0 R/W              |

本レジスタは、ストップウォッチタイマの100Hz、10Hz、1Hz信号による割り込み要求を個々に許可または禁止します。SIE\*ビットを1に設定すると、対応する周波数の信号の立ち下がりエッジによるストップウォッチタイマ割り込み要求が許可され、0に設定すると割り込みが禁止されます。

なお、割り込みを発生させるには、ITCのストップウォッチタイマ割り込みイネーブルビットも割り込み許可に設定する必要があります。

### D[7:3] Reserved

#### D2 SIE1: 1 Hz Interrupt Enable Bit

1Hz信号による割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

#### D1 SIE10: 10 Hz Interrupt Enable Bit

10Hz信号による割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

#### D0 SIE100: 100 Hz Interrupt Enable Bit

100Hz信号による割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

## 0x5023: Stopwatch Timer Interrupt Flag Register (SWT\_IFLG)

| Register name                                               | Address            | Bit  | Name   | Function              | Setting |                             | Init. | R/W                             | Remarks                   |
|-------------------------------------------------------------|--------------------|------|--------|-----------------------|---------|-----------------------------|-------|---------------------------------|---------------------------|
| Stopwatch<br>Timer Interrupt<br>Flag Register<br>(SWT_IFLG) | 0x5023<br>(8 bits) | D7-3 | —      | reserved              | —       |                             | —     | —                               | 0 when being read.        |
|                                                             |                    | D2   | SIF1   | 1 Hz interrupt flag   | 1       | Cause of interrupt occurred | 0     | Cause of interrupt not occurred | 0 R/W Reset by writing 1. |
|                                                             |                    | D1   | SIF10  | 10 Hz interrupt flag  |         |                             |       |                                 | 0 R/W                     |
|                                                             |                    | D0   | SIF100 | 100 Hz interrupt flag |         |                             |       |                                 | 0 R/W                     |

本レジスタは、ストップウォッチタイマの100Hz、10Hz、1Hz信号による割り込み要因の発生状態を示します。ストップウォッチタイマ割り込みが発生した場合は、本レジスタの割り込みフラグを読み出して発生した割り込み要因(周波数)を特定してください。

SIF\*は100Hz、10Hz、1Hz割り込みに個々に対応するSWTモジュールの割り込みフラグです。SIE\*(SWT\_IMSKレジスタ)を1に設定しておくことにより、各信号の立ち下がりエッジで1にセットされます。同時に、ITCに対してストップウォッチタイマ割り込み要求信号が outputされます。この割り込み要求信号により、ITC内のストップウォッチタイマ割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

割り込み要因の発生状態を本レジスタで管理するため、以下の処理が必要です。

1. ITCのストップウォッチタイマ割り込みのトリガモードをレベルトリガモードに設定
2. 割り込み発生後は、割り込み処理ルーチン内で、SWTモジュール内の割り込みフラグをリセット（これによりITCの割り込みフラグもリセットされます）

SIF\*は1の書き込みによりリセットされます。

注: 不要な割り込みの発生を防止するため、SIE\*によってストップウォッチタイマ割り込みを許可する前に、SIF\*をリセットしてください。

### D[7:3] Reserved

#### D2 SIF1: 1 Hz Interrupt Flag

1Hz割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり  
0(R): 割り込み要因なし(デフォルト)  
1(W): フラグをリセット  
0(W): 無効

SIF1はSIE1(D2/SWT\_IMSKレジスタ)を1に設定しておくことにより、1Hz信号の立ち下がりエッジで1にセットされます。

#### D1 SIF10: 10 Hz Interrupt Flag

10Hz割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり  
0(R): 割り込み要因なし(デフォルト)  
1(W): フラグをリセット  
0(W): 無効

SIF10はSIE10(D1/SWT\_IMSKレジスタ)を1に設定しておくことにより、10Hz信号の立ち下がりエッジで1にセットされます。

#### D0 SIF100: 100 Hz Interrupt Flag

100Hz割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり  
0(R): 割り込み要因なし(デフォルト)  
1(W): フラグをリセット  
0(W): 無効

SIF100はSIE100(D0/SWT\_IMSKレジスタ)を1に設定しておくことにより、100Hz信号の立ち下がりエッジで1にセットされます。

## 16.8 注意事項

- ・ストップウォッチタイマを動作させるには、その前にOSC1発振回路をOnさせておく必要があります。
- ・不要な割り込みの発生を防止するため、SWT\_IMSKレジスタによってストップウォッチタイマ割り込みを許可する前に、SWT\_IFLGレジスタの割り込みフラグをリセットしてください。
- ・ストップウォッチタイマはSWTRUN(D0/SWT\_CTLレジスタ)への書き込みに対して、256Hz信号の立ち下がりエッジに同期して実際にRun/Stop状態となる場合があります。したがって、SWTRUNに0を書き込んだ場合は、“+1”余分にカウントしたところでタイマが停止状態となります。また、このときSWTRUNは実際にタイマがStop状態となるまで、読み出しに対して1を保持します。

図16.8.1にRun/Stop制御のタイミングチャートを示します。



図16.8.1 Run/Stop制御のタイミングチャート

- ・ストップウォッチタイマがRunしている状態(SWTRUN = 1)でslp命令を実行した場合は、SLEEP状態からの復帰時にストップウォッチタイマが不安定な動作となります。したがって、SLEEP状態へ移行する場合は、slp命令の実行以前にストップウォッチタイマをSTOP状態(SWTRUN = 0)に設定してください。

このページはブランクです。

# 17 ウオッチドッグタイマ(WDT)

## 17.1 ウオッチドッグタイマの概要

S1C17001はOSC1発振回路を原振とするウォッチドッグタイマを内蔵しています。ウォッチドッグタイマは131072/fosc1秒( $f_{osc1} = 32.768\text{kHz}$ の場合4秒)以上リセットが行われない場合、CPUに対してNMIまたはリセット(ソフトウェアで選択可能)を発生します。

ソフトウェアによってこの周期以内にウォッチドッグタイマをリセットし、NMI/リセットが発生しないように処理しておくことで、その処理ルーチンを通らないようなプログラムの暴走を検出することができます。

図17.1.1にウォッチドッグタイマのブロック図を示します。



図17.1.1 ウオッチドッグタイマのブロック図

## 17.2 動作クロック

ウォッチドッグタイマは、OSCモジュールが送出する256Hzクロックを動作クロックとして使用します。OSCモジュールはOSC1クロックを1/128に分周してこの動作クロックを生成します。したがって、OSC1クロック周波数が32.768kHzの場合に256Hzとなります。それ以外のOSC1クロック周波数では、本節に記載の周波数や時間が変わります。

OSCモジュールに256Hzクロックの出力制御ビットは設けられていません。OSC1発振がOnの場合は、常に256Hzクロックがウォッチドッグタイマに供給されます。OSC1発振回路の制御については、“7 発振回路(OSC)”を参照してください。

## 17.3 ウオッチドッグタイマの制御

### 17.3.1 NMI/リセットモードの選択

NMI/リセット発生周期以内にウォッチドッグタイマがリセットされなかった場合に、NMI信号を出力するかリセット信号を出力するかWDTMD(D1/WDT\_STレジスタ)で選択できます。

\* **WDTMD**: NMI/Reset Mode Select Bit in the Watchdog Timer Status (WDT\_ST) Register (D1/0x5041)

NMIを発生させるにはWDTMDを0(デフォルト)に、リセットを発生させるには1に設定します。

### 17.3.2 ウオッチドッグタイマのRUN/STOP制御

ウォッチドッグタイマはWDTRUN[3:0](D[3:0]/WDT\_CTLレジスタ)に0b1010以外の値を書き込むことでカウントを開始し、0b1010を書き込むと停止します。

\* **WDTRUN[3:0]**: Watchdog Timer Run/Stop Control Bits in the Watchdog Timer Control (WDT\_CTL) Register (D[3:0]/0x5040)

イニシャルリセット時はWDTRUN[3:0]が0b1010に設定され、ウォッチドッグタイマは停止状態となります。

カウンタの値によってはRun直後にNMI/リセットが発生する場合がありますので、ウォッチドッグタイマをRunさせる際には次節で説明するウォッチドッグタイマのリセットも同時にに行ってください。

### 17.3.3 ウオッチドッグタイマのリセット

ウォッチドッグタイマをリセットするには、WDTRST(D4/WDT\_CTLレジスタ)に1を書き込みます。

\* **WDTRST**: Watchdog Timer Reset Bit in the Watchdog Timer Control (WDT\_CTL) Register (D4/0x5040)

ウォッチドッグタイマを使用する場合は、NMI/リセットが発生する前にウォッチドッグタイマをリセットするルーチンを定期的に処理される場所に用意しておきます。このルーチンは131072/fosc1秒(fosc1 = 32.768kHzの場合4秒)周期以内で処理されるようにしてください。

リセット後、ウォッチドッグタイマは新たなNMI/リセット発生周期のカウントを始めます。

何らかの原因によってウォッチドッグタイマがNMI/リセット発生周期以内にリセットされなかった場合、NMIまたはリセットによってCPUは割り込み処理に移行し、割り込みベクタを読み出して割り込み処理ルーチンを実行します。

リセットとNMIのベクタアドレスは、0x8000と0x8008です。

ウォッチドッグタイマがリセットされずにカウンタがオーバーフローしてNMIが発生した場合は、WDTST(D0/WDT\_STレジスタ)が1に設定されます。

\* **WDTST**: NMI Status Bit in the Watchdog Timer Status (WDT\_ST) Register (D0/0x5041)

このビットはNMIの発生元がウォッチドッグタイマであることを確認するために設けられています。1にセットされたWDTSTはウォッチドッグタイマをリセットすることで0にクリアされます。

### 17.3.4 スタンバイモード時の動作

#### HALTモード時

HALTモード時はクロックが供給されるため、ウォッチドッグタイマは動作します。したがって、NMI/リセット発生周期以上、HALTモードを続けるとNMIまたはリセットによりHALTモードが解除されます。HALTモード時にウォッチドッグタイマを無効にするには、halt命令実行前にWDTRUN[3:0]に0b1010を書き込んでウォッチドッグタイマを停止させてください。HALTモードを解除後は、動作を再開させる前にウォッチドッグタイマをリセットしてください。

#### SLEEPモード時

SLEEPモード時はOSCモジュールからのクロックの供給が停止します。したがって、ウォッチドッグタイマも動作を停止します。SLEEPモード解除後に不要なNMIまたはリセットが発生することを防ぐため、slp命令の実行前にウォッチドッグタイマをリセットしてください。また、必要に応じWDTRUN[3:0]によってウォッチドッグタイマを停止させてください。



## 17.4 制御レジスタ詳細

表17.4.1 ウオッヂドッグタイマレジスター一覧

| アドレス   | レジスタ名   | 機能                                                     |
|--------|---------|--------------------------------------------------------|
| 0x5040 | WDT_CTL | Watchdog Timer Control Register<br>タイマのリセットとRUN/STOP制御 |
| 0x5041 | WDT_ST  | Watchdog Timer Status Register<br>タイマモードの設定とNMI状態表示    |

以下、ウォッヂドッグタイマのレジスタを個々に説明します。これらはすべて8ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

## 0x5040: Watchdog Timer Control Register (WDT\_CTL)

| Register name                                      | Address            | Bit  | Name        | Function                        | Setting            |              | Init. | R/W     | Remarks            |
|----------------------------------------------------|--------------------|------|-------------|---------------------------------|--------------------|--------------|-------|---------|--------------------|
| Watchdog<br>Timer Control<br>Register<br>(WDT_CTL) | 0x5040<br>(8 bits) | D7–5 | –           | reserved                        | –                  | –            | –     | –       | 0 when being read. |
|                                                    |                    | D4   | WDTRST      | Watchdog timer reset            | 1                  | Reset        | 0     | Ignored | 0 W                |
|                                                    |                    | D3–0 | WDTRUN[3:0] | Watchdog timer run/stop control | Other than<br>1010 | 1010<br>Stop | 1010  | R/W     |                    |

### D[7:5] Reserved

#### D4 WDTRST: Watchdog Timer Reset Bit

ウォッチドッグタイマをリセットします。

1(W): リセット

0(W): 無効

0(R): 読み出し時は常時0(デフォルト)

ウォッチドッグタイマを使用する場合は、NMI/リセット発生周期( $fosc1 = 32.768\text{kHz}$ の場合4秒)以内に本ビットに1を書き込み、ウォッチドッグタイマをリセットする必要があります。この書き込みでアップカウンタは0にリセットされ、そこから新たなNMI/リセット発生周期のカウントを始めます。

#### D[3:0] WDTRUN[3:0]: Watchdog Timer Run/Stop Control Bits

ウォッチドッグタイマのRun/Stopを制御します。

0b1010以外(R/W): Run

0b1010(R/W): Stop(デフォルト)

ウォッチドッグタイマをRunさせる場合は、不要なNMIまたはリセットの発生を防ぐため、必ずウォッチドッグタイマのリセットも行ってください。

## 0x5041: Watchdog Timer Status Register (WDT\_ST)

| Register name                                    | Address            | Bit  | Name  | Function              | Setting |                   | Init. | R/W               | Remarks            |
|--------------------------------------------------|--------------------|------|-------|-----------------------|---------|-------------------|-------|-------------------|--------------------|
| Watchdog<br>Timer Status<br>Register<br>(WDT_ST) | 0x5041<br>(8 bits) | D7-2 | –     | reserved              | –       |                   | –     | –                 | 0 when being read. |
|                                                  |                    | D1   | WDTMD | NMI/Reset mode select | 1       | Reset             | 0     | NMI               | 0 R/W              |
|                                                  |                    | D0   | WDTST | NMI status            | 1       | NMI oc-<br>curred | 0     | Not oc-<br>curred | 0 R                |

### D[7:2] Reserved

#### D1 WDTMD: NMI/Reset Mode Select Bit

カウンタのオーバーフロー時にNMIとリセットのどちらを発生させるか選択します。

1(R/W): リセット

0(R/W): NMI(デフォルト)

本ビットを1に設定すると、カウンタがオーバーフローした時点でリセット信号を出力します。0に設定した場合はNMI信号を出力します。

#### D0 WDTST: NMI Status Bit

カウンタがオーバーフローしてNMIが発生したことを示します。

1(R): NMI発生(カウンタオーバーフロー)

0(R): NMI未発生(デフォルト)

このビットはNMIの発生元がウォッチドッグタイマであることを確認するために設けられています。1にセットされたWDTSTはウォッチドッグタイマをリセットすることで0にクリアされます。

リセット出力選択時も、カウンタオーバーフローで一旦セットされますが、イニシャルリセットによりクリアされ確認することはできません。

このページはブランクです。

# 18 UART

## 18.1 UARTの構成

S1C17001はUARTを1チャネル内蔵しています。UARTは150～460800bps(IrDAモードは115200bps)の転送速度で外部シリアルデバイスとの非同期データ転送を行います。2バイトの受信データバッファと1バイトの送信データバッファを内蔵し、全二重通信が可能です。転送クロックにはタイマモジュールによる内部生成クロックと、SCLK(P25)端子から入力する外部クロックのいずれかを使用できます。データ長(7ビットまたは8ビット)、ストップビット長(1ビットまたは2ビット)、パリティモード(偶数、奇数、パリティなし)はソフトウェアで選択します。スタートビットは1ビットに固定されています。データ受信時には、オーバーランエラー、フレーミングエラー、パリティエラーが検出可能です。UARTは3種類の割り込み(送信バッファエンプティ、受信バッファフル、受信エラー)を発生しますので、シリアルデータ転送を割り込み処理によって効率よく処理することができます。

また、本UARTモジュールにはRZI変調/復調回路が組み込まれており、簡単な外付け回路の追加のみで、IrDA 1.0に対応する赤外線通信回路を構成することができます。

図18.1.1に、UARTの構造を示します。



図18.1.1 UARTの構造

## 18.2 UART端子

表18.2.1にUARTの入出力端子の一覧を示します。

表18.2.1 UART端子一覧

| 端子名        | I/O | 本数 | 機能                                                 |
|------------|-----|----|----------------------------------------------------|
| SIN (P23)  | I   | 1  | UARTデータ入力端子<br>外部シリアルデバイスから送られるシリアルデータを入力します。      |
| SOUT (P24) | O   | 1  | UARTデータ出力端子<br>外部シリアルデバイスに送るシリアルデータを出力します。         |
| SCLK (P25) | I   | 1  | UARTクロック入力端子<br>転送クロックに外部クロックを使用する場合に、この端子から入力します。 |

UARTの入出力端子(SIN、SOUT、SCLK)は汎用入出力ポート端子(P23、P24、P25)を兼用しており、初期状態では汎用入出力ポート端子に設定されます。これらをUARTの入出力端子として使用するには、P2\_PMUXレジスタの設定により機能を切り換える必要があります。以下の制御ビットを1に設定して、端子をシリアルインターフェース用に切り換えてください。

### P23 → SIN

\* **P23MUX**: P23 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register (D3/0x52a2)

### P24 → SOUT

\* **P24MUX**: P24 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register (D4/0x52a2)

### P25 → SCLK (外部クロックを使用する場合のみ)

\* **P25MUX**: P25 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register (D5/0x52a2)

端子の機能と切り換えの詳細については、“10.2 入出力端子機能の選択(ポートMUX)”を参照してください。

## 18.3 転送クロック

UARTの転送クロックは、SSCK(D0/UART\_MODレジスタ)を使用して内部クロックまたは外部クロックのいずれかを選択可能です。

\* **SSCK**: Input Clock Select Bit in the UART Mode (UART\_MOD) Register (D0/0x4103)

注: SSCKの変更は、必ずUARTが動作停止中 (RXEN/UART\_CTLレジスタ = 0)に行ってください。

\* **RXEN**: UART Enable Bit in the UART Control (UART\_CTL) Register (D0/0x4104)

### 内部クロック

SSCKを0(デフォルト)に設定すると、内部クロックが選択されます。UARTは8ビットタイマの出力クロックを転送クロックとして使用します。したがって、8ビットタイマを、転送レートに合ったクロックを出力するようにプログラムしておく必要があります。

8ビットタイマの制御については、“12.8ビットタイマ(T8F)”を参照してください。

### 外部クロック

SSCKを1に設定すると、外部クロックが選択されます。この場合は、P25をSCLK端子に設定し(18.2節参照)、外部クロックを入力してください。

- 注:
- UARTは8ビットタイマの出力または外部クロックを1/16に分周してサンプリングクロックを生成します。転送レートを設定する際には注意してください。
  - SCLK端子から外部クロックを入力する場合、クロックの周波数はPCLKの1/2以下で、デューティ比は50%である必要があります。

## 18.4 転送データの設定

以下の条件を選択して転送データ形式を設定できます。

- データ長: 7ビット、または8ビット
- スタートビット: 1ビット固定
- ストップビット: 1ビット、または2ビット
- パリティビット: 偶数、奇数、パリティなし

注: 転送データ形式の設定は、必ずUARTが動作停止中(RXEN/UART\_CTLレジスタ = 0)に行ってください。

\* **RXEN**: UART Enable Bit in the UART Control (UART\_CTL) Register (D0/0x4104)

### データ長

データ長は、CHLN(D4/UART\_MODレジスタ)で選択します。CHLNを0(デフォルト)に設定すると、データ長は7ビットに設定されます。CHLNを1に設定すると、8ビットに設定されます。

\* **CHLN**: Character Length Select Bit in the UART Mode (UART\_MOD) Register (D4/0x4103)

### ストップビット

ストップビット長はSTPB(D1/UART\_MODレジスタ)で選択します。STPBを0(デフォルト)に設定すると、ストップビット長は1ビットに設定されます。STPBを1に設定すると、2ビットに設定されます。

\* **STPB**: Stop Bit Select Bit in the UART Mode (UART\_MOD) Register (D1/0x4103)

### パリティビット

パリティ機能を有効にするか否かについては、PREN(D3/UART\_MODレジスタ)で選択します。PRENを0(デフォルト)に設定すると、パリティ機能は無効となります。この場合、転送データにパリティビットは付加されず、データ受信時もパリティチェックは行われません。PRENを1に設定すると、パリティ機能が有効になります。この場合、転送データにパリティビットが付加され、データ受信時はパリティチェックを行います。

パリティ機能を有効にする場合は、PMD(D2/UART\_MODレジスタ)でパリティモードを選択します。PMDを0(デフォルト)に設定すると、偶数パリティとしてパリティビットの付加とチェックが行われます。PMDを1に設定すると、奇数パリティとしてパリティビットの付加とチェックが行われます。

\* **PREN**: Parity Enable Bit in the UART Mode (UART\_MOD) Register (D3/0x4103)

\* **PMD**: Parity Mode Select Bit in the UART Mode (UART\_MOD) Register (D2/0x4103)



s1: スタートビット, s2 & s3: ストップビット, p: パリティビット

図18.4.1 転送データ形式

## 18.5 データ送受信の制御

データ転送を開始する前に、以下の設定を行ってください。

- (1) 入力クロックを選択します。18.3節を参照してください。  
内部クロックを使用する場合は、転送クロックを出力するように8ビットタイマをプログラムします。  
12章を参照してください。
- (2) 転送データ形式を設定します。18.4節を参照してください。
- (3) IrDAインターフェースを使用する場合は、IrDAモードを設定します。18.8節を参照してください。
- (4) UART割り込みを使用する場合は、割り込み条件を設定します。18.7節を参照してください。

注: 上記の設定は、必ずUARTが動作停止中(RXEN/UART\_CTLレジスタ = 0)に行ってください。

\* **RXEN**: UART Enable Bit in the UART Control (UART\_CTL) Register (D0/0x4104)

### データ送受信を許可

最初にRXENビット(D0/UART\_CTLレジスタ)を1に設定してデータの送受信を許可します。これにより、送受信回路が送受信可能な状態になります。

注: UARTが送受信中はRXENビットを0に設定しないでください。

### データ送信制御

送信を開始するには、UART\_TXDレジスタ(0x4101)に送信データを書き込みます。

\* **UART\_TXD**: UART Transmit Data Register (0x4101)

データは送信データバッファに書き込まれ、送信回路がデータ送信を開始します。

バッファのデータは送信用シフトレジスタに送られ、スタートビットがSOUT端子から出力されます。続いて、シフトレジスタのデータがLSBから出力されます。転送データビットはサンプリングクロックの立ち上がりエッジに同期してシフトし、SOUT端子から順次出力されます。MSBの出力後、パリティビット(パリティ有効時のみ)とストップビットが出力されます。

送信回路にはTDBE(D0/UART\_STレジスタ)とTRBS(D2/UART\_STレジスタ)の2つのステータスフラグが用意されています。

\* **TDBE**: Transmit Data Buffer Empty Flag in the UART Status (UART\_ST) Register (D0/0x4100)

\* **TRBS**: Transmit Busy Flag in the UART Status (UART\_ST) Register (D2/0x4100)

TDBEフラグは送信データバッファの状態を示します。このフラグはアプリケーションプログラムが送信データバッファにデータを書き込むと0になり、バッファのデータが送信用シフトレジスタに送られると1に戻ります。このフラグが1になった時点で割り込みを発生させることができます(18.7節参照)。この割り込みを利用するか、TDBEフラグの読み出しによって送信データバッファが空であることを確認し、次のデータ送信を行います。送信バッファサイズは1バイトですが、シフトレジスタが別に用意されていますので、1つ前のデータを送信中に、データの書き込みが行えます。ただし、送信データを書き込む前に、送信データバッファが空になっていることを確認してください。TDBEフラグが0の場合にデータを書き込むと、送信データバッファ内にある1つ前の送信データが新たなデータで上書きされてしまいます。

TRBSフラグはシフトレジスタの状態を示します。このフラグは送信データが送信データバッファからシフトレジスタにロードされると1になり、データ送信が完了すると0に戻ります。送信回路が動作中か待機中かについては、このフラグを読み出して確認してください。



図18.5.1 データ送信タイミングチャート

### データ受信制御

受信回路はRXENビットを1に設定すると起動し、外部シリアルデバイスからのデータを受信可能な状態になります。

外部シリアルデバイスがスタートビットを送信すると、受信回路はそのLowレベルを検出して、続くデータビットのサンプリングを開始します。データビットはサンプリングクロックの立ち上がりエッジでサンプリングされ、先頭ビットをLSBとして受信用シフトレジスタに取り込まれます。MSBをシフトレジスタに受信し終わると、受信データは受信データバッファにロードされます。パリティチェックが有効に設定されている場合、これと同時に、受信回路はMSBの直後に受信したパリティビットでパリティチェックを行います。

受信データバッファは2バイトのFIFOで、満杯になるまでデータを受信可能です。

バッファ内の受信データはUART\_RXDレジスタ(0x4102)から読み出すことができます。古いデータから先に読み出され、読み出しによりクリアされます。

#### \* UART\_RXD: UART Receive Data Register (0x4102)

受信回路にはRDRY(D1/UART\_STレジスタ)とRD2B(D3/UART\_STレジスタ)の2つのバッファステータスフラグが用意されています。

\* **RDRY**: Receive Data Ready Flag in the UART Status (UART\_ST) Register (D1/0x4100)

\* **RD2B**: Second Byte Receive Flag in the UART Status (UART\_ST) Register (D3/0x4100)

RDRYフラグは受信データバッファ内に受信データが存在することを示します。RD2Bフラグは受信データバッファが満杯になっていることを示します。

(1)RDRY = 0, RD2B = 0

データを受信していません。したがって、受信データバッファを読み出す必要はありません。

(2)RDRY = 1, RD2B = 0

1個のデータを受信しています。受信データバッファを1回読み出してください。この読み出しによりRDRYフラグがリセットされます。バッファは上記(1)の状態に戻ります。

受信データバッファを2回読み出した場合、2つ目の読み出しデータは無効です。

(3)RDRY = 1, RD2B = 1

2個のデータを受信しています。受信データバッファを2回読み出してください。最初の読み出しで、受信データバッファは古い方の受信データを出力します。この読み出しにより、RD2Bフラグがリセットされます。バッファは上記(2)の状態になります。2回目の読み出しで最新の受信データが出力されます。2回の読み出し後、バッファは上記(1)の状態になります。

受信バッファが満杯でも、シフトレジスタは8ビットデータをもう一つ受信開始することができます。受信データバッファの読み出しがなく受信が終了した場合、オーバーランエラーが発生し、最後の受信データは読み出しができません。したがって、受信データバッファはオーバーランエラーが発生する前に読み出してください。オーバーランエラーについては、18.6節を参照してください。

これらのフラグを読み出すことで、受信データ数を確認することができます。

また、UARTは受信データバッファにデータを受信した時点で受信バッファフル割り込みを発生可能で、この割り込みを利用して受信データバッファを読み出すことができます。デフォルト設定では、

受信データバッファが1個のデータを受信すると(前記(2)の状態)、受信バッファフル割り込みが発生するようになっています。これを、RBFIビット(D1/UART\_CTLレジスタ)を1に設定することで、受信データバッファが2個のデータを受信した時点で割り込みが発生するように変更できます。

\* **RBFI**: Receive Buffer Full Interrupt Condition Setup Bit in the UART Control (UART\_CTL) Register (D1/0x4104)

前述のフラグの他に、3つのエラーフラグも用意されています。それらのフラグと受信エラーについては、18.6節を参照してください。



S1: スタートビット, S2: ストップビット, P: パリティビット, Rd: RXD[7:0]からのデータリード  
図18.5.2 データ受信タイミングチャート

### データ送受信を禁止

データ転送(送信と受信の両方)を終了後は、RXENビットに0を書き込んでデータ送受信を禁止します。ただし、データ送受信を禁止する前に、TDBEフラグが1、TRBSとRDREADYフラグが0になっていることを確認してください。

RXENビットを0に設定すると、送信データバッファは空の状態になります(データが残っていればクリアされます)。また、データの送受信中にRXENを0に設定した場合、転送中のデータは保証されません。

## 18.6 受信エラー

データ受信時は、3種類の受信エラーを検出可能です。

受信エラーは割り込み要因のため、割り込みを発生させてエラーを処理することができます。UART割り込みの制御については、18.7節を参照してください。

### パリティエラー

PREN(D3/UART\_MODレジスタ)が1(パリティ有効)に設定されている場合、受信時にパリティチェックが行われます。

パリティチェックはシフトレジスタに受信したデータが受信データバッファに転送される際に行われ、PMD(D2/UART\_MODレジスタ)の設定(奇数または偶数パリティ)との整合をチェックします。この結果が不整合の場合はパリティエラーと判断され、パリティエラーフラグPER(D5/UART\_STレジスタ)が1にセットされます。

本エラーが発生した場合でも、その受信データは受信データバッファに転送され、受信動作も継続して行われます。ただし、受信データはパリティエラーのため保証されません。

なお、PERフラグ(D5/UART\_STレジスタ)は1を書き込むことによって0にリセットされます。

\* **PREN:** Parity Enable Bit in the UART Mode (UART\_MOD) Register (D3/0x4103)

\* **PMD:** Parity Mode Select Bit in the UART Mode (UART\_MOD) Register (D2/0x4103)

\* **PER:** Parity Error Flag in the UART Status (UART\_ST) Register (D5/0x4100)

### フレーミングエラー

ストップビットを0として受信すると、UARTは同期ずれと判断してフレーミングエラーを発生します。ストップビットを2ビットに設定している場合は、最初の1ビットのみチェックします。

本エラーが発生すると、フレーミングエラーフラグFER(D6/UART\_STレジスタ)が1にセットされます。本エラーが発生した場合でも、その受信データは受信データバッファに転送され、受信動作も継続して行われます。ただし、以後のデータ受信でフレーミングエラーとならない場合でも、それらのデータは保証されません。

なお、FERフラグ(D6/UART\_STレジスタ)は1を書き込むことによって0にリセットされます。

\* **FER:** Framing Error Flag in the UART Status (UART\_ST) Register (D6/0x4100)

### オーバーランエラー

受信データバッファが満杯(2データ受信済み)の状態でも、次に送られる3番目のデータはシフトレジスタに受信可能です。ただし、その受信が終了した時点で、受信データバッファに空きがなければ(それまでにデータが読み出されていなければ)、シフトレジスタに受信した3番目のデータはバッファに送られず、オーバーランエラーが発生します。

オーバーランエラーが発生するとオーバーランエラーフラグOER(D4/UART\_STレジスタ)が1にセットされます。

本エラーが発生した場合でも、受信動作は継続して行われます。

なお、OERフラグ(D4/UART\_STレジスタ)は1を書き込むことによって0にリセットされます。

\* **OER:** Overrun Error Flag in the UART Status (UART\_ST) Register (D4/0x4100)

## 18.7 UART割り込み

UARTには、以下の3種類の割り込みを発生させる機能があります。

- 送信バッファエンプティ割り込み
- 受信バッファフル割り込み
- 受信エラー割り込み

UARTは、上記3種類の割り込み要因が共有する1つの割り込み信号を割り込みコントローラ(ITC)に対して出力します。発生した割り込み要因を特定するには、ステータスフラグおよびエラーフラグを読み出してください。

### 送信バッファエンプティ割り込み

この割り込みを使用するには、TIEN(D4/UART\_CTLレジスタ)を1に設定します。TIENが0(デフォルト)に設定されていると、この要因による割り込み要求はITCに送られません。

\* **TIEN:** Transmit Buffer Empty Interrupt Enable Bit in the UART Control (UART\_CTL) Register (D4/0x4104)

送信データバッファに書き込まれた送信データがシフトレジスタに転送されると、UARTはTDBEビット(D0/UART\_STレジスタ)を1にセットして送信データバッファが空であることを示します。送信バッファエンプティ割り込みが許可されていれば(TIEN = 1)、これと同時に割り込み要求パルスがITCに出力されます。

\* **TDBE:** Transmit Data Buffer Empty Flag in the UART Status (UART\_ST) Register (D0/0x4100)

もし、他の割り込み条件が満たされていれば、割り込みが発生します。

UART割り込みが送信バッファエンプティによるものかどうかについては、UART割り込み処理ルーチンでTDBEフラグを読み出して確認してください。TDBEが0であれば、割り込み処理ルーチンで次の送信データを送信データバッファに書き込むことができます。

### 受信バッファフル割り込み

この割り込みを使用するには、RIEN(D5/UART\_CTLレジスタ)を1に設定します。RIENが0(デフォルト)に設定されていると、この要因による割り込み要求はITCに送られません。

\* **RIEN:** Receive Buffer Full Interrupt Enable Bit in the UART Control (UART\_CTL) Register (D5/0x4104)

受信バッファフル割り込みが許可されている場合(RIEN = 1)、指定数の受信データが受信データバッファにロードされると、UARTは割り込み要求パルスをITCに出力します。RBFI(D1/UART\_CTLレジスタ)が0の場合、1個の受信データが受信データバッファにロードされた(RDRYフラグ(D1/UART\_STレジスタ)が1にセットされた)時点で割り込み要求パルスが出力されます。RBFI(D1/UART\_CTLレジスタ)が1の場合、2個の受信データが受信データバッファにロードされた(RD2Bフラグ(D3/UART\_STレジスタ)が1にセットされた)時点で割り込み要求パルスが出力されます。

\* **RBFI:** Receive Buffer Full Interrupt Condition Setup Bit in the UART Control (UART\_CTL) Register (D1/0x4104)

\* **RDRY:** Receive Data Ready Flag in the UART Status (UART\_ST) Register (D1/0x4100)

\* **RD2B:** Second Byte Receive Flag in the UART Status (UART\_ST) Register (D3/0x4100)

もし、他の割り込み条件が満たされていれば、割り込みが発生します。

UART割り込みが受信バッファフルによるものかどうかについては、UART割り込み処理ルーチンでRDRYとRD2Bフラグを読み出して確認してください。RDRYまたはRD2Bが1であれば、割り込み処理ルーチンで受信データバッファから受信データを読み出すことができます。

## 受信エラー割り込み

この割り込みを使用するには、REIEN(D6/UART\_CTLレジスタ)を1に設定します。REIENが0(デフォルト)に設定されていると、この要因による割り込み要求はITCに送られません。

\* **REIEN**: Receive Error Interrupt Enable Bit in the UART Control (UART\_CTL) Register (D6/0x4104)

データ受信時にパリティエラー、フレーミングエラー、またはオーバーランエラーを検出すると、UARTは以下に示すエラーフラグを1に設定します。受信エラー割り込みが許可されていれば(REIEN = 1)、これと同時に割り込み要求パルスがITCに出力されます。

\* **PER**: Parity Error Flag in the UART Status (UART\_ST) Register (D5/0x4100)

\* **FER**: Framing Error Flag in the UART Status (UART\_ST) Register (D6/0x4100)

\* **OER**: Overrun Error Flag in the UART Status (UART\_ST) Register (D4/0x4100)

もし、他の割り込み条件が満たされていれば、割り込みが発生します。

UART割り込みが受信エラーによるものかどうかについては、UART割り込み処理ルーチンで上記のエラーフラグを読み出して確認してください。いずれかのエラーフラグが1であれば、割り込み処理ルーチンでエラーからの復旧処理を行います。

## UART割り込み用ITCレジスタ

以下に、UART用のITC制御ビットを示します。

### 割り込みフラグ

\* **IIFT4**: UART Interrupt Flag in the Interrupt Flag (ITC\_IFLG) Register (D12/0x4300)

### 割り込みイネーブルビット

\* **IEN4**: UART Interrupt Enable Bit in the Interrupt Enable (ITC\_EN) Register (D12/0x4302)

### 割り込みレベル設定ビット

\* **ILV4[2:0]**: UART Interrupt Level Bits in the Internal Interrupt Level Setup (ITC\_ILV2) Register 2 (D[2:0]/0x4312)

UARTが割り込み要求パルスを出力すると、対応する割り込みフラグが1にセットされます。

その割り込みフラグに対応する割り込みイネーブルビットが1に設定されていると、ITCは割り込み要求をS1C17コアに送ります。UARTによる割り込みを禁止するには、割り込みイネーブルビットを0に設定しておきます。割り込みフラグは、割り込みイネーブルビットの設定にかかわらず(0に設定していても)、UARTの割り込み要求パルスによって1にセットされます。

割り込みレベル設定ビットは、UART割り込みのレベル(0~7)を設定します。

S1C17コアは、以下のすべての条件が成立している場合に割り込みを受け付けます。

- 割り込みイネーブルビットが1にセットされている。
- PSR(S1C17コア内のプロセッサステータスレジスタ)のIE(割り込みイネーブル)ビットが1にセットされている。
- UART割り込みが、PSRのIL(割り込みレベル)に設定されている値よりも高い割り込みレベルに設定されている。
- NMIなど、他の優先順位の高い割り込み要因が発生していない。

これらの割り込み制御レジスタの詳細と割り込み発生時の動作については、“6 割り込みコントローラ(ITC)”を参照してください。

## 割り込みベクタ

UART割り込みのベクタ番号とベクタアドレスは以下のとおりです。

ベクタ番号: 16(0x10)

ベクタアドレス: 0x8040

## 18.8 IrDAインターフェース

本UARTモジュールにはRZI変調/復調回路が組み込まれており、簡単な外付け回路の追加のみで、IrDA 1.0に対応する赤外線通信回路を構成することができます。

UARTの送信用シフトレジスタから出力された送信データは変調回路に入力され、Lowパルス幅が3/16sclkサイクルに変換された後にSOUT端子から出力されます。



図18.8.1 送信信号波形

受信したIrDA信号は復調回路に入力され、Lowパルス幅が16sclkサイクルに変換された後に受信用シフトレジスタに入力されます。入力されるLowパルス(最小パルス幅 = 1.41μs/115200bps時)を検出するため、復調回路は転送クロックとは別に、プリスケーラ出力クロックから選択したパルス検出クロックを使用します。



図18.8.2 受信信号波形

### IrDAイネーブル

IrDAインターフェース機能を使用するには、IRMD(D0/UART\_EXPレジスタ)を1に設定します。これにより、RZI変調/復調回路が有効になります。

\* **IRMD:** IrDA Mode Select Bit in the UART Expansion (UART\_EXP) Register (D0/0x4105)

注: この設定は、UARTの他の条件を設定する前に実行する必要があります。

## IrDA受信検出クロックの選択

入力パルス検出用クロックを、IRCLK[2:0](D[6:4]/UART\_EXPレジスタ)を使用してプリスケーラ出力クロックのPCLK•1/1～PCLK•1/128の中から選択します。

\* **IRCLK[2:0]**: IrDA Receive Detection Clock Select Bits in the UART Expansion (UART\_EXP) Register (D[6:4]/0x4105)

表18.8.1 IrDA受信検出クロックの選択

| IRCLK[2:0] | プリスケーラ出力クロック |
|------------|--------------|
| 0x7        | PCLK•1/128   |
| 0x6        | PCLK•1/64    |
| 0x5        | PCLK•1/32    |
| 0x4        | PCLK•1/16    |
| 0x3        | PCLK•1/8     |
| 0x2        | PCLK•1/4     |
| 0x1        | PCLK•1/2     |
| 0x0        | PCLK•1/1     |

(デフォルト:0x0)

このクロックには、8ビットタイムまたはSCLK端子から入力される転送クロックsclkよりも高速なクロックを選択する必要があります。

復調回路はIrDA受信検出クロックの2サイクル以上の幅を持つLowパルスを有効と見なし、16 sclkサイクル幅のLowパルスに変換します。最小1.41μs幅の入力パルスが検出できるように、適切なプリスケーラ出力クロックを選択してください。

## シリアルデータ転送の制御

IrDAモードの場合も、データ送受信の制御方法は通常のインターフェースと同じです。データ形式の設定やデータ転送、割り込みの制御方法については、前記の説明を参照してください。

## 18.9 制御レジスタ詳細

表18.9.1 UARTレジスター一覧

| アドレス   | レジスタ名    |                             | 機能                  |
|--------|----------|-----------------------------|---------------------|
| 0x4100 | UART_ST  | UART Status Register        | 転送、バッファ、エラーステータスの表示 |
| 0x4101 | UART_TXD | UART Transmit Data Register | 送信データ               |
| 0x4102 | UART_RXD | UART Receive Data Register  | 受信データ               |
| 0x4103 | UART_MOD | UART Mode Register          | 転送データ形式の設定          |
| 0x4104 | UART_CTL | UART Control Register       | データ転送の制御            |
| 0x4105 | UART_EXP | UART Expansion Register     | IrDAモードの設定          |

以下、UARTのレジスタを個々に説明します。これらはすべて8ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

## 0x4100: UART Status Register (UART\_ST)

| Register name                  | Address | Bit | Name | Function                        | Setting |       |   | Init.     | R/W | Remarks            |
|--------------------------------|---------|-----|------|---------------------------------|---------|-------|---|-----------|-----|--------------------|
| UART Status Register (UART_ST) | 0x4100  | D7  | —    | reserved                        | —       | —     | — | —         | —   | 0 when being read. |
|                                |         | D6  | FER  | Framing error flag              | 1       | Error | 0 | Normal    | 0   | R/W                |
|                                |         | D5  | PER  | Parity error flag               | 1       | Error | 0 | Normal    | 0   | R/W                |
|                                |         | D4  | OER  | Overrun error flag              | 1       | Error | 0 | Normal    | 0   | R/W                |
|                                |         | D3  | RD2B | Second byte receive flag        | 1       | Ready | 0 | Empty     | 0   | R                  |
|                                |         | D2  | TRBS | Transmit busy flag              | 1       | Busy  | 0 | Idle      | 0   | R                  |
|                                |         | D1  | RDRY | Receive data ready flag         | 1       | Ready | 0 | Empty     | 0   | R                  |
|                                |         | D0  | TDBE | Transmit data buffer empty flag | 1       | Empty | 0 | Not empty | 1   | R                  |

### D7 Reserved

### D6 FER: Framing Error Flag

フレーミングエラーが発生しているか否かを示します。

1(R): エラー発生

0(R): エラーなし(デフォルト)

1(W): 0にリセット

0(W): 無効

FERはフレーミングエラーが発生すると1にセットされます。フレーミングエラーは、ストップビットを0としてデータを受信した場合に発生します。

FERは1を書き込むことによりリセットされます。

### D5 PER: Parity Error Flag

パリティエラーが発生しているか否かを示します。

1(R): エラー発生

0(R): エラーなし(デフォルト)

1(W): 0にリセット

0(W): 無効

PERはパリティエラーが発生すると1にセットされます。パリティチェックはPREN(D3/UART\_MODレジスタ)が1に設定されている場合にのみ有効で、受信データがシフトレジスタから受信データバッファに転送される際に実行されます。

PERは1を書き込むことによりリセットされます。

### D4 OER: Overrun Error Flag

オーバーランエラーが発生しているか否かを示します。

1(R): エラー発生

0(R): エラーなし(デフォルト)

1(W): 0にリセット

0(W): 無効

OERはオーバーランエラーが発生すると1にセットされます。オーバーランエラーは、受信データバッファが満杯の状態で、次のデータをシフトレジスタに受信し、さらに続くデータが送られてきた場合に発生します。このエラーが発生した場合、受信データバッファは上書きされず、エラーが発生した時点のシフトレジスタが上書きされます。

OERは1を書き込むことによりリセットされます。

### D3 RD2B: Second Byte Received Flag

受信データバッファに2個の受信データがあることを示します。

1(R): 2バイト目が読み出し可

0(R): 2バイト目は未受信(デフォルト)

RD2Bは、受信データバッファに2バイト目のデータがロードされると1にセットされ、受信データバッファから最初のデータが読み出されると0にリセットされます。

**D2 TRBS: Transmit Busy Flag**

送信シフトレジスタの状態を示します。

1(R): 動作中

0(R): 待機中(デフォルト)

TRBSは、送信データが送信データバッファからシフトレジスタにロードされると1にセットされ、データ送信が完了すると0にリセットされます。送信回路が動作中か待機中かを確認する際に、読み出してください。

**D1 RDRY: Receive Data Ready Flag**

受信データバッファに有効な受信データがあることを示します。

1(R): データ読み出し可

0(R): バッファは空(デフォルト)

RDRYは、受信データバッファに受信データがロードされると1にセットされ、受信データバッファからすべてのデータが読み出されると0にリセットされます。

**D0 TDBE: Transmit Data Buffer Empty Flag**

送信データバッファの状態を示します。

1(R): バッファは空(デフォルト)

0(R): データあり

TDBEは、送信データが送信データバッファに書き込まれると0にリセットされ、そのデータがシフトレジスタに転送されると1にセットされます。

## 0x4101: UART Transmit Data Register (UART\_TXD)

| Register name                          | Address         | Bit  | Name     | Function                                     | Setting            | Init. | R/W | Remarks |
|----------------------------------------|-----------------|------|----------|----------------------------------------------|--------------------|-------|-----|---------|
| UART Transmit Data Register (UART_TXD) | 0x4101 (8 bits) | D7-0 | TXD[7:0] | Transmit data<br>TXD7(6) = MSB<br>TXD0 = LSB | 0x0 to 0xff (0x7f) | 0x0   | R/W |         |

### D[7:0] TXD[7:0]: Transmit Data

送信データバッファにセットする送信データを書き込みます。(デフォルト: 0x0)

このレジスタにデータを書き込むことにより、UARTは送信を開始します。TXD[7:0]に書き込んだデータは送信データバッファに入り送信まで待機します。

送信データバッファ内のデータが送信されると、送信バッファエンプティ割り込み要因が発生します。

7ビットモードでは、TXD7(MSB)が無効となります。

SOUT端子からはシリアル変換されたデータがLSBを先頭に、1に設定されたビットがHighレベル、0に設定されたビットがLowレベルとして出力されます。

このレジスタは読み出もし可能です。

## 0x4102: UART Receive Data Register (UART\_RXD)

| Register name                         | Address         | Bit  | Name     | Function                                                               | Setting            | Init. | R/W | Remarks                                     |
|---------------------------------------|-----------------|------|----------|------------------------------------------------------------------------|--------------------|-------|-----|---------------------------------------------|
| UART Receive Data Register (UART_RXD) | 0x4102 (8 bits) | D7–0 | RXD[7:0] | Receive data in the receive data buffer<br>RXD7(6) = MSB<br>RXD0 = LSB | 0x0 to 0xff (0x7f) | 0x0   | R   | Older data in the buffer is read out first. |

### D[7:0] RXD[7:0]: Receive Data

受信データバッファのデータが古いものから順に読み出せます。受信したデータは受信データバッファに入ります。受信データバッファは2バイトのFIFOで、これが満杯になるまでは、読み出しを行わなくても正しく受信できます。バッファが満杯でシフトレジスタにもデータが受信されている状態では、次の受信が始まるまでにデータを読み出さないとオーバーランエラーになります。

受信回路にはRDRY(D1/UART\_STレジスタ)とRD2B(D3/UART\_STレジスタ)の2つの受信バッファステータスフラグが用意されています。RDRYフラグは受信データバッファ内に有効な受信データが存在することを示し、RD2Bフラグは受信データバッファに2個の受信データがあることを示します。

受信データバッファ内の受信データがRBFI(D1/UART\_CTLレジスタ)で指定した数になると、受信バッファフル割り込み要因が発生します。

7ビットモードでは、RXD7に0がロードされます。

SIN端子から入力されたシリアルデータは先頭をLSBとして、Highレベルのビットを1、Lowレベルのビットを0としてパラレル変換され、受信データバッファにロードされます。

このレジスタは読み出し専用で、書き込みは行えません。(デフォルト: 0x0)

## 0x4103: UART Mode Register (UART\_MOD)

| Register name                 | Address         | Bit  | Name | Function           | Setting |             | Init. | R/W       | Remarks            |
|-------------------------------|-----------------|------|------|--------------------|---------|-------------|-------|-----------|--------------------|
| UART Mode Register (UART_MOD) | 0x4103 (8 bits) | D7–5 | –    | reserved           | –       | –           | –     | –         | 0 when being read. |
|                               |                 | D4   | CHLN | Character length   | 1       | 8 bits      | 0     | 7 bits    | 0 R/W              |
|                               |                 | D3   | PREN | Parity enable      | 1       | With parity | 0     | No parity | 0 R/W              |
|                               |                 | D2   | PMD  | Parity mode select | 1       | Odd         | 0     | Even      | 0 R/W              |
|                               |                 | D1   | STPB | Stop bit select    | 1       | 2 bits      | 0     | 1 bit     | 0 R/W              |
|                               |                 | D0   | SSCK | Input clock select | 1       | External    | 0     | Internal  | 0 R/W              |

### D[7:5] Reserved

#### D4 CHLN: Character Length Select Bit

シリアル転送データのデータ長を選択します。

1(R/W): 8ビット

0(R/W): 7ビット(デフォルト)

#### D3 PREN: Parity Enable Bit

パリティ機能を有効にします。

1(R/W): パリティ付き

0(R/W): パリティなし(デフォルト)

PRENによって、受信データのパリティチェック、および送信データへのパリティビットの付加を行うかどうかを選択します。PRENを1に設定すると、受信データはパリティチェックが行われます。送信データに対してはパリティビットが自動的に付加されます。PRENを0に設定した場合はパリティビットのチェックおよび付加は行われません。

#### D2 PMD: Parity Mode Select Bit

パリティモードを選択します。

1(R/W): 奇数パリティ

0(R/W): 偶数パリティ(デフォルト)

PMDに1を書き込むと奇数パリティが選択され、0を書き込むと偶数パリティが選択されます。パリティチェックおよびパリティビットの付加はPREN(D3)が1に設定されている場合にのみ有効で、PREN(D3)が0の場合、PMDの設定は無効となります。

#### D1 STPB: Stop Bit Select Bit

ストップビット長を選択します。

1(R/W): 2ビット

0(R/W): 1ビット(デフォルト)

STPBに1を書き込むとストップビットが2ビットに、0を書き込むと1ビットになります。スタートビットは1ビットに固定です。

#### D0 SSCK: Input Clock Select Bit

入力クロックを選択します。

1(R/W): 外部クロック(SCLK)

0(R/W): 内部クロック(デフォルト)

内部クロック(8ビットタイム出力クロック)を使用するか、外部クロック(SCLK端子から入力)を使用するか選択します。SSCKに1を書き込むと外部クロック、0を書き込むと内部クロックが選択されます。

## 0x4104: UART Control Register (UART\_CTL)

| Register name                    | Address         | Bit  | Name  | Function                           | Setting |         |   | Init.   | R/W | Remarks            |
|----------------------------------|-----------------|------|-------|------------------------------------|---------|---------|---|---------|-----|--------------------|
| UART Control Register (UART_CTL) | 0x4104 (8 bits) | D7   | —     | reserved                           | —       | —       | — | —       | —   | 0 when being read. |
|                                  |                 | D6   | REIEN | Receive error int. enable          | 1       | Enable  | 0 | Disable | 0   | R/W                |
|                                  |                 | D5   | RIEN  | Receive buffer full int. enable    | 1       | Enable  | 0 | Disable | 0   | R/W                |
|                                  |                 | D4   | TIEN  | Transmit buffer empty int. enable  | 1       | Enable  | 0 | Disable | 0   | R/W                |
|                                  |                 | D3-2 | —     | reserved                           | —       | —       | — | —       | —   | 0 when being read. |
|                                  |                 | D1   | RBFI  | Receive buffer full int. condition | 1       | 2 bytes | 0 | 1 byte  | 0   | R/W                |
|                                  |                 | D0   | RXEN  | UART enable                        | 1       | Enable  | 0 | Disable | 0   | R/W                |

**D7 Reserved**

**D6 REIEN: Receive Error Interrupt Enable Bit**

受信エラー発生時のITCへの割り込み要求を許可します。

1(R/W): 許可

0(R/W): 禁止(デフォルト)

受信エラーを割り込みによって処理する場合は、このビットを1に設定してください。

**D5 RIEN: Receive Buffer Full Interrupt Enable Bit**

受信データバッファの受信データ数がRBFI(D1)の指定値になったことによるITCへの割り込み要求を許可します。

1(R/W): 許可

0(R/W): 禁止(デフォルト)

受信データを割り込みによって読み出す場合は、このビットを1に設定してください。

**D4 TIEN: Transmit Buffer Empty Interrupt Enable Bit**

送信データバッファの送信データがシフトレジスタに送られた(データ送信を開始した)ことによるITCへの割り込み要求を許可します。

1(R/W): 許可

0(R/W): 禁止(デフォルト)

送信データバッファへのデータ書き込みを割り込みによって行う場合は、このビットを1に設定してください。

**D[3:2] Reserved**

**D1 RBFI: Receive Buffer Full Interrupt Condition Setup Bit**

受信バッファフル割り込みを発生させる、受信バッファ内のデータ数を設定します。

1(R/W): 2バイト

0(R/W): 1バイト(デフォルト)

受信バッファフル割り込みが許可されている場合(RIEN = 1)、RBFIで指定されている数の受信データが受信データバッファにロードされると、UARTは割り込み要求パルスをITCに出力します。RBFIビットが0の場合、1個の受信データが受信データバッファにロードされた(RDRYフラグ(D1/UART\_STレジスタ)が1にセットされた)時点での割り込み要求パルスが発出されます。RBFIが1の場合、2個の受信データが受信データバッファにロードされた(RD2Bフラグ(D3/UART\_STレジスタ)が1にセットされた)時点での割り込み要求パルスが発出されます。

**D0 RXEN: UART Enable Bit**

UARTによるデータ送受信を許可します。

1(R/W): 許可

0(R/W): 禁止(デフォルト)

UARTで送受信を始める前にRXENを1に設定してください。RXENを0に設定するとデータ送受信が禁止されます。転送条件の設定は、RXENが0の状態で行ってください。

RXENに0を書き込んで送受信を禁止すると、送信データバッファもクリアされます。

## 0x4105: UART Expansion Register (UART\_EXP)

| Register name                      | Address         | Bit  | Name       | Function                            | Setting    |            | Init. | R/W | Remarks            |
|------------------------------------|-----------------|------|------------|-------------------------------------|------------|------------|-------|-----|--------------------|
| UART Expansion Register (UART_EXP) | 0x4105 (8 bits) | D7   | —          | reserved                            | —          | —          | —     | —   | 0 when being read. |
|                                    |                 | D6-4 | IRCLK[2:0] | IrDA receive detection clock select | IRCLK[2:0] | Clock      | 0x0   | R/W |                    |
|                                    |                 |      |            |                                     | 0x7        | PCLK•1/128 |       |     |                    |
|                                    |                 |      |            |                                     | 0x6        | PCLK•1/64  |       |     |                    |
|                                    |                 |      |            |                                     | 0x5        | PCLK•1/32  |       |     |                    |
|                                    |                 |      |            |                                     | 0x4        | PCLK•1/16  |       |     |                    |
|                                    |                 |      |            |                                     | 0x3        | PCLK•1/8   |       |     |                    |
|                                    |                 |      |            |                                     | 0x2        | PCLK•1/4   |       |     |                    |
|                                    |                 | D3-1 | —          | reserved                            | 0x1        | PCLK•1/2   |       |     |                    |
|                                    |                 | D0   | IRMD       | IrDA mode select                    | 1   On     | 0   Off    | 0     | R/W |                    |

### D7 Reserved

### D[6:4] IRCLK[2:0]: IrDA Receive Detection Clock Select Bits

IrDA入力パルス検出クロックとして使用するプリスケーラ出力クロックを選択します。

表18.9.2 IrDA受信検出クロックの選択

| IRCLK[2:0] | プリスケーラ出力クロック |
|------------|--------------|
| 0x7        | PCLK•1/128   |
| 0x6        | PCLK•1/64    |
| 0x5        | PCLK•1/32    |
| 0x4        | PCLK•1/16    |
| 0x3        | PCLK•1/8     |
| 0x2        | PCLK•1/4     |
| 0x1        | PCLK•1/2     |
| 0x0        | PCLK•1/1     |

(デフォルト: 0x0)

このクロックには、8ビットタイムまたはSCLK端子から入力される転送クロックsclkよりも高速なクロックを選択する必要があります。

復調回路はIrDA受信検出クロックの2サイクル以上の幅を持つLowパルスを有効と見なします。最小1.41μs幅の入力パルスが検出できるように、適切なプリスケーラ出力クロックを選択してください。

### D[3:1] Reserved

### D0 IRMD: IrDA Mode Select Bit

IrDAインターフェース機能をOn/Offします。

1 (R/W): On

0 (R/W): Off(デフォルト)

IrDAインターフェースを使用する場合に1に設定します。0に設定すると、本モジュールはIrDA機能のない通常のUARTとして機能します。

## 18.10 注意事項

- UARTの各種設定は、送受信禁止の状態(RXEN = 0)で行ってください。  
\* **RXEN**: UART Enable Bit in the UART Control (UART\_CTL) Register (D0/0x4104)
- UARTが送信または受信中は、RXENを0に設定しないでください。
- UARTの転送レートは最大460800bps(IrDAモードは115200bps)に制限されています。これ以上の転送レートは設定しないでください。
- RXENを0に設定して送受信を禁止すると、送信データバッファがクリア(初期化)されます。RXENに0を書き込む前に、バッファ内に送信待ちのデータが残っていないことを確認してください。
- IrDA受信検出クロックには、8ビットタイムまたはSCLK端子から入力される転送クロックsclkよりも高速なクロックを選択する必要があります。
- IrDAインターフェースの復調回路はIrDA受信検出クロックの2サイクル以上の幅を持つLowパルスを有効と見なします。最小1.41 $\mu$ s幅の入力パルスが検出できるように、適切なプリスケーラ出力クロックをIrDA受信検出クロックとして選択してください。

このページはブランクです。

# 19 SPI

## 19.1 SPIの構成

S1C17001は同期式シリアルインターフェースモジュール(以降SPI)を内蔵しています。このSPIモジュールはマスタおよびスレーブの両モードに対応し、8ビットのデータ転送を行います。データ転送のタイミング(クロックの位相と極性)は4種類から選択可能です。

シフトレジスタとは別に送信データバッファと受信データバッファを内蔵し、2種類の割り込み(送信バッファエンプティと受信バッファフル)を発生可能です。これにより、連続したシリアルデータ転送を割り込みによって簡潔に処理することができます。

図19.1.1にSPIモジュールの構造を示します。



図19.1.1 SPIモジュールの構造

## 19.2 SPI入出力端子

表19.2.1にSPI端子の一覧を示します。

表19.2.1 SPI端子一覧

| 端子名          | I/O | 本数 | 機能                                                                                   |
|--------------|-----|----|--------------------------------------------------------------------------------------|
| SDI (P20)    | I   | 1  | SPIデータ入力端子<br>SPIバスからシリアルデータを入力します。                                                  |
| SDO (P21)    | O   | 1  | SPIデータ出力端子<br>シリアルデータをSPIバスに出力します。                                                   |
| SPICLK (P22) | I/O | 1  | SPI外部クロック入出力端子<br>本SPIがマスタモードの場合にSPIクロックを出力します。<br>本SPIをスレーブモードで使用する場合は外部クロックを入力します。 |
| #SPISS (P17) | I   | 1  | SPIスレーブ選択信号(アクティブLow)入力端子<br>この端子へのLow入力により、本SPI(スレーブモード)がスレーブデバイスとして選択されます。         |

SPIの入出力端子(SDI、SDO、SPICLK、#SPISS)は汎用入出力ポート端子(P20、P21、P22、P17)を兼用しており、初期状態では汎用入出力ポート端子に設定されます。これらをSPIの入出力端子として使用するには、P2\_PMUXおよびP1\_PMUXレジスタの設定により機能を切り換える必要があります。以下の制御ビットを1に設定して、端子をSPI用に切り換えてください。

### P20 → SDI

\* **P20MUX:** P20 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register (D0/0x52a2)

### P21 → SDO

\* **P21MUX:** P21 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register (D1/0x52a2)

### P22 → SPICLK

\* **P22MUX:** P22 Port Function Select Bit in the P2 Port Function Select (P2\_PMUX) Register (D2/0x52a2)

### P17 → #SPISS

\* **P17MUX:** P17 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D7/0x52a1)

端子の機能と切り換えの詳細については、“10.2 入出力端子機能の選択(ポートMUX)”を参照してください。

### 19.3 SPIクロック

マスタモードのSPIは、16ビットタイマCh.1が出力する内部クロックをSPIクロックとして使用します。このクロックはシフトレジスタを駆動すると共に、SPICLK端子からスレーブデバイスへ出力されます。16ビットタイマCh.1から転送レートに合ったクロックが出力されるようにプログラムしてください。16ビットタイマの制御については、“11 16ビットタイマ(T16)”を参照してください。



図19.3.1 マスタモードのSPIクロック

スレーブモードでは、SPICLK端子からSPIクロックを入力します。

注: SPICLK端子から入力するクロックのデューティ比は50%である必要があります。

## 19.4 データ転送条件の設定

SPIモジュールはマスタモードまたはスレーブモードに設定できます。また、SPIクロックの極性と位相をSPI\_CTLレジスタで設定可能です。

データ長は8ビットに固定されています。

注: マスタ/スレーブモードの選択およびクロック条件の設定は、SPIモジュールが停止中(SPEN/SPI\_CTLレジスタ = 0)に行ってください。

\* **SPEN**: SPI Enable Bit in the SPI Control (SPI\_CTL) Register (D0/0x4326)

### マスタ/スレーブモードの選択

MSSL(D1/SPI\_CTLレジスタ)を使用して、SPIモジュールをマスタモードまたはスレーブモードに設定します。MSSLを1に設定するとマスタモード、0(デフォルト)に設定するとスレーブモードになります。マスタモードでは、内部クロックを使用してデータ転送を行います。スレーブモードでは、マスタデバイスのクロックを入力してデータ転送を行います。

\* **MSSL**: Master/Slave Mode Select Bit in the SPI Control (SPI\_CTL) Register (D1/0x4326)

### SPIクロック極性と位相の設定

SPIクロックの極性は、CPOL(D2/SPI\_CTLレジスタ)で選択します。CPOLを1に設定するとSPIクロックはアクティブLow、0(デフォルト)に設定するとアクティブHighと見なされます。

\* **CPOL**: Clock Polarity Select Bit in the SPI Control (SPI\_CTL) Register (D2/0x4326)

SPIクロックの位相はCPHA(D3/SPI\_CTLレジスタ)で選択します。

\* **CPHA**: Clock Phase Select Bit in the SPI Control (SPI\_CTL) Register (D3/0x4326)

これらの制御ビットにより、転送タイミングは下図のように設定されます。



図19.4.1 クロックとデータ転送タイミング

注: SPIをマスタモードかつCPHA = 0の設定で使用する場合、送信データ1ビット目の変化からクロックの変化までが最短でシステムクロックの1周期の長さになる場合があります。



図19.4.2 CPHA = 0 時のSDOxおよびSPICLKxの変化タイミング

送信データの2ビット目以降および連続転送時の2バイト目以降については、データの変化からクロックの変化まではSPICLKx半周期の長さが確保されます。

## 19.5 データ送受信の制御

データ転送を開始する前に、以下の設定を行ってください。

- (1) SPIクロックが outputされるように16ビットタイムCh.1を設定します。11章を参照してください。
- (2) マスタモードまたはスレーブモードを選択します。19.4節を参照してください。
- (3) クロック条件を設定します。19.4節を参照してください。
- (4) SPI割り込みを使用する場合は、割り込み条件を設定します。19.6節を参照してください。

注: 上記の設定は、必ずSPIが停止中(SPEN/SPI\_CTLレジスタ = 0)に行ってください。

\* **SPEN:** SPI Enable Bit in the SPI Control (SPI\_CTL) Register (D0/0x4326)

### データ送受信を許可

最初にSPEN(D0/SPI\_CTLレジスタ)を1に設定してSPIの動作を許可します。これにより、SPIが送受信可能な状態となり、クロックの入出力も許可されます。

注: SPIモジュールが送受信中はSPENを0に設定しないでください。

### データ送信制御

送信を開始するには、SPI\_TXDレジスタ(0x4322)に送信データを書き込みます。

\* **SPI\_TXD:** SPI Transmit Data Register (0x4322)

データは送信データバッファに書き込まれ、SPIモジュールはデータ送信を開始します。

バッファのデータは送信用シフトレジスタに送られます。マスタモードでは、SPICLK端子からクロックの出力を開始します。スレーブモードではSPICLK端子からのクロック入力を待ちます。シフトレジスタ内のデータはCPHA(D3/SPI\_CTLレジスタ)とCPOL(D2/SPI\_CTLレジスタ)で決まるクロックの立ち上がりまたは立ち下がりエッジで順次シフトされ(図19.4.1参照)、SDO端子からMSBを先頭に送信されます。

\* **CPHA:** Clock Phase Select Bit in the SPI Control (SPI\_CTL) Register (D3/0x4326)

\* **CPOL:** Clock Polarity Select Bit in the SPI Control (SPI\_CTL) Register (D2/0x4326)

SPIモジュールには送信の制御用にSPTBE(D0/SPI\_STレジスタ)とSPBSY(D2/SPI\_STレジスタ)の2つのステータスフラグが用意されています。

\* **SPTBE:** Transmit Data Buffer Empty Flag in the SPI Status (SPI\_ST) Register (D0/0x4320)

\* **SPBSY:** Transfer Busy Flag in the SPI Status (SPI\_ST) Register (D2/0x4320)

SPTBEフラグは送信データバッファの状態を示します。このフラグはアプリケーションプログラムがSPI\_TXDレジスタ(送信データバッファ)にデータを書き込むと0になり、バッファのデータが送信用シフトレジスタに送られると1に戻ります。このフラグが1になった時点で割り込みを発生させることができます(19.6節参照)。この割り込みを利用するか、SPTBEフラグの読み出しによって送信データバッファが空であることを確認し、次のデータ送信を行います。送信バッファサイズは1バイトですが、シフトレジスタが別に用意されていますので、1つ前のデータを送信中に、データの書き込みが行えます。ただし、送信データを書き込む前に、送信データバッファが空になっていることを確認してください。SPTBEフラグが0の場合にデータを書き込むと、送信データバッファ内にある1つ前の送信データが新たなデータで上書きされてしまいます。

マスタモード時、SPBSYフラグはシフトレジスタの状態を示します。このフラグは送信データが送信データバッファからシフトレジスタにロードされると1になり、データ送信が完了すると0に戻ります。SPIモジュールが動作中か待機中かについては、このフラグを読み出して確認してください。スレーブモードのSPBSYフラグはSPIスレーブ選択信号(#SPISS端子)の状態を示します。本SPIモジュールがスレーブとして選択されている場合に1となり、非選択状態では0になります。

## データ受信制御

マスタモードの場合、ダミーデータをSPI\_TXDレジスタ(0x4322)に書き込みます。SPI\_TXDレジスタへの書き込みは、送信の開始だけではなく受信のトリガにもなります。実際の送信データを書き込んで送受信を同時に行うことも可能です。

これにより、SPICLKからSPIクロック出力を開始します。

スレーブモードの場合は、SPICLKからクロックが入力されるまで待機します。スレーブモードで受信のみを行い、送信が不要の場合はSPI\_TXDレジスタへの書き込み操作は必要ありません。受信動作はマスタデバイスからのクロック入力により開始します。送受信を同時に行う場合は、クロックが入力される前に送信データをSPI\_TXDレジスタに書き込んでおきます。

データはMSBを先頭に、CPHA(D3/SPI\_CTLレジスタ)とCPOL(D2/SPI\_CTLレジスタ)で決まるクロックの立ち上がりまたは立ち下がりエッジで順次シフトレジスタに取り込まれます(図19.4.1参照)。

8ビットのデータをシフトレジスタに受信し終わると、受信データは受信データバッファにロードされます。

バッファ内の受信データはSPI\_RXDレジスタ(0x4324)から読み出すことができます。

\* **SPI\_RXD**: SPI Receive Data Register (0x4324)

SPIモジュールには受信の制御用にSPRBFフラグ(D1/SPI\_STレジスタ)が用意されています。

\* **SPRBF**: Receive Data Buffer Full Flag in the SPI Status (SPI\_ST) Register (D1/0x4320)

SPRBFフラグは受信データバッファの状態を示します。このフラグはシフトレジスタに受信したデータが受信データバッファにロードされると1になり、受信データが読み出せることを示します。バッファのデータがSPI\_RXDレジスタから読み出されると0に戻ります。このフラグが1になった時点で割り込みを発生させることができます(19.6節参照)。この割り込みを利用するか、SPRBFフラグの読み出しによって受信データバッファに有効な受信データがあることを確認し、受信データを読み出してください。受信バッファサイズは1バイトですが、シフトレジスタが別に用意されていますので、次のデータを受信中も、バッファ内の受信データは保持されます。ただし、次のデータ受信が終了する前に受信データバッファを読み出してください。受信データバッファを読み出す前に次の受信が終了すると、バッファ内の1つ前の受信データは新たな受信データで上書きされてしまいます。

マスタモードでは、シフトレジスタの状態を示すSPBSYフラグが、データ送信時と同様に使用可能です。



図19.5.1 データ送受信タイミングチャート (MSB先頭)

### データ送受信を禁止

データ転送(送信と受信の両方)を終了後は、SPENビットに0を書き込んでデータ送受信を禁止します。ただし、データ送受信を禁止する前に、SPTBEフラグが1、SPBSYフラグが0になっていることを確認してください。

データの送受信中にSPENを0に設定した場合、転送中のデータは保証されません。

## 19.6 SPI割り込み

SPIモジュールには、以下の2種類の割り込みを発生させる機能があります。

- 送信バッファエンプティ割り込み
- 受信バッファフル割り込み

SPIモジュールは、上記2種類の割り込み要因が共有する1本の割り込み信号を割り込みコントローラ(ITC)に対して出力します。発生した割り込み要因を特定するには、ステータスフラグを読み出してください。

### 送信バッファエンプティ割り込み

この割り込みを使用するには、SPTIE(D4/SPI\_CTLレジスタ)を1に設定します。SPTIEが0(デフォルト)に設定されていると、この要因による割り込み要求はITCに送られません。

\* **SPTIE:** Transmit Data Buffer Empty Interrupt Enable Bit in the SPI Control (SPI\_CTL) Register (D4/0x4326)

送信データバッファに書き込まれた送信データがシフトレジスタに転送されると、SPIモジュールはSPTBEビット(D0/SPI\_STレジスタ)を1にセットして送信データバッファが空であることを示します。送信バッファエンプティ割り込みが許可されていれば(SPTIE = 1)、これと同時に割り込み要求パルスがITCに出力されます。

\* **SPTBE:** Transmit Data Buffer Empty Flag in the SPI Status (SPI\_ST) Register (D0/0x4320)

もし、他の割り込み条件が満たされていれば、割り込みが発生します。

SPI割り込みが送信バッファエンプティによるものかどうかについては、SPI割り込み処理ルーチンでSPTBEフラグを読み出して確認してください。SPTBEが1であれば、割り込み処理ルーチンで次の送信データを送信データバッファに書き込むことができます。

### 受信バッファフル割り込み

この割り込みを使用するには、SPRIE(D5/SPI\_CTLレジスタ)を1に設定します。SPRIEが0(デフォルト)に設定されていると、この要因による割り込み要求はITCに送られません。

\* **SPRIE:** Receive Data Buffer Full Interrupt Enable Bit in the SPI Control (SPI\_CTL) Register (D5/0x4326)

シフトレジスタに受信したデータが受信データバッファにロードされると、SPIモジュールはSPRBFビット(D1/SPI\_STレジスタ)を1にセットして、受信データバッファに読み出し可能な受信データがあることを示します。受信バッファフル割り込みが許可されていれば(SPRIE = 1)、これと同時に割り込み要求パルスがITCに出力されます。

\* **SPRBF:** Receive Data Buffer Full Flag in the SPI Status (SPI\_ST) Register (D1/0x4320)

もし、他の割り込み条件が満たされていれば、割り込みが発生します。

SPI割り込みが受信バッファフルによるものかどうかについては、SPI割り込み処理ルーチンでSPRBFフラグを読み出して確認してください。SPRBFが1であれば、割り込み処理ルーチンで受信データバッファから受信データを読み出すことができます。

### SPI割り込み用ITCレジスタ

ITC内のSPIモジュール用制御ビットを以下に示します。

#### 割り込みフラグ

\* **IIFT6:** SPI Interrupt Flag in the Interrupt Flag (ITC\_IFLG) Register (D14/0x4300)

#### 割り込みイネーブルビット

\* **IIEN6:** SPI Interrupt Enable Bit in the Interrupt Enable (ITC\_EN) Register (D14/0x4302)

#### 割り込みレベル設定ビット

\* **ILV6[2:0]:** SPI Interrupt Level Bits in the Internal Interrupt Level Setup (ITC\_ILV3) Register 3 (D[2:0]/0x4314)

SPIモジュールが割り込み要求パルスを出力すると、割り込みフラグIIFT6が1にセットされます。

割り込みイネーブルビットIIEN6が1に設定されていると、ITCは割り込み要求をS1C17コアに送ります。SPIによる割り込みを禁止するには、IIEN6を0に設定しておきます。

IIFT6フラグは、IIEN6ビットの設定にかかわらず(0に設定されていても)、SPIの割り込み要求パルスによって1にセットされます。

割り込みレベル設定ビットIILV6[2:0]は、SPI割り込みのレベル(0~7)を設定します。

S1C17コアは、以下のすべての条件が成立している場合に割り込みを受け付けます。

- 割り込みイネーブルビットが1にセットされている。

- PSR(S1C17コア内のプロセッサステータスレジスタ)のIE(割り込みイネーブル)ビットが1にセットされている。

- SPI割り込みが、PSRのIL(割り込みレベル)に設定されている値よりも高い割り込みレベルに設定されている。

- NMIなど、他の優先順位の高い割り込み要因が発生していない。

これらの割り込み制御レジスタの詳細と割り込み発生時の動作については、“6 割り込みコントローラ(ITC)”を参照してください。

## 割り込みベクタ

SPI割り込みのベクタ番号とベクタアドレスは以下のとおりです。

ベクタ番号: 18(0x12)

ベクタアドレス: 0x8048

## 19.7 制御レジスタ詳細

表19.7.1 SPIレジスター一覧

| アドレス   | レジスター名  |                            | 機能                |
|--------|---------|----------------------------|-------------------|
| 0x4320 | SPI_ST  | SPI Status Register        | 転送、バッファステータスの表示   |
| 0x4322 | SPI_TXD | SPI Transmit Data Register | 送信データ             |
| 0x4324 | SPI_RXD | SPI Receive Data Register  | 受信データ             |
| 0x4326 | SPI_CTL | SPI Control Register       | SPIモードとデータ転送許可の設定 |

以下、SPIのレジスターを個々に説明します。これらはすべて16ビットレジスターです。

- 注: • レジスターにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。
- SPIレジスターのリード/ライトには必ず16ビットアクセス命令を使用してください。32ビットおよび8ビットアクセス命令でSPIレジスターをリード/ライトすることはできません。

## 0x4320: SPI Status Register (SPI\_ST)

| Register name                | Address          | Bit   | Name  | Function                                                  | Setting   |               | Init. | R/W | Remarks            |
|------------------------------|------------------|-------|-------|-----------------------------------------------------------|-----------|---------------|-------|-----|--------------------|
| SPI Status Register (SPI_ST) | 0x4320 (16 bits) | D15-3 | —     | reserved                                                  | —         | —             | —     | —   | 0 when being read. |
|                              |                  | D2    | SPBSY | Transfer busy flag (master)<br>ss signal low flag (slave) | 1   Busy  | 0   ss = L    | 0     | R   |                    |
|                              |                  | D1    | SPRBF | Receive data buffer full flag                             | 1   Full  | 0   Not full  | 0     | R   |                    |
|                              |                  | D0    | SPTBE | Transmit data buffer empty flag                           | 1   Empty | 0   Not empty | 1     | R   |                    |

### D[15:3] Reserved

#### D2 SPBSY: Transfer Busy Flag (Master Mode)/ss Signal Low Flag (Slave Mode)

##### マスタモード

SPIの送受信動作状態を示します。

1(R): 動作中

0(R): 待機中(デフォルト)

SPBSYはSPIがマスタモードで送受信を開始すると1にセットされ、送受信中は1を保持します。送受信動作が終了すると、0にクリアされます。

##### スレーブモード

スレーブ選択(#SPISS)信号の状態を示します。

1(R): Lowレベル(本SPIが選択状態)

0(R): Highレベル(本SPIは非選択状態) (デフォルト)

SPBSYは、マスタデバイスが本SPIモジュール(スレーブデバイス)を選択するために#SPISS信号をアクティブにすると1にセットされます。マスタデバイスが#SPISS信号をインアクティブとして本SPIモジュールの選択を解除すると0に戻ります。

#### D1 SPRBF: Receive Data Buffer Full Flag

受信データバッファの状態を示します。

1(R): データフル

0(R): データなし(デフォルト)

SPRBFはシフトレジスタに受信したデータが受信データバッファに転送されると(受信が完了すると)1となり、そのデータが読み出し可能であることを示します。バッファのデータがSPI\_RXDレジスタ(0x4324)から読み出されると0に戻ります。

#### D0 SPTBE: Transmit Data Buffer Empty Flag

送信データバッファの状態を示します。

1(R): エンプティ(デフォルト)

0(R): データあり

SPTBEはSPI\_RXDレジスタ(送信データバッファ、0x4322)に送信データが書き込まれると0となり、そのデータがシフトレジスタに転送されると(送信を開始すると)1となります。SPI\_RXDレジスタへの送信データの書き込みは、このビットが1の場合に行います。

## 0x4322: SPI Transmit Data Register (SPI\_TXD)

| Register name                        | Address          | Bit           | Name            | Function                                                             | Setting          | Init.    | R/W      | Remarks            |
|--------------------------------------|------------------|---------------|-----------------|----------------------------------------------------------------------|------------------|----------|----------|--------------------|
| SPI Transmit Data Register (SPI_TXD) | 0x4322 (16 bits) | D15-8<br>D7-0 | —<br>SPTDB[7:0] | reserved<br>SPI transmit data buffer<br>SPTDB7 = MSB<br>SPTDB0 = LSB | —<br>0x0 to 0xff | —<br>0x0 | —<br>R/W | 0 when being read. |

### D[15:8] Reserved

### D[7:0] SPTDB[7:0]: SPI Transmit Data Buffer Bits

送信データバッファに書き込む送信データを設定します。(デフォルト: 0x0)

マスタモードでは、このレジスタにデータを書き込むことにより送信を開始します。スレーブモードでは、マスタからクロックが入力されるとこのレジスタの内容がシフトレジスタに送られ、送信を開始します。

このレジスタに書き込んだデータがシフトレジスタに転送された時点で、SPTBE(DO/SPI\_STレジスタ)が1(エンプティ)にセットされます。同時に送信バッファエンプティ割り込み要因も発生します。それ以降であれば、データの送信中であっても次の送信データを書き込むことができます。

SDO端子からはシリアル変換されたデータがMSBを先頭に、1に設定されたビットがHighレベル、0に設定されたビットがLowレベルとして出力されます。

注: データの送受信を行う場合、SPI\_TXDへの書き込みはSPENを1に設定した後に行ってください。

## 0x4324: SPI Receive Data Register (SPI\_RXD)

| Register name                       | Address          | Bit           | Name                   | Function                                                            | Setting          | Init.    | R/W    | Remarks            |
|-------------------------------------|------------------|---------------|------------------------|---------------------------------------------------------------------|------------------|----------|--------|--------------------|
| SPI Receive Data Register (SPI_RXD) | 0x4324 (16 bits) | D15–8<br>D7–0 | reserved<br>SPRDB[7:0] | reserved<br>SPI receive data buffer<br>SPRDB7 = MSB<br>SPRDB0 = LSB | –<br>0x0 to 0xff | –<br>0x0 | –<br>R | 0 when being read. |

### D[15:8] Reserved

### D[7:0] SPRDB[7:0]: SPI Receive Data Buffer Bits

受信データが格納されます。(デフォルト: 0x0)

受信が終了し、シフトレジスタのデータが受信データバッファに転送された時点でSPRBF(D1/SPI\_STレジスタ)が1(データフル)にセットされます。同時に受信バッファフル割り込み要因も発生します。これ以降、次のデータの受信を終了するまで、データの読み出しが可能です。このレジスタを読み出す前に次の受信を終了した場合は、新たな受信データで上書きされます。SDI端子から入力されたシリアルデータは先頭をMSBとして、Highレベルのビットを1、Lowレベルのビットを0としてパラレル変換され、本レジスタにロードされます。

このレジスタは読み出し専用で、書き込みは行えません。

## 0x4326: SPI Control Register (SPI\_CTL)

| Register name                  | Address          | Bit   | Name  | Function                               | Setting |          | Init. | R/W      | Remarks                                     |
|--------------------------------|------------------|-------|-------|----------------------------------------|---------|----------|-------|----------|---------------------------------------------|
| SPI Control Register (SPI_CTL) | 0x4326 (16 bits) | D15–6 | –     | reserved                               | –       | –        | –     | –        | 0 when being read.                          |
|                                |                  | D5    | SPRIE | Receive data buffer full int. enable   | 1       | Enable   | 0     | Disable  | 0 R/W                                       |
|                                |                  | D4    | SPTIE | Transmit data buffer empty int. enable | 1       | Enable   | 0     | Disable  | 0 R/W                                       |
|                                |                  | D3    | CPHA  | Clock phase select                     | 1       | Data out | 0     | Data in  | 0 R/W These bits must be set before setting |
|                                |                  | D2    | CPOL  | Clock polarity select                  | 1       | Active L | 0     | Active H | 0 R/W SPEN to 1.                            |
|                                |                  | D1    | MSSL  | Master/slave mode select               | 1       | Master   | 0     | Slave    | 0 R/W                                       |
|                                |                  | D0    | SPEN  | SPI enable                             | 1       | Enable   | 0     | Disable  | 0 R/W                                       |

### D[15:6] Reserved

#### D5 SPRIE: Receive Data Buffer Full Interrupt Enable Bit

受信データバッファフルによるSPI割り込みを許可/禁止します。

1(R/W): 許可

0(R/W): 禁止(デフォルト)

SPRIEを1に設定すると、受信データバッファフルによるSPI割り込み要求のITCへの出力を許可します。この割り込み要求は、シフトレジスタに受信したデータが受信データバッファに転送される(受信が完了する)ことにより発生します。

SPRIEを0に設定すると、受信データバッファフルによるSPI割り込みは発生しません。

#### D4 SPTIE: Transmit Data Buffer Empty Interrupt Enable Bit

送信データバッファエンプティによるSPI割り込みを許可/禁止します。

1(R/W): 許可

0(R/W): 禁止(デフォルト)

SPTIEを1に設定すると、送信データバッファエンプティによるSPI割り込み要求のITCへの出力を許可します。この割り込み要求は、送信データバッファに書き込んだデータがシフトレジスタに転送される(送信を開始する)ことにより発生します。

SPTIEを0に設定すると、送信データバッファエンプティによるSPI割り込みは発生しません。

#### D3 CPHA: SPI Clock Phase Select Bit

SPIクロックの位相を選択します。(デフォルト: 0)

CPOL(D2)と共に、データ転送タイミングを設定します(図19.7.1参照)。

#### D2 CPOL: SPI Clock Polarity Select Bit

SPIクロックの極性を選択します。

1(R/W): アクティブLow

0(R/W): アクティブHigh(デフォルト)

CPHA(D3)と共に、データ転送タイミングを設定します(図19.7.1参照)。



図19.7.1 クロックとデータ転送タイミング

**D1 MSSL: Master/Slave Mode Select Bit**

SPIモジュールをマスタモードまたはスレーブモードに設定します。

1(R/W): マスタモード

0(R/W): スレーブモード(デフォルト)

MSSLを1に設定するとマスタモード、0に設定するとスレーブモードになります。マスタモードでは、16ビットタイムCh.1で生成したクロックでデータ転送を行います。スレーブモードでは、マスタデバイスからクロックを入力してデータ転送を行います。

**D0 SPEN: SPI Enable Bit**

SPIモジュールの動作を許可/禁止します。

1(R/W): 許可

0(R/W): 禁止(デフォルト)

SPENを1に設定するとSPIモジュールが動作を開始し、データ転送が行える状態になります。

SPENを0に設定すると、SPIモジュールは動作を停止します。

注: CPHA、CPOL、MSSLビットの設定は、SPENビットを0に設定して行ってください。

## 19.8 注意事項

- SPIレジスタ(0x4320～0x4326)のリード/ライトには必ず16ビットアクセス命令を使用してください。32ビットおよび8ビットアクセス命令でSPIレジスタをリード/ライトすることはできません。
- SPBSYフラグ(D2/SPI\_STレジスタ)が1の間(データの転送中)は、SPI\_CTLレジスタ(0x4326)にアクセスしないでください。

\* **SPBSY**: Transfer Busy Flag in the SPI Status (SPI\_ST) Register (D2/0x4320)

# 20 I<sup>2</sup>C

## 20.1 I<sup>2</sup>Cの構成

S1C17001は高速同期シリアル通信用に、I<sup>2</sup>Cバスインターフェースモジュールを内蔵しています。I<sup>2</sup>Cモジュールは16ビットタイマCh.2から供給されるクロックを使用し、マスタデバイスとして動作します(シングルマスタとしてのみ使用可能です)。標準(100kbps)モードおよびファストモード(400kbps)、7ビット/10ビットスレーブアドレスモードに対応しています。また、データ転送の信頼性向上に役立つ、ノイズ除去機能が組み込まれています。

本モジュールは、2種類の割り込み(送信バッファエンプティと受信バッファフル割り込み)を発生可能で、連続したシリアルデータ転送を割り込みによって簡潔に処理することができます。

図20.1.1にI<sup>2</sup>Cモジュールの構造を示します。



図20.1.1 I<sup>2</sup>Cモジュールの構造

注: 本I<sup>2</sup>Cモジュールにクロックストレッチ機能はありません。このため、クロックストレッチによって通信の同期を取るI<sup>2</sup>Cスレーブデバイスには対応しません。

## 20.2 I<sup>2</sup>C入出力端子

表20.2.1にI<sup>2</sup>C端子の一覧を示します。

表20.2.1 I<sup>2</sup>C端子一覧

| 端子名       | I/O | 本数 | 機能                                                                                                     |
|-----------|-----|----|--------------------------------------------------------------------------------------------------------|
| SDA (P14) | I/O | 1  | I <sup>2</sup> Cデータ入出力端子<br>I <sup>2</sup> Cバスからシリアルデータを入力します。<br>また、シリアルデータをI <sup>2</sup> Cバスに出力します。 |
| SCL (P15) | I/O | 1  | I <sup>2</sup> Cクロック入出力端子<br>SCLラインの状態を入力します。<br>また、シリアルクロックを出力します。                                    |

I<sup>2</sup>Cの入出力端子(SDA、SCL)は汎用入出力ポート端子(P14、P15)を兼用しており、初期状態では汎用入出力ポート端子に設定されます。これらをI<sup>2</sup>Cの入出力端子として使用するには、P1\_PMUXレジスタの設定により機能を切り換える必要があります。以下の制御ビットを1に設定して、端子をI<sup>2</sup>C用に切り換えてください。

### P14 → SDA

\* **P14MUX:** P14 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D4/0x52a1)

### P15 → SCL

\* **P15MUX:** P15 Port Function Select Bit in the P1 Port Function Select (P1\_PMUX) Register (D5/0x52a1)

端子の機能と切り換えの詳細については、“10.2 入出力端子機能の選択(ポートMUX)”を参照してください。

## 20.3 I<sup>2</sup>Cクロック

I<sup>2</sup>Cモジュールは、16ビットタイマCh.2が出力する内部クロックを同期クロックとして使用します。このクロックはソフトレジスタを駆動すると共に、SCL端子からスレーブデバイスへ出力されます。

16ビットタイマCh.2から転送レートに合ったクロックがout力されるようにプログラムしてください。  
16ビットタイマの制御については、“11 16ビットタイマ(T16)”を参照してください。

I<sup>2</sup>Cモジュールはスレーブデバイスとしては機能しません。SCL入力端子はI<sup>2</sup>CバスのSCL信号の状態チェックに使用され、同期クロックの入力用には使用されません。

## 20.4 データ転送前の設定項目

I<sup>2</sup>Cモジュールには、アプリケーションプログラムから選択可能なノイズ除去のオプション機能があります。

### ノイズ除去機能

I<sup>2</sup>Cモジュールには、SDAおよびSCL端子の入力信号からノイズを除去する機能が組み込まれています。この機能は、NSERM(D4/I2C\_CTLレジスタ)を1に設定することにより有効となります。

ただし、この機能を使用するには、I<sup>2</sup>Cクロック(16ビットタイマCh.2出力クロック)周波数をPCLKの1/6以下に設定する必要があります。

\* **NSERM**: Noise Remove On/Off Bit in the I<sup>2</sup>C Control (I2C\_CTL) Register (D4/0x4342)

## 20.5 データ送受信の制御

データ転送を開始する前に、以下の設定を行ってください。

- (1) I<sup>2</sup>Cクロックが出力されるように16ビットタイマCh.2を設定します。11章を参照してください。
- (2) オプション機能を選択します。20.4節を参照してください。
- (3) I<sup>2</sup>C割り込みを使用する場合は、割り込み条件を設定します。20.6節を参照してください。

注: 上記の設定は、必ずI<sup>2</sup>Cモジュールが停止中(I2CEN/I2C\_ENレジスタ = 0)に行ってください。

\* **I2CEN**: I<sup>2</sup>C Enable Bit in the I<sup>2</sup>C Enable (I2C\_EN) Register (D0/0x4340)

### データ送受信を許可

最初にI2CEN(D0/I2C\_ENレジスタ)を1に設定してI<sup>2</sup>Cの動作を許可します。これにより、I<sup>2</sup>Cが送受信可能な状態となり、クロックの出力も許可されます。

注: I<sup>2</sup>Cモジュールが送受信中はI2CENを0に設定しないでください。

### データ送受信の開始

データの送受信を開始するには、I<sup>2</sup>Cマスタ(本モジュール)がスタートコンディションを生成する必要があります。それに引き続いてスレーブアドレスを送信し、通信を確立します。

#### (1) レジスタの設定順序

スタートコンディションを生成するには、以下の順序でレジスタを設定してください。

1. RTDT[7:0](D[7:0]/I2CM\_DATレジスタ)にスレーブアドレスを設定
2. TXE(D9/I2CM\_DATレジスタ)を1に設定
3. STRT(D0/I2CM\_CTLレジスタ)を1に設定

\* **RTDT[7:0]**: Receive/Transmit Data Bits in the I<sup>2</sup>C Master Data (I2CM\_DAT) Register (D[7:0]/0x4344)

\* **TXE**: Transmit Execution Bit in the I<sup>2</sup>C Master Data (I2CM\_DAT) Register (D9/0x4344)

\* **STRT**: Start Control Bit in the I<sup>2</sup>C Master Control (I2CM\_CTL) Register (D0/0x4342)

これらの手順により、下記(2)と(3)の通信波形が生成されます。必ずレジスタの設定順序を守ってください。

#### (2) スタートコンディションの生成

SCLラインをHighに保った状態で、SDAラインをLowにすることがスタートコンディションです。



図20.5.1 スタートコンディション

スタートコンディションは、STRT(D0/I2C\_CTLレジスタ)を1に設定することで生成されます。

\* **STRT**: Start Control Bit in the I<sup>2</sup>C Control (I2C\_CTL) Register (D0/0x4342)

スタートコンディションが生成されると、STRTは自動的に0にリセットされます。

#### (3) スレーブアドレスの送信

スタートコンディションの生成後、I<sup>2</sup>Cマスタ(本モジュール)は通信を行うスレーブのアドレスと転送方向を示すビットを送信します。I<sup>2</sup>Cのスレーブアドレスには7ビットアドレスと10ビットアドレスの2種類があります。本モジュールは8ビットの送受信データレジスタを使用してスレーブアドレスと転送方向ビットを送信しますので、7ビットアドレスモードの場合は1回で送信可能です。10ビットの場合はソフトウェア制御により2回または3回の送信を行います。アドレスデータの構成を図20.5.2に示します。

## 7ビットアドレスの場合



## 10ビットアドレスの場合



図20.5.2 スレーブアドレスと転送方向を指定する送信データ

転送方向ビットはスレーブアドレスに続くデータ転送の方向を示します。マスターからスレーブへのデータ送信時は転送方向ビットを0に、スレーブからのデータの受信時は1に設定します。

上記のとおり作成した8ビットのデータを送受信データレジスタに設定し、下記のとおり送信の制御を行います。

スレーブアドレスと転送方向ビットはスタートコンディション生成後に1度のみ送信します。  
スレーブアドレス出力後は、データの送信またはデータの受信を必要な回数行います。スレーブアドレスと共に設定した転送方向のとおり、データ送信またはデータ受信を行う必要があります。

## データ送信制御

以下、データの送信方法を説明します。スレーブアドレスの送信も同じ手順で行います。  
バイトデータを送信するには、送信データをRTDT[7:0](D[7:0]/I<sup>2</sup>C\_DATレジスタ)に設定します。同時に、1バイトの送信を実行するTXE(D9/I<sup>2</sup>C\_DATレジスタ)を1に設定します。

\* **RTDT[7:0]:** Receive/Transmit Data Bits in the I<sup>2</sup>C Data (I<sup>2</sup>C\_DAT) Register (D[7:0]/0x4344)

\* **TXE:** Transmit Execution Bit in the I<sup>2</sup>C Data (I<sup>2</sup>C\_DAT) Register (D9/0x4344)

TXEビットが1に設定されると、I<sup>2</sup>Cモジュールはクロックに同期してデータ送信を開始します。スタートコンディションまたは前のデータを送信中の場合は、その完了後に開始します。

まず、I<sup>2</sup>Cモジュールは書き込まれたデータをシフトレジスタに転送し、SCLからクロックの出力を開始します。この時点でTXEが0にリセットされると共に割り込み要因が発生しますので、この後、次の送信データとTXEの再設定を行うことができます。

シフトレジスタ内のデータビットはクロックの立ち上がりエッジで順次シフトされ、MSBを先頭にSDA端子から出力されます。

I<sup>2</sup>Cモジュールは1回のデータ送信に9個のクロックを出力します。9個目のクロックサイクルでは、SDA信号をハイインピーダンスにしてスレーブデバイスからのACKまたはNACKを受信します。

スレーブデバイスは、データを受信できた場合はマスターにACK(0)を返します。受信できなかったときはSDAラインがプルダウンされませんので、I<sup>2</sup>CモジュールはこれをNACK(1)と見なします(送信失敗)。



図20.5.3 ACKとNACK

I<sup>2</sup>Cモジュールには送信の制御用にTBUSY(D8/I2C\_CTLレジスタ)とRTACK(D8/I2C\_DATレジスタ)の2つのステータスビットが用意されています。

- \* **TBUSY:** Transmit Busy Flag in the I<sup>2</sup>C Control (I2C\_CTL) Register (D8/0x4342)
- \* **RTACK:** Receive/Transmit ACK Bit in the I<sup>2</sup>C Data (I2C\_DAT) Register (D8/0x4344)

TBUSYフラグはデータ送信状態を示します。このフラグは送信(スレーブアドレスの送信も含む)を開始すると1になり、データ送信が終了すると0に戻ります。また、ウェイト状態でも0に戻ります。I<sup>2</sup>Cモジュールが送信動作中か待機中かについては、このフラグを読み出して確認してください。

RTACKビットは、前回の送信時にスレーブデバイスがACKを返したかどうかを示します。ACKが返つていればRTACKは0、ACKが返っていない場合はRTACKは1となります。

### データ受信制御

以下、データの受信方法を説明します。データ受信の場合も、その前にスタートコンディションを生成し、転送方向ビットを1としたスレーブアドレスを送信しておく必要があります。

データを受信するには、1バイトの受信を実行するRXE(D10/I2C\_DATレジスタ)を1に設定します。スレーブアドレス送信時にTXE(D9/I2C\_DATレジスタ)を1に設定しますが、そのとき同時にRXEを1に設定しておくことができます。TXEとRXEが両方共に1の場合はTXEが優先されます。

- \* **RXE:** Receive Execution Bit in the I<sup>2</sup>C Data (I2C\_DAT) Register (D10/0x4344)

RXEビットが1に設定され、受信が開始できる状態になると、I<sup>2</sup>CモジュールはSDAラインをハイインピーダンスにして、SCL端子からクロックの出力を開始します。データはMSBを先頭に、クロックの立ち上がりエッジで順次シフトレジスタに取り込まれます。

RXEはD6の取り込み時に0にリセットされます。

8ビットのデータをシフトレジスタに受信し終わると、受信データはRTDT[7:0]にロードされます。I<sup>2</sup>Cモジュールには受信の制御用にRBRDY(D11/I2C\_DATレジスタ)とRBUSY(D9/I2C\_CTLレジスタ)の2つのステータスビットが用意されています。

- \* **RBRDY:** Receive Buffer Ready Bit in the I<sup>2</sup>C Data (I2C\_DAT) Register (D11/0x4344)
- \* **RBUSY:** Receive Busy Flag in the I<sup>2</sup>C Control (I2C\_CTL) Register (D9/0x4342)

RBRDYフラグは受信データの状態を示します。このフラグはシフトレジスタに受信したデータがRTDT[7:0]にロードされると1になり、RTDT[7:0]から受信データが読み出されると0に戻ります。このフラグが1になった時点で割り込みを発生させることもできますので、この割り込みを利用するか、RBRDYフラグの読み出しによってRTDT[7:0]に有効な受信データがあることを確認し、受信データを読み出してください。RTDT[7:0]を読み出す前に次の受信が終了すると、RTDT[7:0]内の1つ前の受信データは新たな受信データで上書きされてしまいます。

RBUSYフラグは受信動作状態を示します。このフラグは受信を開始すると1になり、データ受信が終了すると0に戻ります。また、ウェイト状態でも0に戻ります。I<sup>2</sup>Cモジュールが受信動作中か待機中かについては、このフラグを読み出して確認してください。

I<sup>2</sup>Cモジュールは1回のデータ受信に9個のクロックを出力します。9個目のクロックサイクルでは、RTACK(D8/I2C\_DATレジスタ)に設定された0または1が、それぞれACK, NACK応答として、SDA端子からスレーブへ送信されます。ACK, NACKの応答期間中はRTACKを変化させないようにしてください。

**注:** 受信バッファル割り込みは、ACK/NACKの応答期間中(9個目のクロックサイクル)に発生します。この割り込みが発生した直後に、ACK/NACK期間の終了を待たずにRTACKの設定を書き換えた場合、SDA端子に出力されているACK/NACK応答が応答期間中に変化してしまい、正しい通信が行えなくなってしまいます。

## データ送受信の終了(ストップコンディションの生成)

全データの送受信が終了した後、データ転送を終了するには、I<sup>2</sup>Cマスタ(本モジュール)がストップコンディションを生成する必要があります。SCLラインをHighに保った状態で、SDAラインをLowからHighにすることがストップコンディションとなります。



図20.5.4 ストップコンディション

ストップコンディションは、STP(D1/I2C\_CTLレジスタ)を1に設定しておくことで生成されます。

\* **STP:** Stop Control Bit in the I<sup>2</sup>C Control (I2C\_CTL) Register (D1/0x4342)

データ送受信(ACK送受信も含む)が終了した時点で、STPが1、TXE(D9/I2C\_DATレジスタ)、RXE(D10/I2C\_DATレジスタ)、STRT(D0/I2C\_CTLレジスタ)が0に設定されている場合、上記のストップコンディションが生成されます。これ以降I<sup>2</sup>Cバスは、フリー状態になります。ストップコンディションが生成されると、STPは自動的に0にリセットされます。

TXE、RXE、STRTのいずれかが1の場合、STPは無効となります。

本I<sup>2</sup>Cモジュールはリピートドスタートコンディションには対応していません。ストップコンディションを省略して、次のデータ転送のためのスタートコンディションを生成することはできません。

## TXE、RXE、STRT、STP設定によるウェイト状態

1バイトのデータとACKの送受信が終了した時点で、TXE(D9/I2C\_DATレジスタ)、RXE(D10/I2C\_DATレジスタ)、STRT(D0/I2C\_CTLレジスタ)、およびSTP(D1/I2C\_CTLレジスタ)の全ビットが0の場合、SCL出力がLowに固定されウェイト状態になります。この状態は、TXEまたはRXEに1を書き込んでデータ送受信を再開するか、STPによってストップコンディションを生成することで解除されます。

## データ送受信を禁止

ストップコンディションを生成した後は、I2CENビットに0を書き込んでデータ送受信を禁止します。ストップコンディション生成の完了は、STPを1に設定したのちに、0へ自動的にクリアされたことをポーリングすることにより、確認できます。

I<sup>2</sup>Cバスがビジー状態のときにI2CMENを0に設定した場合、SCLO、SDAOの出力レベル、および転送中のデータは保証されません。

## タイミングチャート

図20.5.5 I<sup>2</sup>Cタイミングチャート1(スタートコンディション→データ送信)図20.5.6 I<sup>2</sup>Cタイミングチャート2(データ送信→ストップコンディション)

図20.5.7 I<sup>2</sup>Cタイミングチャート3(スタートコンディション→データ受信)図20.5.8 I<sup>2</sup>Cタイミングチャート4(データ受信→ストップコンディション)

図20.5.9 I<sup>2</sup>Cタイミングチャート5(ウェイト)

## 20.6 I<sup>2</sup>C割り込み

I<sup>2</sup>Cモジュールには、以下の2種類の割り込みを発生させる機能があります。

- 送信バッファエンプティ割り込み
- 受信バッファフル割り込み

I<sup>2</sup>Cモジュールは、上記2種類の割り込み要因が共有する1本の割り込み信号を割り込みコントローラ(ITE)に対して出力します。

### 送信バッファエンプティ割り込み

この割り込みを使用するには、TINTE(D0/I2C\_ICTLレジスタ)を1に設定します。TINTEが0(デフォルト)に設定されていると、この要因による割り込み要求はITEに送られません。

\* **TINTE**: Transmit Interrupt Enable Bit in the I<sup>2</sup>C Interrupt Control (I2C\_ICTL) Register (D0/0x4346)

送信バッファエンプティ割り込みが許可されていれば(TINTE = 1)、RTDT[7:0](D[7:0]/I2C\_DATレジスタ)に設定された送信データがシフトレジスタに転送された時点で割り込み要求パルスがITEに出力されます。

送信バッファエンプティ割り込みは、データ送信時にのみ、発生します。

- 送信バッファエンプティ割り込みのクリア方法

RTDT/I2CM\_DATにデータをライトします。

TXE/I2CM\_DAT=0とした場合、データは送信されず、割り込みクリアのみ行います。

\* **RTDT[7:0]**: Receive/Transmit Data Bits in the I<sup>2</sup>C Data (I2C\_DAT) Register (D[7:0]/0x4344)

もし、他の割り込み条件が満たされていれば、割り込みが発生します。

### 受信バッファフル割り込み

この割り込みを使用するには、RINTE(D1/I2C\_ICTLレジスタ)を1に設定します。RINTEが0(デフォルト)に設定されていると、この要因による割り込み要求はITEに送られません。

\* **RINTE**: Receive Interrupt Enable Bit in the I<sup>2</sup>C Interrupt Control (I2C\_ICTL) Register (D1/0x4346)

受信バッファフル割り込みが許可されていれば(RINTE = 1)、シフトレジスタに受信したデータがRTDT[7:0]にロードされた時点で割り込み要求パルスがITEに出力されます。

受信バッファフル割り込みは、データ受信時にのみ、発生します。

- 受信バッファフル割り込みのクリア方法

RTDT/I2CM\_DATからデータをリードします。

注: I<sup>2</sup>CMの割り込み発生時、I<sup>2</sup>Cマスターのシーケンス処理に応じて送信バッファエンプティ割り込みと受信バッファフル割り込みを判断してください。送信バッファエンプティ割り込み、または、受信バッファフル割り込みのどちらが発生したかを確認できるレジスタはありません。

もし、他の割り込み条件が満たされていれば、割り込みが発生します。

### I<sup>2</sup>C割り込み用ITEレジスタ

ITE内のI<sup>2</sup>Cモジュール用制御ビットを以下に示します。

#### 割り込みフラグ

\* **IIFT7**: I<sup>2</sup>C Interrupt Flag in the Interrupt Flag (ITE\_IFLG) Register (D15/0x4300)

#### 割り込みイネーブルビット

\* **IHEN7**: I<sup>2</sup>C Interrupt Enable Bit in the Interrupt Enable (ITE\_EN) Register (D15/0x4302)

#### 割り込みレベル設定ビット

\* **ILV7[2:0]**: I<sup>2</sup>C Interrupt Level Bits in the Internal Interrupt Level Setup (ITE\_ILV3) Register 3 (D[10:8]/0x4314)

I<sup>2</sup>Cモジュールが割り込み要求パルスを出力すると、割り込みフラグIIFT7が1にセットされます。

割り込みイネーブルビットIHEN7が1に設定されていると、ITEは割り込み要求をS1C17コアに送ります。I<sup>2</sup>Cによる割り込みを禁止するには、IHEN7を0に設定しておきます。

IIFT7フラグは、IIEN7ビットの設定にかかわらず(0に設定していても)、I<sup>2</sup>Cの割り込み要求パルスによって1にセットされます。

割り込みレベル設定ビットIILV7[2:0]は、I<sup>2</sup>C割り込みのレベル(0~7)を設定します。

S1C17コアは、以下のすべての条件が成立している場合に割り込みを受け付けます。

- 割り込みイネーブルビットが1にセットされている。
- PSR(S1C17コア内のプロセッサステータスレジスタ)のIE(割り込みイネーブル)ビットが1にセットされている。
- I<sup>2</sup>C割り込みが、PSRのIL(割り込みレベル)に設定されている値よりも高い割り込みレベルに設定されている。
- NMIなど、他の優先順位の高い割り込み要因が発生していない。

これらの割り込み制御レジスタの詳細と割り込み発生時の動作については、“6 割り込みコントローラ(ITC)”を参照してください。

### 割り込みベクタ

I<sup>2</sup>C割り込みのベクタ番号とベクタアドレスは以下のとおりです。

ベクタ番号: 19(0x13)

ベクタアドレス: 0x804c

## 20.7 制御レジスタ詳細

表20.7.1 I<sup>2</sup>Cレジスタ一覧

| アドレス   | レジスタ名                 |                                             | 機能                          |
|--------|-----------------------|---------------------------------------------|-----------------------------|
| 0x4340 | I <sup>2</sup> C_EN   | I <sup>2</sup> C Enable Register            | I <sup>2</sup> Cモジュールイネーブル  |
| 0x4342 | I <sup>2</sup> C_CTL  | I <sup>2</sup> C Control Register           | I <sup>2</sup> Cの制御と転送状態の表示 |
| 0x4344 | I <sup>2</sup> C_DAT  | I <sup>2</sup> C Data Register              | 送受信データ                      |
| 0x4346 | I <sup>2</sup> C_ICTL | I <sup>2</sup> C Interrupt Control Register | I <sup>2</sup> C割り込みの制御     |

以下、I<sup>2</sup>Cモジュールのレジスタを個々に説明します。これらはすべて16ビットレジスタです。

- 注:
- レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。
  - I<sup>2</sup>Cレジスタのリード/ライトには必ず16ビットアクセス命令を使用してください。32ビットおよび8ビットアクセス命令でI<sup>2</sup>Cレジスタをリード/ライトすることはできません。

## 0x4340: I<sup>2</sup>C Enable Register (I<sup>2</sup>C\_EN)

| Register name                                          | Address          | Bit   | Name | Function | Setting | Init. | R/W | Remarks            |
|--------------------------------------------------------|------------------|-------|------|----------|---------|-------|-----|--------------------|
| I <sup>2</sup> C Enable Register (I <sup>2</sup> C_EN) | 0x4340 (16 bits) | D15-1 | —    | reserved | —       | —     | —   | 0 when being read. |

### D[15:1] Reserved

#### D0 I<sup>2</sup>CEN: I<sup>2</sup>C Enable Bit

I<sup>2</sup>Cモジュールの動作を許可/禁止します。

1(R/W): 許可

0(R/W): 禁止(デフォルト)

I<sup>2</sup>CENを1に設定するとI<sup>2</sup>Cモジュールが動作を開始し、データ転送が行える状態になります。

I<sup>2</sup>CENを0に設定すると、I<sup>2</sup>Cモジュールは動作を停止します。

## 0x4342: I<sup>2</sup>C Control Register (I2C\_CTL)

| Register name                               | Address | Bit    | Name         | Function            | Setting |       | Init. | R/W     | Remarks            |     |
|---------------------------------------------|---------|--------|--------------|---------------------|---------|-------|-------|---------|--------------------|-----|
| I <sup>2</sup> C Control Register (I2C_CTL) | 0x4342  | D15–10 | –            | reserved            | –       | –     | –     | –       | 0 when being read. |     |
|                                             |         | D9     | <b>RBUSY</b> | Receive busy flag   | 1       | Busy  | 0     | Idle    | 0                  | R   |
|                                             |         | D8     | <b>TBUSY</b> | Transmit busy flag  | 1       | Busy  | 0     | Idle    | 0                  | R   |
|                                             |         | D7–5   | –            | reserved            | –       | –     | –     | –       | 0 when being read. |     |
|                                             |         | D4     | <b>NSERM</b> | Noise remove on/off | 1       | On    | 0     | Off     | 0                  | R/W |
|                                             |         | D3–2   | –            | reserved            | –       | –     | –     | –       | 0 when being read. |     |
|                                             |         | D1     | <b>STP</b>   | Stop control        | 1       | Stop  | 0     | Ignored | 0                  | R/W |
|                                             |         | D0     | <b>STRT</b>  | Start control       | 1       | Start | 0     | Ignored | 0                  | R/W |

### D[15:10] Reserved

#### D9 RBUSY: Receive Busy Flag

I<sup>2</sup>Cの受信動作状態を示します。

1(R): 動作中

0(R): 待機中(デフォルト)

RBUSYはI<sup>2</sup>Cがデータ受信を開始すると1にセットされ、受信中は1を保持します。受信動作が終了すると、0にクリアされます。また、ウェイト状態でも0に戻ります。

#### D8 TBUSY: Transmit Busy Flag

I<sup>2</sup>Cの送信動作状態を示します。

1(R): 動作中

0(R): 待機中(デフォルト)

TBUSYはI<sup>2</sup>Cがデータ送信を開始すると1にセットされ、送信中は1を保持します。送信動作が終了すると、0にクリアされます。また、ウェイト状態でも0に戻ります。

### D[7:5] Reserved

#### D4 NSERM: Noise Remove On/Off Bit

ノイズ除去機能をOn/Offします。

1(R/W): On

0(R/W): Off(デフォルト)

I<sup>2</sup>Cモジュールには、SDAおよびSCL端子の入力信号からノイズを除去する機能が組み込まれており、NSERMを1に設定することにより有効となります。

ただし、この機能を使用するには、I<sup>2</sup>Cクロック(16ビットタイマCh.2出力クロック)周波数をPCLKの1/6以下に設定する必要があります。

### D[3:2] Reserved

#### D1 STP: Stop Control Bit

ストップコンディションを生成します。

1(R/W): ストップコンディションを生成

0(R/W): 無効(デフォルト)

STPを1に設定しておくことで、I<sup>2</sup>CモジュールはI<sup>2</sup>CバスのSCLラインをHighに保った状態でSDAラインをLowからHighにしてストップコンディションを生成します。これ以降I<sup>2</sup>Cバスは、フリー状態になります。

ただし、ストップコンディションが生成されるのは、データ送受信(ACK送受信も含む)が終了した時点で、STPが1、TXE(D9/I2C\_DATレジスタ)、RXE(D10/I2C\_DATレジスタ)、STRT(D0)が0に設定されている場合のみです。TXE、RXE、STRTのいずれかが1の場合、STPは無効となります。

ストップコンディションが生成されると、STPは自動的に0にリセットされます。

**D0 STRT: Start Control Bit**

スタートコンディションを生成します。

1(R/W): スタートコンディションを生成

0(R/W): 無効(デフォルト)

STRTを1に設定すると、I<sup>2</sup>CモジュールはI<sup>2</sup>CバスのSCLラインをHighに保った状態で、SDAラインをLowにしてスタートコンディションを生成します。これ以降I<sup>2</sup>Cバスは、ビジー状態になります。

スタートコンディションを生成するには、以下の順序でレジスタを設定してください。

1. RTDT[7:0](D[7:0]/I2CM\_DATレジスタ)にスレーブアドレスを設定

2. TXE(D9/I2CM\_DATレジスタ)を1に設定

3. STRTを1に設定

スタートコンディションが生成されると、STRTは自動的に0にリセットされます。

## 0x4344: I<sup>2</sup>C Data Register (I2C\_DAT)

| Register name                            | Address          | Bit    | Name      | Function                                            | Setting     |          | Init. | R/W     | Remarks            |
|------------------------------------------|------------------|--------|-----------|-----------------------------------------------------|-------------|----------|-------|---------|--------------------|
| I <sup>2</sup> C Data Register (I2C_DAT) | 0x4344 (16 bits) | D15–12 | –         | reserved                                            | –           | –        | –     | –       | 0 when being read. |
|                                          |                  | D11    | RBRDY     | Receive buffer ready                                | 1           | Ready    | 0     | Empty   | 0 R                |
|                                          |                  | D10    | RXE       | Receive execution                                   | 1           | Receive  | 0     | Ignored | 0 R/W              |
|                                          |                  | D9     | TXE       | Transmit execution                                  | 1           | Transmit | 0     | Ignored | 0 R/W              |
|                                          |                  | D8     | RTACK     | Receive/transmit ACK                                | 1           | Error    | 0     | ACK     | 0 R/W              |
|                                          |                  | D7–0   | RTDT[7:0] | Receive/transmit data<br>RTDT7 = MSB<br>RTDT0 = LSB | 0x0 to 0xff |          | 0x0   | R/W     |                    |
|                                          |                  |        |           |                                                     |             |          |       |         |                    |

### D[15:12] Reserved

#### D11 RBRDY: Receive Buffer Ready Flag

受信バッファの状態を示します。

1(R): 受信データあり

0(R): 受信データなし(デフォルト)

RBRDYフラグはシフトレジスタに受信したデータがRTDT[7:0](D[7:0])にロードされると1になります。RTDT[7:0]から受信データが読み出されると0に戻ります。このフラグが1になった時点で割り込みを発生させることもできますので、この割り込みを利用するか、RBRDYフラグの読み出しによってRTDT[7:0]に有効な受信データがあることを確認し、受信データを読み出してください。

#### D10 RXE: Receive Execution Bit

1バイトのデータ受信を実行します。

1(R/W): データ受信開始

0(R/W): 無効(デフォルト)

RXEを1、TXE(D9)を0に設定することにより、1バイトのデータ受信を開始します。スレーブアドレスの送信中またはデータの受信中であっても、次の受信のためにRXEを1に設定しておくことができます。RXEはD6がシフトレジスタに取り込まれた時点で0にリセットされます。

#### D9 TXE: Transmit Execution Bit

1バイトのデータ送信を実行します。

1(R/W): データ送信開始

0(R/W): 無効(デフォルト)

送信データをRTDT[7:0](D[7:0])に設定するとともにTXEに1を書き込んで送信を開始します。スレーブアドレスまたはデータの送信中であっても、次の送信のためにTXEを1に設定しておくことができます。TXEはRTDT[7:0]に設定したデータがシフトレジスタに転送された時点で0にリセットされます。

#### D8 RTACK: Receive/Transmit ACK Bit

##### データ送信時

応答ビットの状態を示します。

1(R/W): エラー(NACK)

0(R/W): ACK(デフォルト)

1バイトのデータを送信後、スレーブからACKが返るとRTACKは0になります。これは、スレーブがデータを正常に受信できたことを示します。RTACKが1の場合、スレーブデバイスが動作していないか、データが正常に受信できなかったことを示します。

##### データ受信時

スレーブに送信する応答ビットを設定します。

1(R/W): エラー(NACK)

0(R/W): ACK(デフォルト)

データ受信後にACKを返す場合は、I<sup>2</sup>Cモジュールが応答ビットを送る前にRTACKを0に設定してください。

NACKを返す場合は、RTACKを1に設定します。

**D[7:0] RTDT[7:0]: Receive/Transmit Data Bits****データ送信時**

送信データを設定します。(デフォルト: 0x0)

データ送信は、TXE(D9)を1に設定することにより開始します。現在スレーブアドレスまたはデータを送信中の場合は、その終了後に新たな送信を開始します。SDA端子からはシリアル変換されたデータがMSBを先頭に、0に設定されたビットをLowレベルとして出力されます。このレジスタに書き込んだデータがシフトレジスタに転送された時点で、送信バッファエンブティ割り込み要因が発生します。それ以降であれば、次の送信データを書き込むことができます。

**データ受信時**

受信データが読み出せます。(デフォルト: 0x0)

データ受信はRXE(D10)を1に設定すると開始します。現在スレーブアドレス送信中またはデータ受信中の場合は、その終了後に新たな受信を開始します。受信が終了し、シフトレジスタのデータがこのレジスタに転送された時点でRBRDYフラグ(D11)がセットされ、受信バッファフル割り込み要因が発生します。これ以降、次のデータの受信を終了するまで、データの読み出しが可能です。このレジスタを読み出す前に次の受信を終了した場合は、新たな受信データで上書きされます。

SDA端子から入力されたシリアルデータは先頭をMSBとして、Highレベルのビットを1、Lowレベルのビットを0としてパラレル変換され、本レジスタにロードされます。

## 0x4346: I<sup>2</sup>C Interrupt Control Register (I2C\_ICTL)

| Register name                                          | Address | Bit   | Name  | Function                  | Setting |        | Init. | R/W     | Remarks            |
|--------------------------------------------------------|---------|-------|-------|---------------------------|---------|--------|-------|---------|--------------------|
| I <sup>2</sup> C Interrupt Control Register (I2C_ICTL) | 0x4346  | D15-2 | —     | reserved                  | —       | —      | —     | —       | 0 when being read. |
|                                                        |         | D1    | RINTE | Receive interrupt enable  | 1       | Enable | 0     | Disable | 0 R/W              |
|                                                        |         | D0    | TINTE | Transmit interrupt enable | 1       | Enable | 0     | Disable | 0 R/W              |

### D[15:2] Reserved

#### D1 RINTE: Receive Interrupt Enable Bit

I<sup>2</sup>Cの受信バッファフル割り込みを許可/禁止します。

1(R/W): 許可

0(R/W): 禁止(デフォルト)

RINTEを1に設定すると、受信バッファフルによるI<sup>2</sup>C割り込み要求のITCへの出力を許可します。この割り込み要求は、シフトレジスタに受信したデータがRTDT[7:0](D[7:0]/I2C\_DATレジスタ)に転送される(受信が完了すること)により発生します。

RINTEを0に設定すると、I<sup>2</sup>C受信バッファフル割り込みは発生しません。

#### D0 TINTE: Transmit Interrupt Enable Bit

I<sup>2</sup>Cの送信バッファエンプティ割り込みを許可/禁止します。

1(R/W): 許可

0(R/W): 禁止(デフォルト)

TINTEを1に設定すると、送信バッファエンプティによるI<sup>2</sup>C割り込み要求のITCへの出力を許可します。この割り込み要求は、RTDT[7:0](D[7:0]/I2C\_DATレジスタ)に書き込んだデータがシフトレジスタに転送されることにより発生します。

TINTEを0に設定すると、I<sup>2</sup>C送信バッファエンプティ割り込みは発生しません。

このページはブランクです。

# 21 リモートコントローラ(REMC)

## 21.1 REMCの構成

S1C17001は赤外線リモコンの送受信信号を生成するリモートコントローラ(REMC)モジュールを内蔵しています。REMCモジュールは、プリスケーラ出力クロックを使用してキャリア信号を発生するキャリア発生回路、送受信データ長をカウントする8ビットダウンカウンタ、指定したキャリア長で送信データを生成する変調回路、入力信号の立ち上がりエッジ/立ち下がりエッジを検出するエッジ検出回路で構成されます。

また、指定データ長の送信が終了したことを示すカウンタアンダーフロー割り込み、データ受信処理用の入力立ち上がりエッジ/立ち下がりエッジ検出割り込みを発生可能です。

図21.1.1にREMCモジュールの構造を示します。



図21.1.1 REMCモジュールの構造

## 21.2 REMC入出力端子

表21.2.1にREMCの入出力端子を示します。

表21.2.1 REMC端子一覧

| 端子名        | I/O | 本数 | 機能                                    |
|------------|-----|----|---------------------------------------|
| REMI (P04) | I   | 1  | リモコン受信データ入力端子<br>受信データを入力します。         |
| REMO (P05) | O   | 1  | リモコン送信データ出力端子<br>変調したリモコン送信データを出力します。 |

REMCモジュールの入出力端子(REMI、REMO)は汎用入出力ポート端子(P04、P05)を兼用しており、初期状態では汎用入出力ポート端子に設定されます。これらをREMCの入出力端子として使用するには、P0\_PMUXレジスタの設定により機能を切り換える必要があります。以下の制御ビットを1に設定して、端子をREMC用に切り換えてください。

### P04 → REMI

\* **P04MUX**: P04 Port Function Select Bit in the P0 Port Function Select (P0\_PMUX) Register (D4/0x52a0)

### P05 → REMO

\* **P05MUX**: P05 Port Function Select Bit in the P0 Port Function Select (P0\_PMUX) Register (D5/0x52a0)

端子の機能と切り換えの詳細については、“10.2 入出力端子機能の選択(ポートMUX)”を参照してください。

## 21.3 キャリアの生成

REM**C**モジュールには、キャリア発生回路が組み込まれています。キャリア発生回路はソフトウェアで設定されたクロック、キャリアH区間長、キャリアL区間長に従い、送信用キャリア信号を生成します。

キャリア信号生成用クロックにはプリスケーラ出力クロックを使用します。プリスケーラはPCLKクロックを1/1～1/16Kに分周して15種類のクロックを生成します。この中から1つをCGCLK[3:0](D[7:4]/REM**C**\_PSCレジスタ)で選択します。

\* **CGCLK[3:0]**: Carrier Generator Clock Select Bits in the REMC Prescaler Clock Select (REM**C**\_PSC) Register (D[7:4]/0x5341)

表21.3.1 キャリア生成用クロックの選択

| CGCLK[3:0] | プリスケーラ出力クロック | CGCLK[3:0] | プリスケーラ出力クロック |
|------------|--------------|------------|--------------|
| 0xf        | Reserved     | 0x7        | PCLK•1/128   |
| 0xe        | PCLK•1/16384 | 0x6        | PCLK•1/64    |
| 0xd        | PCLK•1/8192  | 0x5        | PCLK•1/32    |
| 0xc        | PCLK•1/4096  | 0x4        | PCLK•1/16    |
| 0xb        | PCLK•1/2048  | 0x3        | PCLK•1/8     |
| 0xa        | PCLK•1/1024  | 0x2        | PCLK•1/4     |
| 0x9        | PCLK•1/512   | 0x1        | PCLK•1/2     |
| 0x8        | PCLK•1/256   | 0x0        | PCLK•1/1     |

(デフォルト:0x0)

プリスケーラの制御については、“9 プリスケーラ(PSC)”を参照してください。

注: REMCモジュールを動作させるには、その前にプリスケーラを動作させておく必要があります。

キャリアH区間長とキャリアL区間長は、それぞれREM**C**H[5:0](D[5:0]/REM**C**\_CARHレジスタ)とREM**C**L[5:0](D[5:0]/REM**C**\_CARLレジスタ)で設定します。これらのレジスタには、上記のとおり選択したクロックのサイクル数+1の値を設定します。

\* **REM**C**H[5:0]**: H Carrier Length Setup Bits in the REMC H Carrier Length Setup (REM**C**\_CARH) Register (D[5:0]/0x5342)

\* **REM**C**L[5:0]**: L Carrier Length Setup Bits in the REMC L Carrier Length Setup (REM**C**\_CARL) Register (D[5:0]/0x5343)

キャリアH区間長およびキャリアL区間長は次のように計算できます。

$$\text{キャリアH区間長} = \frac{\text{REMCH} + 1}{\text{clk\_in}} [\text{s}]$$

$$\text{キャリアL区間長} = \frac{\text{REMCL} + 1}{\text{clk\_in}} [\text{s}]$$

REM**C**H: キャリアH区間長レジスタデータ値

REM**C**L: キャリアL区間長レジスタデータ値

clk\_in: プリスケーラ出力クロック周波数

これらの設定により、キャリア信号は図21.3.1のとおり生成されます。

例: CGCLK[3:0] = 0x2(PCLK•1/4)、REM**C**H[5:0] = 2、REM**C**L[5:0] = 1



図21.3.1 キャリア信号の生成

## 21.4 データ長カウンタのクロック設定

データ長カウンタはデータ送信時にデータ長を設定するための8ビットカウンタです。

データ送信時にデータパルス幅に相当する値を書き込むと、データ長カウンタはその値からカウントダウンを開始し、カウンタが0になるとアンダーフロー割り込み要因を発生して停止します。

この割り込みを利用して、次の送信データを設定します。

データ受信時もこのカウンタを使用して、受信データ長を計測することができます。データ受信時は、入力信号の立ち上がりおよび立ち下がりエッジで割り込みを発生可能です。入力変化時の割り込みを利用してデータ長カウンタに0xffを設定し、次の入力変化による割り込み発生時にカウント値を読み出すことで、その差分からデータパルス長が得られます。

このデータ長カウンタのカウントクロックにもプリスケーラ出力クロックが使用され、15種類から1つを選択することができます。プリスケーラ出力クロックは、キャリア生成用クロックとは別に用意されている制御ビットLCCLK[3:0](D[3:0]/REMC\_PSCレジスタ)で選択します。

\* **LCCLK[3:0]**: Length Counter Clock Select Bits in the REMC Prescaler Clock Select (REMC\_PSC) Register (D[3:0]/0x5341)

表21.4.1 データ長カウンタ用クロックの選択

| LCCLK[3:0] | プリスケーラ出力クロック | LCCLK[3:0] | プリスケーラ出力クロック |
|------------|--------------|------------|--------------|
| 0xf        | Reserved     | 0x7        | PCLK•1/128   |
| 0xe        | PCLK•1/16384 | 0x6        | PCLK•1/64    |
| 0xd        | PCLK•1/8192  | 0x5        | PCLK•1/32    |
| 0xc        | PCLK•1/4096  | 0x4        | PCLK•1/16    |
| 0xb        | PCLK•1/2048  | 0x3        | PCLK•1/8     |
| 0xa        | PCLK•1/1024  | 0x2        | PCLK•1/4     |
| 0x9        | PCLK•1/512   | 0x1        | PCLK•1/2     |
| 0x8        | PCLK•1/256   | 0x0        | PCLK•1/1     |

(デフォルト:0x0)

データ長カウンタは最大256までカウント可能です。データ長がこの範囲に収まるようにカウントクロックを選択してください。

## 21.5 データ送受信の制御

データ転送を開始する前に、以下の設定を行ってください。

- (1) キャリア信号を設定します。21.3節を参照してください。
- (2) データ長カウンタのクロックを選択します。21.4節を参照してください。
- (3) 割り込み条件を設定します。21.6節を参照してください。

注: 上記の設定は必ずREMCモジュールが停止中(REMEN/REMC\_CFGレジスタ = 0)に行ってください。

\* **REMEN:** REMC Enable Bit in the REMC Configuration (REMC\_CFG) Register (D0/0x5340)

### データ送信制御



図21.5.1 データ送信



図21.5.2 アンダーフロー割り込み発生タイミング

#### (1) データ送信モードの設定

REMMD(D1/REMC\_CFGレジスタ)に0を書き込み、REMCを送信モードに設定します。

\* **REMMD:** REMC Mode Select Bit in the REMC Configuration (REMC\_CFG) Register (D1/0x5340)

#### (2) データ送信を許可

REMEN(D0/REMC\_CFGレジスタ)を1に設定してREMCの動作を許可します。これにより、REMCが送信動作を開始します。

不要なデータが送信されないように、REMENに1を書き込む前にREMDT(D0/REMC\_STレジスタ)を0、REMLEN[7:0](D[7:0]/REMC\_LCNTレジスタ)を0x0に設定してください。

#### (3) 送信データの設定

送信するデータ(HighまたはLow)をREMDT(D0/REMC\_STレジスタ)に設定します。

\* **REMDT:** Transmit/Receive Data Bit in the REMC Status (REMC\_ST) Register (D0/0x5344)

REMDTを1に設定するとHigh、0に設定するとLow出力となり、キャリア信号で変調されたのち、REMO端子から出力されます。

#### (4) データパルス長の設定

送信を開始したデータのパルス長(High期間またはLow期間)に相当する値をREMLEN[7:0](D[7:0]/REMC\_LCNTレジスタ)に書き込んで、データ長カウンタに設定します。

\* **REMLEN[7:0]:** Transmit/Receive Data Length Count Bits in the REMC Length Counter (REMC\_LCNT) Register (D[7:0]/0x5345)

データ長カウンタに設定する値は次のとおりです。

設定値 = データパルス長(秒) × プリスケーラ出力クロック周波数(Hz)

データ長カウンタは書き込まれた値から、選択されているプリスケーラ出力クロックでカウントダウンを開始します。

データ長カウンタの値が0になるとアンダーフロー割り込み要因が発生し、割り込みが許可されている場合は割り込みコントローラ(ITC)にREMC割り込み要求を出力します。データ長カウンタは0の状態でカウントを停止します。

#### (5) 割り込み処理

続くデータを送信する場合は、データ長カウンタのアンダーフローにより発生した割り込みの処理ルーチンの中で、次の送信データの設定(3)とデータパルス長の設定(4)を行います。

#### (6) データ送信の終了

データ送信を終了するには、最後のデータ送信が終了後(アンダーフロー割り込み発生後)、REMENに0を書き込んでください。

### データ受信制御



図21.5.3 データ受信

#### (1) データ受信モードの設定

REMMD(D1/REMC\_CFGレジスタ)に1を書き込み、REMCを受信モードに設定します。

#### (2) データ受信を許可

REMEN(D0/REMC\_CFGレジスタ)を1に設定してREMCの動作を許可します。これにより、REMCが受信動作(入力エッジ検出動作)を開始します。

REMCはREMI端子からの入力信号を、キャリア生成用に選択したプリスケーラ出力クロックでサンプリングして入力の変化(信号の立ち上がりエッジまたは立ち下がりエッジ)を検出します。信号のエッジが検出されると、立ち上がりエッジまたは立ち下がりエッジ割り込み要因が発生し、割り込みが許可されている場合はITCにREMC割り込み要求を出力します。立ち上がりエッジ割り込みと立ち下がりエッジ割り込みは個別に許可/禁止が可能です。

なお、入力が変化した後の信号レベルがサンプリングクロックの2サイクル以上連続して検出されない場合はノイズと見なされ、立ち上がりエッジまたは立ち下がりエッジ割り込みは発生しません。

### (3)割り込み処理

立ち上がりエッジまたは立ち下がりエッジ割り込みが発生した場合は、その割り込み処理ルーチンの中で、0xffをREMLEN[7:0](D[7:0]/REM**C**\_LCNTレジスタ)に書き込んで、データ長カウンタに設定します。

データ長カウンタは書き込まれた値から、選択されているプリスケーラ出力クロックでカウントダウンを開始します。

受信したデータはREM**D**T(D0/REM**C**\_STレジスタ)から読み出すことができます。

データパルスが終了すると次の立ち下がりエッジまたは立ち上がりエッジ割り込みが発生しますので、そこでデータ長カウンタを読み出します。0xffと読み出し値の差分からデータ長が算出できます。続くデータを受信する場合は、データ長カウンタを再度0xffに設定し、次の割り込みを待ちます。

データ長カウンタを0xffに設定後、エッジ割り込みが発生せずにデータ長カウンタが0になった場合はデータの終了か、何らかの受信エラーが考えられます。受信時でもデータ長カウンタのアンダーフロー割り込みは発生しますので、終了/エラー処理に利用してください。

### (4)データ受信の終了

データ受信を終了するには、最後のデータ受信が終了後、REM**E**Nに0を書き込んでください。

## 21.6 REMC割り込み

REMCモジュールには、以下の3種類の割り込みを発生させる機能があります。

- ・アンダーフロー割り込み
- ・立ち上がりエッジ割り込み
- ・立ち下がりエッジ割り込み

REMCモジュールは、上記3種類の割り込み要因が共有する1本の割り込み信号を割り込みコントローラ(ITC)に対して出力します。発生した割り込み要因を特定するには、REMCモジュール内の割り込みフラグを読み出してください。

### アンダーフロー割り込み

この割り込み要求は、データ長カウンタがカウントダウンにより0になった時点で発生し、REMC内の割り込みフラグREMUIF(D0/REMC\_IFLGレジスタ)を1にセットします。

データ送信時は、設定したデータ長の送信が完了したことを示します。データ受信時は受信データが終了したか、受信エラーが発生したことを示します。

\* **REMUIF:** Underflow Interrupt Flag in the REMC Interrupt Flag (REMC\_IFLG) Register (D0/0x5347)

この割り込みを使用するには、REMUIE(D0/REMC\_IMSKレジスタ)を1に設定します。REMUIEが0(デフォルト)に設定されているとREMUIFが1にセットされず、この要因による割り込み要求はITCに送られません。

\* **REMUIE:** Underflow Interrupt Enable Bit in the REMC Interrupt Mask (REMC\_IMSK) Register (D0/0x5346)

REMUIFが1にセットされるとREMCは割り込み要求をITCに出力します。この割り込み要求信号により、ITC内のREMC割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

REMC割り込みがデータ長カウンタのアンダーフローによるものかどうかについては、REMC割り込み処理ルーチンでREMUIFを読み出して確認してください。

また、割り込み処理ルーチン内では、ITCのREMC割り込みフラグと共にREMCモジュールのREMUIFをリセット(1を書き込み)して割り込み要因をクリアしてください。

### 立ち上がりエッジ割り込み

この割り込み要求は、REMI端子の入力信号がLowからHighに変化すると発生し、REMC内の割り込みフラグREMrif(D1/REMC\_IFLGレジスタ)を1にセットします。

データ受信時、本割り込みと立ち下がりエッジ割り込みの間にデータ長カウンタを動作させることで、そのカウント値から受信データのパルス幅を算出することができます。

\* **REMrif:** Rising Edge Interrupt Flag in the REMC Interrupt Flag (REMC\_IFLG) Register (D1/0x5347)

この割り込みを使用するには、REMRIE(D1/REMC\_IMSKレジスタ)を1に設定します。REMRIEが0(デフォルト)に設定されているとREMrifは1にセットされず、この要因による割り込み要求はITCに送られません。

\* **REMRIE:** Rising Edge Interrupt Enable Bit in the REMC Interrupt Mask (REMC\_IMSK) Register (D1/0x5346)

REMrifが1にセットされるとREMCは割り込み要求をITCに出力します。この割り込み要求信号により、ITC内のREMC割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

REMC割り込みが入力信号の立ち上がりエッジによるものかどうかについては、REMC割り込み処理ルーチンでREMrifを読み出して確認してください。

また、割り込み処理ルーチン内では、ITCのREMC割り込みフラグと共にREMCモジュールのREMrifをリセット(1を書き込み)して割り込み要因をクリアしてください。

## 立ち上がりエッジ割り込み

この割り込み要求は、REM**C**端子の入力信号がHighからLowに変化すると発生し、REM**C**内の割り込みフラグREM**FIF**(D2/REM**C**\_IFLGレジスタ)を1にセットします。

データ受信時、本割り込みと立ち上がりエッジ割り込みの間にデータ長カウンタを動作させることで、そのカウント値から受信データのパルス幅を算出することができます。

\* **REM**FIF****: Falling Edge Interrupt Flag in the REM**C** Interrupt Flag (REM**C**\_IFLG) Register (D2/0x5347)

この割り込みを使用するには、REM**FIE**(D2/REM**C**\_IMSKレジスタ)を1に設定します。REM**FIE**が0(デフォルト)に設定されているとREM**FIF**が1にセットされず、この要因による割り込み要求はITCに送られません。

\* **REM**FIE****: Falling Edge Interrupt Enable Bit in the REM**C** Interrupt Mask (REM**C**\_IMSK) Register (D2/0x5346)

REM**FIF**が1にセットされるとREM**C**は割り込み要求をITCに出力します。この割り込み要求信号により、ITC内のREM**C**割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

REM**C**割り込みが入力信号の立ち上がりエッジによるものかどうかについては、REM**C**割り込み処理ルーチンでREM**FIF**を読み出して確認してください。

また、割り込み処理ルーチン内では、ITCのREM**C**割り込みフラグと共にREM**C**モジュールのREM**FIF**をリセット(1を書き込み)して割り込み要因をクリアしてください。

## REM**C**割り込み用ITCレジスタ

前述の設定により、割り込みを許可した要因が発生するとREM**C**モジュールは割り込み信号をITCに出力します。REM**C**割り込みを発生させるには、ITCレジスタで割り込みレベルと割り込み許可の設定を行ってください。

以下に、REM**C**用のITC制御ビットを示します。

### ITC内の割り込みフラグ

\* **IIFT5**: Remote Controller Interrupt Flag in the Interrupt Flag (ITC\_IFLG) Register (D13/0x4300)

### ITC内の割り込みイネーブルビット

\* **IIEN5**: Remote Controller Interrupt Enable Bit in the Interrupt Enable (ITC\_EN) Register (D13/0x4302)

### ITC内の割り込みレベル設定ビット

\* **ILV5[2:0]**: REM**C** Interrupt Level Bits in the Internal Interrupt Level Setup (ITC\_ILV2) Register 2 (D[10:8]/0x4312)

REM**C**モジュールからの割り込み信号によりIIFT5が1にセットされます。このとき、IIEN5が1に設定されていると、ITCは割り込み要求をS1C17コアに送ります。REM**C**モジュールによる割り込みを禁止するには、IIEN5を0に設定しておきます。IIFT5は、IIEN5の設定にかかわらず(0に設定されても)、REM**C**モジュールからの割り込み信号によって1にセットされます。

ILV5[2:0]は、REM**C**割り込みのレベル(0~7)を設定します。

S1C17コアは、以下のすべての条件が成立している場合に割り込みを受け付けます。

- ・割り込みイネーブルビットが1にセットされている。
- ・PSR(S1C17コア内のプロセッサステータスレジスタ)のIE(割り込みイネーブル)ビットが1にセットされている。
- ・REM**C**割り込みが、PSRのIL(割り込みレベル)に設定されている値よりも高い割り込みレベルに設定されている。
- ・NMIなど、他の優先順位の高い割り込み要因が発生していない。

これらの割り込み制御レジスタの詳細と割り込み発生時の動作については、“6 割り込みコントローラ(ITC)”を参照してください。

## 割り込みベクタ

REM**C**割り込みのベクタ番号とベクタアドレスは以下のとおりです。

ベクタ番号: 17(0x11)

ベクタアドレス: 0x8044

## 21.7 制御レジスタ詳細

表21.7.1 REMCレジスター一覧

| アドレス   | レジスタ名     | 機能                                   |
|--------|-----------|--------------------------------------|
| 0x5340 | REMC_CFG  | REMC Configuration Register          |
| 0x5341 | REMC_PSC  | REMC Prescaler Clock Select Register |
| 0x5342 | REMC_CARH | REMC H Carrier Length Setup Register |
| 0x5343 | REMC_CARL | REMC L Carrier Length Setup Register |
| 0x5344 | REMC_ST   | REMC Status Register                 |
| 0x5345 | REMC_LCNT | REMC Length Counter Register         |
| 0x5346 | REMC_IMSK | REMC Interrupt Mask Register         |
| 0x5347 | REMC_IFLG | REMC Interrupt Flag Register         |

以下、REMCモジュールのレジスタを個々に説明します。これらはすべて8ビットレジスタです。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

**0x5340: REMC Configuration Register (REM**C**\_CFG)**

| Register name                                                    | Address            | Bit  | Name            | Function                 | Setting |         | Init. | R/W      | Remarks            |     |
|------------------------------------------------------------------|--------------------|------|-----------------|--------------------------|---------|---------|-------|----------|--------------------|-----|
| REM <b>C</b><br>Configuration<br>Register<br>(REM <b>C</b> _CFG) | 0x5340<br>(8 bits) | D7-2 | —               | reserved                 | —       | —       | —     | —        | 0 when being read. |     |
|                                                                  |                    | D1   | REM <b>M</b> MD | REM <b>C</b> mode select | 1       | Receive | 0     | Transmit | 0                  | R/W |
|                                                                  |                    | D0   | REM <b>E</b> N  | REM <b>C</b> enable      | 1       | Enable  | 0     | Disable  | 0                  | R/W |

**D[7:2] Reserved****D1 REM**M**MD: REMC Mode Select Bit**

送受信方向を選択します。

1 (R/W): 受信

0 (R/W): 送信(デフォルト)

**D0 REM**E**N: REMC Enable Bit**

REM**C**モジュールの送受信を許可/禁止します。

1 (R/W): 許可

0 (R/W): 禁止(デフォルト)

REM**E**Nを1に設定するとREM**M**MD(D1)の設定に従って送信または受信の動作を開始します。

REM**E**Nを0に設定すると、REM**C**モジュールは動作を停止します。

**0x5341: REMC Prescaler Clock Select Register (REMC\_PSC)**

| Register name                                   | Address         | Bit  | Name       | Function                                                | Setting                                                                                                      | Init.                                                                                                                                                                                                                 | R/W | Remarks |
|-------------------------------------------------|-----------------|------|------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------|
| REMC Prescaler Clock Select Register (REMC_PSC) | 0x5341 (8 bits) | D7-4 | CGCLK[3:0] | Carrier generator clock select (Prescaler output clock) | CGCLK[3:0]<br>LCCLK[3:0]                                                                                     | Clock                                                                                                                                                                                                                 | 0x0 | R/W     |
|                                                 |                 | D3-0 | LCCLK[3:0] | Length counter clock select (Prescaler output clock)    | 0xf<br>0xe<br>0xd<br>0xc<br>0xb<br>0xa<br>0x9<br>0x8<br>0x7<br>0x6<br>0x5<br>0x4<br>0x3<br>0x2<br>0x1<br>0x0 | reserved<br>PCLK-1/16384<br>PCLK-1/8192<br>PCLK-1/4096<br>PCLK-1/2048<br>PCLK-1/1024<br>PCLK-1/512<br>PCLK-1/256<br>PCLK-1/128<br>PCLK-1/64<br>PCLK-1/32<br>PCLK-1/16<br>PCLK-1/8<br>PCLK-1/4<br>PCLK-1/2<br>PCLK-1/1 | 0x0 | R/W     |

**D[7:4] CGCLK[3:0]: Carrier Generator Clock Select Bits**

15種類のプリスケーラ出力クロックから、キャリア生成用クロックを選択します。

表21.7.2 キャリア生成用クロックの選択

| CGCLK[3:0] | プリスケーラ出力クロック | CGCLK[3:0] | プリスケーラ出力クロック |
|------------|--------------|------------|--------------|
| 0xf        | Reserved     | 0x7        | PCLK-1/128   |
| 0xe        | PCLK-1/16384 | 0x6        | PCLK-1/64    |
| 0xd        | PCLK-1/8192  | 0x5        | PCLK-1/32    |
| 0xc        | PCLK-1/4096  | 0x4        | PCLK-1/16    |
| 0xb        | PCLK-1/2048  | 0x3        | PCLK-1/8     |
| 0xa        | PCLK-1/1024  | 0x2        | PCLK-1/4     |
| 0x9        | PCLK-1/512   | 0x1        | PCLK-1/2     |
| 0x8        | PCLK-1/256   | 0x0        | PCLK-1/1     |

(デフォルト: 0x0)

**D[3:0] LCCLK[3:0]: Length Counter Clock Select Bits**

15種類のプリスケーラ出力クロックから、データ長カウンタ用クロックを選択します。

表21.7.3 データ長カウンタ用クロックの選択

| LCCLK[3:0] | プリスケーラ出力クロック | LCCLK[3:0] | プリスケーラ出力クロック |
|------------|--------------|------------|--------------|
| 0xf        | Reserved     | 0x7        | PCLK-1/128   |
| 0xe        | PCLK-1/16384 | 0x6        | PCLK-1/64    |
| 0xd        | PCLK-1/8192  | 0x5        | PCLK-1/32    |
| 0xc        | PCLK-1/4096  | 0x4        | PCLK-1/16    |
| 0xb        | PCLK-1/2048  | 0x3        | PCLK-1/8     |
| 0xa        | PCLK-1/1024  | 0x2        | PCLK-1/4     |
| 0x9        | PCLK-1/512   | 0x1        | PCLK-1/2     |
| 0x8        | PCLK-1/256   | 0x0        | PCLK-1/1     |

(デフォルト: 0x0)

注: クロックの設定は、REMCモジュールが停止中(REMEN/REMC\_CFGレジスタ = 0)に行ってください。

**0x5342: REMC H Carrier Length Setup Register (REM**C**\_CARH)**

| Register name                                                     | Address         | Bit  | Name                | Function               | Setting     | Init. | R/W | Remarks            |
|-------------------------------------------------------------------|-----------------|------|---------------------|------------------------|-------------|-------|-----|--------------------|
| REM <b>C</b> H Carrier Length Setup Register (REM <b>C</b> _CARH) | 0x5342 (8 bits) | D7–6 | –                   | reserved               | –           | –     | –   | 0 when being read. |
|                                                                   |                 | D5–0 | REM <b>C</b> H[5:0] | H carrier length setup | 0x0 to 0x3f | 0x0   | R/W |                    |

**D[7:6] Reserved****D[5:0] REM**C**H[5:0]: H Carrier Length Setup Bits**

キャリア信号のH区間長を設定します。(デフォルト: 0x0)

CGCLK[3:0](D[7:4]/REM**C**\_PSCレジスタ)で選択したキャリア生成用クロックのサイクル数+1の値を指定します。

キャリアH区間長は次のように計算できます。

$$\text{キャリアH区間長} = \frac{\text{REMCH} + 1}{\text{clk\_in}} [\text{s}]$$

REMCH: REMCH[5:0]設定値

clk\_in: プリスケーラ出力クロック周波数

REM**C**L[5:0](D[5:0]/REM**C**\_CARLレジスタ)でL区間長を指定します。

これらの設定により、キャリア信号は図21.7.1のとおり生成されます。

例: CGCLK[3:0] = 0x2(PCLK•1/4)、REMCH[5:0] = 2、REM**C**L[5:0] = 1



図21.7.1 キャリア信号の生成

## 0x5343: REMC L Carrier Length Setup Register (REMC\_CARL)

| Register name                                    | Address         | Bit  | Name | Function | Setting | Init. | R/W | Remarks            |
|--------------------------------------------------|-----------------|------|------|----------|---------|-------|-----|--------------------|
| REMC L Carrier Length Setup Register (REMC_CARL) | 0x5343 (8 bits) | D7–6 | –    | reserved | –       | –     | –   | 0 when being read. |

### D[7:6] Reserved

### D[5:0] REMCL[5:0]: L Carrier Length Setup Bits

キャリア信号のL区間長を設定します。(デフォルト: 0x0)

CGCLK[3:0](D[7:4]/REMC\_PSCレジスタ)で選択したキャリア生成用クロックのサイクル数+1の値を指定します。

キャリアL区間長は次のように計算できます。

$$\text{キャリアL区間長} = \frac{\text{REMCL} + 1}{\text{clk\_in}} \text{ [s]}$$

REMCL: REMCL[5:0]設定値

clk\_in: プリスケーラ出力クロック周波数

REMCH[5:0](D[5:0]/REMC\_CARHレジスタ)でH区間長を指定します。

これらの設定により、キャリア信号は図21.7.1のとおり生成されます。

**0x5344: REMC Status Register (REM**C**\_ST)**

| Register name                                         | Address            | Bit  | Name | Function | Setting | Init. | R/W | Remarks            |
|-------------------------------------------------------|--------------------|------|------|----------|---------|-------|-----|--------------------|
| REM <b>C</b><br>Status Register<br>(REM <b>C</b> _ST) | 0x5344<br>(8 bits) | D7-1 | -    | reserved | -       | -     | -   | 0 when being read. |

**D[7:1] Reserved****D0 REMDT: Transmit/Receive Data Bit**

データ送信時は送信データを設定します。データ受信時は受信データが読み出せます。

1(R/W): 1(H)

0(R/W): 0(L) (デフォルト)

REMEN(D0/REM**C**\_CFGレジスタ)が1に設定されている場合、データ送信時はREM**C**DTの設定値がキャリア信号で変調され、REM**C**端子から出力されます。データ受信時は入力したデータパルスの信号レベルがこのビットにセットされます。

## 0x5345: REMC Length Counter Register (REMC\_LCNT)

| Register name                            | Address         | Bit  | Name        | Function                                          | Setting     | Init. | R/W | Remarks |
|------------------------------------------|-----------------|------|-------------|---------------------------------------------------|-------------|-------|-----|---------|
| REMC Length Counter Register (REMC_LCNT) | 0x5345 (8 bits) | D7-0 | REMLEN[7:0] | Transmit/receive data length count (down counter) | 0x0 to 0xff | 0x0   | R/W |         |

### D[7:0] REMLEN[7:0]: Transmit/Receive Data Length Count Bits

データ長カウンタに値を設定しカウントを開始させます。(デフォルト: 0x0)

カウンタは0になると停止し、アンダーフロー割り込み要因を発生します。

#### データ送信時

データ送信時は送信データ長を設定します。

データパルス幅に相当する値を書き込むと、データ長カウンタはその値からカウントダウンを開始し、カウンタが0になるとアンダーフロー割り込み要因を発生して停止します。

この割り込みを利用して、次の送信データを設定します。

#### データ受信時

データ受信時は、入力信号の立ち上がりおよび立ち下がりエッジで割り込みを発生可能です。

入力変化時の割り込みを利用してデータ長カウンタに0xffを設定し、次の入力変化による割り込み発生時にカウント値を読み出すことで、その差分からデータパルス長が得られます。

**0x5346: REMC Interrupt Mask Register (REM**C**\_IMSK)**

| Register name                                             | Address         | Bit  | Name           | Function                      | Setting |        | Init. | R/W     | Remarks            |
|-----------------------------------------------------------|-----------------|------|----------------|-------------------------------|---------|--------|-------|---------|--------------------|
| REM <b>C</b> Interrupt Mask Register (REM <b>C</b> _IMSK) | 0x5346 (8 bits) | D7–3 | –              | reserved                      | –       | –      | –     | –       | 0 when being read. |
|                                                           |                 | D2   | REM <b>FIE</b> | Falling edge interrupt enable | 1       | Enable | 0     | Disable | 0 R/W              |
|                                                           |                 | D1   | REM <b>RIE</b> | Rising edge interrupt enable  | 1       | Enable | 0     | Disable | 0 R/W              |
|                                                           |                 | D0   | REM <b>UIE</b> | Underflow interrupt enable    | 1       | Enable | 0     | Disable | 0 R/W              |

本レジスタは、データ長カウンタのアンダーフロー、入力信号の立ち上がりエッジ、入力信号の立ち下がりエッジによる割り込み要求を個々に許可または禁止します。割り込みイネーブルビットを1に設定すると、対応する割り込み要因による割り込み要求が許可され、0に設定すると割り込みが禁止されます。なお、割り込みを発生させるには、ITCのREM**C**割り込みイネーブルビットも割り込み許可に設定する必要があります。

**D[7:3] Reserved****D2 REMFIE: Falling Edge Interrupt Enable Bit**

入力信号の立ち下がりエッジによる割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

**D1 REMRIE: Rising Edge Interrupt Enable Bit**

入力信号の立ち上がりエッジによる割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

**D0 REMUIE: Underflow Interrupt Enable Bit**

データ長カウンタのアンダーフローによる割り込みを許可または禁止します。

1(R/W): 割り込み許可

0(R/W): 割り込み禁止(デフォルト)

## 0x5347: REMC Interrupt Flag Register (REMC\_IFLG)

| Register name                            | Address         | Bit  | Name   | Function                    | Setting |                             | Init. | R/W                             | Remarks                   |
|------------------------------------------|-----------------|------|--------|-----------------------------|---------|-----------------------------|-------|---------------------------------|---------------------------|
| REMC Interrupt Flag Register (REMC_IFLG) | 0x5347 (8 bits) | D7-3 | —      | reserved                    | —       |                             | —     | —                               | 0 when being read.        |
|                                          |                 | D2   | REMFIF | Falling edge interrupt flag | 1       | Cause of interrupt occurred | 0     | Cause of interrupt not occurred | 0 R/W Reset by writing 1. |
|                                          |                 | D1   | REMRIF | Rising edge interrupt flag  |         |                             |       |                                 | 0 R/W                     |
|                                          |                 | D0   | REMUIF | Underflow interrupt flag    |         |                             |       |                                 | 0 R/W                     |

本レジスタは、データ長カウンタのアンダーフロー、入力信号の立ち上がりエッジ、入力信号の立ち下がりエッジ割り込み要因の発生状態を示します。REMC割り込みが発生した場合は、本レジスタの割り込みフラグを読み出して発生した割り込み要因を特定してください。

対応する割り込みイネーブルビットを1に設定しておくことで、割り込みフラグはデータ長カウンタのアンダーフロー、入力信号の立ち上がりエッジ、入力信号の立ち下がりエッジにより1にセットされます。同時に、ITCに対してREMC割り込み要求信号が outputされます。この割り込み要求信号により、ITC内のREMC割り込みフラグが1にセットされ、ITCとS1C17コアの割り込み条件が成立していれば割り込みが発生します。

注: 不要な割り込みの発生を防止するため、割り込みイネーブルビットによって割り込みを許可する前に、割り込みフラグをリセットしてください。

### D[7:3] Reserved

#### D2 REMFIF: Falling Edge Interrupt Flag

立ち下がりエッジ割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり
- 0(R): 割り込み要因なし(デフォルト)
- 1(W): フラグをリセット
- 0(W): 無効

REMFIFはREMFIE(D2/REMC\_IMSKレジスタ)を1に設定しておくことにより、入力信号の立ち下がりエッジで1にセットされます。

#### D1 REMRIF: Rising Edge Interrupt Flag

立ち上がりエッジ割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり
- 0(R): 割り込み要因なし(デフォルト)
- 1(W): フラグをリセット
- 0(W): 無効

REMRIFはREMRIE(D1/REMC\_IMSKレジスタ)を1に設定しておくことにより、入力信号の立ち上がりエッジで1にセットされます。

#### D0 REMUIF: Underflow Interrupt Flag

アンダーフロー割り込み要因の発生状態を示す割り込みフラグです。

- 1(R): 割り込み要因あり
- 0(R): 割り込み要因なし(デフォルト)
- 1(W): フラグをリセット
- 0(W): 無効

REMUIFはREMUIE(D1/REMC\_IMSKレジスタ)を1に設定しておくことにより、データ長カウンタのアンダーフローによって1にセットされます。

## 21.8 注意事項

REMCモジュールを動作させるには、その前にプリスケーラを動作させておく必要があります。

このページはブランクです。

# 22 オンチップデバッガ(DBG)

## 22.1 リソース要件とデバッグツール

### デバッグ用ワークエリア

デバッグを行うには、64バイトのデバッグ用ワークエリアが必要です。S1C17001ではRAM内のアドレス0x0007c0～0x0007ffがデバッグ用ワークエリアに設定されています。デバッグ機能を使用する場合、この領域をユーザプログラムからは使用しないでください。

このデバッグ用ワークエリアのスタートアドレスはDBRAMレジスタ(0xffff90)から読み出すことができます。

### デバッグツール

デバッグは、S1C17701のデバッグ端子にS5U1C17001H(ICD Mini)等のICD(In-Circuit Debugger)を接続し、パソコン上のデバッガからデバッグコマンドを入力して行います。このため、以下のツールが必要です。

- S1C17 Family In-Circuit Debugger(S5U1C17001H等)
- S1C17 Family Cコンパイラパッケージ(S5U1C17001C等)

### デバッグ端子

ICD(S5U1C17001H等)との接続に以下のデバッグ端子を使用します。

表22.1.1 デバッグ端子一覧

| 端子名       | I/O | 本数 | 機能                                                   |
|-----------|-----|----|------------------------------------------------------|
| DCLK(P31) | 0   | 1  | オンチップデバッガクロック出力端子<br>ICDにクロックを出力します。                 |
| DSIO(P33) | I/O | 1  | オンチップデバッガデータ入出力端子<br>デバッグ用データの入出力およびブレーク信号の入力に使用します。 |
| DST2(P32) | 0   | 1  | オンチップデバッガステータス信号出力端子<br>デバッグ中のプロセッサの状態を出力します。        |

オンチップデバッガの入出力端子(DCLK、DST2、DSIO)は汎用入出力ポート端子(P31、P32、P33)を兼用しており、初期状態ではデバッグ端子に設定されます。デバッグ機能を使用しない場合は、P3\_PMUXレジスタの設定により、これらの端子を汎用入出力ポート端子に切り換えることができます。以下の制御ビットを1に設定することにより、端子が汎用入出力ポート用に切り換わります。

#### DCLK → P31

\* **P31MUX**: P31 Port Function Select Bit in the P3 Port Function Select (P3\_PMUX) Register (D1/0x52a3)

#### DST2 → P32

\* **P32MUX**: P32 Port Function Select Bit in the P3 Port Function Select (P3\_PMUX) Register (D2/0x52a3)

#### DSIO → P33

\* **P33MUX**: P33 Port Function Select Bit in the P3 Port Function Select (P3\_PMUX) Register (D3/0x52a3)

端子の機能と切り替えの詳細については、“10.2 入出力端子機能の選択(ポートMUX)”を参照してください。

## 22.2 デバッグブレーク時の動作状態

`b dk`命令の実行、またはDSIO端子へのブレーク信号(Low)入力によりデバッグ割り込みが発生すると、S1C17コアはデバッグモードになります。この状態は`retd`命令が実行されるまで続きます。

この間、ハードウェア割り込みおよびNMIは受け付けられません。

デフォルト設定では、周辺回路の動作は停止します。これをデバッグ中でも動作するように変更することができます。

### プリスケーラ出力クロックで動作する周辺回路

- 8ビットタイマ
- 16ビットタイマ
- PWM&キャプチャタイマ
- リモートコントローラ
- Pポート
- UART
- SPI
- I<sup>2</sup>C

デフォルト設定では、デバッグモード時にプリスケーラが停止します。そのため、プリスケーラ出力クロックを使用する上記の周辺回路も停止します。プリスケーラには、デバッグモード時のプリスケーラの動作を指定するPRUND(D1/PSC\_CTLレジスタ)が用意されています。PRUNDを1に設定すると、プリスケーラはデバッグモード時も動作します。これにより、上記の周辺回路も動作可能となります。PRUNDが0(デフォルト)の場合、S1C17コアがデバッグモードになった時点でプリスケーラおよび上記の周辺回路は停止します。

\* **PRUND**: Prescaler Run/Stop Setting (in Debug Mode) Bit in the Prescaler Control (PSC\_CTL) Register (D1/0x4020)

### OSC1クロックで動作する周辺回路

- 計時タイマ
- ウオッヂドッヂタイマ
- ストップウォッヂタイマ

MISCレジスタに、デバッグモード時のOSC1周辺回路(上記)の動作を指定するO1DBG(D0/MISC\_OSC1レジスタ)が用意されています。O1DBGを1に設定すると、OSC1周辺回路はデバッグモード時も動作します。O1DBGが0(デフォルト)の場合、S1C17コアがデバッグモードになった時点でOSC1周辺回路は停止します。

\* **O1DBG**: OSC1 Peripheral Control (in Debug Mode) Bit in the OSC1 Peripheral Control (MISC\_OSC1) Register (D0/0x5322)

O1DBGを1に設定しても、8ビットOSC1タイマはデバッグモード時に停止しません。

## 22.3 制御レジスタ詳細

表22.3.1 デバッグ用レジスター一覧

| アドレス      | レジスタ名     | 機能                                                      |
|-----------|-----------|---------------------------------------------------------|
| 0x5322    | MISC_OSC1 | OSC1 Peripheral Control Register<br>デバッグ時のOSC1動作周辺機能の設定 |
| 0xfffff90 | DBRAM     | Debug RAM Base Register<br>デバッグRAMベースアドレスの表示            |

以下、デバッグ用のレジスタを個々に説明します。

注: レジスタにデータを書き込む際、“Reserved”のビットには必ず0を書き込み、1は書き込まないでください。

**0x5322: OSC1 Peripheral Control Register (MISC\_OSC1)**

| Register name                                | Address         | Bit  | Name | Function | Setting |   | Init. | R/W | Remarks            |
|----------------------------------------------|-----------------|------|------|----------|---------|---|-------|-----|--------------------|
| OSC1 Peripheral Control Register (MISC_OSC1) | 0x5322 (8 bits) | D7-1 | —    | reserved | —       | — | —     | —   | 0 when being read. |

**D[7:1] Reserved****D0 O1DBG: OSC1 Peripheral Control in Debug Mode Bit**

デバッグモード時のOSC1周辺回路の動作を設定します。

1(R/W): 動作

0(R/W): 停止(デフォルト)

OSC1周辺回路はOSC1クロックで動作する以下の周辺回路のことです。

- 計時タイマ
- ウォッチドッグタイマ
- ストップウォッチタイマ

O1DBGを1に設定しても、8ビットOSC1タイマはデバッグモード時に停止しません。

## 0xffff90: Debug RAM Base Register (DBRAM)

| Register name                         | Address               | Bit         | Name                | Function | Setting  | Init. | R/W | Remarks |
|---------------------------------------|-----------------------|-------------|---------------------|----------|----------|-------|-----|---------|
| Debug RAM<br>Base Register<br>(DBRAM) | 0xffff90<br>(32 bits) | D31–24<br>– | Unused (fixed at 0) | 0x0      | 0x0<br>R | 0x7c0 | R   |         |

**D[31:24]** 未使用(0固定)

**D[23:0] DBRAM[23:0]: Debug RAM Base Address Bits**

デバッグ用ワークエリア(64バイト)の先頭アドレスが格納されるリードオンリレジスタです。

このページはブランクです。

# 23 基本外部結線図

単一電源使用時 ( $LV_{DD} = HV_{DD}$ )



外付部品推奨値

| シンボル   | 名称            | 推奨値                           |
|--------|---------------|-------------------------------|
| X'tal1 | 水晶振動子         | 32.768kHz (MC-146, エプソントヨコム製) |
| Cg1    | ゲートキャパシタ      | 7pF                           |
| Cb1    | ドレインキャパシタ     | 7pF                           |
| Rf1    | 帰還抵抗          | 10MΩ                          |
| Rd1    | ドレイン抵抗        | 0Ω                            |
| X'tal3 | 水晶振動子         | 8MHz (CA-301, エプソントヨコム製)      |
| CE     | セラミック振動子      | 0.2~8MHz                      |
| Cg3    | ゲートキャパシタ      | 27pF                          |
| Cd3    | ドレインキャパシタ     | 27pF                          |
| Rf3    | 帰還抵抗          | 1MΩ                           |
| Rd3    | ドレイン抵抗        | 0Ω                            |
| Cp     | 電源間キャパシタ      | 3.3μF                         |
| Cres   | #RESET端子キャパシタ | 0.47μF                        |

注: ここに記載されている値は一例であり、特に動作を保証するものではありません。

複数電源使用時 ( $LV_{DD} \neq HV_{DD}$ )

## 外付部品推奨値

| シンボル   | 名称            | 推奨値                           |
|--------|---------------|-------------------------------|
| X'tal1 | 水晶振動子         | 32.768kHz (MC-146, エプソントヨコム製) |
| CG1    | ゲートキャパシタ      | 7pF                           |
| CD1    | ドレインキャパシタ     | 7pF                           |
| Rf1    | 帰還抵抗          | 10MΩ                          |
| Rd1    | ドレイン抵抗        | 0Ω                            |
| X'tal3 | 水晶振動子         | 8MHz (CA-301, エプソントヨコム製)      |
| CE     | セラミック振動子      | 0.2~8MHz                      |
| Cg3    | ゲートキャパシタ      | 27pF                          |
| Cd3    | ドレインキャパシタ     | 27pF                          |
| Rf3    | 帰還抵抗          | 1MΩ                           |
| Rd3    | ドレイン抵抗        | 0Ω                            |
| Cp     | 電源間キャパシタ      | 3.3μF                         |
| Cres   | #RESET端子キャパシタ | 0.47μF                        |

注: ここに記載されている値は一例であり、特に動作を保証するものではありません。

# 24 電気的特性

## 24.1 絶対最大定格

(V<sub>SS</sub> = 0V)

| 項目   | 記号               | 条件                                  | 定格値                                               | 単位 |
|------|------------------|-------------------------------------|---------------------------------------------------|----|
| 電源電圧 | HV <sub>DD</sub> | HV <sub>DD</sub> ≥ LV <sub>DD</sub> | V <sub>SS</sub> - 0.3 ~ 4.0                       | V  |
|      | LV <sub>DD</sub> |                                     | V <sub>SS</sub> - 0.3 ~ 3.0                       | V  |
| 入力電圧 | HVi              |                                     | V <sub>SS</sub> - 0.3 ~ HV <sub>DD</sub> + 0.5 *1 | V  |
|      | LVi              |                                     | V <sub>SS</sub> - 0.3 ~ LV <sub>DD</sub> + 0.5 *1 | V  |
| 出力電圧 | HVo              |                                     | V <sub>SS</sub> - 0.3 ~ HV <sub>DD</sub> + 0.5 *1 | V  |
|      | LVo              |                                     | V <sub>SS</sub> - 0.3 ~ LV <sub>DD</sub> + 0.5 *1 | V  |
| 出力電流 | I <sub>OUT</sub> | 1端子                                 | ±30 (±50 *2)                                      | mA |
| 保存温度 | T <sub>STG</sub> |                                     | -65 ~ 150                                         | °C |

\*1 Nチャネルオープンドレインの場合(入力バッファについては-0.3~4.0Vまで可)

\*2 出力電流24mAのバッファに適用

## 24.2 推奨動作条件

(V<sub>SS</sub> = 0V)

| 項目    | 記号                | 条件         | Min. | Typ.   | Max.                      | 単位  |
|-------|-------------------|------------|------|--------|---------------------------|-----|
| 電源電圧  | HV <sub>DD</sub>  |            | 1.65 |        | 3.6                       | V   |
|       | LV <sub>DD</sub>  |            | 1.65 |        | 2.7                       | V   |
| 入力電圧  | HVi               |            | -0.3 |        | HV <sub>DD</sub> + 0.3    | V   |
|       | LVi               |            | -0.3 |        | LV <sub>DD</sub> + 0.3 *1 | V   |
| 動作周波数 | f <sub>OSC3</sub> | 水晶/セラミック発振 | 0.2  |        | 8.2                       | MHz |
|       | f <sub>OSC1</sub> | 水晶発振       |      | 32.768 | 100                       | kHz |
| 周囲温度  | T <sub>a</sub>    |            | -40  |        | 85 *2                     | °C  |

\*1 Nチャネルオープンドレインの場合(入力バッファについては3.9Vまで可)

Fail-safeセルについては、Hレベル出力時にその値を超える電圧を外部から印加しないでください。

\*2 T<sub>j</sub> = -40~125°Cを想定した推奨周囲温度です。

## 24.3 DC特性

特記なき場合: HV<sub>DD</sub> = 1.65~3.6V, V<sub>SS</sub> = 0V, Ta = -40~85°C

| 項目            | 記号              | 条件                                                          | Min.                | Typ. | Max.                | 単位 |
|---------------|-----------------|-------------------------------------------------------------|---------------------|------|---------------------|----|
| 高レベルシミュット入力電圧 | V <sub>T+</sub> | P <sub>xx</sub> , #RESET, #TEST1~5                          | 0.5HV <sub>DD</sub> |      | 0.9HV <sub>DD</sub> | V  |
| 低レベルシミュット入力電圧 | V <sub>T-</sub> | P <sub>xx</sub> , #RESET, #TEST1~5                          | 0.1HV <sub>DD</sub> |      | 0.4HV <sub>DD</sub> | V  |
| ヒステリシス電圧      | ΔV <sub>I</sub> | P <sub>xx</sub> , #RESET, #TEST1~5 (HV <sub>DD</sub> = 3V)  | 0.3                 |      |                     | V  |
| 高レベル出力電流      | I <sub>OH</sub> | P <sub>xx</sub> , V <sub>OH</sub> = HV <sub>DD</sub> - 0.2V |                     |      | -0.9                | mA |
| 低レベル出力電流      | I <sub>OL</sub> | P <sub>xx</sub> , V <sub>OL</sub> = 0.2V                    | 0.9                 |      |                     | mA |
| 入力リーク電流       | I <sub>LI</sub> | P <sub>xx</sub> , #RESET, #TEST1~5                          | -1                  |      | 1                   | μA |
| 出力リーク電流       | I <sub>LO</sub> | P <sub>xx</sub> , #RESET, #TEST1~5                          | -1                  |      | 1                   | μA |
| 入力プルアップ抵抗     | R <sub>PU</sub> | P <sub>xx</sub> , #RESET, #TEST1~5                          | 30                  |      | 480                 | kΩ |



特記なき場合: LV<sub>DD</sub> = 1.65~2.7V, V<sub>SS</sub> = 0V, Ta = -40~85°C

| 項目        | 記号              | 条件                | Min.                | Typ. | Max.                | 単位 |
|-----------|-----------------|-------------------|---------------------|------|---------------------|----|
| 高レベル入力電圧  | V <sub>IH</sub> | TEST0, OSC1, OSC3 | 0.9LV <sub>DD</sub> |      |                     | V  |
| 低レベル入力電圧  | V <sub>IL</sub> | TEST0, OSC1, OSC3 |                     |      | 0.1LV <sub>DD</sub> | V  |
| 入力プルダウン抵抗 | R <sub>PD</sub> | TEST0             | 20                  |      | 240                 | kΩ |

## 24.4 消費電流

特記なき場合: HV<sub>DD</sub> = 1.8V, LV<sub>DD</sub> = 1.8V, V<sub>SS</sub> = 0V, Ta = 25°C, PCKEN = 3

| 項目                    | 記号                 | 条件                                                    | Min. | Typ. | Max. | 単位 |
|-----------------------|--------------------|-------------------------------------------------------|------|------|------|----|
| SLEEP時消費電流            | I <sub>SLP</sub>   | OSC1 = OFF, OSC3 = OFF                                |      | 0.5  |      | μA |
| HALT時消費電流             | I <sub>HALT1</sub> | OSC1 = 32kHz, OSC3 = OFF, PCKEN = 0                   |      | 2.5  |      | μA |
|                       | I <sub>HALT2</sub> | OSC1 = 32kHz, OSC3 = 8MHz(セラミック)                      |      | 580  |      | μA |
| 実行時消費電流 <sup>*1</sup> | I <sub>EXE1</sub>  | OSC1 = 32kHz, OSC3 = OFF,<br>FLCYC = 4(1サイクル)         |      | 10   |      | μA |
|                       | I <sub>EXE2</sub>  | OSC1 = 32kHz, OSC3 = 8MHz(セラミック),<br>FLCYC = 4(1サイクル) |      | 1800 |      | μA |
|                       | I <sub>EXE3</sub>  | OSC1 = 32kHz, OSC3 = 2MHz(セラミック),<br>FLCYC = 4(1サイクル) |      | 500  |      | μA |

\*1 実行時の消費電流は、“ALU命令 60.5%、分岐命令 17%、メモリリード 12%、メモリライト 10.5%”の試験プログラムをROMからフェッチしながら連続動作させた場合の値です。

## 24.5 AC特性

### 24.5.1 SPI AC特性



#### マスタモード時

特記なき場合: HV<sub>DD</sub> = 1.65~3.6V, LV<sub>DD</sub> = 1.65~2.7V, V<sub>SS</sub> = 0V, Ta = -40~85°C

| 項目           | 記号    | Min. | Typ. | Max. | 単位 |
|--------------|-------|------|------|------|----|
| SPICLKサイクル時間 | tSPCK | 500  |      |      | ns |
| SDIセットアップ時間  | tSDS  | 70   |      |      | ns |
| SDIホールド時間    | tSDH  | 10   |      |      | ns |
| SDO出力遅延時間    | tSDO  |      |      | 20   | ns |

#### スレーブモード時

特記なき場合: HV<sub>DD</sub> = 1.65~3.6V, LV<sub>DD</sub> = 1.65~2.7V, V<sub>SS</sub> = 0V, Ta = -40~85°C

| 項目           | 記号    | Min. | Typ. | Max. | 単位 |
|--------------|-------|------|------|------|----|
| SPICLKサイクル時間 | tSPCK | 500  |      |      | ns |
| SDIセットアップ時間  | tSDS  | 10   |      |      | ns |
| SDIホールド時間    | tSDH  | 10   |      |      | ns |
| SDO出力遅延時間    | tSDO  |      |      | 80   | ns |

### 24.5.2 I<sup>2</sup>C AC特性



特記なき場合: HV<sub>DD</sub> = 1.65~3.6V, LV<sub>DD</sub> = 1.65~2.7V, V<sub>SS</sub> = 0V, Ta = -40~85°C

| 項目                | 記号   | Min.               | Typ. | Max. | 単位 |
|-------------------|------|--------------------|------|------|----|
| SCLサイクル時間         | tSCL | 2500               |      |      | ns |
| スタートコンディションホールド時間 | tSTH | 1/f <sub>sys</sub> |      |      | ns |
| データ出力遅延時間         | tsDD | 1/f <sub>sys</sub> |      |      | ns |
| ストップコンディションホールド時間 | tSPH | 1/f <sub>sys</sub> |      |      | ns |

\* f<sub>sys</sub>: システム動作クロック周波数

### 24.5.3 外部クロック入力AC特性



特記なき場合:  $HV_{DD} = 1.65\sim3.6V$ ,  $LV_{DD} = 1.65\sim2.7V$ ,  $V_{SS} = 0V$ ,  $T_a = -40\sim85^{\circ}C$

| 項目                  | 記号         | Min.        | Typ. | Max.   | 単位  |
|---------------------|------------|-------------|------|--------|-----|
| EXCLx入力High/パルス幅    | $t_{ECH}$  | $2/f_{SYS}$ |      |        | s   |
| EXCLx入力Low/パルス幅     | $t_{ECL}$  | $2/f_{SYS}$ |      |        | s   |
| UART転送レート           | $R_u$      |             |      | 460800 | bps |
| UART転送レート (IrDAモード) | $R_{UiDA}$ |             |      | 115200 | bps |

\*  $f_{SYS}$ : システム動作クロック周波数

### 24.5.4 システムAC特性



特記なき場合:  $HV_{DD} = 1.65\sim3.6V$ ,  $LV_{DD} = 1.65\sim2.7V$ ,  $V_{SS} = 0V$ ,  $T_a = -40\sim85^{\circ}C$

| 項目           | 記号       | Min. | Typ. | Max. | 単位      |
|--------------|----------|------|------|------|---------|
| リセットLow/パルス幅 | $t_{SR}$ | 100  |      |      | $\mu s$ |

## 24.6 発振特性

発振特性は使用部品(振動子、 $R_f$ 、 $R_d$ 、 $C_G$ 、 $C_D$ )や基板パターンなどの諸条件により変化します。以下の特性は参考値としてご使用ください。特にセラミック発振子または水晶振動子を使用する場合、外付けの抵抗( $R_f$ 、 $R_d$ )や容量( $C_G$ 、 $C_D$ )の値は、実際の基板上に各部品を実装した状態で十分評価を行って適切なものを選んでください。

### OSC1発振回路(水晶発振)

特記なき場合:  $HV_{DD} = 1.65\sim 3.6V$ ,  $LV_{DD} = 1.65\sim 2.7V$ ,  $V_{SS} = 0V$ ,  $T_a = 25^{\circ}C$

| 項目     | 記号        | 条件 | Min. | Typ. | Max. | 単位 |
|--------|-----------|----|------|------|------|----|
| 発振開始時間 | $t_{sta}$ |    |      |      | 3    | s  |

### OSC3発振回路(水晶/セラミック発振)

注: OSC3水晶発振回路には、“基本波を使用した水晶振動子”を使用してください。

特記なき場合:  $HV_{DD} = 1.65\sim 3.6V$ ,  $LV_{DD} = 1.65\sim 2.7V$ ,  $V_{SS} = 0V$ ,  $T_a = 25^{\circ}C$

| 項目     | 記号        | 条件 | Min. | Typ. | Max. | 単位 |
|--------|-----------|----|------|------|------|----|
| 発振開始時間 | $t_{sta}$ |    |      |      | 25   | ms |

# 25 パッケージ

## WCSP-48pin

### Top View



### Bottom View



| Symbol         | Dimension in Millimeters |       |       |
|----------------|--------------------------|-------|-------|
|                | Min                      | Nom   | Max   |
| D              | 3.024                    | 3.124 | 3.224 |
| E              | 3.024                    | 3.124 | 3.224 |
| A              | —                        | —     | 0.78  |
| A <sub>1</sub> | —                        | 0.23  | —     |
| A <sub>2</sub> | —                        | 0.49  | —     |
| θ <sub>1</sub> | —                        | 0.40  | —     |
| θ <sub>2</sub> | —                        | 0.40  | —     |
| b              | 0.23                     | 0.26  | 0.29  |
| X              | —                        | —     | 0.08  |
| y              | —                        | —     | 0.05  |
| Z <sub>D</sub> | —                        | 0.362 | —     |
| Z <sub>E</sub> | —                        | 0.362 | —     |

このページはブランクです。

# Appendix A I/Oレジスター一覧

| 周辺回路                               | アドレス   | レジスタ名    | 機能                                                                               |
|------------------------------------|--------|----------|----------------------------------------------------------------------------------|
| プリスケーラ<br>(8ビットデバイス)               | 0x4020 | PSC_CTL  | Prescaler Control Register<br>プリスケーラのスタート/ストップ制御                                 |
|                                    | -      | -        | Reserved                                                                         |
| UART(IrDA付き)<br>(8ビットデバイス)         | 0x4100 | UART_ST  | UART Status Register<br>転送、バッファ、エラーステータスの表示                                      |
|                                    | 0x4101 | UART_TXD | UART Transmit Data Register<br>送信データ                                             |
|                                    | 0x4102 | UART_RXD | UART Receive Data Register<br>受信データ                                              |
|                                    | 0x4103 | UART_MOD | UART Mode Register<br>転送データ形式の設定                                                 |
|                                    | 0x4104 | UART_CTL | UART Control Register<br>データ転送の制御                                                |
|                                    | 0x4105 | UART_EXP | UART Expansion Register<br>IrDAモードの設定                                            |
|                                    | -      | -        | Reserved                                                                         |
| 8ビットタイマ<br>(Fモード付き)<br>(16ビットデバイス) | 0x4200 | T8F_CLK  | 8-bit Timer Input Clock Select Register<br>プリスケーラ出力クロックの選択                       |
|                                    | 0x4202 | T8F_TR   | 8-bit Timer Reload Data Register<br>リロードデータの設定                                   |
|                                    | 0x4204 | T8F_TC   | 8-bit Timer Counter Data Register<br>カウンタデータ                                     |
|                                    | 0x4206 | T8F_CTL  | 8-bit Timer Control Register<br>タイマモードの設定とタイマのRUN/STOP                           |
|                                    | -      | -        | Reserved                                                                         |
| 16ビットタイマ<br>Ch.0<br>(16ビットデバイス)    | 0x4220 | T16_CLK0 | 16-bit Timer Ch.0 Input Clock Select Register<br>プリスケーラ出力クロックの選択                 |
|                                    | 0x4222 | T16_TR0  | 16-bit Timer Ch.0 Reload Data Register<br>リロードデータの設定                             |
|                                    | 0x4224 | T16_TC0  | 16-bit Timer Ch.0 Counter Data Register<br>カウンタデータ                               |
|                                    | 0x4226 | T16_CTL0 | 16-bit Timer Ch.0 Control Register<br>タイマモードの設定とタイマのRUN/STOP                     |
|                                    | -      | -        | Reserved                                                                         |
| 16ビットタイマ<br>Ch.1<br>(16ビットデバイス)    | 0x4240 | T16_CLK1 | 16-bit Timer Ch.1 Input Clock Select Register<br>プリスケーラ出力クロックの選択                 |
|                                    | 0x4242 | T16_TR1  | 16-bit Timer Ch.1 Reload Data Register<br>リロードデータの設定                             |
|                                    | 0x4244 | T16_TC1  | 16-bit Timer Ch.1 Counter Data Register<br>カウンタデータ                               |
|                                    | 0x4246 | T16_CTL1 | 16-bit Timer Ch.1 Control Register<br>タイマモードの設定とタイマのRUN/STOP                     |
|                                    | -      | -        | Reserved                                                                         |
| 16ビットタイマ<br>Ch.2<br>(16ビットデバイス)    | 0x4260 | T16_CLK2 | 16-bit Timer Ch.2 Input Clock Select Register<br>プリスケーラ出力クロックの選択                 |
|                                    | 0x4262 | T16_TR2  | 16-bit Timer Ch.2 Reload Data Register<br>リロードデータの設定                             |
|                                    | 0x4264 | T16_TC2  | 16-bit Timer Ch.2 Counter Data Register<br>カウンタデータ                               |
|                                    | 0x4266 | T16_CTL2 | 16-bit Timer Ch.2 Control Register<br>タイマモードの設定とタイマのRUN/STOP                     |
|                                    | -      | -        | Reserved                                                                         |
| 割り込み<br>コントローラ<br>(16ビットデバイス)      | 0x4300 | ITC_IFLG | Interrupt Flag Register<br>割り込み発生状態の表示/リセット                                      |
|                                    | 0x4302 | ITC_EN   | Interrupt Enable Register<br>各マスク可能割り込みの許可/禁止                                    |
|                                    | 0x4304 | ITC_CTL  | ITC Control Register<br>ITC動作の許可/禁止                                              |
|                                    | 0x4306 | ITC_ELV0 | External Interrupt Level Setup Register 0<br>P0、P1ポート割り込みレベルとトリガモードの設定           |
|                                    | 0x4308 | ITC_ELV1 | External Interrupt Level Setup Register 1<br>ストップウォッチタイマ、計時タイマ割り込みレベルとトリガモードの設定  |
|                                    | 0x430a | ITC_ELV2 | External Interrupt Level Setup Register 2<br>8ビットOSC1タイマ割り込みレベルとトリガモードの設定        |
|                                    | 0x430c | ITC_ELV3 | External Interrupt Level Setup Register 3<br>PWM&キャプチャタイマ割り込みレベルとトリガモードの設定       |
|                                    | 0x430e | ITC_ILV0 | Internal Interrupt Level Setup Register 0<br>8ビットタイマ、16ビットタイマCh.0割り込みレベルの設定      |
|                                    | 0x4310 | ITC_ILV1 | Internal Interrupt Level Setup Register 1<br>16ビットタイマCh.1、16ビットタイマCh.2割り込みレベルの設定 |
|                                    | 0x4312 | ITC_ILV2 | Internal Interrupt Level Setup Register 2<br>UART、リモートコントローラ割り込みレベルの設定           |
|                                    | 0x4314 | ITC_ILV3 | Internal Interrupt Level Setup Register 3<br>SPI、I2C割り込みレベルの設定                   |
|                                    | -      | -        | Reserved                                                                         |
| SPI<br>(16ビットデバイス)                 | 0x4320 | SPI_ST   | SPI Status Register<br>転送、バッファステータスの表示                                           |
|                                    | 0x4322 | SPI_TXD  | SPI Transmit Data Register<br>送信データ                                              |
|                                    | 0x4324 | SPI_RXD  | SPI Receive Data Register<br>受信データ                                               |
|                                    | 0x4326 | SPI_CTL  | SPI Control Register<br>SPIモードとデータ転送許可の設定                                        |
|                                    | -      | -        | Reserved                                                                         |
| I2C<br>(16ビットデバイス)                 | 0x4340 | I2C_EN   | I2C Enable Register<br>I2Cモジュールイネーブル                                             |
|                                    | 0x4342 | I2C_CTL  | I2C Control Register<br>I2Cの制御と転送状態の表示                                           |
|                                    | 0x4344 | I2C_DAT  | I2C Data Register<br>送受信データ                                                      |
|                                    | 0x4346 | I2C_ICTL | I2C Interrupt Control Register<br>I2C割り込みの制御                                     |
|                                    | -      | -        | Reserved                                                                         |

| 周辺回路                          | アドレス   | レジスタ名       | 機能                                             |
|-------------------------------|--------|-------------|------------------------------------------------|
| 計時タイマ<br>(8ビットデバイス)           | 0x5000 | CT_CTL      | Clock Timer Control Register                   |
|                               | 0x5001 | CT_CNT      | Clock Timer Counter Register                   |
|                               | 0x5002 | CT_IMSK     | Clock Timer Interrupt Mask Register            |
|                               | 0x5003 | CT_IFLG     | Clock Timer Interrupt Flag Register            |
|                               | -      | -           | Reserved                                       |
|                               | -      | -           | Reserved                                       |
| ストップ<br>ウォッチタイマ<br>(8ビットデバイス) | 0x5020 | SWT_CTL     | Stopwatch Timer Control Register               |
|                               | 0x5021 | SWT_BCNT    | Stopwatch Timer BCD Counter Register           |
|                               | 0x5022 | SWT_IMSK    | Stopwatch Timer Interrupt Mask Register        |
|                               | 0x5023 | SWT_IFLG    | Stopwatch Timer Interrupt Flag Register        |
|                               | -      | -           | Reserved                                       |
| ウォッチドッグ<br>タイマ<br>(8ビットデバイス)  | 0x5040 | WDT_CTL     | Watchdog Timer Control Register                |
|                               | 0x5041 | WDT_ST      | Watchdog Timer Status Register                 |
|                               | -      | -           | Reserved                                       |
| 発振回路<br>(8ビットデバイス)            | 0x5060 | OSC_SRC     | Clock Source Select Register                   |
|                               | 0x5061 | OSC_CTL     | Oscillation Control Register                   |
|                               | 0x5062 | OSC_NFEN    | Noise Filter Enable Register                   |
|                               | 0x5063 | -           | Reserved                                       |
|                               | 0x5064 | OSC_FOUT    | FOUT Control Register                          |
|                               | 0x5065 | OSC_T8OSC1  | T8OSC1 Clock Control Register                  |
| クロック<br>ジェネレータ<br>(8ビットデバイス)  | 0x5080 | CLG_PCLK    | PCLK Control Register                          |
|                               | 0x5081 | CLG_CCLK    | CCLK Control Register                          |
|                               | -      | -           | Reserved                                       |
| 8ビットOSC1<br>タイマ<br>(8ビットデバイス) | 0x50c0 | T8OSC1_CTL  | 8-bit OSC1 Timer Control Register              |
|                               | 0x50c1 | T8OSC1_CNT  | 8-bit OSC1 Timer Counter Data Register         |
|                               | 0x50c2 | T8OSC1_CMP  | 8-bit OSC1 Timer Compare Data Register         |
|                               | 0x50c3 | T8OSC1_IMSK | 8-bit OSC1 Timer Interrupt Mask Register       |
|                               | 0x50c4 | T8OSC1_IFLG | 8-bit OSC1 Timer Interrupt Flag Register       |
|                               | -      | -           | Reserved                                       |
| Pポート&<br>ポートMUX<br>(8ビットデバイス) | 0x5200 | P0_IN       | P0 Port Input Data Register                    |
|                               | 0x5201 | P0_OUT      | P0 Port Output Data Register                   |
|                               | 0x5202 | P0_IO       | P0 Port I/O Direction Control Register         |
|                               | 0x5203 | P0_PU       | P0 Port Pull-up Control Register               |
|                               | 0x5204 | -           | Reserved                                       |
|                               | 0x5205 | P0_IMSK     | P0 Port Interrupt Mask Register                |
|                               | 0x5206 | P0_EDGE     | P0 Port Interrupt Edge Select Register         |
|                               | 0x5207 | P0_IFLG     | P0 Port Interrupt Flag Register                |
|                               | 0x5208 | P0_CHAT     | P0 Port Chattering Filter Control Register     |
|                               | 0x5209 | P0_KRST     | P0 Port Key-Entry Reset Configuration Register |
|                               | -      | -           | Reserved                                       |
|                               | 0x5210 | P1_IN       | P1 Port Input Data Register                    |
|                               | 0x5211 | P1_OUT      | P1 Port Output Data Register                   |
|                               | 0x5212 | P1_IO       | P1 Port I/O Direction Control Register         |
|                               | 0x5213 | P1_PU       | P1 Port Pull-up Control Register               |
|                               | 0x5214 | -           | Reserved                                       |
|                               | 0x5215 | P1_IMSK     | P1 Port Interrupt Mask Register                |
|                               | 0x5216 | P1_EDGE     | P1 Port Interrupt Edge Select Register         |
|                               | 0x5217 | P1_IFLG     | P1 Port Interrupt Flag Register                |
|                               | -      | -           | Reserved                                       |
|                               | 0x5220 | P2_IN       | P2 Port Input Data Register                    |
|                               | 0x5221 | P2_OUT      | P2 Port Output Data Register                   |
|                               | 0x5222 | P2_IO       | P2 Port I/O Direction Control Register         |
|                               | 0x5223 | P2_PU       | P2 Port Pull-up Control Register               |
|                               | -      | -           | Reserved                                       |
|                               | 0x5230 | P3_IN       | P3 Port Input Data Register                    |
|                               | 0x5231 | P3_OUT      | P3 Port Output Data Register                   |
|                               | 0x5232 | P3_IO       | P3 Port I/O Direction Control Register         |
|                               | 0x5233 | P3_PU       | P3 Port Pull-up Control Register               |
|                               | -      | -           | Reserved                                       |
|                               | 0x52a0 | P0_PMUX     | P0 Port Function Select Register               |
|                               | 0x52a1 | P1_PMUX     | P1 Port Function Select Register               |
|                               | 0x52a2 | P2_PMUX     | P2 Port Function Select Register               |
|                               | 0x52a3 | P3_PMUX     | P3 Port Function Select Register               |
|                               | -      | -           | Reserved                                       |

| 周辺回路                            | アドレス   | レジスタ名     | 機能                                                       |
|---------------------------------|--------|-----------|----------------------------------------------------------|
| PWM&<br>キャプチャタイマ<br>(16ビットデバイス) | 0x5300 | T16E_CA   | PWM Timer Compare Data A Register<br>コンペアデータAの設定         |
|                                 | 0x5302 | T16E_CB   | PWM Timer Compare Data B Register<br>コンペアデータBの設定         |
|                                 | 0x5304 | T16E_TC   | PWM Timer Counter Data Register<br>カウンタデータ               |
|                                 | 0x5306 | T16E_CTL  | PWM Timer Control Register<br>タイマモードの設定とタイマのRUN/STOP     |
|                                 | 0x5308 | T16E_CLK  | PWM Timer Input Clock Select Register<br>プリスケーラ出力クロックの選択 |
|                                 | 0x530a | T16E_IMSK | PWM Timer Interrupt Mask Register<br>割り込みマスクの設定          |
|                                 | 0x530c | T16E_IFLG | PWM Timer Interrupt Flag Register<br>割り込み発生状態の表示/リセット    |
|                                 | -      | -         | Reserved                                                 |
| MISCレジスタ<br>(8ビットデバイス)          | 0x5320 | MISC_FL   | ROM Control Register<br>ROMアクセス条件設定                      |
|                                 | 0x5321 | -         | Reserved                                                 |
|                                 | 0x5322 | MISC_OSC1 | OSC1 Peripheral Control Register<br>デバッグ時のOSC1動作周辺機能の設定  |
|                                 | -      | -         | Reserved                                                 |
| リモート<br>コントローラ<br>(8ビットデバイス)    | 0x5340 | REMC_CFG  | REMC Configuration Register<br>送受信の選択と許可                 |
|                                 | 0x5341 | REMC_PSC  | REMC Prescaler Clock Select Register<br>プリスケーラ出力クロックの選択  |
|                                 | 0x5342 | REMC_CARH | REMC H Carrier Length Setup Register<br>キャリアのH区間長設定      |
|                                 | 0x5343 | REMC_CARL | REMC L Carrier Length Setup Register<br>キャリアのL区間長設定      |
|                                 | 0x5344 | REMC_ST   | REMC Status Register<br>送受信ビット                           |
|                                 | 0x5345 | REMC_LCNT | REMC Length Counter Register<br>送受信データ長の設定               |
|                                 | 0x5346 | REMC_IMSK | REMC Interrupt Mask Register<br>割り込みマスクの設定               |
|                                 | 0x5347 | REMC_IFLG | REMC Interrupt Flag Register<br>割り込み発生状態の表示/リセット         |
|                                 | -      | -         | Reserved                                                 |

注: 表中の“Reserved”で示されたアドレス、および表に記載のない周辺回路エリアの未使用領域は、アプリケーションプログラムからアクセスしないでください。

## 0x4020

## Prescaler

| Register name                        | Address         | Bit  | Name  | Function                         | Setting |     | Init. | R/W  | Remarks            |
|--------------------------------------|-----------------|------|-------|----------------------------------|---------|-----|-------|------|--------------------|
| Prescaler Control Register (PSC_CTL) | 0x4020 (8 bits) | D7-2 | —     | reserved                         | —       |     | —     | —    | 0 when being read. |
|                                      |                 | D1   | PRUND | Prescaler run/stop in debug mode | 1       | Run | 0     | Stop | 0 R/W              |
|                                      |                 | D0   | PRUN  | Prescaler run/stop control       | 1       | Run | 0     | Stop | 0 R/W              |

## 0x4100–0x4105

## UART (with IrDA)

| Register name                          | Address         | Bit  | Name       | Function                                                               | Setting            |             |     | Init.     | R/W | Remarks                                     |
|----------------------------------------|-----------------|------|------------|------------------------------------------------------------------------|--------------------|-------------|-----|-----------|-----|---------------------------------------------|
| UART Status Register (UART_ST)         | 0x4100 (8 bits) | D7   | –          | reserved                                                               | –                  | –           | –   | –         | –   | 0 when being read.                          |
|                                        |                 | D6   | FER        | Framing error flag                                                     | 1                  | Error       | 0   | Normal    | 0   | R/W                                         |
|                                        |                 | D5   | PER        | Parity error flag                                                      | 1                  | Error       | 0   | Normal    | 0   | R/W                                         |
|                                        |                 | D4   | OER        | Overrun error flag                                                     | 1                  | Error       | 0   | Normal    | 0   | R/W                                         |
|                                        |                 | D3   | RD2B       | Second byte receive flag                                               | 1                  | Ready       | 0   | Empty     | 0   | R                                           |
|                                        |                 | D2   | TRBS       | Transmit busy flag                                                     | 1                  | Busy        | 0   | Idle      | 0   | R                                           |
|                                        |                 | D1   | RDRY       | Receive data ready flag                                                | 1                  | Ready       | 0   | Empty     | 0   | R                                           |
|                                        |                 | D0   | TDBE       | Transmit data buffer empty flag                                        | 1                  | Empty       | 0   | Not empty | 1   | R                                           |
| UART Transmit Data Register (UART_TXD) | 0x4101 (8 bits) | D7–0 | TXD[7:0]   | Transmit data<br>TXD7(6) = MSB<br>TXD0 = LSB                           | 0x0 to 0xff (0x7f) |             |     | 0x0       | R/W |                                             |
| UART Receive Data Register (UART_RXD)  | 0x4102 (8 bits) | D7–0 | RXD[7:0]   | Receive data in the receive data buffer<br>RXD7(6) = MSB<br>RXD0 = LSB | 0x0 to 0xff (0x7f) |             |     | 0x0       | R   | Older data in the buffer is read out first. |
| UART Mode Register (UART_MOD)          | 0x4103 (8 bits) | D7–5 | –          | reserved                                                               | –                  | –           | –   | –         | –   | 0 when being read.                          |
|                                        |                 | D4   | CHLN       | Character length                                                       | 1                  | 8 bits      | 0   | 7 bits    | 0   | R/W                                         |
|                                        |                 | D3   | PREN       | Parity enable                                                          | 1                  | With parity | 0   | No parity | 0   | R/W                                         |
|                                        |                 | D2   | PMD        | Parity mode select                                                     | 1                  | Odd         | 0   | Even      | 0   | R/W                                         |
|                                        |                 | D1   | STPB       | Stop bit select                                                        | 1                  | 2 bits      | 0   | 1 bit     | 0   | R/W                                         |
|                                        |                 | D0   | SSCK       | Input clock select                                                     | 1                  | External    | 0   | Internal  | 0   | R/W                                         |
| UART Control Register (UART_CTL)       | 0x4104 (8 bits) | D7   | –          | reserved                                                               | –                  | –           | –   | –         | –   | 0 when being read.                          |
|                                        |                 | D6   | REIEN      | Receive error int. enable                                              | 1                  | Enable      | 0   | Disable   | 0   | R/W                                         |
|                                        |                 | D5   | RIEN       | Receive buffer full int. enable                                        | 1                  | Enable      | 0   | Disable   | 0   | R/W                                         |
|                                        |                 | D4   | TIEN       | Transmit buffer empty int. enable                                      | 1                  | Enable      | 0   | Disable   | 0   | R/W                                         |
|                                        |                 | D3–2 | –          | reserved                                                               | –                  | –           | –   | –         | –   | 0 when being read.                          |
|                                        |                 | D1   | RBF1       | Receive buffer full int. condition                                     | 1                  | 2 bytes     | 0   | 1 byte    | 0   | R/W                                         |
| UART Expansion Register (UART_EXP)     | 0x4105 (8 bits) | D0   | RXEN       | UART enable                                                            | 1                  | Enable      | 0   | Disable   | 0   | R/W                                         |
|                                        |                 | D7   | –          | reserved                                                               | –                  | –           | –   | –         | –   | 0 when being read.                          |
|                                        |                 | D6–4 | IRCLK[2:0] | IrDA receive detection clock select                                    | IRCLK[2:0]         | Clock       | 0x0 | R/W       |     |                                             |
|                                        |                 |      |            |                                                                        | 0x7                | PCLK-1/128  |     |           |     |                                             |
|                                        |                 |      |            |                                                                        | 0x6                | PCLK-1/64   |     |           |     |                                             |
|                                        |                 |      |            |                                                                        | 0x5                | PCLK-1/32   |     |           |     |                                             |
|                                        |                 |      |            |                                                                        | 0x4                | PCLK-1/16   |     |           |     |                                             |
|                                        |                 |      |            |                                                                        | 0x3                | PCLK-1/8    |     |           |     |                                             |
|                                        |                 |      |            |                                                                        | 0x2                | PCLK-1/4    |     |           |     |                                             |
|                                        |                 |      |            |                                                                        | 0x1                | PCLK-1/2    |     |           |     |                                             |
|                                        |                 |      |            |                                                                        | 0x0                | PCLK-1/1    |     |           |     |                                             |
|                                        |                 | D3–1 | –          | reserved                                                               | –                  | –           | –   | –         | –   | 0 when being read.                          |
|                                        |                 | D0   | IRMD       | IrDA mode select                                                       | 1                  | On          | 0   | Off       | 0   | R/W                                         |

## 0x4200–0x4206

## 8-bit Timer (with Fine Mode)

| Register name                                              | Address             | Bit    | Name      | Function                                             | Setting     |          | Init. | R/W     | Remarks                                                                               |  |
|------------------------------------------------------------|---------------------|--------|-----------|------------------------------------------------------|-------------|----------|-------|---------|---------------------------------------------------------------------------------------|--|
| 8-bit Timer<br>Input Clock<br>Select Register<br>(T8F_CLK) | 0x4200<br>(16 bits) | D15–4  | —         | reserved                                             | DF[3:0]     | Clock    | —     | —       | 0 when being read.                                                                    |  |
|                                                            |                     | D3–0   | DF[3:0]   | Timer input clock select<br>(Prescaler output clock) |             |          | 0x0   | R/W     |                                                                                       |  |
|                                                            |                     |        |           |                                                      |             |          | 0xf   |         | reserved                                                                              |  |
|                                                            |                     |        |           |                                                      |             |          | 0xe   |         | PCLK-1/16384                                                                          |  |
|                                                            |                     |        |           |                                                      |             |          | 0xd   |         | PCLK-1/8192                                                                           |  |
|                                                            |                     |        |           |                                                      |             |          | 0xc   |         | PCLK-1/4096                                                                           |  |
|                                                            |                     |        |           |                                                      |             |          | 0xb   |         | PCLK-1/2048                                                                           |  |
|                                                            |                     |        |           |                                                      |             |          | 0xa   |         | PCLK-1/1024                                                                           |  |
|                                                            |                     |        |           |                                                      |             |          | 0x9   |         | PCLK-1/512                                                                            |  |
|                                                            |                     |        |           |                                                      |             |          | 0x8   |         | PCLK-1/256                                                                            |  |
|                                                            |                     |        |           |                                                      |             |          | 0x7   |         | PCLK-1/128                                                                            |  |
|                                                            |                     |        |           |                                                      |             |          | 0x6   |         | PCLK-1/64                                                                             |  |
|                                                            |                     |        |           |                                                      |             |          | 0x5   |         | PCLK-1/32                                                                             |  |
|                                                            |                     |        |           |                                                      |             |          | 0x4   |         | PCLK-1/16                                                                             |  |
|                                                            |                     |        |           |                                                      |             |          | 0x3   |         | PCLK-1/8                                                                              |  |
|                                                            |                     |        |           |                                                      |             |          | 0x2   |         | PCLK-1/4                                                                              |  |
|                                                            |                     |        |           |                                                      |             |          | 0x1   |         | PCLK-1/2                                                                              |  |
|                                                            |                     |        |           |                                                      |             |          | 0x0   |         | PCLK-1/1                                                                              |  |
| 8-bit Timer<br>Reload Data<br>Register<br>(T8F_TR)         | 0x4202              | D15–8  | —         | reserved                                             | —           |          | —     | —       | 0 when being read.                                                                    |  |
|                                                            | (16 bits)           | D7–0   | TR[7:0]   | 8-bit timer reload data<br>TR7 = MSB<br>TR0 = LSB    | 0x0 to 0xff |          | 0x0   | R/W     |                                                                                       |  |
| 8-bit Timer<br>Counter Data<br>Register<br>(T8F_TC)        |                     | D15–8  | —         | reserved                                             | —           |          | —     | —       | 0 when being read.                                                                    |  |
|                                                            | (16 bits)           | D7–0   | TC[7:0]   | 8-bit timer counter data<br>TC7 = MSB<br>TC0 = LSB   | 0x0 to 0xff |          | 0x0   | R       |                                                                                       |  |
| 8-bit Timer<br>Control Register<br>(T8F_CTL)               |                     | D15–12 | —         | reserved                                             | —           |          | —     | —       | 0 when being read.                                                                    |  |
|                                                            | (16 bits)           | D11–8  | TFMD[3:0] | Fine mode setup                                      | 0x0 to 0xf  |          | 0x0   | R/W     | Set a number of<br>times to insert delay<br>into a 16-underflow<br>0 when being read. |  |
|                                                            |                     | D7–5   | —         | reserved                                             | —           |          | —     | —       |                                                                                       |  |
|                                                            |                     | D4     | TRMD      | Count mode select                                    | 1           | One shot | 0     | Repeat  | 0                                                                                     |  |
|                                                            |                     | D3–2   | —         | reserved                                             | —           |          | —     | —       | 0 when being read.                                                                    |  |
|                                                            |                     | D1     | PRESER    | Timer reset                                          | 1           | Reset    | 0     | Ignored | 0                                                                                     |  |
|                                                            |                     | D0     | PRUN      | Timer run/stop control                               | 1           | Run      | 0     | Stop    | 0                                                                                     |  |

## 0x4220–0x4246

## 16-bit Timer

| Register name                                            | Address          | Bit    | Name      | Function                                             | Setting       |                | Init. | R/W     | Remarks            |     |
|----------------------------------------------------------|------------------|--------|-----------|------------------------------------------------------|---------------|----------------|-------|---------|--------------------|-----|
| 16-bit Timer Ch.0 Input Clock Select Register (T16_CLK0) | 0x4220 (16 bits) | D15–4  | –         | reserved                                             | –             | –              | –     | –       | 0 when being read. |     |
|                                                          |                  | D3–0   | DF[3:0]   | Timer input clock select (Prescaler output clock)    | DF[3:0]       | Clock          | 0x0   | R/W     |                    |     |
|                                                          |                  |        |           |                                                      | 0xf           | reserved       |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0xe           | PCLK-1/16384   |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0xd           | PCLK-1/8192    |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0xc           | PCLK-1/4096    |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0xb           | PCLK-1/2048    |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0xa           | PCLK-1/1024    |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x9           | PCLK-1/512     |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x8           | PCLK-1/256     |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x7           | PCLK-1/128     |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x6           | PCLK-1/64      |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x5           | PCLK-1/32      |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x4           | PCLK-1/16      |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x3           | PCLK-1/8       |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x2           | PCLK-1/4       |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x1           | PCLK-1/2       |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x0           | PCLK-1/1       |       |         |                    |     |
| 16-bit Timer Ch.0 Reload Data Register (T16_TR0)         | 0x4222 (16 bits) | D15–0  | TR[15:0]  | 16-bit timer reload data<br>TR15 = MSB<br>TR0 = LSB  | 0x0 to 0xffff |                | 0x0   | R/W     |                    |     |
| 16-bit Timer Ch.0 Counter Data Register (T16_TC0)        | 0x4224 (16 bits) | D15–0  | TC[15:0]  | 16-bit timer counter data<br>TC15 = MSB<br>TC0 = LSB | 0x0 to 0xffff |                | 0x0   | R       |                    |     |
| 16-bit Timer Ch.0 Control Register (T16_CTL0)            | 0x4226 (16 bits) | D15–11 | –         | reserved                                             | –             | –              | –     | –       | 0 when being read. |     |
|                                                          |                  | D10    | CKACTV    | External clock active level select                   | 1             | High           | 0     | Low     | 1                  | R/W |
|                                                          |                  | D9–8   | CKSL[1:0] | Input clock and pulse width measurement mode select  | CKSL[1:0]     | Mode           | 0x0   | R/W     |                    |     |
|                                                          |                  |        |           |                                                      | 0x3           | reserved       |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x2           | Pulse width    |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x1           | External clock |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x0           | Internal clock |       |         |                    |     |
|                                                          |                  | D7–5   | –         | reserved                                             | –             | –              | –     | –       | 0 when being read. |     |
|                                                          |                  | D4     | TRMD      | Count mode select                                    | 1             | One shot       | 0     | Repeat  | 0                  | R/W |
|                                                          |                  | D3–2   | –         | reserved                                             | –             | –              | –     | –       | 0 when being read. |     |
|                                                          |                  | D1     | PRESER    | Timer reset                                          | 1             | Reset          | 0     | Ignored | 0                  | W   |
|                                                          |                  | D0     | PRUN      | Timer run/stop control                               | 1             | Run            | 0     | Stop    | 0                  | R/W |
| 16-bit Timer Ch.1 Input Clock Select Register (T16_CLK1) | 0x4240 (16 bits) | D15–4  | –         | reserved                                             | –             | –              | –     | –       | 0 when being read. |     |
|                                                          |                  | D3–0   | DF[3:0]   | Timer input clock select (Prescaler output clock)    | DF[3:0]       | Clock          | 0x0   | R/W     |                    |     |
|                                                          |                  |        |           |                                                      | 0xf           | reserved       |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0xe           | PCLK-1/16384   |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0xd           | PCLK-1/8192    |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0xc           | PCLK-1/4096    |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0xb           | PCLK-1/2048    |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0xa           | PCLK-1/1024    |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x9           | PCLK-1/512     |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x8           | PCLK-1/256     |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x7           | PCLK-1/128     |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x6           | PCLK-1/64      |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x5           | PCLK-1/32      |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x4           | PCLK-1/16      |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x3           | PCLK-1/8       |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x2           | PCLK-1/4       |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x1           | PCLK-1/2       |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x0           | PCLK-1/1       |       |         |                    |     |
| 16-bit Timer Ch.1 Reload Data Register (T16_TR1)         | 0x4242 (16 bits) | D15–0  | TR[15:0]  | 16-bit timer reload data<br>TR15 = MSB<br>TR0 = LSB  | 0x0 to 0xffff |                | 0x0   | R/W     |                    |     |
| 16-bit Timer Ch.1 Counter Data Register (T16_TC1)        | 0x4244 (16 bits) | D15–0  | TC[15:0]  | 16-bit timer counter data<br>TC15 = MSB<br>TC0 = LSB | 0x0 to 0xffff |                | 0x0   | R       |                    |     |
| 16-bit Timer Ch.1 Control Register (T16_CTL1)            | 0x4246 (16 bits) | D15–11 | –         | reserved                                             | –             | –              | –     | –       | 0 when being read. |     |
|                                                          |                  | D10    | CKACTV    | External clock active level select                   | 1             | High           | 0     | Low     | 1                  | R/W |
|                                                          |                  | D9–8   | CKSL[1:0] | Input clock and pulse width measurement mode select  | CKSL[1:0]     | Mode           | 0x0   | R/W     |                    |     |
|                                                          |                  |        |           |                                                      | 0x3           | reserved       |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x2           | Pulse width    |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x1           | External clock |       |         |                    |     |
|                                                          |                  |        |           |                                                      | 0x0           | Internal clock |       |         |                    |     |
|                                                          |                  | D7–5   | –         | reserved                                             | –             | –              | –     | –       | 0 when being read. |     |
|                                                          |                  | D4     | TRMD      | Count mode select                                    | 1             | One shot       | 0     | Repeat  | 0                  | R/W |
|                                                          |                  | D3–2   | –         | reserved                                             | –             | –              | –     | –       | 0 when being read. |     |
|                                                          |                  | D1     | PRESER    | Timer reset                                          | 1             | Reset          | 0     | Ignored | 0                  | W   |
|                                                          |                  | D0     | PRUN      | Timer run/stop control                               | 1             | Run            | 0     | Stop    | 0                  | R/W |

## 0x4260–0x4266

## 16-bit Timer

| Register name                                            | Address          | Bit    | Name      | Function                                             | Setting       |                | Init. | R/W     | Remarks            |
|----------------------------------------------------------|------------------|--------|-----------|------------------------------------------------------|---------------|----------------|-------|---------|--------------------|
| 16-bit Timer Ch.2 Input Clock Select Register (T16_CLK2) | 0x4260 (16 bits) | D15–4  | –         | reserved                                             | –             |                | –     | –       | 0 when being read. |
|                                                          |                  | D3–0   | DF[3:0]   | Timer input clock select (Prescaler output clock)    | DF[3:0]       | Clock          | 0x0   | R/W     |                    |
|                                                          |                  |        |           |                                                      | 0xf           | reserved       |       |         |                    |
|                                                          |                  |        |           |                                                      | 0xe           | PCLK-1/16384   |       |         |                    |
|                                                          |                  |        |           |                                                      | 0xd           | PCLK-1/8192    |       |         |                    |
|                                                          |                  |        |           |                                                      | 0xc           | PCLK-1/4096    |       |         |                    |
|                                                          |                  |        |           |                                                      | 0xb           | PCLK-1/2048    |       |         |                    |
|                                                          |                  |        |           |                                                      | 0xa           | PCLK-1/1024    |       |         |                    |
|                                                          |                  |        |           |                                                      | 0x9           | PCLK-1/512     |       |         |                    |
|                                                          |                  |        |           |                                                      | 0x8           | PCLK-1/256     |       |         |                    |
|                                                          |                  |        |           |                                                      | 0x7           | PCLK-1/128     |       |         |                    |
|                                                          |                  |        |           |                                                      | 0x6           | PCLK-1/64      |       |         |                    |
|                                                          |                  |        |           |                                                      | 0x5           | PCLK-1/32      |       |         |                    |
|                                                          |                  |        |           |                                                      | 0x4           | PCLK-1/16      |       |         |                    |
|                                                          |                  |        |           |                                                      | 0x3           | PCLK-1/8       |       |         |                    |
|                                                          |                  |        |           |                                                      | 0x2           | PCLK-1/4       |       |         |                    |
|                                                          |                  |        |           |                                                      | 0x1           | PCLK-1/2       |       |         |                    |
|                                                          |                  |        |           |                                                      | 0x0           | PCLK-1/1       |       |         |                    |
| 16-bit Timer Ch.2 Reload Data Register (T16_TR2)         | 0x4262 (16 bits) | D15–0  | TR[15:0]  | 16-bit timer reload data<br>TR15 = MSB<br>TR0 = LSB  | 0x0 to 0xffff |                | 0x0   | R/W     |                    |
| 16-bit Timer Ch.2 Counter Data Register (T16_TC2)        | 0x4264 (16 bits) | D15–0  | TC[15:0]  | 16-bit timer counter data<br>TC15 = MSB<br>TC0 = LSB | 0x0 to 0xffff |                | 0x0   | R       |                    |
| 16-bit Timer Ch.2 Control Register (T16_CTL2)            | 0x4266 (16 bits) | D15–11 | –         | reserved                                             | –             |                | –     | –       | 0 when being read. |
|                                                          |                  | D10    | CKACTV    | External clock active level select                   | 1             | High           | 0     | Low     | 1                  |
|                                                          |                  | D9–8   | CKSL[1:0] | Input clock and pulse width measurement mode select  | CKSL[1:0]     | Mode           | 0x0   | R/W     |                    |
|                                                          |                  |        |           |                                                      | 0x3           | reserved       |       |         |                    |
|                                                          |                  |        |           |                                                      | 0x2           | Pulse width    |       |         |                    |
|                                                          |                  |        |           |                                                      | 0x1           | External clock |       |         |                    |
|                                                          |                  |        |           |                                                      | 0x0           | Internal clock |       |         |                    |
|                                                          |                  | D7–5   | –         | reserved                                             | –             |                | –     | –       | 0 when being read. |
|                                                          |                  | D4     | TRMD      | Count mode select                                    | 1             | One shot       | 0     | Repeat  | 0                  |
|                                                          |                  | D3–2   | –         | reserved                                             | –             |                | –     | –       | 0 when being read. |
|                                                          |                  | D1     | PRESER    | Timer reset                                          | 1             | Reset          | 0     | Ignored | 0                  |
|                                                          |                  | D0     | PRUN      | Timer run/stop control                               | 1             | Run            | 0     | Stop    | 0                  |
|                                                          |                  |        |           |                                                      |               |                |       | R/W     |                    |

0x4300–0x4310

Interrupt Controller

| Register name                                        | Address          | Bit    | Name       | Function                           | Setting                       |                                   | Init. | R/W     | Remarks                                   |
|------------------------------------------------------|------------------|--------|------------|------------------------------------|-------------------------------|-----------------------------------|-------|---------|-------------------------------------------|
| Interrupt Flag Register (ITC_IFLG)                   | 0x4300 (16 bits) | D15    | IIFT7      | I2C interrupt flag                 | 1 Cause of interrupt occurred | 0 Cause of interrupt not occurred | 0     | R/W     | Reset by writing 1.                       |
|                                                      |                  | D14    | IIFT6      | SPI interrupt flag                 |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D13    | IIFT5      | Remote controller interrupt flag   |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D12    | IIFT4      | UART interrupt flag                |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D11    | IIFT3      | 16-bit timer Ch.2 interrupt flag   |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D10    | IIFT2      | 16-bit timer Ch.1 interrupt flag   |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D9     | IIFT1      | 16-bit timer Ch.0 interrupt flag   |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D8     | IIFT0      | 8-bit timer interrupt flag         |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D7     | EIFT7      | PWM&capture timer interrupt flag   | 1 Cause of interrupt occurred | 0 Cause of interrupt not occurred | 0     | R/W     | Reset by writing 1 in pulse trigger mode. |
|                                                      |                  | D6     | EIFT6      | reserved                           |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D5     | EIFT5      | reserved                           |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D4     | EIFT4      | 8-bit OSC1 timer interrupt flag    |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D3     | EIFT3      | Clock timer interrupt flag         |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D2     | EIFT2      | Stopwatch timer interrupt flag     |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D1     | EIFT1      | P1 port interrupt flag             |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D0     | EIFT0      | P0 port interrupt flag             |                               |                                   | 0     | R/W     |                                           |
| Interrupt Enable Register (ITC_EN)                   | 0x4302 (16 bits) | D15    | IEN7       | I2C interrupt enable               | 1 Enable                      | 0 Disable                         | 0     | R/W     |                                           |
|                                                      |                  | D14    | IEN6       | SPI interrupt enable               |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D13    | IEN5       | Remote controller interrupt enable |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D12    | IEN4       | UART interrupt enable              |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D11    | IEN3       | 16-bit timer Ch.2 interrupt enable |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D10    | IEN2       | 16-bit timer Ch.1 interrupt enable |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D9     | IEN1       | 16-bit timer Ch.0 interrupt enable |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D8     | IEN0       | 8-bit timer interrupt enable       |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D7     | EIEN7      | PWM&capture timer interrupt enable |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D6     | EIEN6      | reserved                           |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D5     | EIEN5      | reserved                           |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D4     | EIEN4      | 8-bit OSC1 timer interrupt enable  |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D3     | EIEN3      | Clock timer interrupt enable       |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D2     | EIEN2      | Stopwatch timer interrupt enable   |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D1     | EIEN1      | P1 port interrupt enable           |                               |                                   | 0     | R/W     |                                           |
|                                                      |                  | D0     | EIEN0      | P0 port interrupt enable           |                               |                                   | 0     | R/W     |                                           |
| ITC Control Register (ITC_CTL)                       | 0x4304 (16 bits) | D15–1  | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D0     | ITEN       | ITC enable                         | 1                             | Enable                            | 0     | Disable | 0 R/W                                     |
| External Interrupt Level Setup Register 0 (ITC_ELV0) | 0x4306 (16 bits) | D15–13 | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D12    | EITG1      | P1 interrupt trigger mode          | 1                             | Level                             | 0     | Pulse   | 0 R/W                                     |
|                                                      |                  | D11    | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D10–8  | EILV1[2:0] | P1 interrupt level                 | 0 to 7                        |                                   | 0x0   | R/W     |                                           |
|                                                      |                  | D7–5   | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D4     | EITG0      | P0 interrupt trigger mode          | 1                             | Level                             | 0     | Pulse   | 0 R/W                                     |
|                                                      |                  | D3     | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
| External Interrupt Level Setup Register 1 (ITC_ELV1) | 0x4308 (16 bits) | D2–0   | EILV0[2:0] | P0 interrupt level                 | 0 to 7                        |                                   | 0x0   | R/W     |                                           |
|                                                      |                  | D15–13 | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D12    | EITG3      | CT interrupt trigger mode          | 1                             | Level                             | 0     | Pulse   | 0 R/W                                     |
|                                                      |                  | D11    | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D10–8  | EILV3[2:0] | CT interrupt level                 | 0 to 7                        |                                   | 0x0   | R/W     |                                           |
|                                                      |                  | D7–5   | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D4     | EITG2      | SWT interrupt trigger mode         | 1                             | Level                             | 0     | Pulse   | 0 R/W                                     |
| External Interrupt Level Setup Register 2 (ITC_ELV2) | 0x430a (16 bits) | D3     | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D2–0   | EILV2[2:0] | SWT interrupt level                | 0 to 7                        |                                   | 0x0   | R/W     |                                           |
|                                                      |                  | D15–5  | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D4     | EITG4      | T8OSC1 interrupt trigger mode      | 1                             | Level                             | 0     | Pulse   | 0 R/W                                     |
| External Interrupt Level Setup Register 3 (ITC_ELV3) | 0x430c (16 bits) | D3     | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D2–0   | EILV4[2:0] | T8OSC1 interrupt level             | 0 to 7                        |                                   | 0x0   | R/W     |                                           |
|                                                      |                  | D15–13 | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D12    | EITG7      | T16E interrupt trigger mode        | 1                             | Level                             | 0     | Pulse   | 0 R/W                                     |
| Internal Interrupt Level Setup Register 0 (ITC_ILV0) | 0x430e (16 bits) | D11    | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D10–8  | EILV7[2:0] | T16E interrupt level               | 0 to 7                        |                                   | 0x0   | R/W     |                                           |
|                                                      |                  | D7–5   | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D2–0   | EILV0[2:0] | T8 interrupt level                 | 0 to 7                        |                                   | 0x0   | R/W     |                                           |
| Internal Interrupt Level Setup Register 1 (ITC_ILV1) | 0x4310 (16 bits) | D15–11 | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D10–8  | EILV3[2:0] | T16 Ch.0 interrupt level           | 0 to 7                        |                                   | 0x0   | R/W     |                                           |
|                                                      |                  | D7–3   | –          | reserved                           | –                             |                                   | –     | –       | 0 when being read.                        |
|                                                      |                  | D2–0   | EILV2[2:0] | T16 Ch.1 interrupt level           | 0 to 7                        |                                   | 0x0   | R/W     |                                           |

## 0x4312–0x4314

## Interrupt Controller

| Register name    | Address             | Bit    | Name       | Function                         | Setting | Init. | R/W | Remarks            |
|------------------|---------------------|--------|------------|----------------------------------|---------|-------|-----|--------------------|
| Internal         | 0x4312<br>(16 bits) | D15–11 | —          | reserved                         | —       | —     | —   | 0 when being read. |
| Interrupt Level  |                     | D10–8  | IILV5[2:0] | REMC interrupt level             | 0 to 7  | 0x0   | R/W |                    |
| Setup Register 2 |                     | D7–3   | —          | reserved                         | —       | —     | —   | 0 when being read. |
| (ITC_ILV2)       |                     | D2–0   | IILV4[2:0] | UART interrupt level             | 0 to 7  | 0x0   | R/W |                    |
| Internal         | 0x4314<br>(16 bits) | D15–11 | —          | reserved                         | —       | —     | —   | 0 when being read. |
| Interrupt Level  |                     | D10–8  | IILV7[2:0] | I <sup>2</sup> C interrupt level | 0 to 7  | 0x0   | R/W |                    |
| Setup Register 3 |                     | D7–3   | —          | reserved                         | —       | —     | —   | 0 when being read. |
| (ITC_ILV3)       |                     | D2–0   | IILV6[2:0] | SPI interrupt level              | 0 to 7  | 0x0   | R/W |                    |

## 0x4320–0x4326

## SPI

| Register name                        | Address          | Bit   | Name              | Function                                                  | Setting     |          | Init. | R/W       | Remarks            |
|--------------------------------------|------------------|-------|-------------------|-----------------------------------------------------------|-------------|----------|-------|-----------|--------------------|
| SPI Status Register (SPI_ST)         | 0x4320 (16 bits) | D15–3 | –                 | reserved                                                  | –           |          | –     | –         | 0 when being read. |
|                                      |                  | D2    | <b>SPBSY</b>      | Transfer busy flag (master)<br>ss signal low flag (slave) | 1           | Busy     | 0     | Idle      | 0 R                |
|                                      |                  | D1    | <b>SPRBF</b>      | Receive data buffer full flag                             | 1           | Full     | 0     | Not full  | 0 R                |
|                                      |                  | D0    | <b>SPTBE</b>      | Transmit data buffer empty flag                           | 1           | Empty    | 0     | Not empty | 1 R                |
| SPI Transmit Data Register (SPI_TXD) | 0x4322 (16 bits) | D15–8 | –                 | reserved                                                  | –           |          | –     | –         | 0 when being read. |
|                                      |                  | D7–0  | <b>SPTDB[7:0]</b> | SPI transmit data buffer<br>SPTDB7 = MSB<br>SPTDB0 = LSB  | 0x0 to 0xff |          | 0x0   | R/W       |                    |
| SPI Receive Data Register (SPI_RXD)  | 0x4324 (16 bits) | D15–8 | –                 | reserved                                                  | –           |          | –     | –         | 0 when being read. |
|                                      |                  | D7–0  | <b>SPRDB[7:0]</b> | SPI receive data buffer<br>SPRDB7 = MSB<br>SPRDB0 = LSB   | 0x0 to 0xff |          | 0x0   | R         |                    |
| SPI Control Register (SPI_CTL)       | 0x4326 (16 bits) | D15–6 | –                 | reserved                                                  | –           |          | –     | –         | 0 when being read. |
|                                      |                  | D5    | <b>SPRIE</b>      | Receive data buffer full int. enable                      | 1           | Enable   | 0     | Disable   | 0 R/W              |
|                                      |                  | D4    | <b>SPTIE</b>      | Transmit data buffer empty int. enable                    | 1           | Enable   | 0     | Disable   | 0 R/W              |
|                                      |                  | D3    | <b>CPHA</b>       | Clock phase select                                        | 1           | Data out | 0     | Data in   | 0 R/W              |
|                                      |                  | D2    | <b>CPOL</b>       | Clock polarity select                                     | 1           | Active L | 0     | Active H  | 0 R/W              |
|                                      |                  | D1    | <b>MSSL</b>       | Master/slave mode select                                  | 1           | Master   | 0     | Slave     | 0 R/W              |
|                                      |                  | D0    | <b>SPEN</b>       | SPI enable                                                | 1           | Enable   | 0     | Disable   | 0 R/W              |

## 0x4340–0x4346

I<sup>2</sup>C

| Register name                                          | Address          | Bit    | Name      | Function                                            | Setting     |          | Init. | R/W     | Remarks            |
|--------------------------------------------------------|------------------|--------|-----------|-----------------------------------------------------|-------------|----------|-------|---------|--------------------|
| I <sup>2</sup> C Enable Register (I2C_EN)              | 0x4340 (16 bits) | D15–1  | –         | reserved                                            | –           |          | –     | –       | 0 when being read. |
|                                                        |                  | D0     | I2CEN     | I <sup>2</sup> C enable                             | 1           | Enable   | 0     | Disable | 0 R/W              |
| I <sup>2</sup> C Control Register (I2C_CTL)            | 0x4342 (16 bits) | D15–10 | –         | reserved                                            | –           |          | –     | –       | 0 when being read. |
|                                                        |                  | D9     | RBUSY     | Receive busy flag                                   | 1           | Busy     | 0     | Idle    | 0 R                |
|                                                        |                  | D8     | TBUSY     | Transmit busy flag                                  | 1           | Busy     | 0     | Idle    | 0 R                |
|                                                        |                  | D7–5   | –         | reserved                                            | –           |          | –     | –       | 0 when being read. |
|                                                        |                  | D4     | NSERM     | Noise remove on/off                                 | 1           | On       | 0     | Off     | 0 R/W              |
|                                                        |                  | D3–2   | –         | reserved                                            | –           |          | –     | –       | 0 when being read. |
|                                                        |                  | D1     | STP       | Stop control                                        | 1           | Stop     | 0     | Ignored | 0 R/W              |
| I <sup>2</sup> C Data Register (I2C_DAT)               | 0x4344 (16 bits) | D0     | STRT      | Start control                                       | 1           | Start    | 0     | Ignored | 0 R/W              |
|                                                        |                  | D15–12 | –         | reserved                                            | –           |          | –     | –       | 0 when being read. |
|                                                        |                  | D11    | RBRDY     | Receive buffer ready                                | 1           | Ready    | 0     | Empty   | 0 R                |
|                                                        |                  | D10    | RXE       | Receive execution                                   | 1           | Receive  | 0     | Ignored | 0 R/W              |
|                                                        |                  | D9     | TXE       | Transmit execution                                  | 1           | Transmit | 0     | Ignored | 0 R/W              |
|                                                        |                  | D8     | RTACK     | Receive/transmit ACK                                | 1           | Error    | 0     | ACK     | 0 R/W              |
| I <sup>2</sup> C Interrupt Control Register (I2C_ICTL) | 0x4346 (16 bits) | D7–0   | RTDT[7:0] | Receive/transmit data<br>RTDT7 = MSB<br>RTDT0 = LSB | 0x0 to 0xff |          | 0x0   | R/W     |                    |
|                                                        |                  | D15–2  | –         | reserved                                            | –           |          | –     | –       | 0 when being read. |
|                                                        |                  | D1     | RINTE     | Receive interrupt enable                            | 1           | Enable   | 0     | Disable | 0 R/W              |
|                                                        |                  | D0     | TINTE     | Transmit interrupt enable                           | 1           | Enable   | 0     | Disable | 0 R/W              |

## 0x5000–0x5003

## Clock Timer

| Register name                                 | Address         | Bit  | Name       | Function                     | Setting     |                             | Init. | R/W                             | Remarks                                |
|-----------------------------------------------|-----------------|------|------------|------------------------------|-------------|-----------------------------|-------|---------------------------------|----------------------------------------|
| Clock Timer Control Register (CT_CTL)         | 0x5000 (8 bits) | D7–5 | –          | reserved                     | –           | –                           | –     | –                               | 0 when being read.                     |
|                                               |                 | D4   | CTRST      | Clock timer reset            | 1           | Reset                       | 0     | Ignored                         | 0 R/W                                  |
|                                               |                 | D3–1 | –          | reserved                     | –           | –                           | –     | –                               |                                        |
|                                               |                 | D0   | CTRUN      | Clock timer run/stop control | 1           | Run                         | 0     | Stop                            | 0 R/W                                  |
| Clock Timer Counter Register (CT_CNT)         | 0x5001          | D7–0 | CTCNT[7:0] | Clock timer counter value    | 0x0 to 0xff |                             | 0     | R                               |                                        |
| Clock Timer Interrupt Mask Register (CT_IMSK) | 0x5002 (8 bits) | D7–4 | –          | reserved                     | –           | –                           | –     | –                               | 0 when being read.                     |
|                                               |                 | D3   | CTIE32     | 32 Hz interrupt enable       | 1           | Enable                      | 0     | Disable                         | 0 R/W                                  |
|                                               |                 | D2   | CTIE8      | 8 Hz interrupt enable        | 1           | Enable                      | 0     | Disable                         | 0 R/W                                  |
|                                               |                 | D1   | CTIE2      | 2 Hz interrupt enable        | 1           | Enable                      | 0     | Disable                         | 0 R/W                                  |
|                                               |                 | D0   | CTIE1      | 1 Hz interrupt enable        | 1           | Enable                      | 0     | Disable                         | 0 R/W                                  |
| Clock Timer Interrupt Flag Register (CT_IFLG) | 0x5003 (8 bits) | D7–4 | –          | reserved                     | –           | –                           | –     | –                               | 0 when being read. Reset by writing 1. |
|                                               |                 | D3   | CTIF32     | 32 Hz interrupt flag         | 1           | Cause of interrupt occurred | 0     | Cause of interrupt not occurred | 0 R/W                                  |
|                                               |                 | D2   | CTIF8      | 8 Hz interrupt flag          | 1           |                             | 0     |                                 | 0 R/W                                  |
|                                               |                 | D1   | CTIF2      | 2 Hz interrupt flag          | 1           |                             | 0     |                                 | 0 R/W                                  |
|                                               |                 | D0   | CTIF1      | 1 Hz interrupt flag          | 1           |                             | 0     |                                 | 0 R/W                                  |

## 0x5020–0x5023

## Stopwatch Timer

| Register name                                               | Address            | Bit  | Name        | Function                         | Setting                               |                                               | Init. | R/W | Remarks                                   |
|-------------------------------------------------------------|--------------------|------|-------------|----------------------------------|---------------------------------------|-----------------------------------------------|-------|-----|-------------------------------------------|
| Stopwatch<br>Timer Control<br>Register<br>(SWT_CTL)         | 0x5020<br>(8 bits) | D7–5 | –           | reserved                         | –                                     | –                                             | –     | –   | 0 when being read.                        |
|                                                             |                    | D4   | SWTRST      | Stopwatch timer reset            | 1   Reset                             | 0   Ignored                                   | 0     | W   |                                           |
|                                                             |                    | D3–1 | –           | reserved                         | –                                     | –                                             | –     | –   |                                           |
|                                                             |                    | D0   | SWTRUN      | Stopwatch timer run/stop control | 1   Run                               | 0   Stop                                      | 0     | R/W |                                           |
| Stopwatch<br>Timer BCD<br>Counter Register<br>(SWT_BCNT)    | 0x5021<br>(8 bits) | D7–4 | BCD10[3:0]  | 1/10 sec. BCD counter value      | 0 to 9                                |                                               | 0     | R   |                                           |
|                                                             |                    | D3–0 | BCD100[3:0] | 1/100 sec. BCD counter value     | 0 to 9                                |                                               | 0     | R   |                                           |
| Stopwatch<br>Timer Interrupt<br>Mask Register<br>(SWT_IMSK) | 0x5022<br>(8 bits) | D7–3 | –           | reserved                         | –                                     |                                               | –     | –   | 0 when being read.                        |
|                                                             |                    | D2   | SIE1        | 1 Hz interrupt enable            | 1   Enable                            | 0   Disable                                   | 0     | R/W |                                           |
|                                                             |                    | D1   | SIE10       | 10 Hz interrupt enable           | 1   Enable                            | 0   Disable                                   | 0     | R/W |                                           |
|                                                             |                    | D0   | SIE100      | 100 Hz interrupt enable          | 1   Enable                            | 0   Disable                                   | 0     | R/W |                                           |
| Stopwatch<br>Timer Interrupt<br>Flag Register<br>(SWT_IFLG) | 0x5023<br>(8 bits) | D7–3 | –           | reserved                         | –                                     |                                               | –     | –   | 0 when being read.<br>Reset by writing 1. |
|                                                             |                    | D2   | SIF1        | 1 Hz interrupt flag              | 1   Cause of<br>interrupt<br>occurred | 0   Cause of in-<br>interrupt not<br>occurred | 0     | R/W |                                           |
|                                                             |                    | D1   | SIF10       | 10 Hz interrupt flag             |                                       |                                               | 0     | R/W |                                           |
|                                                             |                    | D0   | SIF100      | 100 Hz interrupt flag            |                                       |                                               | 0     | R/W |                                           |

## 0x5040–0x5041

## Watchdog Timer

| Register name                                      | Address            | Bit  | Name        | Function                        | Setting            |                   | Init. | R/W               | Remarks            |
|----------------------------------------------------|--------------------|------|-------------|---------------------------------|--------------------|-------------------|-------|-------------------|--------------------|
| Watchdog<br>Timer Control<br>Register<br>(WDT_CTL) | 0x5040<br>(8 bits) | D7–5 | –           | reserved                        | –                  | –                 | –     | –                 | 0 when being read. |
|                                                    |                    | D4   | WDTRST      | Watchdog timer reset            | 1                  | Reset             | 0     | Ignored           | 0<br>W             |
|                                                    |                    | D3–0 | WDTRUN[3:0] | Watchdog timer run/stop control | Other than<br>1010 | 1010<br>Stop      | 1010  | R/W               |                    |
| Watchdog<br>Timer Status<br>Register<br>(WDT_ST)   | 0x5041<br>(8 bits) | D7–2 | –           | reserved                        | –                  | –                 | –     | –                 | 0 when being read. |
|                                                    |                    | D1   | WDTMD       | NMI/Reset mode select           | 1                  | Reset             | 0     | NMI               | 0<br>R/W           |
|                                                    |                    | D0   | WDTST       | NMI status                      | 1                  | NMI oc-<br>curred | 0     | Not oc-<br>curred | 0<br>R             |

## 0x5060–0x5065

## Oscillator

| Register name                              | Address         | Bit  | Name        | Function                           | Setting     |                | Init. | R/W | Remarks            |
|--------------------------------------------|-----------------|------|-------------|------------------------------------|-------------|----------------|-------|-----|--------------------|
| Clock Source Select Register (OSC_SRC)     | 0x5060 (8 bits) | D7–1 | –           | reserved                           | –           |                | –     | –   | 0 when being read. |
|                                            |                 | D0   | CLKSRC      | System clock source select         | 1   OSC1    | 0   OSC3       | 0     | R/W |                    |
| Oscillation Control Register (OSC_CTL)     | 0x5061 (8 bits) | D7–6 | –           | reserved                           | –           |                | –     | –   | 0 when being read. |
|                                            |                 | D5–4 | OSC3WT[1:0] | OSC3 wait cycle select             | OSC3WT[1:0] | Wait cycle     | 0x0   | R/W |                    |
|                                            |                 |      |             |                                    | 0x3         | 128 cycles     |       |     |                    |
|                                            |                 |      |             |                                    | 0x2         | 256 cycles     |       |     |                    |
|                                            |                 |      |             |                                    | 0x1         | 512 cycles     |       |     |                    |
|                                            |                 | D3–2 | –           | reserved                           | –           |                | –     | –   | 0 when being read. |
|                                            |                 | D1   | OSC1EN      | OSC1 enable                        | 1   Enable  | 0   Disable    | 1     | R/W |                    |
|                                            |                 | D0   | OSC3EN      | OSC3 enable                        | 1   Enable  | 0   Disable    | 1     | R/W |                    |
| Noise Filter Enable Register (OSC_NFEN)    | 0x5062 (8 bits) | D7–2 | –           | reserved                           | –           |                | –     | –   | 0 when being read. |
|                                            |                 | D1   | RSTFE       | Reset noise filter enable          | 1   Enable  | 0   Disable    | 1     | R/W |                    |
|                                            |                 | D0   | NMIFE       | NMI noise filter enable            | 1   Enable  | 0   Disable    | 1     | R/W |                    |
| FOUT Control Register (OSC_FOUT)           | 0x5064 (8 bits) | D7–4 | –           | reserved                           | –           |                | –     | –   | 0 when being read. |
|                                            |                 | D3–2 | FOUT3D[1:0] | FOUT3 clock division ratio select  | FOUT3D[1:0] | Division ratio | 0x0   | R/W |                    |
|                                            |                 |      |             |                                    | 0x3         | reserved       |       |     |                    |
|                                            |                 |      |             |                                    | 0x2         | OSC3•1/4       |       |     |                    |
|                                            |                 |      |             |                                    | 0x1         | OSC3•1/2       |       |     |                    |
|                                            |                 |      |             |                                    | 0x0         | OSC3•1/1       |       |     |                    |
|                                            |                 | D1   | FOUT3E      | FOUT3 output enable                | 1   Enable  | 0   Disable    | 0     | R/W |                    |
|                                            |                 | D0   | FOUT1E      | FOUT1 output enable                | 1   Enable  | 0   Disable    | 0     | R/W |                    |
| T8OSC1 Clock Control Register (OSC_T8OSC1) | 0x5065 (8 bits) | D7–4 | –           | reserved                           | –           |                | –     | –   | 0 when being read. |
|                                            |                 | D3–1 | T8O1CK[2:0] | T8OSC1 clock division ratio select | T8O1CK[2:0] | Division ratio | 0x0   | R/W |                    |
|                                            |                 |      |             |                                    | 0x7–0x6     | reserved       |       |     |                    |
|                                            |                 |      |             |                                    | 0x5         | OSC1•1/32      |       |     |                    |
|                                            |                 |      |             |                                    | 0x4         | OSC1•1/16      |       |     |                    |
|                                            |                 |      |             |                                    | 0x3         | OSC1•1/8       |       |     |                    |
|                                            |                 |      |             |                                    | 0x2         | OSC1•1/4       |       |     |                    |
|                                            |                 |      |             |                                    | 0x1         | OSC1•1/2       |       |     |                    |
|                                            |                 |      |             |                                    | 0x0         | OSC1•1/1       |       |     |                    |
|                                            |                 | D0   | T8O1CE      | T8OSC1 clock output enable         | 1   Enable  | 0   Disable    | 0     | R/W |                    |

## 0x5080–0x5081

## Clock Generator

| Register name                    | Address            | Bit  | Name        | Function                     | Setting     |             | Init. | R/W | Remarks            |
|----------------------------------|--------------------|------|-------------|------------------------------|-------------|-------------|-------|-----|--------------------|
| PCLK Control Register (CLG_PCLK) | 0x5080<br>(8 bits) | D7–2 | –           | reserved                     | –           |             | –     | –   | 0 when being read. |
|                                  |                    | D1–0 | PCKEN[1:0]  | PCLK enable                  | PCKEN[1:0]  | PCLK supply | 0x3   | R/W |                    |
| CCLK Control Register (CLG_CCLK) | 0x5081<br>(8 bits) | D7–2 | –           | reserved                     | –           |             | –     | –   | 0 when being read. |
|                                  |                    | D1–0 | CCLKGR[1:0] | CCLK clock gear ratio select | CCLKGR[1:0] | Gear ratio  | 0x0   | R/W |                    |

## 0x50c0–0x50c4

## 8-bit OSC1 Timer

| Register name                                                   | Address            | Bit  | Name        | Function                                             | Setting     |                                   | Init. | R/W                                       | Remarks            |                            |
|-----------------------------------------------------------------|--------------------|------|-------------|------------------------------------------------------|-------------|-----------------------------------|-------|-------------------------------------------|--------------------|----------------------------|
| 8-bit OSC1<br>Timer Control<br>Register<br>(T8OSC1_CTL)         | 0x50c0<br>(8 bits) | D7–5 | —           | reserved                                             | —           | —                                 | —     | —                                         | 0 when being read. |                            |
|                                                                 |                    | D4   | T8ORST      | Timer reset                                          | 1           | Reset                             | 0     | Ignored                                   | 0                  |                            |
|                                                                 |                    | D3–2 | —           | reserved                                             | —           | —                                 | —     | —                                         |                    |                            |
|                                                                 |                    | D1   | T8ORMD      | Count mode select                                    | 1           | One shot                          | 0     | Repeat                                    | 0                  |                            |
|                                                                 |                    | D0   | T8ORUN      | Timer run/stop control                               | 1           | Run                               | 0     | Stop                                      | 0                  |                            |
| 8-bit OSC1<br>Timer Counter<br>Data Register<br>(T8OSC1_CNT)    | 0x50c1             | D7–0 | T8OCNT[7:0] | Timer counter data<br>T8OCNT7 = MSB<br>T8OCNT0 = LSB | 0x0 to 0xff |                                   |       | 0xff                                      | R                  |                            |
| 8-bit OSC1<br>Timer Compare<br>Data Register<br>(T8OSC1_CMP)    | 0x50c2             | D7–0 | T8OCMP[7:0] | Compare data<br>T8OCMP7 = MSB<br>T8OCMP0 = LSB       | 0x0 to 0xff |                                   |       | 0x0                                       | R/W                |                            |
| 8-bit OSC1<br>Timer Interrupt<br>Mask Register<br>(T8OSC1_IMSK) | 0x50c3             | D7–1 | —           | reserved                                             | —           |                                   | —     | —                                         | 0 when being read. |                            |
|                                                                 |                    | D0   | T8OIE       | 8-bit OSC1 timer interrupt enable                    | 1           | Enable                            | 0     | Disable                                   | 0                  |                            |
| 8-bit OSC1<br>Timer Interrupt<br>Flag Register<br>(T8OSC1_IFLG) | 0x50c4             | D7–1 | —           | reserved                                             | —           |                                   | —     | —                                         | 0 when being read. |                            |
|                                                                 |                    | D0   | T8OIF       | 8-bit OSC1 timer interrupt flag                      | 1           | Cause of<br>interrupt<br>occurred | 0     | Cause of in-<br>interrupt not<br>occurred | 0                  | R/W<br>Reset by writing 1. |

## 0x5200–0x5216

## P Port &amp; Port MUX

| Register name                                            | Address            | Bit  | Name        | Function                              | Setting     |                             | Init. | R/W                             | Remarks            |     |
|----------------------------------------------------------|--------------------|------|-------------|---------------------------------------|-------------|-----------------------------|-------|---------------------------------|--------------------|-----|
| P0 Port Input Data Register (P0_IN)                      | 0x5200<br>(8 bits) | D7–0 | P0IN[7:0]   | P0[7:0] port input data               | 1           | 1 (H)                       | 0     | 0 (L)                           | ×                  | R   |
| P0 Port Output Data Register (P0_OUT)                    | 0x5201<br>(8 bits) | D7–0 | P0OUT[7:0]  | P0[7:0] port output data              | 1           | 1 (H)                       | 0     | 0 (L)                           | 0                  | R/W |
| P0 Port I/O Direction Control Register (P0_IO)           | 0x5202<br>(8 bits) | D7–0 | P0IO[7:0]   | P0[7:0] port I/O direction select     | 1           | Output                      | 0     | Input                           | 0                  | R/W |
| P0 Port Pull-up Control Register (P0_PU)                 | 0x5203<br>(8 bits) | D7–0 | P0PU[7:0]   | P0[7:0] port pull-up enable           | 1           | Enable                      | 0     | Disable                         | 1                  | R/W |
| P0 Port Interrupt Mask Register (P0_IMSK)                | 0x5205<br>(8 bits) | D7–0 | P0IE[7:0]   | P0[7:0] port interrupt enable         | 1           | Enable                      | 0     | Disable                         | 0                  | R/W |
| P0 Port Interrupt Edge Select Register (P0_EDGE)         | 0x5206<br>(8 bits) | D7–0 | P0EDGE[7:0] | P0[7:0] port interrupt edge select    | 1           | Falling edge                | 0     | Rising edge                     | 0                  | R/W |
| P0 Port Interrupt Flag Register (P0_IFLG)                | 0x5207<br>(8 bits) | D7–0 | P0IF[7:0]   | P0[7:0] port interrupt flag           | 1           | Cause of interrupt occurred | 0     | Cause of interrupt not occurred | 0                  | R/W |
| P0 Port Chattering Filter Control Register (P0_CHAT)     | 0x5208<br>(8 bits) | D7   | –           | reserved                              | –           |                             | –     | –                               | 0 when being read. |     |
|                                                          |                    | D6–4 | P0CF2[2:0]  | P0[7:4] chattering filter time        | P0CF2[2:0]  | Filter time                 | 0     | R/W                             |                    |     |
|                                                          |                    |      |             |                                       | 0x7         | 16384/fpCLK                 | 0x0   | R/W                             |                    |     |
|                                                          |                    |      |             |                                       | 0x6         | 8192/fpCLK                  |       |                                 |                    |     |
|                                                          |                    |      |             |                                       | 0x5         | 4096/fpCLK                  |       |                                 |                    |     |
|                                                          |                    |      |             |                                       | 0x4         | 2048/fpCLK                  |       |                                 |                    |     |
|                                                          |                    |      |             |                                       | 0x3         | 1024/fpCLK                  |       |                                 |                    |     |
|                                                          |                    |      |             |                                       | 0x2         | 512/fpCLK                   |       |                                 |                    |     |
|                                                          |                    | D3   | –           | reserved                              | 0x1         | 256/fpCLK                   |       |                                 |                    |     |
|                                                          |                    | D2–0 | P0CF1[2:0]  | P0[3:0] chattering filter time        | P0CF1[2:0]  | Filter time                 | 0x0   | R/W                             |                    |     |
|                                                          |                    |      |             |                                       | 0x7         | 16384/fpCLK                 |       |                                 |                    |     |
|                                                          |                    |      |             |                                       | 0x6         | 8192/fpCLK                  |       |                                 |                    |     |
|                                                          |                    |      |             |                                       | 0x5         | 4096/fpCLK                  |       |                                 |                    |     |
|                                                          |                    |      |             |                                       | 0x4         | 2048/fpCLK                  |       |                                 |                    |     |
|                                                          |                    |      |             |                                       | 0x3         | 1024/fpCLK                  |       |                                 |                    |     |
|                                                          |                    |      |             |                                       | 0x2         | 512/fpCLK                   |       |                                 |                    |     |
|                                                          |                    |      |             |                                       | 0x1         | 256/fpCLK                   |       |                                 |                    |     |
|                                                          |                    |      |             |                                       | 0x0         | None                        |       |                                 |                    |     |
| P0 Port Key-Entry Reset Configuration Register (P0_KRST) | 0x5209<br>(8 bits) | D7–2 | –           | reserved                              | –           |                             | –     | –                               | 0 when being read. |     |
|                                                          |                    | D1–0 | P0KRST[1:0] | P0 port key-entry reset configuration | P0KRST[1:0] | Configuration               | 0x0   | R/W                             |                    |     |
|                                                          |                    |      |             |                                       | 0x3         | P0[3:0] = 0                 |       |                                 |                    |     |
| P1 Port Input Data Register (P1_IN)                      | 0x5210<br>(8 bits) | D7–0 | P1IN[7:0]   | P1[7:0] port input data               | 1           | 1 (H)                       | 0     | 0 (L)                           | ×                  | R   |
|                                                          |                    |      |             |                                       | 1           | 0 (L)                       | 0     | 1 (H)                           | 0                  | R/W |
| P1 Port Output Data Register (P1_OUT)                    | 0x5211<br>(8 bits) | D7–0 | P1OUT[7:0]  | P1[7:0] port output data              | 1           | 1 (H)                       | 0     | 0 (L)                           | 0                  | R/W |
|                                                          |                    |      |             |                                       | 1           | 0 (L)                       | 0     | 1 (H)                           | 0                  | R/W |
| P1 Port I/O Direction Control Register (P1_IO)           | 0x5212<br>(8 bits) | D7–0 | P1IO[7:0]   | P1[7:0] port I/O direction select     | 1           | Output                      | 0     | Input                           | 0                  | R/W |
|                                                          |                    |      |             |                                       | 1           | Input                       | 0     | Output                          | 0                  | R/W |
| P1 Port Pull-up Control Register (P1_PU)                 | 0x5213<br>(8 bits) | D7–0 | P1PU[7:0]   | P1[7:0] port pull-up enable           | 1           | Enable                      | 0     | Disable                         | 1                  | R/W |
|                                                          |                    |      |             |                                       | 1           | Disable                     | 0     | Enable                          | 0                  | R/W |
| P1 Port Interrupt Mask Register (P1_IMSK)                | 0x5215<br>(8 bits) | D7–0 | P1IE[7:0]   | P1[7:0] port interrupt enable         | 1           | Enable                      | 0     | Disable                         | 0                  | R/W |
|                                                          |                    |      |             |                                       | 1           | Disable                     | 0     | Enable                          | 0                  | R/W |
| P1 Port Interrupt Edge Select Register (P1_EDGE)         | 0x5216<br>(8 bits) | D7–0 | P1EDGE[7:0] | P1[7:0] port interrupt edge select    | 1           | Falling edge                | 0     | Rising edge                     | 0                  | R/W |
|                                                          |                    |      |             |                                       | 1           | Rising edge                 | 0     | Falling edge                    | 0                  | R/W |

## 0x5217–0x52a3

## P Port &amp; Port MUX

| Register name                                  | Address         | Bit  | Name       | Function                          | Setting                       |   |                                 | Init. | R/W | Remarks             |
|------------------------------------------------|-----------------|------|------------|-----------------------------------|-------------------------------|---|---------------------------------|-------|-----|---------------------|
| P1 Port Interrupt Flag Register (P1_IFLG)      | 0x5217 (8 bits) | D7–0 | P1IF[7:0]  | P1[7:0] port interrupt flag       | 1 Cause of interrupt occurred | 0 | Cause of interrupt not occurred | 0     | R/W | Reset by writing 1. |
| P2 Port Input Data Register (P2_IN)            | 0x5220 (8 bits) | D7–0 | P2IN[7:0]  | P2[7:0] port input data           | 1 1 (H)                       | 0 | 0 (L)                           | ×     | R   |                     |
| P2 Port Output Data Register (P2_OUT)          | 0x5221 (8 bits) | D7–0 | P2OUT[7:0] | P2[7:0] port output data          | 1 1 (H)                       | 0 | 0 (L)                           | 0     | R/W |                     |
| P2 Port I/O Direction Control Register (P2_IO) | 0x5222 (8 bits) | D7–0 | P2IO[7:0]  | P2[7:0] port I/O direction select | 1 Output                      | 0 | Input                           | 0     | R/W |                     |
| P2 Port Pull-up Control Register (P2_PU)       | 0x5223 (8 bits) | D7–0 | P2PU[7:0]  | P2[7:0] port pull-up enable       | 1 Enable                      | 0 | Disable                         | 1     | R/W |                     |
| P3 Port Input Data Register (P3_IN)            | 0x5230 (8 bits) | D7–4 | –          | reserved                          | –                             |   |                                 | –     | –   | 0 when being read.  |
|                                                |                 | D3–0 | P3IN[3:0]  | P3[3:0] port input data           | 1 1 (H)                       | 0 | 0 (L)                           | ×     | R   |                     |
| P3 Port Output Data Register (P3_OUT)          | 0x5231 (8 bits) | D7–4 | –          | reserved                          | –                             |   |                                 | –     | –   | 0 when being read.  |
|                                                |                 | D3–0 | P3OUT[3:0] | P3[3:0] port output data          | 1 1 (H)                       | 0 | 0 (L)                           | 0     | R/W |                     |
| P3 Port I/O Direction Control Register (P3_IO) | 0x5232 (8 bits) | D7–4 | –          | reserved                          | –                             |   |                                 | –     | –   | 0 when being read.  |
|                                                |                 | D3–0 | P3IO[3:0]  | P3[3:0] port I/O direction select | 1 Output                      | 0 | Input                           | 0     | R/W |                     |
| P3 Port Pull-up Control Register (P3_PU)       | 0x5233 (8 bits) | D7–4 | –          | reserved                          | –                             |   |                                 | –     | –   | 0 when being read.  |
|                                                |                 | D3–0 | P3PU[3:0]  | P3[3:0] port pull-up enable       | 1 Enable                      | 0 | Disable                         | 1     | R/W |                     |
| P0 Port Function Select Register (P0_PMUX)     | 0x52a0 (8 bits) | D7–6 | –          | reserved                          | –                             |   |                                 | –     | –   | 0 when being read.  |
|                                                |                 | D5   | P05MUX     | P05 port function select          | 1 REMO                        | 0 | P05                             | 0     | R/W |                     |
|                                                |                 | D4   | P04MUX     | P04 port function select          | 1 REMI                        | 0 | P04                             | 0     | R/W |                     |
| P1 Port Function Select Register (P1_PMUX)     | 0x52a1 (8 bits) | D3–0 | –          | reserved                          | –                             |   |                                 | –     | –   | 0 when being read.  |
|                                                |                 | D7   | P17MUX     | P17 port function select          | 1 #SPISS                      | 0 | P17                             | 0     | R/W |                     |
|                                                |                 | D6   | –          | reserved                          | –                             |   |                                 | –     | –   | 0 when being read.  |
|                                                |                 | D5   | P15MUX     | P15 port function select          | 1 SCL                         | 0 | P15                             | 0     | R/W |                     |
|                                                |                 | D4   | P14MUX     | P14 port function select          | 1 SDA                         | 0 | P14                             | 0     | R/W |                     |
|                                                |                 | D3   | P13MUX     | P13 port function select          | 1 FOUT1                       | 0 | P13                             | 0     | R/W |                     |
| P2 Port Function Select Register (P2_PMUX)     | 0x52a2 (8 bits) | D2–0 | –          | reserved                          | –                             |   |                                 | –     | –   | 0 when being read.  |
|                                                |                 | D7   | P27MUX     | P27 port function select          | 1 EXCL3                       | 0 | P27                             | 0     | R/W |                     |
|                                                |                 | D6   | P26MUX     | P26 port function select          | 1 TOUT                        | 0 | P26                             | 0     | R/W |                     |
|                                                |                 | D5   | P25MUX     | P25 port function select          | 1 SCLK                        | 0 | P25                             | 0     | R/W |                     |
|                                                |                 | D4   | P24MUX     | P24 port function select          | 1 SOUT                        | 0 | P24                             | 0     | R/W |                     |
|                                                |                 | D3   | P23MUX     | P23 port function select          | 1 SIN                         | 0 | P23                             | 0     | R/W |                     |
|                                                |                 | D2   | P22MUX     | P22 port function select          | 1 SPICLK                      | 0 | P22                             | 0     | R/W |                     |
|                                                |                 | D1   | P21MUX     | P21 port function select          | 1 SD0                         | 0 | P21                             | 0     | R/W |                     |
| P3 Port Function Select Register (P3_PMUX)     | 0x52a3 (8 bits) | D0   | P20MUX     | P20 port function select          | 1 SDI                         | 0 | P20                             | 0     | R/W |                     |
|                                                |                 | D7–4 | –          | reserved                          | –                             |   |                                 | –     | –   | 0 when being read.  |
|                                                |                 | D3   | P33MUX     | P33 port function select          | 1 P33                         | 0 | DSIO                            | 0     | R/W |                     |
|                                                |                 | D2   | P32MUX     | P32 port function select          | 1 P32                         | 0 | DST2                            | 0     | R/W |                     |
|                                                |                 | D1   | P31MUX     | P31 port function select          | 1 P31                         | 0 | DCLK                            | 0     | R/W |                     |
|                                                |                 | D0   | P30MUX     | P30 port function select          | 1 FOUT3                       | 0 | P30                             | 0     | R/W |                     |

## 0x5300–0x530c

## PWM &amp; Capture Timer

| Register name                                    | Address          | Bit   | Name         | Function                                          | Setting                                                                                                                                                                                                                                                                                                    | Init. | R/W | Remarks             |
|--------------------------------------------------|------------------|-------|--------------|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|---------------------|
| PWM Timer Compare Data A Register (T16E_CA)      | 0x5300 (16 bits) | D15–0 | T16ECA[15:0] | Compare data A<br>T16ECA15 = MSB<br>T16ECA0 = LSB | 0x0 to 0xffff                                                                                                                                                                                                                                                                                              | 0x0   | R/W |                     |
| PWM Timer Compare Data B Register (T16E_CB)      | 0x5302 (16 bits) | D15–0 | T16ECB[15:0] | Compare data B<br>T16ECB15 = MSB<br>T16ECB0 = LSB | 0x0 to 0xffff                                                                                                                                                                                                                                                                                              | 0x0   | R/W |                     |
| PWM Timer Counter Data Register (T16E_TC)        | 0x5304 (16 bits) | D15–0 | T16ETC[15:0] | Counter data<br>T16ETC15 = MSB<br>T16ETC0 = LSB   | 0x0 to 0xffff                                                                                                                                                                                                                                                                                              | 0x0   | R/W |                     |
| PWM Timer Control Register (T16E_CTL)            | 0x5306 (16 bits) | D15–9 | –            | reserved                                          | –                                                                                                                                                                                                                                                                                                          | –     | –   | 0 when being read.  |
|                                                  |                  | D8    | INITOL       | Initial output level                              | 1 High 0 Low                                                                                                                                                                                                                                                                                               | 0     | R/W |                     |
|                                                  |                  | D7    | –            | reserved                                          | –                                                                                                                                                                                                                                                                                                          | –     | –   | 0 when being read.  |
|                                                  |                  | D6    | SELFM        | Fine mode select                                  | 1 Fine mode 0 Normal mode                                                                                                                                                                                                                                                                                  | 0     | R/W |                     |
|                                                  |                  | D5    | CBUFEN       | Comparison buffer enable                          | 1 Enable 0 Disable                                                                                                                                                                                                                                                                                         | 0     | R/W |                     |
|                                                  |                  | D4    | INVOUT       | Inverse output                                    | 1 Invert 0 Normal                                                                                                                                                                                                                                                                                          | 0     | R/W |                     |
|                                                  |                  | D3    | CLKSEL       | Input clock select                                | 1 External 0 Internal                                                                                                                                                                                                                                                                                      | 0     | R/W |                     |
|                                                  |                  | D2    | OUTEN        | Clock output enable                               | 1 Enable 0 Disable                                                                                                                                                                                                                                                                                         | 0     | R/W |                     |
|                                                  |                  | D1    | T16ERST      | Timer reset                                       | 1 Reset 0 Ignored                                                                                                                                                                                                                                                                                          | 0     | W   | 0 when being read.  |
|                                                  |                  | D0    | T16ERUN      | Timer run/stop control                            | 1 Run 0 Stop                                                                                                                                                                                                                                                                                               | 0     | R/W |                     |
| PWM Timer Input Clock Select Register (T16E_CLK) | 0x5308 (16 bits) | D15–4 | –            | reserved                                          | –                                                                                                                                                                                                                                                                                                          | –     | –   | 0 when being read.  |
|                                                  |                  | D3–0  | T16EDF[3:0]  | Timer input clock select (Prescaler output clock) | T16EDF[3:0] Clock<br>0xf reserved<br>0xe PCLK-1/16384<br>0xd PCLK-1/8192<br>0xc PCLK-1/4096<br>0xb PCLK-1/2048<br>0xa PCLK-1/1024<br>0x9 PCLK-1/512<br>0x8 PCLK-1/256<br>0x7 PCLK-1/128<br>0x6 PCLK-1/64<br>0x5 PCLK-1/32<br>0x4 PCLK-1/16<br>0x3 PCLK-1/8<br>0x2 PCLK-1/4<br>0x1 PCLK-1/2<br>0x0 PCLK-1/1 | 0x0   | R/W |                     |
| PWM Timer Interrupt Mask Register (T16E_IMSK)    | 0x530a (16 bits) | D15–2 | –            | reserved                                          | –                                                                                                                                                                                                                                                                                                          | –     | –   | 0 when being read.  |
|                                                  |                  | D1    | CBIE         | Compare B interrupt enable                        | 1 Enable 0 Disable                                                                                                                                                                                                                                                                                         | 0     | R/W |                     |
|                                                  |                  | D0    | CAIE         | Compare A interrupt enable                        | 1 Enable 0 Disable                                                                                                                                                                                                                                                                                         | 0     | R/W |                     |
| PWM Timer Interrupt Flag Register (T16E_IFLG)    | 0x530c (16 bits) | D15–2 | –            | reserved                                          | –                                                                                                                                                                                                                                                                                                          | –     | –   | 0 when being read.  |
|                                                  |                  | D1    | CBIF         | Compare B interrupt flag                          | 1 Cause of interrupt occurred 0 Cause of interrupt not occurred                                                                                                                                                                                                                                            | 0     | R/W | Reset by writing 1. |
|                                                  |                  | D0    | CAIF         | Compare A interrupt flag                          | 1 Cause of interrupt not occurred 0                                                                                                                                                                                                                                                                        | 0     | R/W |                     |

## 0x5320–0x5322

## MISC Registers

| Register name                                | Address         | Bit  | Name       | Function                              | Setting    |            | Init. | R/W  | Remarks            |
|----------------------------------------------|-----------------|------|------------|---------------------------------------|------------|------------|-------|------|--------------------|
| ROM Control Register (MISC_FL)               | 0x5320 (8 bits) | D7–3 | –          | reserved                              | –          |            | –     | –    | 0 when being read. |
|                                              |                 | D2–0 | FLCYC[2:0] | ROM read access cycle                 | FLCYC[2:0] | Read cycle | 0x3   | R/W  |                    |
|                                              |                 |      |            |                                       | 0x7–0x5    | reserved   |       |      |                    |
|                                              |                 |      |            |                                       | 0x4        | 1 cycle    |       |      |                    |
|                                              |                 |      |            |                                       | 0x3        | 5 cycles   |       |      |                    |
|                                              |                 |      |            |                                       | 0x2        | 4 cycles   |       |      |                    |
|                                              |                 |      |            |                                       | 0x1        | 3 cycles   |       |      |                    |
|                                              |                 |      |            |                                       | 0x0        | 2 cycles   |       |      |                    |
| OSC1 Peripheral Control Register (MISC_OSC1) | 0x5322 (8 bits) | D7–1 | –          | reserved                              | –          |            | –     | –    | 0 when being read. |
|                                              |                 | D0   | O1DBG      | OSC1 peripheral control in debug mode | 1          | Run        | 0     | Stop | 0 R/W              |

## 0x5340–0x5347

## Remote Controller

| Register name                                    | Address         | Bit  | Name        | Function                                                | Setting     |                                                                                                                          | Init. | R/W      | Remarks             |
|--------------------------------------------------|-----------------|------|-------------|---------------------------------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------|-------|----------|---------------------|
| REMC Configuration Register (REMC_CFG)           | 0x5340 (8 bits) | D7–2 | –           | reserved                                                | –           |                                                                                                                          | –     | –        | 0 when being read.  |
|                                                  |                 | D1   | REMMD       | REMC mode select                                        | 1           | Receive                                                                                                                  | 0     | Transmit | 0 R/W               |
|                                                  |                 | D0   | REMEN       | REMC enable                                             | 1           | Enable                                                                                                                   | 0     | Disable  | 0 R/W               |
| REMC Prescaler Clock Select Register (REMC_PSC)  | 0x5341 (8 bits) | D7–4 | CGCLK[3:0]  | Carrier generator clock select (Prescaler output clock) | CGCLK[3:0]  | Clock                                                                                                                    |       | 0x0      | R/W                 |
|                                                  |                 | D3–0 | LCCLK[3:0]  | Length counter clock select (Prescaler output clock)    | LCCLK[3:0]  | reserved<br>0xf<br>0xe<br>0xd<br>0xc<br>0xb<br>0xa<br>0x9<br>0x8<br>0x7<br>0x6<br>0x5<br>0x4<br>0x3<br>0x2<br>0x1<br>0x0 |       | 0x0      | R/W                 |
| REMC H Carrier Length Setup Register (REMC_CARH) | 0x5342 (8 bits) | D7–6 | –           | reserved                                                | –           |                                                                                                                          | –     | –        | 0 when being read.  |
|                                                  |                 | D5–0 | REMCH[5:0]  | H carrier length setup                                  | 0x0 to 0x3f |                                                                                                                          | 0x0   | R/W      |                     |
| REMC L Carrier Length Setup Register (REMC_CARL) | 0x5343 (8 bits) | D7–6 | –           | reserved                                                | –           |                                                                                                                          | –     | –        | 0 when being read.  |
|                                                  |                 | D5–0 | REMCL[5:0]  | L carrier length setup                                  | 0x0 to 0x3f |                                                                                                                          | 0x0   | R/W      |                     |
| REMC Status Register (REMC_ST)                   | 0x5344 (8 bits) | D7–1 | –           | reserved                                                | –           |                                                                                                                          | –     | –        | 0 when being read.  |
|                                                  |                 | D0   | REMDT       | Transmit/receive data                                   | 1           | 1 (H)                                                                                                                    | 0     | 0 (L)    | 0 R/W               |
| REMC Length Counter Register (REMC_LCNT)         | 0x5345 (8 bits) | D7–0 | REMLEN[7:0] | Transmit/receive data length count (down counter)       | 0x0 to 0xff |                                                                                                                          | 0x0   | R/W      |                     |
| REMC Interrupt Mask Register (REMC_IMSK)         | 0x5346 (8 bits) | D7–3 | –           | reserved                                                | –           |                                                                                                                          | –     | –        | 0 when being read.  |
|                                                  |                 | D2   | REMFI       | Falling edge interrupt enable                           | 1           | Enable                                                                                                                   | 0     | Disable  | 0 R/W               |
|                                                  |                 | D1   | REMRI       | Rising edge interrupt enable                            | 1           | Enable                                                                                                                   | 0     | Disable  | 0 R/W               |
| REMC Interrupt Flag Register (REMC_IFLG)         | 0x5347 (8 bits) | D0   | REMUI       | Underflow interrupt enable                              | 1           | Enable                                                                                                                   | 0     | Disable  | 0 R/W               |
|                                                  |                 | D7–3 | –           | reserved                                                | –           |                                                                                                                          | –     | –        | 0 when being read.  |
|                                                  |                 | D2   | REMFI       | Falling edge interrupt flag                             | 1           | Cause of interrupt occurred                                                                                              | 0     | R/W      | Reset by writing 1. |
|                                                  |                 | D1   | REMRI       | Rising edge interrupt flag                              | 1           | Cause of interrupt not occurred                                                                                          | 0     | R/W      |                     |
|                                                  |                 | D0   | REMUI       | Underflow interrupt flag                                | 1           | Cause of interrupt not occurred                                                                                          | 0     | R/W      |                     |

## 0xfffff80–0xfffff90

## S1C17 Core I/O

| Register name                      | Address   | Bit    | Name        | Function                         | Setting | Init.      | R/W | Remarks |
|------------------------------------|-----------|--------|-------------|----------------------------------|---------|------------|-----|---------|
| Vector Table                       | 0xfffff80 | D31–24 | –           | Unused (fixed at 0)              | 0x0     | 0x0        | R   |         |
| Base Register<br>(TTBR)            | (32 bits) | D23–0  | TTBR[23:0]  | Vector table base address        | 0x8000  | 0x80<br>00 | R   |         |
| Processor ID<br>Register<br>(IDIR) | 0xfffff84 | D7–0   | IDIR[7:0]   | Processor ID<br>0x10: S1C17 Core | 0x10    | 0x10       | R   |         |
| Debug RAM                          | 0xfffff90 | D31–24 | –           | Unused (fixed at 0)              | 0x0     | 0x0        | R   |         |
| Base Register<br>(DBRAM)           | (32 bits) | D23–0  | DBRAM[23:0] | Debug RAM base address           | 0x7c0   | 0x7c0      | R   |         |

# Appendix B パワーセーブ

消費電流はCPUの動作モード、動作クロック周波数、動作させる周辺回路により大きく変わります。以下に、省電力化のための制御方法をまとめます。

## B.1 クロック制御によるパワーセーブ

図B.1.1にS1C17001のクロックシステムを示します。



図B.1.1 クロックシステム

ソフトウェアによって制御可能なクロック系とパワーセーブのための制御内容を以下に示します。制御レジスタや制御方法の詳細については、それぞれのモジュールの章を参照してください。

### システムのスリープ(全クロックの停止)

- `s1p`命令の実行

システム全体を停止可能な場合は、`s1p`命令を実行します。CPUはSLEEPモードとなり、システムクロックが停止します。これにより、クロックを使用する周辺回路はすべて停止します。このため、SLEEPモードからのCPUの起動方法はポートによる起動(後述)に限られます。

### システムクロック

- クロック源の選択(OSCモジュール)

システムクロック源をOSC3とするかOSC1とするか選択できます。低速動作で処理可能な際にはOSC1クロックを選択することで消費電流を低減できます。

- OSC3発振回路の停止(OSCモジュール)

システムクロック源としている発振回路を動作させ、可能であればもう一方を停止します。OSC1をシステムクロックとし、OSC3発振回路を停止することで、消費電流をより低減できます。

### CPUクロック(CCLK)

- `halt`命令の実行

表示のみ必要な場合や割り込み待ちなど、CPUによるプログラムの実行が不要な場合は、`halt`命令を実行します。CPUはHALTモードとなり動作を停止しますが、周辺回路は`halt`命令実行時の状態を維持します。このため、タイマや、割り込みに使用する周辺回路を動作させておくことができます。また、不要な周辺回路を停止してから`halt`命令を実行することで、パワーセーブの効果は高まります。HALTモードからは、ポートまたはHALTモード時に動作させている周辺回路からの割り込みによりCPUが起動します。

- 低速クロックギアの選択(CLGモジュール)

CLGモジュールは、クロックギアの設定により、CPUクロックをシステムクロックの1/1～1/8に減速することができます。アプリケーションに必要最低限の速度でCPUを動作させることにより、消費電流を低減できます。

### 周辺クロック(PCLK)

- PCLKの停止(CLGモジュール)

以下の周辺回路の動作がすべて不要な場合は、CLGから周辺回路へのPCLKクロックの供給を停止することができます。

PCLKで動作する周辺モジュール

- プリスケーラ(PWM&キャプチャタイマ、リモートコントローラ、Pポート)
- UART
- 8ビットタイマ
- 16ビットタイマ Ch.0～2
- 割り込みコントローラ
- SPI
- I<sup>2</sup>C
- Pポート&ポートMUX(制御レジスタ、チャタリング除去)
- PWM&キャプチャタイマ
- MISCレジスタ
- リモートコントローラ

以下の周辺モジュールは制御レジスタへのアクセスを除き、PCLK以外のクロックで動作します。したがって、制御レジスタを設定して動作を開始後はPCLKは必要ありません。

- 計時タイマ
- ストップウォッチタイマ
- ウォッチドッグタイマ
- 8ビットOSC1タイマ

PCLKが停止中はマスク可能な割り込みは発生しません。PCLKの供給を再開するまで、割り込みは保留されます。

クロック制御とCPUの起動/停止方法の一覧を表B.1.1に示します。

表B.1.1 クロック制御一覧

| 消費電流   | OSC1            | OSC3            | CPU(CCLK) | PCLK周辺 | OSC1周辺 | CPU停止方法  | CPU起動方法 |
|--------|-----------------|-----------------|-----------|--------|--------|----------|---------|
| ↑<br>低 | 停止              | 停止              | 停止        | 停止     | 停止     | slp命令実行  | 1       |
|        | 発振<br>(システムCLK) | 停止              | 停止        | 停止     | 動作     | halt命令実行 | 1, 2    |
|        | 発振<br>(システムCLK) | 停止              | 停止        | 動作     | 動作     | halt命令実行 | 1, 2, 3 |
|        | 発振              | 停止              | 動作(1/1)   | 動作     | 動作     |          |         |
|        | 発振              | 発振<br>(システムCLK) | 停止        | 動作     | 動作     | halt命令実行 | 1, 2, 3 |
|        | 発振              | 発振<br>(システムCLK) | 動作(低ギア)   | 動作     | 動作     |          |         |
|        | 発振              | 発振<br>(システムCLK) | 動作(1/1)   | 動作     | 動作     |          |         |
| ↓<br>高 |                 |                 |           |        |        |          |         |

HALT, SLEEPモードの解除方法(CPU起動方法)

### 1. ポートによる起動

入出力ポート割り込み要因、デバッグ割り込み(ICD強制ブレーキ発行)により起動します。入出力ポート割り込みが、割り込みコントローラ、CPUのIEフラグで禁止されている場合、CPUは割り込みを受け付けず、haltまたはslp命令に続く命令を実行します。割り込みが許可されていて、かつhaltまたはslp命令実行前にPCLKが動作していた場合、CPUは割り込み処理ルーチンに分岐します。割り込みが許可されていても、haltまたはslp命令実行前にPCLKが停止していた場合は、PCLKを動作させるまで割り込み処理ルーチンへの分岐は保留されます。

### 2. OSC1周回路による起動

計時タイマ、ストップウォッチタイマ、ウォッチドッグタイマ、8ビットOSC1タイマの割り込み要因により起動します。これらの割り込みが、割り込みコントローラ、CPUのIEフラグで禁止されている場合、CPUは割り込みを受け付けず、halt命令に続く命令を実行します。割り込みが許可されていて、かつhalt命令実行前にPCLKが動作していた場合、CPUは割り込み処理ルーチンに分岐します。割り込みが許可されていても、halt命令実行前にPCLKが停止していた場合は、PCLKを動作させるまで割り込み処理ルーチンへの分岐は保留されます。

### 3. PCLK周回路による起動

割り込みコントローラで割り込みが許可されているPCLK周回路の割り込み要因により起動します。CPUのIEフラグが0の場合、CPUは割り込みを受け付けず、halt命令に続く命令を実行します。IEフラグが1の場合、CPUは割り込み処理ルーチンに分岐します。

# Appendix C 実装上の注意事項

基板の設計およびICを実装する際の注意事項を以下に示します。

## 発振回路

- 発振特性は使用部品(振動子、Rf、Cg、Cd)や基板パターンなどにより変化します。特にセラミック発振子または水晶振動子を使用する場合、外付けの抵抗(Rf)や容量(Cg、Cd)の値は、実際の基板上に各部品を実装した状態で十分評価を行って適切なものを選んでください。

- ノイズによる発振クロックの乱れは誤動作の原因となります。これを防止するため以下の点に配慮してください。特に最新機種は、より微細なプロセスで製造されており、ノイズに敏感になっています。

最もノイズ対策が必要となるのは、OSC2端子とその回路構成部品および配線です。OSC1端子の処理もこれらと同様に重要です。以下、OSC1、OSC2端子のノイズ対策を記載します。

なお、OSC3、OSC4端子や配線等、高速発振回路系についても、これに準じたノイズ対策を施すことを推奨します。

(1) OSC1(OSC3)、OSC2(OSC4)端子に接続する発振子、抵抗、コンデンサ等の部品は、できるだけ最短で接続してください。

(2) OSC1(OSC3)、OSC2(OSC4)端子とこれらの回路構成部品、および配線から3mm以内の領域には、できるだけデジタル信号線を配置しないでください。特に、スイッチングが激しい信号を近くに配置することは避けてください。多層プリント基板の各層の間隔は0.1～0.2mm程度しかありませんので、デジタル信号線を他のどの層に配置する場合でも同様です。

また、これらの部品や配線とデジタル信号線を絶対に並走させないでください。3mm以上の距離がある場合や基板の他の層であっても禁止します。配線を交差させることも避けてください。

(3) OSC1(OSC3)、OSC2(OSC4)端子と配線は、基板の隣接する層も含めVssでシールドしてください。

隣接する層についてはできれば全面をグラウンド層に、最低でも上記端子と配線の周囲を5mm以上カバーするようにシールドしてください。

この対策を施した場合でも、(2)に記載したようにデジタル信号線との並走は禁止します。他の層での交差についても、スイッチング頻度の低い信号以外はできるだけ避けてください。

(4) 上記の対策を施した後は、実機で実際のアプリケーションプログラムを動作させた状態での出力クロック波形も確認してください。

FOUT1/FOUT3端子の出力をオシロスコープなどで確認します。

OSC3の出力波形の品質は、FOUT3出力で確認します。設計どおりの周波数でノイズが乗っていないかどうか、およびジッタがほとんどないことを確認してください。

OSC1波形の品質はFOUT1出力で確認します。特にクロックの立ち上がり/立ち下がりの両エッジの前後を拡大し、前後100ns程度の範囲にクロック状のノイズやスパイクノイズなどが乗っていないか注意して見てください。

(1)～(3)の対応が不十分な場合、OSC3出力にはジッタが発生し、OSC1出力にはノイズが乗ることがあります。OSC3出力にジッタが発生するとその分、動作周波数が低下します。OSC1出力にノイズが乗ると、OSC1クロックで動作するタイマや、システムクロックをOSC1に切り換えた際のCPUコアの動作が不安定になります。

## リセット回路

- 電源投入時、#RESET端子に入力されるリセット信号は、諸条件(電源の立ち上がり時間、使用部品、基板パターン等)により変化します。容量や抵抗などの定数は応用製品にて十分確認を行い、決定してください。#RESET端子のプルアップ抵抗については、抵抗値のばらつきを十分考慮した定数設定が必要です。

- ノイズによる動作中のリセットを防ぐため、#RESET端子に接続するコンデンサ、抵抗等の部品は、できるだけ最短で接続してください。

## 電源

ノイズによる急激な電源変動は誤動作の原因となります。これを防止するため次の点に配慮してください。

- (1) 電源からLVDD、HVDDおよびVss端子へはできるだけ短くかつ太いパターンで接続してください。
- (2) LVDD/HVDD-Vssのバイパスコンデンサを接続する場合、LVDD/HVDD端子とVss端子をできるだけ最短で接続してください。

## 信号線の配置

- 相互インダクタンスによって生じる電磁誘導ノイズを防止するために、クロック入力部等のノイズに弱い回路近くには、大電流信号線を配置しないでください。
- 高速動作する信号線と、長くかつ平行にまたは交差させて別の信号線を配置することは、信号間の相互干渉によって発生するノイズにより誤動作の原因となります。  
特に、クロック入力部等のノイズに弱い回路近くには、高速に動作する信号線を配置しないでください。

## ノイズによる誤動作について

ノイズによるICの誤動作が考えられる場合、以下の3点について確認してみてください。

- (1) DSIO端子  
この端子にLowレベルのノイズが入るとデバッグモードになります。デバッグモードになったことは、DCLKからクロックが出力され、DST2端子がHighになっていることで確認できます。  
製品版では、DSIO端子をHVDDに直結、もしくは10kΩ以下の抵抗でプルアップすることを推奨します。  
IC内にプルアップ抵抗が付いていますが、50~100kΩ程度と高インピーダンスなため、ノイズには強くありません。
- (2) #RESET端子  
この端子にLowレベルのノイズが入るとICがリセットされます。ただし、入力波形によっては正常なリセット動作が行えない場合があります。  
回路設計上、リセット入力がHigh状態でのインピーダンスが高いときに起こりやすくなります。
- (3) LVDD、HVDD、Vss電源  
規定の電圧を下回るようなノイズが入った場合、その瞬間にICが誤動作します。  
基板の電源系のベタパターン化、ノイズ除去用デカップリングコンデンサの追加、電源ラインへのサージ/ノイズ対策部品の追加など、基板上での対策をお願いします。

上記の確認作業は、200MHz以上の波形が観測できるオシロスコープを使用して行ってください。  
低速なオシロスコープでは、高速なノイズの発生を観測できない場合があります。

ノイズによる誤動作の可能性をオシロスコープの波形観測で発見した場合は、その端子をGNDまたは電源に低インピーダンス(1kΩ以下)で接続して再確認してください。誤動作しなくなる、頻度が低くなる、あるいは症状が変わるなどの変化が見受けられる場合、その端子での誤動作が確実と考えられます。

上記のDSIO、#RESET入力の回路は入力信号のエッジを検出しているため、ひげ状のノイズでも誤動作しやすく、デジタル信号の中では最もノイズに弱い端子です。

ノイズが乗りにくいように、基板設計の際には以下の2点を考慮してください。

- (A) まず、上記の各項目にあるように、信号を駆動するインピーダンスを低くすることが重要です。  
目安としては1kΩ以下、できれば0Ωとなるように電源やGNDに接続してください。また、接続する信号線長は5cm程度以下としてください。
- (B) 基板上で他のデジタル線と並走したために、その信号の1→0、0→1の変化点で発生するノイズの影響を受ける場合があります。  
特に、同時変化する複数の信号線に両側から挟まれると、最も大きなノイズが乘ります。並走距離を短くする(数cm以下に抑える)、信号を離す(2mm以上離す)、といった対策が有効です。

## その他

本製品シリーズは0.25μm微細プロセスにより製造されています。

ICの基本信頼性に関してはEIAJ、MIL規格を満足するように設計されていますが、実装段階においては以下の点に十分注意してください。

実装時の機械的ダメージのほか、

- (1) 実装時リフロー工程、実装後のリワーク、個別特性評価(実験確認)の各工程における商用電源からの電磁誘導ノイズ
- (2) 半田ごて使用時のこて先からの電磁誘導ノイズ

など、緩やかな時間的変化を伴う絶対最大定格(2.5V)以上の電圧となる外乱が、電気的損傷につながる可能性があります。

特に半田ごて使用時には、ICのGNDと半田ごてのGND(こて先の電位)を同電位として作業を行ってください。

# Appendix D 初期化ルーチン

ベクターテーブルと初期化ルーチンの例を以下に示します。

## boot.s

```

.org      0x8000
.section .rodata
; =====
;      Vector table
; =====
;      ; interrupt  vector  interrupt
;      ; number      offset   source
; =====
.long BOOT          ; 0x00      0x00      reset      ...(1)
.long unalign_handler ; 0x01      0x04      unalign
.long nmi_handler   ; 0x02      0x08      NMI
.long int03_handler ; 0x03      0x0c      -
.long p0_handler    ; 0x04      0x10      P0 port
.long p1_handler    ; 0x05      0x14      P1 port
.long swt_handler   ; 0x06      0x18      SWT
.long ct_handler    ; 0x07      0x1c      CT
.long t8osc1_handler; 0x08      0x20      T8OSC1
.long int09_handler ; 0x09      0x24      -
.long int0a_handler ; 0x0a      0x28      -
.long t16e_handler  ; 0x0b      0x2c      T16E
.long t8f_handler   ; 0x0c      0x30      T8F
.long t16_0_handler ; 0x0d      0x34      T16 ch0
.long t16_1_handler ; 0x0e      0x38      T16 ch1
.long t16_2_handler ; 0x0f      0x3c      T16 ch2
.long uart_handler  ; 0x10      0x40      UART
.long remc_handler  ; 0x11      0x44      REMC
.long spi_handler   ; 0x12      0x48      SPI
.long i2c_handler   ; 0x13      0x4c      I2C
.long int14_handler ; 0x14      0x50      -
.long int15_handler ; 0x15      0x54      -
.long int16_handler ; 0x16      0x58      -
.long int17_handler ; 0x17      0x5c      -
.long int18_handler ; 0x18      0x60      -
.long int19_handler ; 0x19      0x64      -
.long int1a_handler ; 0x1a      0x68      -
.long int1b_handler ; 0x1b      0x6c      -
.long int1c_handler ; 0x1c      0x70      -
.long int1d_handler ; 0x1d      0x74      -
.long int1e_handler ; 0x1e      0x78      -
.long int1f_handler ; 0x1f      0x7c      -
; =====
;      Program code
; =====
.text
.align 1
...  

BOOT:
; ===== Initialize =====
; ----- Stack pointer -----
Xld.a %sp, 0x7c0
...  

; ----- Memory controller -----
Xld.a %r1, 0x5320 ; MISC register base address
; ROM
Xld.a %r0, 0x04 ; 1 cycle access
ld.b [%r1], %r0 ; [0x5320] <= 0x04
...  


```

```

; ----- ITC (interrupt controller) -----
Xld.a  %r7, 0x4300      ; ITC register base address
Xld.a  %r0, 0x1010      ; P0, P1 interrupt level & trigger mode
ext    0x06
ld     [%r7], %r0       ; [0x4306] <= 0x1010          ...⑥
Xld.a  %r0, 0x1010      ; SWT, CT interrupt level & trigger mode
ext    0x08
ld     [%r7], %r0       ; [0x4308] <= 0x1010          ...⑥
Xld.a  %r0, 0x0010      ; T8OSC1 interrupt level & trigger mode
ext    0x0a
ld     [%r7], %r0       ; [0x430a] <= 0x0010          ...⑥
Xld.a  %r0, 0x1000      ; T16E interrupt level & trigger mode
ext    0x0c
ld     [%r7], %r0       ; [0x430c] <= 0x1000          ...⑥

; ===== Main routine =====
...
; =====
;       Interrupt handler
; =====
; ----- Address unalign -----
unalign_handler:
...
; ----- NMI -----
nmi_handler:
...

```

- (1) ベクターテーブルを .vector セクションに配置するために .rodata セクションを宣言します。
- (2) 割り込み処理ルーチンのアドレスをベクタとして定義します。  
intXX\_handler はソフトウェア割り込みとして使用可能です。
- (3) プログラムコードは .text セクションに記述します。
- (4) スタックポインタを設定します。
- (5) ROM のリードアクセスサイクル数を設定します。  
("3 メモリマップ, バス制御" 参照)
- (6) 以下の周辺回路については、割り込みのトリガモードをレベルトリガに設定します。  
P0ポート、P1ポート、ストップウォッチタイマ、計時タイマ、8ビットOSC1タイマ、PWM&キャプチャタイマ  
("6 割り込みコントローラ(ITC)" 参照)

# Appendix E S1C17001マスクROMコードの開発について

- (1) S1C17001のマスクROMコードはS1C17704 Flashマイコンを用いて開発します。
- (2) EPSONに提出するROMデータの形式は“file.PAn”(winmdc出力)です。お客様のROMデータの最終検証は“file.psa”(sconv32出力)で行ってください。
- (3) S1C17001では、moto2ff実行時の引数に以下の値を設定をしてください。
  - データの開始アドレス = 8000
  - データのブロックサイズ = 8000
- (4) 下表に示す機能の違いを充分考慮し、S1C17704で動作確認をしてください。
  - ROMのサイズが異なります。(3)の手順で32KBのコードを抜き出し、“file.psa”(sconv32出力)で最終確認をしてください。
  - RAMのサイズが異なります。スタッカブルインタアドレスに注意してください。プログラム動作確認後、アドレス0x800～0xfefのデータが変化していないことを確認してください。
  - S1C17001に存在しないLCDドライバ、SVD関連のレジスタにアクセスしないでください。

表E.1 S1C17704とS1C17001の機能比較

| 回路/機能                 | S1C17704     | S1C17001                                                                |
|-----------------------|--------------|-------------------------------------------------------------------------|
| Flash                 | 64Kバイト       | なし                                                                      |
| ROM(マスクROM)           | なし           | 32Kバイト                                                                  |
| RAM                   | 4Kバイト        | 2Kバイト                                                                   |
| 表示RAM                 | 572バイト       | なし                                                                      |
| 動作周波数                 | 32kHz～8.2MHz | ←                                                                       |
| OSC3発振回路              | 水晶/CR        | ←                                                                       |
| OSC1発振回路              | 水晶           | ←                                                                       |
| 動作クロック入力(OSC3)        | 評価目的のみ可能     | ○                                                                       |
| 動作クロック入力(OSC1)        | 評価目的のみ可能     | ○                                                                       |
| 入出力ポート                | 28本          | ←                                                                       |
| 外部ポート割り込み             | 16本          | ←                                                                       |
| SPI(マスタ/スレーブ)         | 1ch.         | ←                                                                       |
| I <sup>2</sup> C(マスタ) | 1ch.         | ←                                                                       |
| UART(IrDA1.0対応)       | 1ch.         | ←                                                                       |
| 8ビットタイマ(T8F)          | 1ch.         | ←                                                                       |
| 16ビットタイマ(T16)         | 3ch.         | ←                                                                       |
| PWM&キャプチャタイマ(T16E)    | 1ch.         | ←                                                                       |
| 計時タイマ(CT)             | 1ch.         | ←                                                                       |
| ストップウォッチタイマ(SWT)      | 1ch.         | ←                                                                       |
| ウォッチドッグタイマ(WDT)       | 1ch.         | ←                                                                       |
| 8ビットOSC1タイマ(T8OSC1)   | 1ch.         | ←                                                                       |
| LCDドライバ               | ○            | なし                                                                      |
| 電源電圧検出(SVD)回路         | ○            | なし                                                                      |
| 電源電圧                  | 1.8V～3.6V    | コア電圧(LV <sub>DD</sub> ) 1.65～2.7V<br>I/O電圧(HV <sub>DD</sub> ) 1.65～3.6V |

# Appendix F 更新履歴

| Rev. No. | 日付         | ページ   | 章/節                            | 内容                                             |
|----------|------------|-------|--------------------------------|------------------------------------------------|
| 0.8      | 2007.9.21  | 1-3   | 1.3.1 端子配置図                    | 図1.3.1.1変更                                     |
|          |            | 1-4   | 1.3.2 端子説明                     | 表1.3.2.1変更                                     |
|          |            | 23-1  | 23 基本外部結線図                     | 図変更、追加                                         |
|          |            | AP-31 | Appendix D 初期化ルーチン             | サンプルプログラム変更                                    |
| 0.9      | 2007.10.28 | 1-2   | 1.2 ブロック図                      | 図1.2.1変更                                       |
|          |            | 2-1   | 2 CPU                          | 説明変更<br>低消費電力、...組み込み用に最適です。                   |
|          |            | 2-3~5 | 2.3 命令セット                      | 表2.3.1変更(*→*1)<br>注(*2)追加                      |
|          |            | 2-7   | 2.4 ベクターテーブル                   | 表2.4.1変更                                       |
|          |            | 3-1   | 3 メモリマップ、バス制御                  | 図3.1変更                                         |
|          |            | 3-2   | 3.1 バスサイクル                     | 説明変更<br>割り込み処理の...読み出しを行います。                   |
|          |            | 3-2   | 3.1.2 命令実行サイクルの制限              | 節変更                                            |
|          |            | 3-3   | 3.2 内蔵ROMエリア                   | 節タイトル変更                                        |
|          |            | 3-4   | 3.3 内蔵RAMエリア                   | 節タイトル変更                                        |
|          |            | 3-5   | 3.4 内蔵周辺回路エリア                  | 説明変更<br>0x4000番地から...割り付けられています。               |
|          |            | 5-3   | 5.2 イニシャルリセットシーケンス             | 説明変更<br>電源投入時の...OSC3クロック周波数                   |
|          |            | 6-1   | 6.1 ITCの構成                     | 図6.1.1変更                                       |
|          |            | 6-2   | 6.2 ベクターテーブル                   | 表6.2.1変更                                       |
|          |            | 6-3   | 6.3.2 周辺モジュールからの割り込み要求と割り込みフラグ | 表6.3.2.1変更                                     |
|          |            | 6-8   | 6.3.6 S1C17コアの割り込み処理           | 説明追加<br>・ITEN...1に設定されている。                     |
|          |            | 6-11  | 6.6 割り込み要因によるHALT, SLEEPモードの解除 | 節タイトル変更<br>説明変更<br>HALT, SLEEPモード...を参照してください。 |
|          |            | 6-13  | 6.7 制御レジスタ詳細                   | 表6.7.2変更                                       |
|          |            | 6-15  |                                | 表6.7.4変更                                       |
|          |            | 7-1   | 7.1 OSCモジュールの構成                | 図7.1.1変更                                       |
|          |            | 8-1   | 8.1 クロックジェネレータの構成              | 図8.1.1変更                                       |
|          |            | 10-1  | 10.1 入出力ポートの構成                 | 説明(注)変更<br>この機能を使用する...Onにしてください。              |
|          |            | 10-2  | 10.2 入出力端子機能の選択(ポートMUX)        | 説明変更<br>イニシャルリセット...初期化されます。                   |
|          |            | 10-3  | 10.3 データの入出力                   | 説明変更<br>入出力ポートは、PxIO[7:0]...います。               |
|          |            | 10-4  | 10.4 ブルアップ制御                   | 説明変更<br>入出力ポートはブルアップ抵抗...います。                  |
|          |            | 10-7  | 10.7 ポート入力割り込み                 | 説明変更<br>実際に割り込みを発生...参照してください。                 |
|          |            | 10-24 | 10.9 注意事項                      | 説明追加<br>ブルアップ<br>・使用しない入出力ポート...ください。          |
|          |            | 11-3  | 11.2.2 外部クロックモード               | 説明変更<br>チャタリング除去回路の制御...ください。                  |
|          |            | 11-8  | 11.6 16ビットタイマRUN/STOP制御        | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)             |
|          |            | 11-10 | 11.8 16ビットタイマ割り込み              | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)             |
|          |            | 12-2  | 12.2 8ビットタイマのカウントモード           | 説明追加<br>注: カウントモードの設定は、...ください。                |
|          |            | 12-6  | 12.6 8ビットタイマRUN/STOP制御         | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)             |
|          |            | 12-9  | 12.9 8ビットタイマ割り込み               | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)             |
|          |            | 12-15 | 12.10 制御レジスタ詳細                 | 説明追加(0x4206, D4)<br>注: カウントモードの設定は、...ください。    |
|          |            | 13-4  | 13.4 コンペアデータの設定                | カウンタリセット周期計算式を追加                               |
|          |            | 13-5  | 13.5 PWM&キャプチャタイマRUN/STOP制御    | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)             |

| Rev. No. | 日付         | ページ                         | 章/節                        | 内容                                                        |
|----------|------------|-----------------------------|----------------------------|-----------------------------------------------------------|
| 0.9      | 2007.10.28 | 13-8                        | 13.6 クロック出力の制御             | 説明変更<br>ファインモードのクロック ... 変化します。<br>---                    |
|          |            | 13-9                        | 13.7 PWM&キャプチャタイマ割り込み      | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)                        |
|          |            | 13-20                       | 13.9 注意事項                  | 説明変更<br>・コンペアデータをA > B ... 固定されます。                        |
|          |            | 14-2                        | 14.2 8ビットOSC1タイマのカウントモード   | 説明追加<br>注: カウントモードの設定は、... ください。                          |
|          |            | 14-5                        | 14.5 コンペアデータの設定            | コンペアマッチ周期計算式を追加                                           |
|          |            | 14-6                        | 14.6 8ビットOSC1タイマRUN/STOP制御 | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)                        |
|          |            | 14-7                        | 14.7 8ビットOSC1タイマ割り込み       | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)                        |
|          |            | 14-10                       | 14.8 制御レジスタ詳細              | 説明追加(0x50c0、D1)<br>注: カウントモードの設定は、... ください。               |
|          |            | 15-4                        | 15.4 計時タイマRUN/STOP制御       | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)                        |
|          |            | 15-5                        | 15.5 計時タイマ割り込み             | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)                        |
|          |            | 16-5                        | 16.5 ストップウォッチタイマRUN/STOP制御 | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)                        |
|          |            | 16-6                        | 16.6 ストップウォッチタイマ割り込み       | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)                        |
|          |            | 18-9                        | 18.7 UART割り込み              | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)                        |
|          |            | 19-8                        | 19.6 SPI割り込み               | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)                        |
|          |            | 20-1,<br>20-11,<br>20-18~19 | 20 I <sup>2</sup> C        | 割り込み名称変更<br>受信割り込み→受信バッファフル割り込み<br>送信割り込み→送信バッファエンブティ割り込み |
|          |            | 20-11                       | 20.6 I <sup>2</sup> C割り込み  | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)                        |
|          |            | 21-3                        | 21.3 キャリアの生成               | キャリアH/L区間計算式を追加                                           |
|          |            | 21-6                        | 21.5 データ送受信の制御             | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)                        |
|          |            | 21-8                        | 21.6 REMC割り込み              | 説明変更(1カ所のみ)<br>ITC→割り込みコントローラ(ITC)                        |
|          |            | 21-13                       | 21.7 制御レジスタ詳細              | キャリアH区間計算式を追加                                             |
|          |            | 21-14                       |                            | キャリアL区間計算式を追加                                             |
|          |            | 22-1                        | 22.1 リソース要件とデバッグツール        | ICDの記述を変更<br>ICD Mini→ICD(S5U1C17001H等)                   |
|          |            | 22-2                        | 22.2 デバッグブレーク時の動作状態        | 説明追加<br>O1DBGを1に設定しても... 停止しません。                          |
|          |            | 22-4                        | 22.3 制御レジスタ詳細              | 説明追加(0x5322、D0)<br>O1DBGを1に設定しても... 停止しません。               |
|          |            | 23-1~2                      | 23 基本外部結線図                 | 表変更                                                       |
|          |            | 24-1                        | 24.2 推奨動作条件                | 表変更                                                       |
|          |            | 24-2~3                      | 24.5 AC特性                  | 24.5.1~24.5.4節および表追加                                      |
|          |            | 24-6~7                      | 24.7 特性グラフ(参考値)            | グラフ(TBD)追加                                                |
|          |            | AP-23                       | Appendix A I/Oレジスター一覧      | 誤記訂正<br>0x5340~0x5347 Remote Controller                   |
|          |            | AP-25                       | B.1 クロック制御によるパワーセーブ        | 図B.1.1変更                                                  |
|          |            | AP-26                       |                            | 説明変更<br>・slp命令の実行<br>... 起動(後述)に限られます。                    |
|          |            | AP-27                       |                            | 表B.1.1および説明変更<br>HALT, SLEEPモードの解除方法<br>... 処理ルーチンに分岐します。 |
| 1.0      | 2008.1.30  | 1-1                         | 1.1 特長                     | TBD部Fix                                                   |
|          |            | 7-2                         | 7.2 OSC3発振回路               | 図7.2.1変更<br>説明追加<br>また、必要に応じて... 接続してください。                |
|          |            | 7.3                         | 7.3 OSC1発振回路               | 図7.3.1変更<br>説明追加<br>また、必要に応じて... 接続してください。                |
|          |            | 11-3                        | 11.2.2 外部クロックモード           | (TBD)削除                                                   |

| Rev. No. | 日付        | ページ    | 章/節                                 | 内容                                                                                         |
|----------|-----------|--------|-------------------------------------|--------------------------------------------------------------------------------------------|
| 1.0      | 2008.1.30 | 11-6   | 11.4 16ビットタイマリロードレジスタと<br>アンダーフロー周期 | TBD部Fix                                                                                    |
|          |           | 11-9   | 11.7 16ビットタイマ出力信号                   | TBD部Fix                                                                                    |
|          |           | 12-4   | 12.4 8ビットタイマリロードレジスタと<br>アンダーフロー周期  | TBD部Fix                                                                                    |
|          |           | 12-8   | 12.8 フайнモード                        | (TBD)削除                                                                                    |
|          |           | 12-14  | 12.10 制御レジスタ詳細<br>0x4206            | (TBD)削除                                                                                    |
|          |           | 17-3   | 17.3.3 ウオッチドッグタイマのリセット              | (TBD)削除                                                                                    |
|          |           |        | 17.4 制御レジスタ詳細<br>0x5041             | (TBD)削除                                                                                    |
|          |           | 23-1   | 23 基本外部結線図                          | 図、表変更                                                                                      |
|          |           | 24-1~6 | 24 電気的特性                            | 全特性表変更<br>特性グラフ削除                                                                          |
|          | 2008.2.8  | 1-1    | 1 概要                                | 説明削除<br>オンチップICE機能は、... 可能とします。                                                            |
|          |           | 1-1    | 1.1 特長                              | 説明変更<br>●メイン(OSC3)発振回路<br>●サブ(OSC1)発振回路<br>●シリアルインターフェース<br>説明追加<br>●マスクROMコード開発用Flashメモリ品 |
|          |           | 1-4    | 1.3.2 端子説明                          | 表1.3.2.1変更                                                                                 |
|          |           | 7-2    | 7.2 OSC3発振回路                        | 図7.2.1変更<br>説明追加<br>外部クロックを使用...入力してください。                                                  |
|          |           | 7-4    | 7.3 OSC1発振回路                        | 図7.3.1変更<br>説明追加<br>外部クロックを使用...入力してください。                                                  |
|          |           | 12-4   | 12.4 8ビットタイマリロードレジスタと<br>アンダーフロー周期  | (TBD)削除                                                                                    |
|          |           | 18-1   | 18.1 UARTの構成                        | 説明変更<br>UARTは150~460800bps(IrDAモードは<br>115200bps)...転送を行います。                               |
|          |           | 18-21  | 18.10 注意事項                          | 説明変更<br>UARTの...最大460800bps(IrDAモードは<br>115200bps)に制限されています。                               |
|          |           | 24-1   | 24.2 推奨動作条件                         | 表変更(動作周波数追加)                                                                               |
|          |           | 24-3   | 24.4 消費電流                           | 説明変更<br>*1 実行時の...ROMからフェッチ...させた<br>場合の値です。                                               |
|          |           | 24-5   | 24.5.3 外部クロック入力AC特性                 | 表変更(UART転送レート)                                                                             |
|          |           | AP-31  | Appendix D 初期化ルーチン                  | サンプルコードコメント削除<br>(under 3.3 MHz system clock)                                              |
|          |           | AP-32  |                                     | 説明削除<br>(システムクロックが3.3MHz...可能です。)                                                          |
|          |           | AP-33  |                                     | 章追加                                                                                        |

## 改訂履歴表

| コードNo.    | ページ           | 改訂内容(旧内容を含む)および改訂理由                                                                                                                                                                     |
|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 411412002 | 4, 5, 6       | 説明追加<br>パッケージ、端子説明                                                                                                                                                                      |
|           | 11            | 説明変更<br>分岐 ipa.d→jpa.d                                                                                                                                                                  |
|           | 63, 64        | 図7.6.2、図7.6.3変更                                                                                                                                                                         |
|           | 218           | 説明変更<br>(2) RDRY = 1, RD2B = 0...したがって、受信データバッファはオーバーランエラーが発生する前に読み出してください。                                                                                                             |
|           | 219, 231, 233 | 説明変更<br>RXENビットを0に設定すると、送信データバッファは空の状態になります<br>RXENに0を書き込んで送受信を禁止すると、送信データバッファもクリアされます。<br>•RXENを0に設定して送受信を禁止すると、送信データバッファがクリア(初期化)されます。RXENに0を書き込む前に、バッファ内に送信待ちのデータが残っていないことを確認してください。 |
|           | 220           | 説明変更<br>受信データバッファが満杯(2データ受信済み)の状態...送られず、オーバーランエラーが発生します。                                                                                                                               |
|           | 226           | 説明変更<br>FERIは1を書き込むことによりリセットされます。...OERIは1を書き込むことによりリセットされます。                                                                                                                           |
|           | 237           | 説明削除<br>内部回路はPCLKクロック...同期用に使用されます。<br>説明削除<br>クロックの周波数はPCLKの1/3以下で、<br>図19.3.2削除                                                                                                       |
|           | 238           | 説明追加<br>図19.4.2追加                                                                                                                                                                       |
|           | 240, 241      | 図19.5.1、図19.5.2削除<br>図19.5.1追加                                                                                                                                                          |
|           | 241           | 説明変更<br>データ転送(送信と受信の両方)を終了後は...を0に設定した場合、転送中のデータは保証されません。                                                                                                                               |
|           | 246           | 説明追加<br>注:データの送受信を行う場合、SPI_TXDへの書き込みはSPENを1に設定した後に行ってください。                                                                                                                              |
|           | 255           | 説明変更<br>(1)レジスタの設定順序...または3回の送信を行います。アドレスデータの構成を図20.5.2に示します。                                                                                                                           |
|           | 256           | 図20.5.2変更                                                                                                                                                                               |
|           | 257           | 説明変更<br>9個目のクロックサイクルでは、RTACK...正しい通信が行えなくなってしまいます。                                                                                                                                      |
|           | 258           | 説明変更<br>ストップコンディションを生成した後は...出力レベル、および転送中のデータは保証されません。                                                                                                                                  |
|           | 259           | 図20.5.5変更                                                                                                                                                                               |
|           | 260           | 図20.5.7、図20.5.8変更                                                                                                                                                                       |
|           | 261           | 図20.9変更                                                                                                                                                                                 |
|           | 262           | 説明追加<br>送信バッファエンブティ割り込み...割り込みを判断してください。送信バッファエンブティ割り込み、または、受信バッファフル割り込みのどちらが発生したかを確認できるレジスタはありません。                                                                                     |
|           | 266           | 説明変更<br>スタートコンディションを生成するには、以下の順序でレジスタを設定して...3.SRTTを1に設定                                                                                                                                |
|           | 303           | EXCLx入力High/パルス幅 1/fSYS→2/fSYS<br>EXCLx入力Low/パルス幅 1/fSYS→2/fSYS                                                                                                                         |

**セイコーエプソン株式会社  
マイクロデバイス事業本部 デバイス営業部**

---

<IC国内営業グループ>

東京 〒191-8501 東京都日野市日野421-8

TEL (042) 587-5313(直通) FAX (042) 587-5116

大阪 〒541-0059 大阪市中央区博労町3-5-1 エプソン大阪ビル15F  
TEL (06) 6120-6000(代表) FAX (06) 6120-6100

---

ドキュメントコード: 411412003  
2008年4月 作成  
2011年3月 改訂 (H)