19.4MB

本ドキュメントはCypress (サイプレス) 製品に関する情報が記載されております。
New 8FX
MB95710L/770L シリーズ
MB95710M/770M シリーズ
8 ビット・マイクロコントローラ
ハードウェアマニュアル
MB90880???? Cover Sheet
Hardware Manual
Publication Number MB95F718M_MN702-00014
Revision 3.0
Issue Date April 4, 2014
New 8FX
MB95710L/770L シリーズ
MB95710M/770M シリーズ
8 ビット・マイクロコントローラ
ハードウェアマニュアル
MB90880???? Cover Sheet
Hardware Manual
Spansion のマイコンを効率的に開発するための情報を下記 URL にてご紹介いたします。
ご採用を検討中 , またはご採用いただいたお客様に有益な情報を公開しています。
http://www.spansion.com/JP/Support/microcontrollers/
Ha rdware
Manual
はじめに
■ 本書の目的と対象読者
Spansion 製品につきまして , 平素より格別のご愛読を賜り厚くお礼申し上げます。
MB95710L/770L シリーズは , ASIC (Application Specific IC) 対応が可能なオリジナル 8
ビット・ワンチップ・マイクロコントローラである New 8FX ファミリの汎用品の 1 つ
として開発された製品です。MB95710L/770L シリーズは , 携帯機器をはじめ民生機器
から産業機器まで , 幅広い用途でご利用いただけます。
本書は , 実際に MB95710L/770L シリーズマイクロコントローラを使って製品を設計す
る技術者を対象に , その機能や動作について記載していますので , ぜひご一読くださ
い。
なお , 各種命令の詳細については ,「F2MC-8FX プログラミングマニュアル」を参照して
ください。
本マニュアルは周辺機能の構成および動作を説明するものであり , 各デバイスの使用
を説明するものではありません。
デバイス仕様の詳細については , それぞれのデータシートを参照してください。
■ 商標
F2MC は , Spansion LLC の登録商標です。
本書に記載されている社名および製品名などの固有名詞は , 各社の商標または登録商
標です。
■ サンプルプログラム
Spansion Inc.は, New 8FX ファミリマイクロコントローラの周辺機器を動作させるため
のサンプルプログラムを無償で提供いたします。サンプルプログラムを使用し ,
Spansion マイクロコントローラの動作仕様や使用方法の確認にお役立てください。
サンプルプログラムは, 予告なく変更される場合がありますのでご注意ください。これ
らのソフトウェアは , 標準的な動作や使い方を示したものですので , お客様のシステム
上でご使用の際には十分に評価した上でご使用ください。Spansion Inc. は , これらサン
プルプログラムの使用に起因する損害などについては一切責任を負いません。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
i
H ard war e
Ma nu al
本書の使い方
■ 機能の探し方
本書では次の方法で , 使いたい機能の説明を探すことができます。
• 目次から探す
本書の内容を記載順に示します。
• レジスタから探す
本文中では各レジスタの配置アドレスを記載しておりません。各レジスタのアドレスを確認するときは
データシートの「■ I/O マップ」を参照してください。
■ 章について
本書では , 基本的に 1 つの周辺機能を 1 つの章で説明しています。
■ 用語について
本書で使用している用語について示します。
用語
説明
ワード
16 ビット単位によるアクセスを指します。
バイト
8 ビット単位によるアクセスを指します。
■ 表記について
本書の「■ レジスタ構成」のレジスタ構成表では以下のように表記しています。
• bit: ビット番号
• Field: ビットフィールド名
• 属性 : 各ビットのリード , ライト属性
- R: リードオンリ
- W: ライトオンリ
- R/W: リード ・ ライト可能
- —: 未定義
• 初期値 : リセット直後のレジスタ初期値
- 0: 初期値 "0"
- 1: 初期値 "1"
- X: 初期値不定
本書では , 複数のビットを以下のように表記しています。
例 1: bit7 から bit0 の場合は bit7:0
例 2: SCM2 から SCM0 の場合は SCM[2:0]
本書では , アドレスなどの数値を以下のように表記しています。
• 16 進数 : プレフィックス ( 接頭辞 ) として "0x" を付けて表記しています ( 例 : 0xFFFF)。
• 2 進数 : プレフィックス ( 接頭辞 ) として "0b" を付けて表記しています ( 例 : 0b1111)。
• 10 進数 : 数値だけで表記しています ( 例 : 1234)。
本書では , 端子名とレジスタ略称にある "n" はチャネル番号を示します。
ii
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
April 4, 2014, MB95F718M_MN702-00014-3v0-J
Manual
iii
H ard war e
iv
Ma nu al
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
目次
第1章
1.1
第2章
メモリアクセスモード ............................................................................... 1
メモリアクセスモード............................................................................................................ 2
CPU............................................................................................................ 3
2.1 専用レジスタ .......................................................................................................................... 4
2.1.1
レジスタバンクポインタ (RP)......................................................................................... 7
2.1.2
ダイレクトバンクポインタ (DP) ..................................................................................... 8
2.1.3
コンディションコードレジスタ (CCR) ......................................................................... 10
2.2 汎用レジスタ ........................................................................................................................ 12
2.3 16 ビットデータのメモリ上の配置 ...................................................................................... 14
第3章
クロック制御部 ........................................................................................ 15
3.1 概要 ...................................................................................................................................... 16
3.2 発振安定待ち時間 ................................................................................................................. 24
3.3 レジスタ ............................................................................................................................... 27
3.3.1
システムクロック制御レジスタ (SYCC) ....................................................................... 28
3.3.2
PLL 制御レジスタ (PLLC) ............................................................................................. 30
3.3.3
発振安定待ち時間設定レジスタ (WATR) ...................................................................... 32
3.3.4
スタンバイ制御レジスタ (STBC) .................................................................................. 34
3.3.5
システムクロック制御レジスタ 2 (SYCC2) .................................................................. 36
3.4 クロックモード .................................................................................................................... 39
3.5 低消費電力モード ( スタンバイモード ) の動作 ................................................................... 45
3.5.1
スタンバイモード使用上の注意 .................................................................................... 46
3.5.2
スリープモード ............................................................................................................. 49
3.5.3
ストップモード ............................................................................................................. 50
3.5.4
タイムベースタイマモード ........................................................................................... 52
3.5.5
時計モード..................................................................................................................... 54
3.6 クロック発振回路 ................................................................................................................. 55
3.7 プリスケーラの概要 ............................................................................................................. 56
3.8 プリスケーラの構成 ............................................................................................................. 57
3.9 プリスケーラの動作 ............................................................................................................. 58
3.10 プリスケーラ使用上の注意................................................................................................... 60
第4章
リセット................................................................................................... 61
4.1 リセット動作 ........................................................................................................................ 62
4.2 レジスタ ............................................................................................................................... 66
4.2.1
リセット要因レジスタ (RSRR) ..................................................................................... 67
4.3 使用上の注意 ........................................................................................................................ 70
第5章
割込み ...................................................................................................... 71
5.1 割込み ................................................................................................................................... 72
5.1.1
割込みレベル設定レジスタ (ILR0 ~ ILR5) ................................................................... 73
5.1.2
割込み動作時の処理 ...................................................................................................... 75
5.1.3
多重割込み..................................................................................................................... 78
April 4, 2014, MB95F718M_MN702-00014-3v0-J
v
H ard war e
5.1.4
5.1.5
5.1.6
第6章
6.1
6.2
Ma nu al
割込み処理時間 ............................................................................................................. 79
割込み処理時のスタック動作........................................................................................ 80
割込み処理のスタック領域 ........................................................................................... 81
I/O ポート................................................................................................. 83
概要 ...................................................................................................................................... 84
構成と動作............................................................................................................................ 85
第7章
タイムベースタイマ................................................................................. 89
7.1 概要 ...................................................................................................................................... 90
7.2 構成 ...................................................................................................................................... 91
7.3 割込み ................................................................................................................................... 93
7.4 動作説明と設定手順例.......................................................................................................... 94
7.5 レジスタ ............................................................................................................................... 98
7.5.1
タイムベースタイマ制御レジスタ (TBTC) .................................................................... 99
7.6 使用上の注意 ...................................................................................................................... 101
第8章
ハードウェア / ソフトウェアウォッチドッグタイマ ............................. 103
8.1 概要 .................................................................................................................................... 104
8.2 構成 .................................................................................................................................... 106
8.3 動作説明と設定手順例........................................................................................................ 108
8.4 レジスタ ............................................................................................................................. 111
8.4.1
ウォッチドッグタイマ制御レジスタ (WDTC)............................................................. 112
8.5 使用上の注意 ...................................................................................................................... 114
第9章
時計プリスケーラ .................................................................................. 117
9.1 概要 .................................................................................................................................... 118
9.2 構成 .................................................................................................................................... 119
9.3 割込み ................................................................................................................................. 121
9.4 動作説明と設定手順例........................................................................................................ 122
9.5 レジスタ ............................................................................................................................. 125
9.5.1
時計プリスケーラ制御レジスタ (WPCR) .................................................................... 126
9.6 使用上の注意 ...................................................................................................................... 128
第 10 章
時計カウンタ.......................................................................................... 129
10.1 概要 .................................................................................................................................... 130
10.2 構成 .................................................................................................................................... 131
10.3 割込み ................................................................................................................................. 133
10.4 動作説明と設定手順例........................................................................................................ 134
10.5 レジスタ ............................................................................................................................. 136
10.5.1 時計カウンタデータレジスタ (WCDR) ....................................................................... 137
10.5.2 時計カウンタ制御レジスタ (WCSR) ........................................................................... 138
10.6 使用上の注意 ...................................................................................................................... 139
第 11 章
11.1
11.2
11.3
11.4
vi
ワイルドレジスタ機能 ........................................................................... 141
概要 .................................................................................................................................... 142
構成 .................................................................................................................................... 143
動作説明 ............................................................................................................................. 145
レジスタ ............................................................................................................................. 146
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
11.4.1 ワイルドレジスタデータ設定レジスタ (WRDR0 ~ WRDR2) .................................... 147
11.4.2 ワイルドレジスタアドレス設定レジスタ (WRAR0 ~ WRAR2) ................................. 148
11.4.3 ワイルドレジスタアドレス比較許可レジスタ (WREN) .............................................. 149
11.4.4 ワイルドレジスタデータテスト設定レジスタ (WROR).............................................. 150
11.5 一般的なハードウェア接続例 ............................................................................................. 151
第 12 章
8/16 ビット複合タイマ........................................................................... 153
12.1 概要 .................................................................................................................................... 154
12.2 構成 .................................................................................................................................... 156
12.3 チャネル ............................................................................................................................. 159
12.4 端子 .................................................................................................................................... 160
12.5 割込み ................................................................................................................................. 162
12.6 インターバルタイマ機能 ( ワンショットモード ) の動作説明............................................ 163
12.7 インターバルタイマ機能 ( 連続モード ) の動作説明 .......................................................... 165
12.8 インターバルタイマ機能 ( フリーランモード ) の動作説明 ............................................... 167
12.9 PWM タイマ機能 ( 周期固定モード ) の動作説明............................................................... 169
12.10 PWM タイマ機能 ( 周期可変モード ) の動作説明............................................................... 171
12.11 PWC タイマ機能の動作説明 .............................................................................................. 173
12.12 インプットキャプチャ機能の動作説明............................................................................... 175
12.13 ノイズフィルタの動作説明................................................................................................. 177
12.14 レジスタ ............................................................................................................................. 178
12.14.1 8/16 ビット複合タイマステータス制御レジスタ 0 (Tn0CR0/Tn1CR0) ...................... 179
12.14.2 8/16 ビット複合タイマステータス制御レジスタ 1 (Tn0CR1/Tn1CR1) ...................... 182
12.14.3 8/16 ビット複合タイマタイマモード制御レジスタ (TMCRn) ..................................... 186
12.14.4 8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) ........................................... 189
12.15 使用上の注意 ...................................................................................................................... 192
第 13 章
外部割込み回路 ...................................................................................... 195
13.1 概要 .................................................................................................................................... 196
13.2 構成 .................................................................................................................................... 197
13.3 チャネル ............................................................................................................................. 198
13.4 端子 .................................................................................................................................... 199
13.5 割込み ................................................................................................................................. 200
13.6 動作説明と設定手順例........................................................................................................ 201
13.7 レジスタ ............................................................................................................................. 203
13.7.1 外部割込み制御レジスタ (EIC).................................................................................... 204
13.8 使用上の注意 ...................................................................................................................... 207
第 14 章
割込み端子選択回路.............................................................................. 209
14.1 概要 .................................................................................................................................... 210
14.2 構成 .................................................................................................................................... 211
14.3 端子 .................................................................................................................................... 213
14.4 動作 .................................................................................................................................... 214
14.5 レジスタ ............................................................................................................................. 215
14.5.1 割込み端子選択回路制御レジスタ (WICR).................................................................. 216
14.6 使用上の注意 ...................................................................................................................... 218
第 15 章
8/12 ビット A/D コンバータ................................................................... 219
15.1 概要 .................................................................................................................................... 220
April 4, 2014, MB95F718M_MN702-00014-3v0-J
vii
H ard war e
Ma nu al
15.2 構成 .................................................................................................................................... 221
15.3 端子 .................................................................................................................................... 224
15.4 割込み ................................................................................................................................. 225
15.5 8/12 ビット A/D コンバータの動作許可 ............................................................................. 226
15.6 動作説明と設定手順例........................................................................................................ 227
15.7 レジスタ ............................................................................................................................. 231
15.7.1 8/12 ビット A/D コンバータ制御レジスタ 1 (ADC1)................................................... 232
15.7.2 8/12 ビット A/D コンバータ制御レジスタ 2 (ADC2)................................................... 234
15.7.3 8/12 ビット A/D コンバータ制御レジスタ 3 (ADC3)................................................... 236
15.7.4 8/12 ビット A/D コンバータデータレジスタ ( 上位 / 下位 ) (ADDH/ADDL) ................ 238
15.8 使用上の注意 ...................................................................................................................... 239
第 16 章
低電圧検出回路 ...................................................................................... 241
16.1 概要 .................................................................................................................................... 242
16.2 構成 .................................................................................................................................... 243
16.3 端子 .................................................................................................................................... 244
16.4 割込み ................................................................................................................................. 245
16.5 動作説明 ............................................................................................................................. 246
16.6 レジスタ ............................................................................................................................. 249
16.6.1 LVD 制御レジスタ (LVDC) .......................................................................................... 250
第 17 章
クロックスーパバイザカウンタ ............................................................. 253
17.1 概要 .................................................................................................................................... 254
17.2 構成 .................................................................................................................................... 255
17.3 動作説明 ............................................................................................................................. 257
17.4 レジスタ ............................................................................................................................. 262
17.4.1 クロック監視データレジスタ (CMDR)........................................................................ 263
17.4.2 クロック監視制御レジスタ (CMCR) ........................................................................... 264
17.5 使用上の注意 ...................................................................................................................... 266
第 18 章
8/16 ビット PPG .................................................................................... 269
18.1 概要 .................................................................................................................................... 270
18.2 構成 .................................................................................................................................... 271
18.3 チャネル ............................................................................................................................. 273
18.4 端子 .................................................................................................................................... 274
18.5 割込み ................................................................................................................................. 275
18.6 動作説明と設定手順例........................................................................................................ 276
18.6.1 8 ビット PPG 独立モード ........................................................................................... 277
18.6.2 8 ビットプリスケーラ + 8 ビット PPG モード ........................................................... 279
18.6.3 16 ビット PPG モード ................................................................................................ 282
18.7 レジスタ ............................................................................................................................. 285
18.7.1 8/16 ビット PPG タイマ n1 制御レジスタ (PCn1) ...................................................... 286
18.7.2 8/16 ビット PPG タイマ n0 制御レジスタ (PCn0) ...................................................... 288
18.7.3 8/16 ビット PPG タイマ n1/n0 周期設定バッファレジスタ (PPSn1/PPSn0) ............. 290
18.7.4 8/16 ビット PPG タイマ n1/n0 デューティ設定バッファレジスタ (PDSn1/PDSn0).. 291
18.7.5 8/16 ビット PPG 起動レジスタ (PPGS)...................................................................... 292
18.7.6 8/16 ビット PPG 出力反転レジスタ (REVC) .............................................................. 294
18.8 使用上の注意 ...................................................................................................................... 296
viii
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
第 19 章
Manual
16 ビットリロードタイマ ...................................................................... 297
19.1 概要 .................................................................................................................................... 298
19.2 構成 .................................................................................................................................... 300
19.3 チャネル ............................................................................................................................. 302
19.4 端子 .................................................................................................................................... 303
19.5 割込み ................................................................................................................................. 304
19.6 動作説明と設定手順例........................................................................................................ 305
19.6.1 内部クロックモード .................................................................................................... 307
19.6.2 イベントカウントモード ............................................................................................. 311
19.7 レジスタ ............................................................................................................................. 313
19.7.1 16 ビットリロードタイマ制御ステータスレジスタ ( 上位 ) ch. n (TMCSRHn) .......... 314
19.7.2 16 ビットリロードタイマ制御ステータスレジスタ ( 下位 ) ch. n (TMCSRLn)........... 316
19.7.3 16 ビットリロードタイマタイマレジスタ ( 上位 / 下位 ) ch. n (TMRHn/TMRLn)....... 319
19.7.4 16 ビットリロードタイマリロードレジスタ ( 上位 / 下位 ) ch. n
(TMRLRHn/TMRLRLn)................................................................................................ 320
19.8 使用上の注意 ...................................................................................................................... 321
第 20 章
イベントカウンタ .................................................................................. 323
20.1 概要 .................................................................................................................................... 324
20.2 構成 .................................................................................................................................... 325
20.3 イベントカウンタ動作モードの動作説明 ........................................................................... 326
20.4 設定手順例.......................................................................................................................... 329
20.5 周波数の測定範囲および測定精度...................................................................................... 332
20.6 レジスタ ............................................................................................................................. 333
20.6.1 イベントカウンタ制御レジスタ (EVCR) ..................................................................... 334
20.7 使用上の注意 ...................................................................................................................... 336
第 21 章
UART/SIO .............................................................................................. 337
21.1 概要 .................................................................................................................................... 338
21.2 構成 .................................................................................................................................... 339
21.3 チャネル ............................................................................................................................. 341
21.4 端子 .................................................................................................................................... 342
21.5 割込み ................................................................................................................................. 343
21.6 動作説明と設定手順例........................................................................................................ 344
21.6.1 動作モード 0 の動作説明............................................................................................. 345
21.6.2 動作モード 1 の動作説明............................................................................................. 352
21.7 レジスタ ............................................................................................................................. 358
21.7.1 UART/SIO シリアルモード制御レジスタ 1 ch. n (SMC1n)......................................... 359
21.7.2 UART/SIO シリアルモード制御レジスタ 2 ch. n (SMC2n)......................................... 361
21.7.3 UART/SIO シリアルステータスアンドデータレジスタ ch. n (SSRn)......................... 363
21.7.4 UART/SIO シリアル入力データレジスタ ch. n (RDRn) .............................................. 365
21.7.5 UART/SIO シリアル出力データレジスタ ch. n (TDRn) .............................................. 366
第 22 章
22.1
22.2
22.3
22.4
UART/SIO 専用 ボーレートジェネレータ ............................................. 367
概要 .................................................................................................................................... 368
チャネル ............................................................................................................................. 369
動作説明 ............................................................................................................................. 370
レジスタ ............................................................................................................................. 371
April 4, 2014, MB95F718M_MN702-00014-3v0-J
ix
H ard war e
Ma nu al
22.4.1
UART/SIO 専用ボーレートジェネレータプリスケーラ選択レジスタ ch. n
(PSSRn) ...................................................................................................................... 372
22.4.2
UART/SIO 専用ボーレートジェネレータボーレート設定レジスタ ch. n (BRSRn) .... 373
第 23 章
I2C バスインタフェース......................................................................... 375
23.1 概要 .................................................................................................................................... 376
23.2 構成 .................................................................................................................................... 377
23.3 チャネル ............................................................................................................................. 380
23.4 端子 .................................................................................................................................... 381
23.5 割込み ................................................................................................................................. 382
23.6 動作説明と設定手順例........................................................................................................ 384
23.6.1 l2C バスインタフェース .............................................................................................. 385
23.6.2 MCU スタンバイモードに対するウェイクアップ機能................................................ 393
23.7 レジスタ ............................................................................................................................. 395
23.7.1 I2C バス制御レジスタ 0 ch. n (IBCR0n) ...................................................................... 396
23.7.2 I2C バス制御レジスタ 1 ch. n (IBCR1n) ...................................................................... 400
23.7.3 I2C バスステータスレジスタ ch. n (IBSRn) ................................................................ 404
23.7.4 I2C データレジスタ ch. n (IDDRn) .............................................................................. 407
23.7.5 I2C アドレスレジスタ ch. n (IAARn) ........................................................................... 408
23.7.6 I2C クロック制御レジスタ ch. n (ICCRn) ................................................................... 409
23.8 使用上の注意 ...................................................................................................................... 411
第 24 章
LCD コントローラ (MB95710L シリーズ ) ............................................ 413
24.1 概要 .................................................................................................................................... 414
24.2 構成 .................................................................................................................................... 415
24.2.1 LCD コントローラの内部分割抵抗.............................................................................. 418
24.2.2 LCD コントローラの外部分割抵抗.............................................................................. 422
24.3 端子 .................................................................................................................................... 424
24.4 ディスプレイ RAM ............................................................................................................. 425
24.5 割込み ................................................................................................................................. 427
24.6 動作説明 ............................................................................................................................. 428
24.6.1 4 COM モードにおける LCD コントローラ動作時の出力波形
(1/2 バイアス , 1/2 デューティ ) .................................................................................. 433
24.6.2 4 COM モードにおける LCD コントローラ動作時の出力波形
(1/3 バイアス , 1/3 デューティ ) .................................................................................. 434
24.6.3 4 COM モードにおける LCD コントローラ動作時の出力波形
(1/3 バイアス , 1/4 デューティ ) .................................................................................. 436
24.6.4 8 COM モードにおける LCD コントローラ動作時の出力波形
(1/3 バイアス , 1/8 デューティ ) .................................................................................. 438
24.6.5 8 COM モードにおける LCD コントローラ動作時の出力波形
(1/4 バイアス , 1/8 デューティ ) .................................................................................. 440
24.7 レジスタ ............................................................................................................................. 442
24.7.1 LCDC 制御レジスタ 1 (LCDCC1)................................................................................ 443
24.7.2 LCDC 制御レジスタ 2 (LCDCC2)................................................................................ 446
24.7.3 LCDC 許可レジスタ 1 (LCDCE1)................................................................................ 448
24.7.4 LCDC 許可レジスタ 2 (LCDCE2)................................................................................ 450
24.7.5 LCDC 許可レジスタ 3 (LCDCE3)................................................................................ 452
24.7.6 LCDC 許可レジスタ 4 (LCDCE4)................................................................................ 454
24.7.7 LCDC 許可レジスタ 5 (LCDCE5)................................................................................ 456
24.7.8 LCDC 許可レジスタ 6 (LCDCE6)................................................................................ 458
x
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
24.7.9 LCDC 許可レジスタ 7 (LCDCE7)................................................................................ 460
24.7.10 LCDC ブリンキング設定レジスタ 1 (LCDCB1) .......................................................... 462
24.7.11 LCDC ブリンキング設定レジスタ 2 (LCDCB2) .......................................................... 465
24.8 使用上の注意 ...................................................................................................................... 468
第 25 章
LCD コントローラ (MB95770L シリーズ ) ............................................ 469
25.1 概要 .................................................................................................................................... 470
25.2 構成 .................................................................................................................................... 471
25.2.1 LCD コントローラの内部分割抵抗.............................................................................. 474
25.2.2 LCD コントローラの外部分割抵抗.............................................................................. 478
25.3 端子 .................................................................................................................................... 480
25.4 ディスプレイ RAM ............................................................................................................. 481
25.5 割込み ................................................................................................................................. 483
25.6 動作説明 ............................................................................................................................. 484
25.6.1 4 COM モードにおける LCD コントローラ動作時の出力波形
(1/2 バイアス , 1/2 デューティ ) .................................................................................. 489
25.6.2 4 COM モードにおける LCD コントローラ動作時の出力波形
(1/3 バイアス , 1/3 デューティ ) .................................................................................. 490
25.6.3 4 COM モードにおける LCD コントローラ動作時の出力波形
(1/3 バイアス , 1/4 デューティ ) .................................................................................. 492
25.6.4 8 COM モードにおける LCD コントローラ動作時の出力波形
(1/3 バイアス , 1/8 デューティ ) .................................................................................. 494
25.6.5 8 COM モードにおける LCD コントローラ動作時の出力波形
(1/4 バイアス , 1/8 デューティ ) .................................................................................. 496
25.7 レジスタ ............................................................................................................................. 498
25.7.1 LCDC 制御レジスタ 1 (LCDCC1)................................................................................ 499
25.7.2 LCDC 制御レジスタ 2 (LCDCC2)................................................................................ 502
25.7.3 LCDC 許可レジスタ 1 (LCDCE1)................................................................................ 504
25.7.4 LCDC 許可レジスタ 2 (LCDCE2)................................................................................ 506
25.7.5 LCDC 許可レジスタ 3 (LCDCE3)................................................................................ 508
25.7.6 LCDC 許可レジスタ 4 (LCDCE4)................................................................................ 510
25.7.7 LCDC 許可レジスタ 5 (LCDCE5)................................................................................ 512
25.7.8 LCDC 許可レジスタ 6 (LCDCE6)................................................................................ 514
25.7.9 LCDC ブリンキング設定レジスタ 1 (LCDCB1) .......................................................... 516
25.7.10 LCDC ブリンキング設定レジスタ 2 (LCDCB2) .......................................................... 519
25.8 使用上の注意 ...................................................................................................................... 522
第 26 章
シリアル書込み接続例 ........................................................................... 523
26.1 シリアル書込み接続の基本構成 ......................................................................................... 524
26.2 シリアル書込み接続例........................................................................................................ 525
第 27 章
デュアルオペレーションフラッシュメモリ ........................................... 527
27.1 概要 .................................................................................................................................... 528
27.2 セクタ / バンク構成 ............................................................................................................ 530
27.3 フラッシュメモリ自動アルゴリズムの起動方法 ................................................................ 531
27.4 自動アルゴリズム実行状態の確認...................................................................................... 533
27.4.1 データポーリングフラグ (DQ7) .................................................................................. 535
27.4.2 トグルビットフラグ (DQ6) ......................................................................................... 537
27.4.3 タイミングリミット超過フラグ (DQ5) ....................................................................... 539
27.4.4 セクタ消去タイマフラグ (DQ3) .................................................................................. 540
April 4, 2014, MB95F718M_MN702-00014-3v0-J
xi
H ard war e
Ma nu al
27.4.5 トグルビット 2 フラグ (DQ2)...................................................................................... 541
27.5 フラッシュメモリの書込み / 消去....................................................................................... 542
27.5.1 フラッシュメモリの読出し / リセット状態への遷移................................................... 543
27.5.2 フラッシュメモリへのデータ書込み ........................................................................... 544
27.5.3 フラッシュメモリの全データ消去 ( チップ消去 ) ....................................................... 546
27.5.4 フラッシュメモリの特定データ消去 ( セクタ消去 ) .................................................... 547
27.5.5 フラッシュメモリセクタ消去の一時停止.................................................................... 549
27.5.6 フラッシュメモリセクタ消去の再開 ........................................................................... 550
27.5.7 アンロックバイパス書込み ......................................................................................... 551
27.6 動作説明 ............................................................................................................................. 552
27.7 フラッシュセキュリティ .................................................................................................... 554
27.8 レジスタ ............................................................................................................................. 555
27.8.1 フラッシュメモリステータスレジスタ 2 (FSR2) ........................................................ 556
27.8.2 フラッシュメモリステータスレジスタ (FSR) ............................................................. 559
27.8.3 フラッシュメモリセクタ書込み制御レジスタ 0 (SWRE0) ......................................... 562
27.8.4 フラッシュメモリステータスレジスタ 3 (FSR3) ........................................................ 564
27.8.5 フラッシュメモリステータスレジスタ 4 (FSR4) ........................................................ 566
27.9 使用上の注意 ...................................................................................................................... 574
第 28 章
不揮発性レジスタ (NVR) インタフェース ............................................. 575
28.1 概要 .................................................................................................................................... 576
28.2 構成 .................................................................................................................................... 577
28.3 レジスタ ............................................................................................................................. 578
28.3.1 メイン CR クロックトリミングレジスタ ( 上位 ) (CRTH) .......................................... 579
28.3.2 メイン CR クロックトリミングレジスタ ( 下位 ) (CRTL) ........................................... 580
28.3.3 メイン CR クロック温度依存調節レジスタ (CRTDA)................................................. 581
28.3.4 ウォッチドッグタイマ選択 ID レジスタ ( 上位 / 下位 ) (WDTH/WDTL)...................... 582
28.4 メイン CR クロックトリミング使用上の注意 .................................................................... 583
28.5 使用上の注意 ...................................................................................................................... 585
第 29 章
コンパレータ.......................................................................................... 587
29.1 概要 .................................................................................................................................... 588
29.2 構成 .................................................................................................................................... 589
29.3 端子 .................................................................................................................................... 591
29.4 割込み ................................................................................................................................. 592
29.5 動作説明と設定手順例........................................................................................................ 593
29.6 レジスタ ............................................................................................................................. 594
29.6.1 コンパレータ制御レジスタ ch. n (CMRn) ................................................................... 595
第 30 章
システム構成コントローラ .................................................................... 597
30.1 概要 .................................................................................................................................... 598
30.2 レジスタ ............................................................................................................................. 599
30.2.1 システム構成レジスタ (SYSC) ................................................................................... 600
30.2.2 システム構成レジスタ 2 (SYSC2) .............................................................................. 603
30.3 使用上の注意 ...................................................................................................................... 604
付録
付録 A
A.1
xii
............................................................................................................... 607
命令概要 ........................................................................................................................ 608
アドレッシング ........................................................................................................... 611
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
A.2
A.3
A.4
A.5
付録 B
Manual
特殊な命令について.................................................................................................... 615
ビット操作命令 (SETB, CLRB)................................................................................... 619
F2MC-8FX 命令一覧表 ................................................................................................ 620
命令マップ .................................................................................................................. 624
主な変更内容 ................................................................................................................. 625
April 4, 2014, MB95F718M_MN702-00014-3v0-J
xiii
H ard war e
xiv
Ma nu al
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第1章
メモリアクセスモード
メモリアクセスモードについて説明します。
1.1
April 4, 2014, MB95F718M_MN702-00014-3v0-J
メモリアクセスモード
1
第 1 章 メモリアクセスモード
1.1 メモリアクセスモード
H ard war e
Ma nu al
メモリアクセスモード
1.1
本シリーズ のメモリアクセスは , シングルチップモードのみです。
■ シングルチップモード
シングルチップモードでは , 内部の RAM およびフラッシュメモリのみが使用され , 外
部バスアクセスは行いません。
● モードデータ
モードデータは ,CPU のメモリアクセスモードを決定するデータです。
モードデータアドレスは ,"0xFFFD" に固定されます。フラッシュメモリのモードデータ
は必ず "0x00" に設定してシングルチップモードを選択してください。
図 1.1-1 モードデータの設定
アドレス
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
0xFFFD
動作
データ
0x00
0x00以外
シングルチップモード選択
予約済み, 0x00以外モードデータに設定しないでください
リセット解除後に , CPU は最初にモードデータをフェッチします。
CPU はモードデータの次に , リセットベクタをフェッチします。リセットベクタで設定
されたアドレスから命令の実行を開始します。
2
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第2章
CPU
CPU の機能と動作について説明します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
2.1
専用レジスタ
2.2
汎用レジスタ
2.3
16 ビットデータのメモリ上の配置
3
第 2 章 CPU
2.1 専用レジスタ
H ard war e
2.1
Ma nu al
専用レジスタ
CPU には , プログラムカウンタ (PC), 2 つの演算用レジスタ (A, T), 3 つのアドレスポ
インタ (IX, EP, SP) およびプログラムステータス (PS) の専用レジスタがあります。各
レジスタは , 16 ビット長です。PS レジスタは , レジスタバンクポインタ (RP), ダイレ
クトバンクポインタ (DP) およびコンディションコードレジスタ (CCR) から構成され
ます。
■ 専用レジスタの構成
CPU 内の専用レジスタは , 7 つの 16 ビットレジスタから構成されます。アキュムレータ
(A) およびテンポラリアキュムレータ (T) については , 下位 8 ビットのみの使用もでき
ます。
図 2.1-1 に , 専用レジスタの構成を示します。
図 2.1-1 専用レジスタの構成
16 ビット
初期値
: プログラムカウンタ
PC
0xFFFD
現在の命令格納位置を示します。
0x0000
AH
AL
: アキュムレータ (A)
0x0000
TH
TL
: テンポラリアキュムレータ (T)
演算や転送などの一時記憶レジスタです。
アキュムレータとの間で演算を行います。
0x0000
IX
: インデックスレジスタ
0x0000
EP
: エクストラポインタ
インデックスアドレスを示すレジスタです。
メモリアドレスを示すポインタです。
0x0000
: スタックポインタ
SP
現在のスタック位置を示します。
0x0030
RP
DP
PS
4
CCR
: プログラムステータス
レジスタバンクポインタ, ダイレクトバンクポインタ
やコンディションコードを格納するレジスタです。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 2 章 CPU
2.1 専用レジスタ
Ha rdware
Manual
■ 専用レジスタの機能
● プログラムカウンタ (PC)
プログラムカウンタは , CPU により現在実行されている命令のメモリアドレスを示す
16 ビットのカウンタです。プログラムカウンタは , 命令の実行 , 割込み , リセットなど
によりその内容が更新されます。リセット直後の初期値は , モードデータの読出しアド
レス (0xFFFD) です。
● アキュムレータ (A)
アキュムレータは, 16ビット長の演算用レジスタで, メモリ上のデータやテンポラリア
キュムレータ (T) などほかのレジスタ内のデータと各種の演算および転送処理を行い
ます。アキュムレータ内のデータは , ワード長 (16 ビット)としてもバイト長 (8 ビット)
としても扱えます。バイト長データの演算処理や転送処理では , アキュムレータの下位
8 ビット (AL) のみが使用され , 上位 8 ビット (AH) は変化しません。リセット直後の初
期値は "0x0000" です。
● テンポラリアキュムレータ (T)
テンポラリアキュムレータは , 16 ビット長の演算用補助レジスタで , アキュムレータ
(A) 内のデータと各種の演算を行います。テンポラリアキュムレータ内のデータは , ア
キュムレータ (A) に対する演算がワード長 (16 ビット ) の場合はワード長で , バイト長
(8 ビット ) の場合はバイト長で扱われます。バイト長演算が行われると , テンポラリア
キュムレータの下位 8 ビット (TL) のみが使用され , 上位 8 ビット (TH) は使われません。
MOV 命令を使用してアキュムレータ (A) にデータを転送する場合 , アキュムレータに
格納されていたデータは自動的にテンポラリアキュムレータへと転送されます。バイ
ト長のデータを転送する場合は , テンポラリアキュムレータの上位 8 ビット (TH) は変
化しません。リセット後の初期値は "0x0000" です。
● インデックスレジスタ (IX)
インデックスレジスタは , インデックスアドレスを保持するための 16 ビット長のレジ
スタで , 1 バイト分 , オフセット (-128 ~ +127) して使用します。インデックスアドレス
にオフセット値を加えることにより , データアクセスのためのメモリアドレスが生成
されます。リセット後の初期値は "0x0000" です。
● エクストラポインタ (EP)
エクストラポインタは , データアクセスのためのメモリアドレスを示す値を保持する
16 ビット長のレジスタです。リセット後の初期値は "0x0000" です。
● スタックポインタ (SP)
スタックポインタは , 割込みやサブルーチン呼び出しが生じたとき , スタックの退避 /
復帰命令によって参照されるアドレスを保持する 16 ビット長のレジスタです。プログ
ラムの実行中 , スタックポインタの値は , スタックに退避された最新データのアドレス
となっています。リセット後の初期値は "0x0000" です。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
5
第 2 章 CPU
2.1 専用レジスタ
H ard war e
Ma nu al
● プログラムステータス (PS)
プログラムステータスは , 16 ビット長の制御レジスタです。上位 8 ビットは , レジスタ
バンクポインタ (RP) とダイレクトバンクポインタ (DP) から構成され , 下位 8 ビットは ,
コンディションコードレジスタ (CCR) となっています。
上位 8 ビットのうち , 上位 5 ビットはレジスタバンクポインタで , 汎用レジスタバンク
のアドレスを保持するために使用します。下位 3 ビットはダイレクトバンクポインタ
で , ダイレクトアドレッシングにより高速にアクセスされる領域を示します。
下位 8 ビットはコンディションコードレジスタ (CCR) で , CPU の状態を表す各種フラ
グで構成されます。
プログラムステータスにアクセス可能な命令は , MOVW A,PS と MOVW PS,A です。プ
ログラムステータスレジスタ内のレジスタバンクポインタ (RP) とダイレクトバンクポ
インタ (DP) は , ミラーアドレス (0x0078) をアクセスすることでも書込み / 読出しがで
きます。
なお , コンディションコードレジスタ (CCR) は , プログラムステータスレジスタの一部
であり , コンディションコードレジスタのみのアクセスはできません。
専用レジスタの詳しい使用方法については,「F2MC-8FXプログラミングマニュアル」を
参照してください。
6
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 2 章 CPU
2.1 専用レジスタ
Ha rdware
Manual
レジスタバンクポインタ (RP)
2.1.1
プログラムステータス (PS) の bit15 ~ bit11 であるレジスタバンクポインタ (RP)
は , 現在使用している汎用レジスタバンクのアドレスを示し , 汎用レジスタアドレッ
シング時に実アドレスに変換されます。
■ レジスタバンクポインタ (RP) の構成
図 2.1-2 に , レジスタバンクポインタの構成を示します。
図 2.1-2 レジスタバンクポインタの構成
RP
DP
CCR
RP 初期値
bit15 bit14 bit13 bit12 bit11 bit10 bit9
PS
R4
R3
R2
R1
R0
DP2
DP1
bit8
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
DP0
H
I
IL1
IL0
N
Z
V
C
0b00000
レジスタバンクポインタは , 現在使用されているレジスタバンクのアドレスを示しま
す。
レジスタバンクポインタの内容は , 図 2.1-3 に示す規則にしたがって , 実アドレスに
変換されます。
図 2.1-3 汎用レジスタ領域の実アドレス変換規則
RP 上位
固定値
"0"
発生アドレス
"0"
"0"
"0"
"0"
"0"
オペコード 下位
"0"
"1"
R4
R3
R2
R1
R0
b2
b1
b0
A15 A14 A13 A12 A11 A10 A9
A8
A7
A6
A5
A4
A3
A2
A1
A0
レジスタバンクポインタは , RAM 領域の中で汎用レジスタとして使用するレジスタバ
ンクを指定します。レジスタバンクは全部で 32 個あり , レジスタバンクポインタの上
位 5 ビットに 0 ~ 31 の値を設定することにより指定されます。1 つのレジスタバンク
には , 8 つの 8 ビット長の汎用レジスタがあり , オペコードの下位 3 ビットで選択され
ます。
このレジスタバンクポインタによって , "0x0100" ~ "0x01FF"( 最大 ) までを , 汎用レジ
スタ領域として使用できます。ただし , 一部の製品には , 汎用レジスタ領域として使用
可能な領域のサイズに制限があります。レジスタバンクポインタのリセット後の初期
値は "0x0000" です。
■ レジスタバンクポインタおよびダイレクトバンクポインタのミラーアドレス
レジスタバンクポインタ (RP) およびダイレクトバンクポインタ (DP) の値は ,「MOVW
PS,A」命令によってプログラムステータス (PS) レジスタにアクセスすることにより , 書
き込めます。読出しは ,「MOVW A,PS」
命令によってプログラムステータス (PS) にアク
セスすることにより行えます。
また , レジスタバンクポインタのミラーアドレス
"0x0078" にアクセスすることで , 両ポインタを直接書込み / 読出しできます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
7
第 2 章 CPU
2.1 専用レジスタ
H ard war e
Ma nu al
ダイレクトバンクポインタ (DP)
2.1.2
プログラムステータス (PS) の bit10 ~ bit8 であるダイレクトバンクポインタ (DP) は ,
ダイレクトアドレッシングでアクセスする領域を指定するためのものです。
■ ダイレクトバンクポインタ (DP) の構成
図 2.1-4 に , ダイレクトバンクポインタの構成を示します。
図 2.1-4 ダイレクトバンクポインタの構成
RP
DP
CCR
DP 初期値
bit15 bit14 bit13 bit12 bit11 bit10 bit9
PS
R4
R3
R2
R1
R0
DP2
DP1
bit8
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
DP0
H
I
IL1
IL0
N
Z
V
C
0b000
0x0000 ~ 0x007F および 0x0090 ~ 0x047F の領域は , ダイレクトアドレッシングにより
アクセスできます。ダイレクトバンクポインタの値にかかわらず 0x0000 ~ 0x007F への
アクセスはオペランドで指定します。0x0090 ~ 0x047F へのアクセスは , ダイレクトバ
ンクポインタの値とオペランドにより指定します。
表 2.1-1 に , ダイレクトバンクポインタ (DP) とアクセス領域の関係を , 表 2.1-2 にダイ
レクトアドレッシング命令一覧を示します。
表 2.1-1
ダイレクトバンクポインタとアクセス領域
ダイレクトバンクポインタ (DP[2:0])
オペランドで指定された dir
アクセス領域 *
0bXXX( マッピングに影響しません )
0x0000 ~ 0x007F
0x0000 ~ 0x007F
0b000( 初期値 )
0b001
0x0090 ~ 0x00FF
0x0090 ~ 0x00FF
0x0100 ~ 0x017F
0b010
0x0180 ~ 0x01FF
0b011
0x0200 ~ 0x027F
0b100
0x0080 ~ 0x00FF
0x0280 ~ 0x02FF
0b101
0x0300 ~ 0x037F
0b110
0x0380 ~ 0x03FF
0b111
0x0400 ~ 0x047F
*: 使用可能なアクセス領域は品種によって異なります。詳細は , 各品種のデータシートを参照してください。
8
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 2 章 CPU
2.1 専用レジスタ
Ha rdware
表 2.1-2
Manual
ダイレクトアドレッシング命令一覧
適用可能な命令
CLRB dir:bit
SETB dir:bit
BBC dir:bit,rel
BBS dir:bit,rel
MOV A,dir
CMP A,dir
ADDC A,dir
SUBC A,dir
MOV dir,A
XOR A,dir
AND A,dir
OR A,dir
MOV dir,#imm
CMP dir,#imm
MOVW A,dir
MOVW dir,A
April 4, 2014, MB95F718M_MN702-00014-3v0-J
9
第 2 章 CPU
2.1 専用レジスタ
H ard war e
Ma nu al
コンディションコードレジスタ (CCR)
2.1.3
プログラムステータス (PS) レジスタの下位 8 ビットであるコンディションコードレ
ジスタ (CCR) は , 演算結果や転送データに関する情報を示すビット (H, N, Z, V, C) と
割込み要求の受付けを制御するためのビット (I, IL[1:0]) によって構成されます。
■ コンディションコードレジスタ (CCR) の構成
図 2.1-5 コンディションコードレジスタの構成
RP
DP
CCR
CCR 初期値
bit15 bit14 bit13 bit12 bit11 bit10 bit9
PS
R4
R3
R2
R1
R0
DP2
DP1
bit8
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
DP0
H
I
IL1
IL0
N
Z
V
C
0b00110000
ハーフキャリフラグ
割込み許可フラグ
割込みレベルビット
ネガティブフラグ
ゼロフラグ
オーバフローフラグ
キャリフラグ
コンディションコードレジスタは , プログラムステータス (PS) レジスタの一部であり ,
そのためコンディションコードレジスタに独立してアクセスすることはできません。
■ 演算結果を示すビット
● ハーフキャリフラグ (H)
このフラグは , 演算の結果 , bit3 から bit4 への繰上げ ( キャリ ) や bit4 から bit3 への借
越し ( ボロー) が発生した場合に "1" になります。発生しなかった場合には , "0" になり
ます。このフラグは10進補正命令用であるため, 加減算以外の演算には使用しないでく
ださい。
● ネガティブフラグ (N)
このフラグは , 演算の結果 , 最上位ビットの値が "1" となった場合に "1" になり , "0" と
なった場合に "0" になります。
● ゼロフラグ (Z)
このフラグは , 演算の結果が "0" のときは "1" になり , それ以外のときは "0" になります。
● オーバフローフラグ (V)
このフラグは, 演算に用いたオペランドを2の補数で表現される整数とみなしての演算
の結果 , オーバフローが発生したかどうかを示します。オーバフローが発生した場合 ,
オーバフローフラグは "1" に , オーバフローが発生しなかった場合は "0" になります。
10
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 2 章 CPU
2.1 専用レジスタ
Ha rdware
Manual
● キャリフラグ (C)
このフラグは , 演算の結果 , bit7 からの繰上げ ( キャリ ) や bit7 への借越し ( ボロー) が
発生した場合に "1" になります。発生しなかった場合には , "0" になります。また , シフ
ト命令の実行時には , シフトアウトした値がこのフラグに設定されます。
図 2.1-6 に , シフト命令によるキャリフラグの変化を示します。
図 2.1-6 シフト命令によるキャリフラグの変化
• 左シフトの場合 (ROLC)
• 右シフトの場合 (RORC)
bit7
bit0
bit7
bit0
C
C
■ 割込みの受付けを制御するビット
● 割込み許可フラグ (I)
このフラグが "1" のときは割込みが許可され , CPU は割込みを受け付けます。
"0" のと
きは割込みが禁止され , CPU は割込みを受け付けません。
リセット後の初期値は "0" です。
このフラグは , SETI 命令で "1" になり , CLRI 命令で "0" になります。
● 割込みレベルビット (IL[1:0])
これらのビットは , CPU が現在受け付けている割込みのレベルを示します。
割込みレベルは , 各周辺機能の割込み要求 (IRQ00 ~ IRQ23) に対応する割込みレベル
設定レジスタ (ILR0 ~ ILR5) の値と比較されます。
割込み許可フラグが許可 (CCR:I=1) 状態であり , 割込み要求の割込みレベルがこれらの
ビットが示す値より小さい場合のみ , CPU はその割込み要求を処理します。
表 2.1-3 に , 割
込みレベルの優先度を示します。リセット後の初期値は "0b11" になります。
表 2.1-3
割込みレベル
IL1
IL0
割込みレベル
優先度
0
0
0
高い
0
1
1
1
0
2
1
1
3
低い ( 割込みなし )
CPU が割込み処理中でなければ ( メインプログラム実行中 ), 割込みレベルビット
(IL[1:0]) は通常 , "0b11" となっています。
割込みの詳細については 「5.1
,
割込み」を参照してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
11
第 2 章 CPU
2.2 汎用レジスタ
H ard war e
2.2
Ma nu al
汎用レジスタ
汎用レジスタは , 8 ビット ×8 個を 1 バンクとするメモリブロックです。最大 32 バン
クまで使用できます。レジスタバンクの指定には , レジスタバンクポインタ (RP) を使
用します。
レジスタバンクは , 割込み処理 , ベクタコール処理およびサブルーチンの呼出しに使
用すると有効です。
■ 汎用レジスタの構成
• 汎用レジスタは 8 ビット長のレジスタで , 汎用レジスタ領域 (RAM 上 ) のレジスタ
バンク内にあります。
• 1 バンクあたり 8 つのレジスタ (R0 ~ R7) があり , 最大 32 バンクまで使用できます。
• 現在使用しているレジスタバンクはレジスタバンクポインタ (RP) で指定され , オペ
コードの下位 3 ビットが汎用レジスタ 0(R0) ~汎用レジスタ 7(R7) を示します。
図 2.2-1 に , レジスタバンクの構成を示します。
図 2.2-1 レジスタバンクの構成
8 ビット
0x1F8
ここのアドレス = 0x0100 + 8 × (RP)
アドレス 0x100
R0
R0
R0
R1
R2
R3
R4
R5
R6
0x107
R1
R2
R3
R4
R5
R6
R7
R7
バンク 0
R1
R2
R3
R4
R5
R6
0x1FF
R7
バンク 31
32 バンク
使用できるRAM容量に
よって, バンク数は
制限されます。
メモリ領域
各品種で使用可能な汎用レジスタ領域については , 各品種のデータシートの「■ 特定用
途の領域」を参照してください。
12
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 2 章 CPU
2.2 汎用レジスタ
Ha rdware
Manual
■ 汎用レジスタの特長
汎用レジスタには , 以下のような特長があります。
• 短い命令によるRAMへの高速アクセス(汎用レジスタアドレッシング)が可能です。
• レジスタバンクのブロックにレジスタをまとめることで , データの保護と , 機能に
よるレジスタの分類が容易になります。
個々の割込みサービスルーチンやベクタコール (CALLV #0 ~ #7) 処理ルーチンに対し
て , 専用の汎用レジスタバンクを割り当てることができます。例えば , 「2 番目の割込
みには必ず 4 番目のレジスタバンクを割り当てる」という使い方ができます。
割込みサービスルーチンの先頭で専用レジスタバンクを指定するだけで , 割込み前に
汎用レジスタに格納されていたデータを , そのレジスタバンクに保存できます。これに
よって , 汎用レジスタのデータをスタックに退避する必要がなくなり , CPU は高速に割
込みを受け付けることができるようになります。
<注意事項>
レジスタバンクを指定するためにレジスタバンクポインタ (RP) を変更するときには , コ
ンディションコードレジスタの割込みレベルビット (CCR:IL[1:0]) の値が変更されないよ
うにするために , 割込みサービスルーチンのプログラムに , 以下の処理のいずれかを入れ
てください。
• RP の値を書き込む前に , 割込みレベルビットを読み出し , その値を保存する。
• RP のミラーアドレス "0x0078" に新しい値を直接書き込んでください。
• RAMサイズが256バイトである製品では, 汎用レジスタとして使用可能な領域は"0x0100" ~
"0x018F" であり , RAM サイズが 512 バイト以上である製品の半分となっています。し
たがって C コンパイラなどのプログラム開発ツールを用いて汎用レジ スタ領域を設定
する際には , 汎用レジスタとして使用する領域がインストールされた RAM のサイズを
超えていないことを確認してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
13
第 2 章 CPU
2.3 16 ビットデータのメモリ上の配置
H ard war e
2.3
Ma nu al
16 ビットデータのメモリ上の配置
16 ビットデータのメモリ上の格納状態について説明します。
■ 16 ビットデータのメモリ上の配置
● RAM による 16 ビットデータの格納状態
メモリに 16 ビットデータを書き込む場合 , アドレス値の小さい方にデータの上位バイ
トが , その次のアドレスにデータの下位バイトがそれぞれ格納されます。
16 ビットデー
タの読出し時も同様に扱われます。
図 2.3-1 に , メモリ上の 16 ビットデータの配置を示します。
図 2.3-1 16 ビットデータのメモリ上の配置
実行前
実行後
メモリ
MOVW 0091H, A
0x0090
0x0091
0x0092
0x0093
A 0x1234
メモリ
A 0x1234
0x12
0x34
0x0090
0x0091
0x0092
0x0093
● オペランドにより指定された 16 ビットデータの格納状態
命令内のオペランドで 16 ビットデータを指定した場合も , オペコード ( 命令 ) に近い
アドレスに上位バイトが , その次のアドレスに下位バイトが格納されます。
これはオペランドがメモリアドレスを示す場合でも , 16 ビットのイミディエートデー
タ ( 即値 ) の場合でも同じです。
図 2.3-2 に , 命令による 16 ビットデータの配置を示します。
図 2.3-2 16 ビットデータの命令における配置
[例]
; エクステンドアドレス
MOV A, 5678H
MOVW A, #1234H ; 16ビットイミディエートデータ
アセンブルすると
0xXXX0
0xXXX2
0xXXX5
0xXXX8
XX XX
60 56 78 ; エクステンドアドレス
E4 12 34 ; 16ビットイミディエートデータ
XX
● スタックにおける 16 ビットデータの格納状態
割込み時にスタックに退避される 16 ビット長のレジスタのデータも , オペランドによ
り指定された 16 ビットデータと同様に , アドレス値の小さい方に上位バイトが格納さ
れます。
14
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第3章
クロック制御部
クロック制御部の機能と動作について説明します。
3.1
概要
3.2
発振安定待ち時間
3.3
レジスタ
3.4
クロックモード
3.5
低消費電力モード ( スタンバイモード ) の動作
3.6
クロック発振回路
3.7
プリスケーラの概要
3.8
プリスケーラの構成
3.9
プリスケーラの動作
3.10 プリスケーラ使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
15
第 3 章 クロック制御部
3.1 概要
H ard war e
3.1
Ma nu al
概要
New 8FX ファミリは , 消費電力の最適な制御を行うクロック制御部を搭載していま
す。このクロック制御部は外部メインクロックと外部サブクロックの両方をサポート
しています。
クロック制御部はクロック発振の許可 / 停止 , 内部回路へのクロック信号供給の
許可 / 停止 , クロックソースの選択および PLL, 内蔵 CR 発振器と周波数分周回路の制
御を行います。
■ クロック制御部の概要
クロック制御部はクロック発振の許可 / 停止 , 内部回路へのクロック供給の許可 / 停止 ,
クロックソースの選択およびPLL, 内蔵CR発振器と周波数分周回路の制御を行います。
クロック制御部ではクロックモードの設定 , スタンバイモードの設定 , リセット動作に
従い内部クロックを制御します。クロックモードにより内部動作クロックの選択が行
われ , スタンバイモードによりクロック発振および信号供給の許可 / 停止を行います。
クロック制御部はクロックモードおよびスタンバイモードの組み合わせに応じた最適
な消費電力と機能を選択します。
本デバイスには 6 種類のソースクロックがあります。これらはメイン発振クロックを
2 分周したメインクロック , PLL 逓倍率をメイン発振クロックにかけて生成したメイン
PLL クロック , サブ発振クロックを 2 分周したサブクロック , メイン CR クロック , PLL
逓倍率をメイン CR 発振クロックにかけて生成したメイン CR PLL クロックおよびサブ
CR 発振クロックを 2 分周したサブ CR クロックの 6 種類です。
16
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.1 概要
Ha rdware
Manual
■ クロック制御部のブロックダイヤグラム
図 3.1-1 にクロック制御部のブロックダイヤグラムを示します。
図 3.1-1 クロック制御部のブロックダイヤグラム
システムクロック制御レジスタ 2 (SYCC2)
スタンバイ制御レジスタ (STBC)
SRDY MRDY SCRDY MCRDY SOSCE MOSCE SCRE MCRE
STP
SLP
SPL
SRST
TMD
-
-
-
時計モードまたは
タイムベースタイマモード
スリープモード
ストップモード
システムクロックセレクタ
メインCR
クロック
発振回路
(5)
プリスケーラ
サブCR
クロック
発振回路
メイン
クロック
発振回路
サブ
クロック
発振回路
(6)
(7)
2分周
分周なし
4分周
8分周
(1)
2分周
(2)
2分周
発振安定
待ち回路
(3)
16分周
(4)
ソース
クロック
選択制御回路
PLLクロック
発振回路
(8)
CPUへの供給
クロック
制御回路
周辺機能への供給
(9)
タイムベースタイマ用クロック
時計タイマ用クロック
MPEN MPMC1 MPMC0 MPRDY
-
-
-
-
PLL制御レジスタ (PLLC)
SWT3 SWT2 SWT1 SWT0 MWT3 MWT2 MWT1 MWT0
発振安定待ち時間設定レジスタ (WATR)
(1): メインクロック (FCH)
(2): サブクロック (FCL)
(3): メインクロック
(4): サブクロック
April 4, 2014, MB95F718M_MN702-00014-3v0-J
SCM2 SCM1 SCM0
SCS2
SCS1
SCS0
DIV1
DIV0
システムクロック制御レジスタ (SYCC)
(5): メインCRクロック (FCRH)
(6): サブCRクロック (FCRL)
(7): ソースクロック (SCLK)
(8): マシンクロック (MCLK)
(9): PLLクロック (FPLL)
17
第 3 章 クロック制御部
3.1 概要
H ard war e
Ma nu al
■ クロック制御部の構成
● メインクロック発振回路
このブロックはメインクロックの発振回路です。
● サブクロック発振回路
このブロックはサブクロックの発振回路です。
● メイン CR クロック発振回路
このブロックはメイン CR クロックの発振回路です。
● PLL クロック発振回路
このブロックは PLL クロックの発振回路です。PLL ソースクロックはメインクロック
とメイン CR クロックから選択できます。
● サブ CR クロック発振回路
このブロックはサブ CR クロックの発振回路です。
● システムクロックセレクタ
このブロックはクロックモードに対応して , メインクロック , サブクロック , メイン CR
クロック , PLL クロックおよびサブ CR クロックの 5 種類のソースクロック中から 1 種
類のクロックが選択されます。選択されたソースクロックはプリスケーラにより分周
され , クロック制御回路へ供給されます。この分周されたクロックを「マシンクロッ
ク」とよびます。
● クロック制御回路
CPU および各周辺機能へのマシンクロックの供給を , 選択されているスタンバイモー
ドまたは発振安定待ち時間に対応して制御します。
● 発振安定待ち回路
動作許可されているクロックにしたがって発振安定待ち時間信号を出力します。
メインクロックの場合は , 発振安定待ち回路の専用タイマにより生成された 14 種類の
発振安定信号から 1 つを選択できます。サブクロックの場合は , 発振安定待ち回路の専
用タイマにより生成された 15 種類の発振安定信号から 1 つを選択できます。
● システムクロック制御レジスタ (SYCC)
このレジスタは , クロックモードの選択 , マシンクロック分周比の選択および現在のク
ロックモードの表示のために使用されます。
● PLL 制御レジスタ (PLLC)
このレジスタは , PLL クロック逓倍率の設定を制御します。
● スタンバイ制御レジスタ (STBC)
このレジスタはRUN状態からスタンバイモードへの遷移, ストップモード, タイムベー
スタイマモードまたは時計モードの端子状態の設定およびソフトウェアリセットの発
生を制御するために使用されます。
18
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.1 概要
Ha rdware
Manual
● システムクロック制御レジスタ 2 (SYCC2)
このレジスタはメインクロック , メイン PLL クロック , メイン CR クロック , サブク
ロック , サブ CR クロックの発振の許可 / 停止およびメインクロック , メイン CR クロッ
ク , サブクロック , サブ CR クロックの発振のレディ信号の表示のために使用されます。
● 発振安定待ち時間設定レジスタ (WATR)
このレジスタはメインクロックとサブクロックの発振安定待ち時間を設定するために
使用されます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
19
第 3 章 クロック制御部
3.1 概要
H ard war e
Ma nu al
■ クロックモード
クロックモードが 6 種類あります。
•
メインクロックモード
•
メイン PLL クロックモード
•
メイン CR クロックモード
•
メイン CR PLL クロックモード
•
サブクロックモード
•
サブ CR クロックモード
表 3.1-1 に , クロックモードとマシンクロック (CPU と周辺機能の動作クロック ) との
関係を示します。
表 3.1-1
クロックモードとマシンクロックの選択
クロックモード
マシンクロック
メインクロックモード
マシンクロックはメインクロックの 2 分周より生成されま
す。
メイン PLL クロックモード
マシンクロックは PLL 逓倍率をメインクロックにかけて生
成されます。
メイン CR クロックモード
マシンクロックはメイン CR クロックより生成されます。
メイン CR PLL クロックモード
マシンクロックは PLL 逓倍率をメイン CR クロックにかけ
て生成されます。
サブクロックモード
マシンクロックはサブクロックの 2 分周 より生成されます。
サブ CR クロックモード
マシンクロックはサブ CR クロックの 2 分周より生成されま
す。
選択されたクロックの周波数の分周は , どのクロックモードでも可能です。
20
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.1 概要
Ha rdware
Manual
■ スタンバイモード
選択されたスタンバイモードによりクロック発振の許可 / 停止および内部回路へのク
ロック供給の許可 / 停止を選択できます。タイムベースタイマモードおよび時計モー
ドを除き , クロックモードの設定とは別にスタンバイモードを設定できます。
表 3.1-2 に , スタンバイモードとクロック供給の状態との関係を示します。
表 3.1-2
スタンバイモードとクロック供給の状態
スタンバイモード
クロック供給の状態
スリープモード
CPU へのクロック供給が停止します。その結果 CPU は動作を停止
しますが , ほかの周辺機能は動作を継続します。
タイムベースタイマ
モード
タイムベースタイマおよび時計プリスケーラへのみクロック信号
を供給し , ほかの回路へのクロック供給は停止します。その結果 ,
タイムベースタイマ , 時計プリスケーラ , 外部割込みおよび低電圧
検出リセット ( オプション ) を除くすべての機能は停止します。
タイムベースタイマモードはメインクロックモード , メイン PLL
クロックモード , メイン CR クロックモードおよびメイン CR PLL
クロックモードにおいて使用可能です。
時計モード
メインクロック発振は停止します。時計プリスケーラへのみク
ロック信号を供給し , ほかの回路へのクロック供給は停止します。
その結果 , 時計プリスケーラ , 外部割込みおよび低電圧検出リセッ
ト ( オプション ) を除くすべての機能は停止します。
時計モードはサブクロックモードおよびサブ CR クロックモード
において使用されるスタンバイモードです。
ストップモード
メインクロック発振およびサブクロック発振を停止し , すべての回
路へのクロック供給を停止します。その結果 , 外部割込みおよび低
電圧検出リセット ( オプション ) を除くすべての機能は停止しま
す。
<注意事項>
特別な設定を行うことで , 表 3.1-2 以外にクロックが供給される場合があります。
例えば , メインクロックモードでストップモードにする場合 , SYCC2:SOSCE または
SYCC2:SCRE に "1" が書かれていれば , 時計プリスケーラが動作します。
また , ハードウェアウォッチドッグタイマを起動した場合は , 不揮発性レジスタインタ
フェースの設定によっては , スタンバイモードでもハードウェアウォッチドッグタイマが
動作します。詳細は , 「第 28 章 不揮発性レジスタ (NVR) インタフェース」を参照して
ください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
21
第 3 章 クロック制御部
3.1 概要
H ard war e
Ma nu al
■ クロックモードとスタンバイモードの組合せ
表 3.1-3 と表 3.1-4 に , クロックモードとスタンバイモードの組合せおよび各種クロッ
クモードとスタンバイモードの組合せを有する異なる内部回路の動作状態をそれぞれ
示します。
表 3.1-3
スタンバイモードとクロックモードの組合せおよび内部動作状態 (1)
スリープ
RUN
機能
メイン
クロック /
メイン PLL
クロック
メイン CR
クロック /
メイン CR
PLL クロック
サブクロック
サブ CR
クロック
CPU
フラッシュ
メモリ
RAM
I/O ポート
タイムベース
タイマ
時計プリス
ケーラ
外部割込み
ハードウェア
ウォッチドッ
グタイマ
ソフトウェア
ウォッチドッ
グタイマ
低電圧検出
リセット
そのほかの周
辺機能
メイン
メイン
CR クロック
クロック
モード /
モード /
メイン
メイン PLL
CR PLL
クロック
クロック
モード
モード
サブ CR
クロック
モード
サブ
クロック
モード
メイン
メイン
CR クロック
クロック
モード /
モード /
メイン
メイン PLL
CR PLL
クロック
クロック
モード
モード
サブ CR
クロック
モード
サブ
クロック
モード
動作
停止 *1
停止
動作
停止 *1
停止
停止 *2
動作
停止
停止 *2
動作
停止
動作 *3
動作
動作 *3
動作 *3
動作
動作 *3
動作 *4
動作 *4
動作
動作 *4
動作 *4
動作
動作
動作
停止
停止
動作
動作
値保持
値保持
動作
動作
値保持
値保持
動作
動作
出力保持
出力保持
動作
停止
動作
停止
動作 *3, *4
動作
動作 *3, *4
動作
動作
動作
動作
動作
動作
動作
動作 *5
動作 *5
動作
動作
停止
停止
動作
動作
動作
動作
動作
動作
動作
動作
*1: システムクロック制御レジスタ 2 のメインクロック発振許可ビット (SYCC2:MOSCE) を "1" に設定すると , メ
インクロックまたはメイン PLL クロックが動作します。
*2: システムクロック制御レジスタ 2 のメイン CR クロック発振許可ビット (SYCC2:MCRE) を "1" に設定すると ,
メイン CR クロックまたはメイン CR PLL クロックが動作します。
*3: システムクロック制御レジスタ 2 のサブクロック発振許可ビット (SYCC2:SOSCE) を "1" に設定すると , このモ
ジュールが動作します。
*4: システムクロック制御レジスタ 2 のサブ CR クロック発振許可ビット (SYCC2:SCRE) を "1" に設定すると , こ
のモジュールが動作します。
*5: 不揮発性レジスタ (NVR) インタフェースによりハードウェアウォッチドッグタイマが禁止されると , ハード
ウェアウォッチドッグタイマが停止します。
22
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.1 概要
Ha rdware
表 3.1-4
Manual
スタンバイモードとクロックモードの組合せおよび内部動作状態 (2)
タイムベースタイマ
機能
メイン
クロック /
メイン PLL
クロック
メイン CR
クロック /
メイン CR
PLL クロック
サブクロック
サブ CR
クロック
CPU
メイン
メイン
CR クロック
クロック
モード /
モード /
メイン
メイン PLL
CR PLL
クロック
クロック
モード
モード
時計
ストップ
サブ CR
クロック
モード
サブ
クロック
モード
メイン
メイン
CR クロック
クロック
モード /
モード /
メイン
メイン PLL
CR PLL
クロック
クロック
モード
モード
動作
停止 *1
停止
停止
停止 *2
動作
停止
停止
動作 *3
動作
*4
動作 *3
動作
動作
*4
動作
動作 *3
停止
*4
停止
動作
停止
停止
停止
値保持
値保持
値保持
フラッシュ
メモリ
RAM
値保持
値保持
値保持
I/O ポート
出力保持 /Hi-Z
出力保持 /Hi-Z
出力保持 /Hi-Z
動作
停止
停止
動作 *3, *4
動作
動作
動作
動作
動作 *5
動作 *5
動作 *5
停止
停止
停止
動作
動作
動作
停止
停止
停止
タイムベース
タイマ
時計プリス
ケーラ
外部割込み
ハードウェア
ウォッチドッ
グタイマ
ソフトウェア
ウォッチドッ
グタイマ
低電圧検出
リセット
そのほかの周
辺機能
サブ CR
クロック
モード
サブ
クロック
モード
動作 *3, *4
停止
*1: システムクロック制御レジスタ 2 のメインクロック発振許可ビット (SYCC2:MOSCE) を "1" に設定すると , メ
インクロックまたはメイン PLL クロックが動作します。
*2: システムクロック制御レジスタ 2 のメイン CR クロック発振許可ビット (SYCC2:MCRE) を "1" に設定すると ,
メイン CR クロックまたはメイン CR PLL クロックが動作します。
*3: システムクロック制御レジスタ 2 のサブクロック発振許可ビット (SYCC2:SOSCE) を "1" に設定すると , このモ
ジュールが動作します。
*4: システムクロック制御レジスタ 2 のサブ CR クロック発振許可ビット (SYCC2:SCRE) を "1" に設定すると , こ
のモジュールが動作します。
*5: 不揮発性レジスタ (NVR) インタフェースによりハードウェアウォッチドッグタイマが禁止されると , ハード
ウェアウォッチドッグタイマが停止します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
23
第 3 章 クロック制御部
3.2 発振安定待ち時間
H ard war e
Ma nu al
発振安定待ち時間
3.2
発振安定待ち時間とは , 発振回路が発振を停止した状態から発振器が固有の周波数で
安定し , 発振状態を再開するまでの時間です。クロック制御部は発振開始後に発振ク
ロック周期を所定の回数までカウントすることにより , 発振安定待ち時間を確保しま
す。発振安定待ち時間中 , クロック制御部は内部回路へのクロック供給を停止します。
■ 発振安定待ち時間
クロック制御部は , 発振開始後に発振クロック周期を所定の回数までカウントするこ
とにより , 発振安定待ち時間を確保します。発振安定待ち時間中 , クロック制御部は内
部回路へのクロック供給を停止します。
電源投入時またはリセット , ストップモード時の割込み , ソフトウェア動作によるク
ロックモードの変更により , 発振停止状態から発振を開始する状態遷移の要求が発生
した場合 , クロック制御部はほかのクロックモードに遷移する前に , 自動的に遷移先の
発振安待ち時間の経過を待ちます。
図 3.2-1 に , 発振開始直後の発振の動作を示します。
図 3.2-1 発振開始直後の発振器の動作
振動子の発振時間
通常動作
ストップモードからの
復帰またはリセット動作
( )
発振安定待ち時間
X1
↑
発振開始
発振安定
発振安定
メインクロック , サブクロック , メイン CR クロック , PLL クロックおよびサブ CR ク
ロックの発振安定待ち時間は専用カウンタを使用してカウントされます。メインク
ロック , サブクロックのカウント値は発振安定待ち時間設定レジスタ (WATR) で設定
可能です。発振器の特性に合わせて指定してください。
パワーオンリセットの場合 , 発振安定待ち時間は初期値に固定されます。
表 3.2-1 に , 発振安定待ち時間の長さを示します。
表 3.2-1
発振安定待ち時間
クロック
メインクロック
サブクロック
24
リセット要因
パワーオンリセット
パワーオンリセット以外
パワーオンリセット
パワーオンリセット以外
発振安定待ち時間
初期値 : (214-2)/FCH (FCH: メインクロック周波数 )
レジスタの設定値 (WATR:MWT[3:0])
初期値 : (215-2)/FCL (FCL: サブクロック周波数 )
レジスタの設定値 (WATR:SWT[3:0])
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.2 発振安定待ち時間
Ha rdware
Manual
■ PLL クロック発振安定待ち時間
発振器の発振安定待ち時間と同様 , ストップモード時の割込み , あるいはソフトウェア
によるクロックモードの変更により , PLL 発振停止状態から PLL 発振を開始する状態
遷移の要求が発生すると , クロック制御部はまずメインクロックの発振安定待ち時間
の経過またはメイン CR クロックの発振安定待ち時間の経過を待った後 , PLL クロック
の発振安定待ち時間の経過を自動的に待ちます。
表 3.2-2 に , PLL 発振安定待ち時間を示します。
表 3.2-2
PLL 発振安定待ち時間
PLL 発振安定待ち時間
メイン PLL クロック
212/FPLL*
メイン CR PLL クロック
*: FPLL: 16 MHz
■ CR クロックの発振安定待ち時間
発振器の発振安定待ち時間と同様 , スタンバイモード時の割込みやソフトウェア動作
によるクロックモードの変更により , CR 発振停止状態から CR 発振を開始する状態遷
移の要求が発生すると , クロック制御部は自動的に CR 発振安定待ち時間の経過を待ち
ます。
表 3.2-3 に , CR 発振安定待ち時間を示します。
表 3.2-3
CR 発振安定待ち時間
CR 発振安定待ち時間
メイン CR クロック
210/FCRH*1
サブ CR クロック
25/FCRL*2
*1: FCRH: 4 MHz
*2: FCRL: 150 kHz
■ 発振安定待ち時間とクロックモード・スタンバイモードの遷移
モード状態の遷移が発生すると , クロック制御部は必要に応じて自動で発振安定待ち
時間の経過を待ちます。モード状態の遷移が発生する状況によってはクロック制御部
は , モード状態の遷移が発生していても発振安定待ち時間の経過を待たない場合があ
ります。
状態遷移の詳細については , 「3.4 クロックモード」および「3.5 低消費電力モード
( スタンバイモード ) の動作」を参照してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
25
第 3 章 クロック制御部
3.2 発振安定待ち時間
H ard war e
Ma nu al
■ 発振安定待ちの優先順位について
複数のクロックの動作が同時に許可された場合 , クロック制御部は決められた優先順
位にしたがってクロックごとに発振安定待ち時間をカウントします。発振安定待ちカ
ウント動作の優先順位を以下に示します。
•
メインクロックモードの場合
サブ CR クロック > サブクロック > メイン PLL クロック > メイン CR クロック > メ
イン CR PLL クロック
•
メイン PLL クロックモードの場合
サブ CR クロック > サブクロック > メイン CR クロック
•
メイン CR クロックモードの場合
サブ CR クロック > サブクロック > メイン CR PLL クロック > メインクロック > メ
イン PLL クロック
•
メイン CR PLL クロックモードの場合
サブ CR クロック > サブクロック > メインクロック
•
サブクロックモードの場合
サブ CR クロック > メイン CR クロックまたはメインクロック > メイン CR PLL ク
ロックまたはメイン PLL クロック
•
サブ CR クロックモードの場合
メイン CR クロックまたはメインクロック > サブクロック > メイン CR PLL クロッ
クまたはメイン PLL クロック
<注意事項>
クロックモードを , メイン CR PLL クロックモードから直接メイン PLL クロックモードに
またはメイン PLL クロックモードから直接メイン CR PLL クロックモードに切り換える
ことは禁止されます。クロックモードをメイン CR PLL クロックモードからメイン PLL ク
ロックモードにまたはメイン PLL クロックモードから直接メイン CR PLL クロックモー
ドに切り換えるとき , 一度クロックモードをメイン PLL クロックモードとメイン CR PLL
クロックモード以外のクロックモードに切り換えてから , メイン PLL クロックモードまた
はメイン CR PLL クロックモードに遷移させてください。
26
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.3 レジスタ
Ha rdware
Manual
レジスタ
3.3
クロック制御部のレジスタについて説明します。
表 3.3-1
クロック制御部のレジスタ一覧
レジスタ略称
レジスタ名
参照先
SYCC
システムクロック制御レジスタ
3.3.1
PLLC
PLL 制御レジスタ
3.3.2
WATR
発振安定待ち時間設定レジスタ
3.3.3
STBC
スタンバイ制御レジスタ
3.3.4
SYCC2
システムクロック制御レジスタ 2
3.3.5
April 4, 2014, MB95F718M_MN702-00014-3v0-J
27
第 3 章 クロック制御部
3.3 レジスタ
H ard war e
3.3.1
Ma nu al
システムクロック制御レジスタ (SYCC)
システムクロック制御レジスタ (SYCC) はマシンクロックの分周比の選択 , クロック
モードの選択および現在のクロックモードの確認に使用されます。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
SCM2
SCM1
SCM0
SCS2
SCS1
SCS0
DIV1
DIV0
属性
R
R
R
R/W
R/W
R/W
R/W
R/W
初期値
X
X
X
1
1
0
1
1
■ レジスタ機能
[bit7:5] SCM[2:0]: クロックモードモニタビット
これらのビットは現在のクロックモードを示します。
これらのビットはリードオンリです。これらのビットに値を書き込んでも動作に影響はありませ
ん。
説明
bit7:5
"000" が読み出された場合
現在のクロックモードはサブクロックモードであることを示します。
"010" が読み出された場合
現在のクロックモードはメインクロックモードであることを示します。
"011" が読み出された場合
現在のクロックモードはメイン PLL クロックモードであることを示します。
"100" が読み出された場合
現在のクロックモードはサブ CR クロックモードであることを示します。
"110" が読み出された場合
現在のクロックモードはメイン CR クロックモードであることを示します。
"111" が読み出された場合
現在のクロックモードはメイン CR PLL クロックモードであることを示しま
す。
[bit4:2] SCS[2:0]: クロックモード選択ビット
これらのビットはクロックモードを選択します。
説明
bit4:2
"000" を書き込んだ場合
サブクロックモード
"010" を書き込んだ場合
メインクロックモード
"011" を書き込んだ場合
メイン PLL クロックモード
"100" を書き込んだ場合
サブ CR クロックモード
"110" を書き込んだ場合
メイン CR クロックモード
"111" を書き込んだ場合
メイン CR PLL クロックモード
( 注意事項 )
• SCS[2:0] に上記以外の値を書き込まないでください。
• クロックモードを , メイン CR PLL クロックモードから直接メイン PLL クロックモードにまたは
メイン PLL クロックモードから直接メイン CR PLL クロックモードに切り換えることは禁止され
ます。クロックモードをメイン CR PLL クロックモードからメイン PLL クロックモードにまたは
メイン PLL クロックモードから直接メイン CR PLL クロックモードに切り換えるとき , 一度クロッ
クモードをメイン PLL クロックモードとメイン CR PLL クロックモード以外のクロックモードに
切り換えてから , メイン PLL クロックモードまたはメイン CR PLL クロックモードに遷移させて
ください。
28
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.3 レジスタ
Ha rdware
Manual
[bit1:0] DIV[1:0]: マシンクロック分周比選択ビット
これらのビットはソースクロックに対するマシンクロックの分周比を選択します。
マシンクロックはこれらのビットで設定された分周比により , ソースクロックから生成されます。
説明
bit1:0
"00" を書き込んだ場合
ソースクロック ( 分周なし )
"01" を書き込んだ場合
ソースクロック / 4
"10" を書き込んだ場合
ソースクロック / 8
"11" を書き込んだ場合
ソースクロック / 16
April 4, 2014, MB95F718M_MN702-00014-3v0-J
29
第 3 章 クロック制御部
3.3 レジスタ
H ard war e
3.3.2
Ma nu al
PLL 制御レジスタ (PLLC)
PLL 制御レジスタ (PLLC) は PLL クロック逓倍率の設定を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
MPEN
MPMC1
MPMC0
MPRDY
—
—
—
—
属性
R/W
R/W
R/W
R
—
—
—
—
初期値
0
0
0
X
0
0
0
0
■ レジスタ機能
[bit7] MPEN: PLL クロック許可ビット
このビットは PLL クロックを許可または禁止します。
SCS[2:0] が "0b011" または "0b111" に設定されると , このビットは自動的に "1" に設定されます。
SCS[2:0] または SCM[2:0] が "0b011" または "0b111" に設定された場合 , このビットに "0" を書き込
んでも動作に影響はありません。
クロックモードがメイン PLL クロックモードとメイン CR PLL クロックモード以外のモードに切り
換わると , このビットは自動的に "0" に設定されます。
現在のクロックモードがサブクロックモードまたはサブ CR クロックモードの場合 , このビットに
"1" を書き込んでも動作に影響はありません。
説明
bit7
"0" を書き込んだ場合
PLL クロックを禁止します。
"1" を書き込んだ場合
PLL クロックを許可します。
[bit6:5] MPMC[1:0]: PLL クロック逓倍率選択ビット
これらのビットは PLL クロックの逓倍率を選択します。
PLL クロックが停止しているときのみ , これらのビットの設定を変更できます。よって , メインク
ロックモード , メイン CR クロックモード , サブクロックモードまたはサブ CR クロックモードで ,
これらのビットの設定が変更できます。
bit6:5
説明
"00" を書き込んだ場合
メインクロック 2 またはメイン CR クロック 2
"01" を書き込んだ場合
メインクロック  2.5 またはメイン CR クロック  2.5
"10" を書き込んだ場合
メインクロック  3 またはメイン CR クロック  3
"11" を書き込んだ場合
メインクロック  4 またはメイン CR クロック  4
( 注意事項 ) SCS[2:0] または SCM[2:0] が "0b011" または "0b111" に設定された場合 , これらのビッ
トに値を書き込むことは禁止されます。
[bit4] MPRDY: PLL クロック発振安定ビット
このビットは PLL クロック発振の準備ができているか否かを示します。
bit4
30
説明
"0" が読み出された場合
PLL クロックの発振安定待ち状態または PLL クロック発振が停止していること
を示します。
"1" が読み出された場合
PLL クロックの発振安定待ちが完了していることを示します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.3 レジスタ
Ha rdware
Manual
[bit3:0] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
31
第 3 章 クロック制御部
3.3 レジスタ
H ard war e
3.3.3
Ma nu al
発振安定待ち時間設定レジスタ (WATR)
発振安定待ち時間設定レジスタ (WATR) は発振安定待ち時間を設定するレジスタで
す。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
SWT3
SWT2
SWT1
SWT0
MWT3
MWT2
MWT1
MWT0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
1
1
1
1
1
1
1
1
■ レジスタ機能
[bit7:4] SWT[3:0]: サブクロック発振安定待ち時間選択ビット
これらのビットはサブクロック発振安定待ち時間を選択します。
詳細
bit7:4
サブクロック FCL = 32.768 kHz の場合
サイクル数
"1111" を書き込んだ場合
215-2
(215-2)/FCL
約 1.0 s
"1110" を書き込んだ場合
214-2
(214-2)/FCL
約 0.5 s
"1101" を書き込んだ場合
213-2
(213-2)/FCL
約 0.25 s
"1100" を書き込んだ場合
212-2
(212-2)/FCL
約 0.125 s
"1011" を書き込んだ場合
211-2
(211-2)/F
CL
約 62.44 ms
"1010" を書き込んだ場合
210-2
(210-2)/FCL
約 31.19 ms
"1001" を書き込んだ場合
29-2
(29-2)/FCL
約 15.56 ms
"1000" を書き込んだ場合
28-2
(28-2)/FCL
約 7.75 ms
7
"0111" を書き込んだ場合
27-2
(2 -2)/FCL
約 3.85 ms
"0110" を書き込んだ場合
26-2
(26-2)/FCL
約 1.89 ms
"0101" を書き込んだ場合
25-2
(25-2)/FCL
約 915.5 µs
"0100" を書き込んだ場合
24-2
(24-2)/FCL
約 427.2 µs
3
"0011" を書き込んだ場合
23-2
(2 -2)/FCL
約 183.1 µs
"0010" を書き込んだ場合
22-2
(22-2)/FCL
約 61.0 µs
"0001" を書き込んだ場合
21-2
(21-2)/FCL
0.0 µs
"0000" を書き込んだ場合
21-2
(21-2)/FCL
0.0 µs
上記表のサイクル数は最小値です。最大値は , 上記表のサイクル数に 1/FCL を加えたものです。
( 注意事項 ) これらのビットをサブクロック発振安定待ち時間中には書き換えないでください。書
き換える場合は , システムクロック制御レジスタ 2 のサブクロック発振安定ビット
(SYCC2:SRDY) が "1" に設定されているときに行ってください。 メインクロックモー
ド , メイン PLL クロックモード , メイン CR クロックモード , メイン CR PLL クロック
モードまたはサブ CR クロックモードにおいて , システムクロック制御レジスタ 2 のサ
ブクロック発振停止ビット (SYCC2:SOSCE) が "0" に設定され , サブクロックが停止し
ている時にこれらのビットを書き換えられます。
32
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.3 レジスタ
Ha rdware
Manual
[bit3:0] MWT[3:0]: メインクロック発振安定待ち時間選択ビット
これらのビットはメインクロック発振安定待ち時間を選択します。
詳細
bit3:0
メインクロック FCH = 4 MHz の場合
サイクル数
"1111" を書き込んだ場合
214-2
(214-2)/FCH
約 4.10 ms
"1110" を書き込んだ場合
213-2
(213-2)/FCH
約 2.05 ms
12
"1101" を書き込んだ場合
212-2
(2 -2)/FCH
約 1.02 ms
"1100" を書き込んだ場合
211-2
(211-2)/FCH
約 511.5 µs
"1011" を書き込んだ場合
210-2
(210-2)/FCH
約 255.5 µs
"1010" を書き込んだ場合
29-2
(29-2)/FCH
約 127.5 µs
"1001" を書き込んだ場合
28-2
(28-2)/FCH
約 63.5 µs
"1000" を書き込んだ場合
27-2
(27-2)/F
CH
約 31.5 µs
"0111" を書き込んだ場合
26-2
(26-2)/FCH
約 15.5 µs
"0110" を書き込んだ場合
25-2
(25-2)/FCH
約 7.5 µs
"0101" を書き込んだ場合
24-2
(24-2)/FCH
約 3.5 µs
"0100" を書き込んだ場合
23-2
(23-2)/F
CH
約 1.5 µs
"0011" を書き込んだ場合
22-2
(22-2)/FCH
約 0.5 µs
"0010" を書き込んだ場合
21-2
(21-2)/FCH
0.0 µs
"0001" を書き込んだ場合
21-2
(21-2)/FCH
0.0 µs
"0000" を書き込んだ場合
21-2
(21-2)/FCH
0.0 µs
上記表のサイクル数は最小値です。最大値は上記表のサイクル数に 1/FCH を加えたものです。
( 注意事項 ) これらのビットをメインクロック発振安定待ち時間中には書き換えないでください。
書き換える場合は, システムクロック制御レジスタ2のメインクロック発振安定ビット
(SYCC2:MRDY) を "1" に設定されているときに行ってください。メイン CR クロック
モード , メイン CR PLL クロックモード , サブクロックモードまたはサブ CR クロック
モードにおいて , システムクロック制御レジスタ 2 のメインクロック発振停止ビット
(SYCC2:MOSCE) が "0" に設定され , メインクロックが停止しているときにこれらの
ビットを書き換えられます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
33
第 3 章 クロック制御部
3.3 レジスタ
H ard war e
3.3.4
Ma nu al
スタンバイ制御レジスタ (STBC)
スタンバイ制御レジスタ (STBC) は, RUN状態からスリープモード, ストップモード,
タイムベースタイマモードまたは時計モードへの遷移 , ストップモード , タイムベー
スタイマモードおよび時計モードの端子状態の設定およびソフトウェアリセットの
発生制御を行います。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
STP
属性
W
SLP
SPL
SRST
TMD
—
—
—
W
R/W
W
W
—
—
—
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] STP: ストップビット
このビットはストップモードへの遷移を設定します。
このビットの読出し値は常に "0" です。
説明
bit7
"0" を書き込んだ場合
動作に影響はありません。
"1" を書き込んだ場合
デバイスはストップモードに遷移します。
( 注意事項 ) 割込み要求が発生した場合は , このビットへの "1" の書込みは無視されます。詳細は ,
「3.5.1 スタンバイモード使用上の注意」を参照してください。
[bit6] SLP: スリープビット
このビットはスリープモードへの遷移を設定します。
このビットの読出し値は常に "0" です。
説明
bit6
"0" を書き込んだ場合
動作に影響はありません。
"1" を書き込んだ場合
デバイスはスリープモードに遷移します。
( 注意事項 ) 割込み要求が発生した場合は , このビットへの "1" の書込みは無視されます。詳細は ,
「3.5.1 スタンバイモード使用上の注意」を参照してください。
[bit5] SPL: 端子状態設定ビット
このビットはストップモード , タイムベースタイマモードおよび時計モードの外部端子の状態を設
定します。
bit5
34
説明
"0" を書き込んだ場合
ストップモード , タイムベースタイマモードおよび時計モードにおける外部端子
の状態 ( レベル ) を保持します。
"1" を書き込んだ場合
外部端子はストップモード , タイムベースタイマモードおよび時計モードでハイ
インピーダンスになります。( プルアップレジスタにてプルアップ抵抗への接続
を選択した端子は , プルアップ状態になります ) 。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.3 レジスタ
Ha rdware
Manual
[bit4] SRST: ソフトウェアリセットビット
このビットはソフトウェアリセットを設定します。
このビットの読出し値は常に "0" です。
説明
bit4
"0" を書き込んだ場合
動作に影響はありません。
"1" を書き込んだ場合
3 マシンクロックリセット信号を発生します。
[bit3] TMD: 時計ビット
このビットはタイムベースタイマモードまたは時計モードへの遷移を設定します。
メインクロックモード , メイン PLL クロックモード , メイン CR クロックモードまたはメイン CR
PLL クロックモードでこのビットに "1" を書き込むと , デバイスはタイムベースタイマモードに遷
移します。
サブクロックモードまたはサブ CR クロックモードでこのビットに "1" を書き込むと , デバイスは時
計モードに遷移します。
このビットに "0" を書き込んでも動作に影響はありません。
このビットの読出し値は常に "0" です。
説明
bit3
メインクロックモード /
メイン PLL クロックモード /
メイン CR クロックモード /
メイン CR PLL クロックモード
サブクロックモード /
サブ CR クロックモード
"0" を書き込んだ場合
動作に影響はありません。
動作に影響はありません。
"1" を書き込んだ場合
デバイスはタイムベースタイマモード
に遷移します。
デバイスは時計モードに遷移します。
( 注意事項 ) 割込み要求が発生した場合は , このビットへの "1" の書込みは無視されます。詳細は ,
「3.5.1 スタンバイモード使用上の注意」を参照してください。
[bit2:0] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
<注意事項>
• スタンバイモードを設定する前に , システムクロック制御レジスタにおけるクロック
モードモニタビット (SYCC:SCM[2:0]) とクロックモード選択ビット (SYCC:SCS[2:0])
の値を比較して , クロックモードへの遷移が完了していることを確認してください。
• ストップビット (STP), スリープビット (SLP), ソフトウェアリセットビット (SRST) お
よび時計ビット (TMD) の中から , 2 つ以上のビットに対し同時に "1" を書き込んだ場合
の優先順位は下記のとおりです。
(1) ソフトウェアリセットビット (SRST)
(2) ストップビット (STP)
(3) 時計ビット (TMD)
(4) スリープビット (SLP)
スタンバイモードが解除されるとデバイスは通常動作状態に戻ります。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
35
第 3 章 クロック制御部
3.3 レジスタ
H ard war e
3.3.5
Ma nu al
システムクロック制御レジスタ 2 (SYCC2)
システムクロック制御レジスタ 2(SYCC2) は , メインクロック , サブクロック , メイ
ン CR クロックおよびサブ CR クロックのそれぞれの発振安定状態を示し , またメイ
ンクロック発振 , サブクロック発振 , メイン CR クロック発振およびサブ CR クロッ
ク発振を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
SRDY
MRDY
SCRDY
MCRDY
SOSCE
MOSCE
SCRE
MCRE
属性
R
R
R
R
R/W
R/W
R/W
R/W
初期値
X
X
X
X
0
0
1
1
■ レジスタ機能
[bit7] SRDY: サブクロック発振安定ビット
このビットはサブクロックの発振が安定したかどうかを示します。
このビットはリードオンリです。このビットに値を書き込んでも動作に影響はありません。
bit7
説明
"0" が読み出された場合
クロック制御部がサブクロック発振安定待ち状態にあることかまたはサブク
ロック発振が停止していることを示します。
"1" が読み出された場合
サブクロックの発振安定待ち時間が完了していることを示します。
[bit6] MRDY: メインクロック発振安定ビット
このビットはメインクロックの発振が安定したかどうかを示します。
このビットはリードオンリです。このビットに値を書き込んでも動作に影響はありません。
bit6
説明
"0" が読み出された場合
クロック制御部がメインクロック発振安定待ち状態にあることかまたはメイン
クロック発振が停止していることを示します。
"1" が読み出された場合
メインクロックの発振安定待ち時間が完了していることを示します。
[bit5] SCRDY: サブ CR クロック発振安定ビット
このビットはサブ CR クロックの発振が安定したかどうかを示します。
このビットはリードオンリです。このビットに値を書き込んでも動作に影響はありません。
bit5
36
説明
"0" が読み出された場合
クロック制御部がサブ CR クロック発振安定待ち状態にあることかまたはサブ
CR クロック発振が停止していることを示します。
"1" が読み出された場合
サブ CR クロックの発振安定待ち時間が完了していることを示します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.3 レジスタ
Ha rdware
Manual
[bit4] MCRDY: メイン CR クロック発振安定ビット
このビットはメイン CR クロックの発振が安定したかどうかを示します。
このビットはリードオンリです。このビットに値を書き込んでも動作に影響はありません。
説明
bit4
"0" が読み出された場合
クロック制御部がメイン CR クロック発振安定待ち状態にあることかまたはメ
イン CR クロック発振が停止していることを示します。
"1" が読み出された場合
メイン CR クロックの発振安定待ち時間が完了していることを示します。
[bit3] SOSCE: サブクロック発振許可ビット
このビットはサブクロック発振を許可または禁止します。
SCS[2:0] が "0b000" に設定された場合 , このビットは自動的に "1" 設定されます。
SCS[2:0] または SCM[2:0] が "0b000" に設定された場合 , このビットに "0" を書き込んでも動作に影
響はありません。
説明
bit3
"0" を書き込んだ場合
サブクロック発振を禁止します。
"1" を書き込んだ場合
サブクロック発振を許可します。
[bit2] MOSCE: メインクロック発振許可ビット
このビットはメインクロック発振を許可または禁止します。
SCS[2:0] が "0b010" または "0b011" に設定された場合 , このビットは自動的に "1" 設定されます。
SCS[2:0] または SCM[2:0] が "0b010" または "0b011" に設定された場合 , このビットに "0" を書き込
んでも動作に影響はありません。
クロックモードがメインクロックモード以外のモードに切り換わると , このビットは自動的に "0"
に設定されます。
現在のクロックモードがサブクロックモードまたはサブ CR クロックモードの場合 , このビットに
"1" を書き込んでも動作に影響はありません。
説明
bit2
"0" を書き込んだ場合
メインクロック発振を禁止します。
"1" を書き込んだ場合
メインクロック発振を許可します。
[bit1] SCRE: サブ CR クロック発振許可ビット
このビットはサブ CR クロック発振を許可または禁止します。
SCS[2:0] が "0b100" に設定された場合 , このビットは自動的に "1" 設定されます。
SCS[2:0] または SCM[2:0] が "0b100" に設定された場合 , このビットに "0" を書き込んでも動作に影
響はありません。
SCS[2:0] と SCM[2:0] が "0b100" 以外の値に設定された場合 , このビットはほかのビットと無関係に
設定できます。
説明
bit1
"0" を書き込んだ場合
サブ CR クロック発振を禁止します。
"1" を書き込んだ場合
サブ CR クロック発振を許可します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
37
第 3 章 クロック制御部
3.3 レジスタ
H ard war e
Ma nu al
[bit0] MCRE: メイン CR クロック発振許可ビット
このビットはメイン CR クロック発振を許可または禁止します。
SCS[2:0] が "0b110" または "0b111" に設定された場合 , このビットは自動的に "1" 設定されます。
SCS[2:0] または SCM[2:0] が "0b110" または "0b111" に設定された場合 , このビットに "0" を書き込
んでも動作に影響はありません。
クロックモードがメイン CR クロックモードとメイン CR PLL クロックモード以外のモードに切り
換わると , このビットは自動的に "0" に設定されます。
現在のクロックモードがサブクロックモードまたはサブ CR クロックモードの場合 , このビットに
"1" を書き込んでも動作に影響はありません。
bit0
38
説明
"0" を書き込んだ場合
メイン CR クロック発振を禁止します。
"1" を書き込んだ場合
メイン CR クロック発振を許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.4 クロックモード
Ha rdware
3.4
Manual
クロックモード
クロックモードには , メインクロックモード , メイン PLL クロックモード , サブク
ロックモード , メイン CR クロックモード , メイン CR PLL クロックモードおよびサ
ブ CR クロックモードの 6 種類があります。システムクロック制御レジスタ (SYCC)
の設定によってモードの切換えを行います。
■ メインクロックモードとメイン PLL クロックモードの動作
メインクロックモードでは CPU と周辺機能のマシンクロックとして , メインクロック
を使用します。メイン PLL クロックモードでは CPU と周辺機能のマシンクロックとし
て , メイン PLL クロックを使用します。
タイムベースタイマは , メインクロックモードでメインクロックで動作し , メイン PLL
クロックモードでメイン PLL クロックで動作します。
時計プリスケーラはサブクロックまたはサブ CR クロックで動作します。
メインクロックモードまたはメイン PLL クロックモードで動作中にスタンバイモード
を設定すると , スリープモード , ストップモードまたはタイムベースタイマモードに遷
移できます。
リセット後はリセット前のクロックモードに関係なく , デバイスは常にメイン CR ク
ロックモードになります。
■ サブクロックモードの動作
サブクロックモードではメインクロック発振 またはメイン PLL クロック発振が停止さ
れ *, サブクロックが CPU と周辺機能のマシンクロックとして使用されます。タイム
ベースタイマは , メインクロックモードでメインクロックを , メイン PLL クロックモー
ドでメイン PLL クロックを使用しているため , 停止しています。
サブクロックモードで動作中にスタンバイモードを設定すると , スリープモード , ス
トップモードまたは時計モードに遷移できます。
■ メイン CR クロックモードとメイン CR PLL クロックモードの動作
メイン CR クロックモードでは CPU と周辺機能のマシンクロックとして , メイン CR ク
ロックを使用します。メイン CR PLL クロックモードでは CPU と周辺機能のマシンク
ロックとして , メイン CR PLL クロックを使用します。タイムベースタイマおよび
ウォッチドッグタイマは , メイン CR クロックモードでメイン CR クロックで動作し ,
メイン CR PLL クロックモードでメイン CR PLL クロックで動作します。
時計プリスケーラはサブクロックまたはサブ CR クロックで動作します。
メイン CR クロックモードまたはメイン CR PLL クロックモードで動作中にスタンバイ
モードを設定すると , スリープモード , ストップモードまたはタイムベースタイマモー
ドに遷移できます。
■ サブ CR クロックモードの動作
サブ CR クロックモードではメインクロック発振 またはメイン PLL クロック発振 が停
止され *, サブ CR クロックが CPU と周辺機能のマシンクロックとして使用されます。
このモードではメインクロックの動作を必要とするタイムベースタイマは動作しませ
ん。時計プリスケーラは , サブ CR クロックで動作します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
39
第 3 章 クロック制御部
3.4 クロックモード
H ard war e
Ma nu al
サブ CR クロックモードで動作中にスタンバイモードを設定すると , スリープモード ,
ストップモードまたは時計モードに遷移できます。
*: クロックモードがメインクロックモード , メイン PLL クロックモード , メイン CR クロック
モードまたはメイン CR PLL クロックモードからサブクロックまたはサブ CR クロックモー
ドに遷移すると , メインクロック , メイン CR クロックおよび PLL クロックは自動的に発振
禁止になります (SYCC2: MOSCE を "0", SYCC2:MCRE を "0" および PLLC:MPEN を "0" に
設定 )。クロックモードがサブクロックモードまたはサブ CR クロックモードの場合 ,
SYCC2:MOSCE に "1", SYCC2:MCRE に "1", あるいは PLLC:MPEN に "1" を書き込んでもメ
インクロック , メイン CR クロック , あるいは PLL クロックを許可できません。
40
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.4 クロックモード
Ha rdware
Manual
■ クロックモードの状態遷移図
クロックモードには , メインクロックモード , メイン PLL クロックモード , サブクロッ
クモード , メイン CR クロックモード , メイン CR PLL クロックモード , サブ CR クロッ
クモードの 6 種類があります。このデバイスではシステムクロック制御レジスタ
(SYCC) の設定によって , クロックモードを切り換えられます。
図 3.4-1 クロックモードの状態遷移図
電源投入
各ステートでリセット発生
リセット状態
<1>
メインCRクロック
発振安定待ち時間
+
サブCRクロック
発振安定待ち時間
(10)
メインCR
クロックモード
メインCR PLL
クロック
(またはメインCR
クロック)
発振安定待ち時間
メインCR
クロックモード
(またはメインCR
PLLクロックモード)
(8)
(7)
メインクロックモード
(またはメインPLLクロックモード)
(5)
(6)
(4)
(3)
(2)
メインクロック
(またはメインPLL
クロック)
発振安定待ち時間
(9)
(12)
(11)
(1)
メインCRクロック
(またはメインCR
PLLクロック)
発振安定
サブCR
クロック発振
安定待ち時間
サブクロック
発振安定
待ち時間
メインクロック
(またはメインPLL
クロック)
発振安定待ち時間
(13)
(18)
(17)
サブCR
クロック発振
安定待ち時間
(20)
(19)
サブCRクロック
モード
(15)
サブクロックモード
(16)
サブクロック
発振安定
待ち時間
(14)
(21)
メインCRクロックモード
メインCRクロック
発振安定待ち時間
メインCR PLLクロックモード
(22)
(23)
メインクロックモード
メインPLLクロック
発振安定待ち時間
メインPLLクロックモード
(24)
April 4, 2014, MB95F718M_MN702-00014-3v0-J
41
第 3 章 クロック制御部
3.4 クロックモード
H ard war e
表 3.4-1
クロックモードの状態遷移表 (1 / 3)
現在の状態
<1> リセット状態
次の状態
メイン CR クロック
サブ CR クロック
システムクロック制御レジスタのクロックモード選択ビット
(SYCC:SCS[2:0]) を "0b100" に設定すると , デバイスはサブ CR ク
ロックモードに遷移します。
ただし , システムクロック制御レジスタ 2 のサブ CR クロック発振
許可ビット (SYCC2:SCRE) の設定によりサブ CR が停止していた場
合 , デバイスはサブ CR クロック発振安定待ち時間の経過を待って
からサブ CR クロックモードに遷移します。サブ CR クロック発振が
あらかじめ許可されており , システムクロック制御レジスタ 2 のサ
ブ CR クロック発振安定ビット (SYCC2:SCRDY) が "1" の場合は , デ
バイスはクロックモード選択ビット (SYCC:SCS[2:0]) が "0b100" に
設定された直後にサブ CR クロックモードに遷移します。
サブクロック
システムクロック制御レジスタのクロックモード選択ビット
(SYCC:SCS[2:0]) に "0b000" を設定すると , デバイスはサブクロック
発振安定待ち時間の経過を待ってからサブクロックモードに遷移
します。
システムクロック制御レジスタ 2 のサブクロック発振許可ビット
(SYCC2:SOSCE) の設定によりサブクロックの発振が許可されてお
り , システムクロック制御レジスタ 2 のサブクロック発振安定ビッ
ト (SYCC2:SRDY) が "1" の場合は , デバイスはクロックモード選択
ビット (SYCC:SCS[2:0]) が "0b000" に設定された直後 , サブクロッ
クモードに遷移します。
(2)
(3)
(4)
メイン CR
クロック /
メイン CR PLL
クロック
(6)
42
説明
リセット後にデバイスは , メイン CR クロック発振安定待ち時間と
サブCRクロック発振安定待ち時間との経過を待ってからメインCR
クロックモードに遷移します。リセットが任意のクロックモードに
よるウォッチドッグリセット , ソフトウェアリセットまたは外部リ
セットの場合でも , デバイスはサブ CR クロックとメイン CR クロッ
ク発振安定待ち時間の経過を待ちます。
(1)
(5)
Ma nu al
システムクロック制御レジスタのクロックモード選択ビット
(SYCC:SCS[2:0]) を "0b010" に設定すると , デバイスはメインクロッ
ク発振安定待ち時間の経過を待ってからメインクロックモードに
遷移します。
システムクロック制御レジスタ 2のメインクロック発振許可ビット
(SYCC2: MOSCE) の設定によりメインクロックの発振が許可され
ており , システムクロック制御レジスタ 2 のメインクロック発振安
定ビット (SYCC2:MRDY) が "1" の場合は , デバイスはクロックモー
ド選択ビット (SYCC:SCS[2:0]) が "0b010" に設定された直後 , メイ
ンクロックモードに遷移します。
メインクロック /
システムクロック制御レジスタのクロックモード選択ビット
メイン PLL クロック
(SYCC:SCS[2:0]) を "0b011" に設定すると , デバイスはメイン PLL
クロック発振安定待ち時間の経過を待ってからメイン PLL クロッ
クモードに遷移します。
クロックモードをメイン CR PLL クロックモードから直接メイン
PLL クロックモードに切り換えることは禁止されます。クロック
モードをメイン CR PLL クロックモードからメイン PLL クロック
モードに切り換えるとき , 一度クロックモードをメイン PLL クロッ
クモードとメイン CR PLL クロックモード以外のクロックモードに
切り換えてから , メイン PLL クロックモードに遷移させてくださ
い。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.4 クロックモード
Ha rdware
表 3.4-1
Manual
クロックモードの状態遷移表 (2 / 3)
現在の状態
次の状態
説明
システムクロック制御レジスタのクロックモード選択ビット
(SYCC:SCS[2:0]) を "0b110" に設定すると , デバイスはメイン CR ク
ロック発振安定待ち時間の経過を待ってからメイン CR クロック
モードに遷移します。システムクロック制御レジスタ 2 のメイン CR
クロック発振許可ビット (SYCC2:MCRE) の設定によりメイン CR ク
(7)
ロックの発振が許可されており , システムクロック制御レジスタ 2
のメイン CR クロック発振安定ビット (SYCC2:MCRDY) が "1" の場
合は , デバイスはクロックモード選択ビット (SYCC2:SCS[2:0]) が
"0b110"に設定された直後, メインCRクロックモードに遷移します。
メイン CR クロック /
システムクロック制御レジスタのクロックモード選択ビット
メイン CR PLL
(SYCC:SCS[2:0])を"0b111"に設定すると, デバイスはメインCR PLL
クロック
クロック発振安定待ち時間の経過を待ってからメイン CR PLL ク
メインクロック /
ロックモードに遷移します。
メイン PLL
クロックモードをメイン PLL クロックモードから直接メイン CR
クロック
PLL クロックモードに切り換えることは禁止されます。クロック
(8)
モードをメイン PLL クロックモードからメイン CR PLL クロック
モードに切り換えるとき , 一度クロックモードをメイン PLL クロッ
クモードとメイン CR PLL クロックモード以外のクロックモードに
切り換えてから , メイン CR PLL クロックモードに遷移させてくだ
さい。
(9)
サブ CR クロック
(1) および (2) と同様
(10)
(11)
サブクロック
(12)
(3) および (4) と同様
システムクロック制御レジスタのクロックモード選択ビット
(SYCC:SCS[2:0]) を "0b110" に設定すると , デバイスはメイン CR ク
ロック発振安定待ち時間の経過を待ってからメイン CR クロック
メイン CR クロック /
モードに遷移します。
メイン CR PLL
システムクロック制御レジスタのクロックモード選択ビット
クロック
(SYCC:SCS[2:0])を"0b111"に設定すると, デバイスはメインCR PLL
クロック発振安定待ち時間の経過を待ってからメイン CR PLL ク
ロックモードに遷移します。
(13)
サブ CR
クロック
(14)
(15)
(16)
システムクロック制御レジスタのクロックモード選択ビット
(SYCC:SCS[2:0]) を "0b010" に設定すると , デバイスはメインクロッ
ク発振安定待ち時間の経過を待ってからメインクロックモードに
メインクロック /
遷移します。
メイン PLL クロック シ ス テ ム ク ロ ッ ク 制 御 レ ジ ス タ の ク ロ ッ ク モ ー ド 選 択 ビ ッ ト
(SYCC:SCS[2:0]) を "0b011" に設定すると , デバイスはメイン PLL
クロック発振安定待ち時間の経過を待ってからメイン PLL クロッ
クモードに遷移します。
サブクロック
(3) および (4) と同様
(17)
メイン CR クロック /
メイン CR PLL
(13) と同様
クロック
(18) サブクロック
メインクロック /
(14) と同様
メイン PLL クロック
(19)
サブ CR クロック
(1) および (2) と同様
(21) メイン CR
クロック
メイン CR PLL
クロック
システムクロック制御レジスタのクロックモード選択ビット
(SYCC:SCS[2:0]) を "0b111" に設定すると , デバイスはメイン CR
PLL クロック発振安定待ち時間の経過を待ってからメイン CR PLL
クロックモードに遷移します。
(22) メイン CR PLL
クロック
メイン CR クロック
システムクロック制御レジスタのクロックモード選択ビット
(SYCC:SCS[2:0]) を "0b110" に設定すると , デバイスは直ちにメイ
ン CR PLL クロックモードに遷移します。
(20)
April 4, 2014, MB95F718M_MN702-00014-3v0-J
43
第 3 章 クロック制御部
3.4 クロックモード
H ard war e
表 3.4-1
Ma nu al
クロックモードの状態遷移表 (3 / 3)
現在の状態
次の状態
説明
システムクロック制御レジスタのクロックモード選択ビット
(23) メインクロック メイン PLL クロック (SYCC:SCS[2:0]) を "0b011" に設定すると , デバイスはメイン PLL
クロック発振安定待ち時間の経過を待ってからメイン PLL クロッ
クモードに遷移します。
(24) メイン PLL
クロック
44
メインクロック
システムクロック制御レジスタのクロックモード選択ビット
(SYCC:SCS[2:0]) を "0b010" に設定すると , デバイスは直ちにメイ
ンクロックモードに遷移します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.5 低消費電力モード ( スタンバイモード ) の動作
Ha rdware
3.5
Manual
低消費電力モード ( スタンバイモード ) の動作
スタンバイモードには , スリープモード , ストップモード , タイムベースタイマモー
ド , 時計モードの 4 種類があります。
■ スタンバイモードの遷移と復帰の概要
スタンバイモードには , スリープモード , ストップモード , タイムベースタイマモード ,
時計モードの 4 種類があります。スタンバイ制御レジスタ (STBC) の設定によって , デ
バイスはスタンバイモードに遷移します。
スタンバイモードの解除は , 割込みまたはリセットにより行われます。通常動作に遷移
する前に , デバイスは必要に応じて自動的に発振安定待ち時間の経過を待ちます。
リセットによりクロックモードがスタンバイモードから復帰する場合は , デバイスは
メイン CR クロックモードに戻ります。割込みによりクロックモードがスタンバイモー
ドから復帰する場合は , スタンバイモードに遷移する前のクロックモードに復帰しま
す。
■ スタンバイモード時の端子の状態
スタンバイ制御レジスタの端子状態設定ビット (STBC:SPL) によって , ストップモード ,
タイムベースタイマモードまたは時計モード時の I/O ポートまたは周辺機能端子の状
態を直前の状態保持または周辺機能端子をハイインピーダンスに設定できます。
スタンバイモード時の全端子の状態については , デバイスのデータシートを参照して
ください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
45
第 3 章 クロック制御部
3.5 低消費電力モード ( スタンバイモード ) の動作
H ard war e
3.5.1
Ma nu al
スタンバイモード使用上の注意
スタンバイ制御レジスタ (STBC) をスタンバイモードに設定した場合でも , 周辺機能
から割込み要求が発生しているときには , スタンバイモードに遷移しません。デバイ
スが割込みに反応してスタンバイモードから通常動作状態へ復帰する場合は , 割込み
要求が受け付けられるかどうかによって復帰後の動作が異なります。
■ スタンバイモード設定を行う命令の直後に NOP 命令を 3 命令以上入れてください。
スタンバイ制御レジスタに設定した後 , デバイスはスタンバイモードに遷移するまで
に 4 マシンクロック周期が必要となります。その間 CPU はプログラムを実行します。
スタンバイモードへの遷移時にプログラムの実行を回避するためには , 必ず NOP 命令
を 3 命令以上入れてください。
デバイスがスタンバイモードに遷移するように設定した命令の後に , NOP 以外の命令
を配置してもデバイスは正常に動作します。その場合 , 下記の 2 つのイベントが起こり
得ます。スタンバイモード解除後に実行するはずの命令がスタンバイモードに遷移す
る前に実行されることがあります。次に , デバイスが命令実行の途中でスタンバイモー
ドに入り , スタンバイモード解除後に同じ命令の実行が再開されることもあります (命
令実行サイクル数の増加 ) 。
■ スタンバイモード設定前にクロックモードの遷移が完了していることを確認して
ください。
スタンバイモードの設定前に , システムクロック制御レジスタにおけるクロックモード
モニタビット (SYCC:SCM[2:0]) とクロックモード選択ビット (SYCC:SCS[2:0]) の値を比
較して , クロックモードの遷移が完了していることを確認してください。
■ 割込み要求によりスタンバイモードへの遷移が抑止されることがあります。
スタンバイモードの設定を行う時に割込みレベルが "0b11" より強い割込み要求が発生
した場合 , デバイスはスタンバイ制御レジスタへの書込みを無視し , 設定されたスタン
バイモードへの遷移はしないで命令の実行を続けます。割込み要求の処理後にもデバ
イスはスタンバイモードに遷移しません。
CPU のコンディションコードレジスタにおける割込み許可フラグ (CCR:I) および割込
みレベルビット (CCR:IL[1:0]) によって割込みが禁止されている場合にも , 同様の動作
が実行されます。
■ スタンバイモードは CPU が割込みを受け付けない場合も解除されます。
スタンバイモード中に割込みレベルが "0b11" より強い割込み要求が発生すると , デバ
イスは CPU のコンディションコードレジスタ (CCR) における割込み許可フラグ (CCR:I)
および割込みレベルビット (CCR:IL[1:0]) の設定に関係なくスタンバイモードから解除
されます。
スタンバイモードからの解除後 , CPU のコンディションコードレジスタ (CCR) の設定
により割込みを受け付けられる状態のときは , デバイスは割込みを処理します。もし
CCR の設定が割込みを受け付けられない場合 , デバイスはスタンバイモードに遷移す
る前に実行した次の命令から実行を再開します。
46
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.5 低消費電力モード ( スタンバイモード ) の動作
Ha rdware
Manual
■ スタンバイモードの状態遷移図
図 3.5-1 に , スタンバイモードの状態遷移図を示します。
図 3.5-1 スタンバイモードの状態遷移図
電源投入
各ステートでリセット発生
リセット状態
<1>
メインCRクロック
発振安定待ち時間
+
サブCRクロック
発振安定待ち時間
(3)
ストップモード
(4)
メインクロック/メインPLLクロック/メインCRクロック/
メインCR PLLクロック/サブクロック/サブCRクロック
発振安定待ち時間
スリープモード (フラッシュリカバリ待ち時間*)
(7)
通常動作
(RUN状態)
スリープモード (フラッシュリカバリ待ち時間*)
(8)
時計モード
(1)
(5)
スリープモード (フラッシュリカバリ待ち時間*)
(6)
(2)
スリープモード (フラッシュリカバリ待ち時間*)
スリープモード
タイムベース
タイマモード
*: フラッシュメモリリカバリ待ち時間 (SCLK: ソースクロック , MCLK: マシンクロック )
•
メインクロックモード , メイン PLL クロックモード , メイン CR クロックモードまたはメ
イン CR PLL クロックモードの場合
最大値 : 10 SCLK + 150 µs + 6 MCLK
•
サブクロックモードまたはサブ CR クロックモードの場合
最大値 : 2 SCLK + 150 µs + 6 MCLK
April 4, 2014, MB95F718M_MN702-00014-3v0-J
47
第 3 章 クロック制御部
3.5 低消費電力モード ( スタンバイモード ) の動作
H ard war e
表 3.5-1
Ma nu al
状態遷移表 ( スタンバイモードへの遷移と解除 )
状態遷移
説明
リセット後 , デバイスがメイン CR クロックモードに遷移します。
<1> リセット状態後の通常動作 パワーオンリセット , ウォッチドッグリセット , ソフトウェアリセット , 外部
リセットの場合 , デバイスは常にサブ CR クロックとメイン CR クロック発
振安定待ち時間の経過を待ちます。
(1)
スタンバイ制御レジスタのスリープビット (STBC:SLP) に "1" を書き込むと ,
デバイスはスリープモードに遷移します。
(2)
周辺機能からの割込みにより , フラッシュリカバリ待ち時間の経過を待って
からデバイスは RUN 状態に復帰します。
また , フラッシュリカバリ待ち時間の間はスリープモード (CPU は動作停止 ,
周辺機能は動作再開 ) となります。
ただし , RAM でプログラムを実行している場合は , フラッシュリカバリ待ち
時間は発生しません。
(3)
スタンバイ制御レジスタのストップビット (STBC:STP) に "1" を書き込むと ,
デバイスはストップモードに遷移します。
(4)
外部割込みにより , 現在のクロックモードに応じて必要な発振安定待ち時間
の経過およびフラッシュリカバリ待ち時間の経過を待ってからデバイスは
RUN 状態に復帰します。
発振安定待ち時間がフラッシュリカバリ待ち時間より短い場合 , 発振安定待
ち時間経過後 , フラッシュリカバリ待ち時間が経過するまでスリープモード
となります。
発振安定待ち時間がフラッシュリカバリ待ち時間より長い場合 , 発振安定待
ち時間経過後 , デバイスは RUN 状態に復帰します。
ただし , RAM でプログラムを実行している場合は , フラッシュリカバリ待ち
時間は発生しません。
(5)
メインクロックモード , メイン PLL クロックモード , メイン CR クロック
モードまたはメイン CR PLL クロックモード中のスタンバイ制御レジスタ
(STBC:TMD) の時計ビットに "1" を書き込むと , デバイスはタイムベース
モードに遷移します。
スリープモード
ストップモード
(6)
タイムベースタイマモード 周辺機能からの割込みにより , フラッシュリカバリ待ち時間の経過を待って
からデバイスは RUN 状態に復帰します。
また , フラッシュリカバリ待ち時間の間はスリープモード (CPU は動作停止 ,
周辺機能は動作再開 ) となります。
ただし , RAM でプログラムを実行している場合は , フラッシュリカバリ待ち
時間は発生しません。
(7)
サブクロックモードまたはサブ CR クロックモードのスタンバイ制御レジス
タの時計ビット (STBC:TMD) に "1" を書き込むと , デバイスは時計モードに
遷移します。
時計モード
(8)
48
周辺機能からの割込みにより , フラッシュリカバリ待ち時間の経過を待って
からデバイスは RUN 状態に復帰します。
また , フラッシュリカバリ待ち時間の間はスリープモード (CPU は動作停止 ,
周辺機能は動作再開 ) となります。
ただし , RAM でプログラムを実行している場合は , フラッシュリカバリ待ち
時間は発生しません。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.5 低消費電力モード ( スタンバイモード ) の動作
Ha rdware
3.5.2
Manual
スリープモード
スリープモードでは CPU とウォッチドッグタイマの動作は停止となります。
■ スリープモードの動作
スリープモードでは CPU とウォッチドッグタイマの動作クロックは停止となります。
CPU はデバイスがスリープモードに遷移する直前に存在しているレジスタと RAM の
内容を保持して停止しますが , ウォッチドッグタイマを除く周辺機能は動作を続けま
す。
ハードウェアウォッチドッグタイマの場合 , 不揮発性レジスタ機能によってスタンバ
イモードが許可されたとき , スリープモードでサブ CR クロックは停止せず , ハード
ウェアウォッチドッグタイマは動作します。詳細は ,「第 28 章 不揮発性レジスタ (NVR)
インタフェース」を参照してください。
● スリープモードへの遷移
スタンバイ制御レジスタのスリープビット (STBC:SLP) を "1" に設定すると , デバイス
はスリープモードに入ります。
● スリープモードの解除
リセットまたは周辺機能からの割込みによって , デバイスはスリープモードから解除
されます。
リセットまたは周辺機能からの割込みが発生した後でも , フラッシュリカバリ待ち時
間が経過するまでデバイスはスリープモードを継続します。
ただし , RAM でプログラムを実行している場合は , フラッシュリカバリ待ち時間は発
生しません。
フラッシュリカバリ待ち時間の詳細については , 図 3.5-1 を参照してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
49
第 3 章 クロック制御部
3.5 低消費電力モード ( スタンバイモード ) の動作
H ard war e
3.5.3
Ma nu al
ストップモード
ストップモードでは , メインクロック , メイン PLL クロック , メイン CR クロック ,
メイン CR PLL クロックおよびサブクロックは停止となります。
■ ストップモードの動作
ストップモードでは , メインクロック , メイン PLL クロック , メイン CR クロック , メ
イン CR PLL クロックおよびサブクロックは停止となります。このモードでは , デバイ
スはストップモードに遷移する直前にレジスタと RAM の内容を保持しつつ , 外部割込
みと低電圧検出リセットを除くすべての機能を停止します。
ハードウェアウォッチドッグタイマの場合 , 不揮発性レジスタ機能によってスタンバ
イモードが許可されたとき , ストップモードでサブ CR クロックは停止せず , ハード
ウェアウォッチドッグタイマは動作します。詳細は「第 28 章 不揮発性レジスタ (NVR)
インタフェース」を参照してください。
● ストップモードへの遷移
スタンバイ制御レジスタのストップビット (STBC:STP) に "1" を書き込むと , デバイス
はストップモードに入ります。このとき , スタンバイ制御レジスタの端子状態設定ビッ
ト (STBC:SPL) が "0" の場合 , 外部端子の状態は保持され , SPL ビットが "1" の場合には
外部端子の状態はハイインピーダンスになります ( プルアップレジスタでプルアップ
抵抗を選択している端子はプルアップ状態になります ) 。
● ストップモードの解除
ストップモードはリセットまたは外部割込みによって解除されます。どのクロック
モードも , スタンバイモードにおいて , ハードウェアウォッチドッグタイマか不揮発性
レジスタ機能によって許可された場合 , サブ CR クロックは停止せず , ウォッチドッグ
タイマおよび時計プリスケーラはストップモードで動作します。また , 時計プリスケー
ラからの割込みによりデバイスはストップモードから解除されます。詳細は , 「第 28
章 不揮発性レジスタ (NVR) インタフェース」を参照してください。
リセットまたは周辺機能からの割込み発生後の動作は , 発振安定待ち時間とフラッ
シュリカバリ待ち時間の関係で以下のようになります。
•
発振安定待ち時間がフラッシュリカバリ待ち時間より短い場合
発振安定待ち時間経過後 , デバイスはスリープモードに遷移し , フラッシュリカバ
リ待ち時間が経過するまでスリープモードを継続します。
•
発振安定待ち時間がフラッシュリカバリ待ち時間より長い場合
発振安定待ち時間経過後 , デバイスは RUN 状態に復帰します。
ただし , RAM でプログラムを実行している場合は , フラッシュリカバリ待ち時間は発
生しません。
フラッシュリカバリ待ち時間の詳細については , 図 3.5-1 を参照してください。
50
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.5 低消費電力モード ( スタンバイモード ) の動作
Ha rdware
Manual
<注意事項>
デバイスが割込みによってストップモードから解除された場合 , 動作途中でストップモー
ドとなった周辺機能はストップモードに遷移した時点の動作から再開します。そのため ,
インターバルタイマにおける初回のインターバル時間などの周辺機能設定が不定になり
ます。デバイスをストップモードから解除した後は必要に応じて周辺機能を初期化してく
ださい。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
51
第 3 章 クロック制御部
3.5 低消費電力モード ( スタンバイモード ) の動作
H ard war e
3.5.4
Ma nu al
タイムベースタイマモード
タイムベースタイマモードではメインクロック発振 , サブクロック発振 , タイムベー
スタイマおよび時計プリスケーラのみ動作します。このモードでは CPU と周辺機能
の動作クロックは停止となります。
■ タイムベースタイマの動作
タイムベースタイマモードは , タイムベースタイマへのクロック供給を除きメインク
ロックの供給を停止させるモードです。このモードではデバイスはタイムベースタイ
マモードに遷移する直前に存在しているレジスタと RAM の内容を保持しつつ , タイム
ベースタイマ , 外部割込みと低電圧検出リセットを除くすべての機能を停止します。
システムクロック制御レジスタ 2 のサブクロック発振許可ビットおよびサブ CR クロッ
ク発振許可ビット (SYCC2:SOSCE, SCRE) の設定により , それぞれサブクロック発振お
よびサブ CR クロック発振をそれぞれ許可または禁止できます。サブクロックが発振
する場合 , 時計プリスケーラが動作します。
ハードウェアウォッチドッグタイマの場合 , 不揮発性レジスタ機能によってスタンバ
イモードが許可されたとき, タイムベースタイマモードでサブCRクロックは停止せず,
ハードウェアウォッチドッグタイマは動作します。詳細は, 「第28章 不揮発性レジス
タ (NVR) インタフェース」 を参照してください。
● タイムベースタイマモードへの遷移
システムクロック制御レジスタのクロックモードモニタビット (SYCC:SCM[2:0]) が
"0b010", "0b011", "0b110" または "0b111"の場合, スタンバイ制御レジスタの時計ビット
(STBC:TMD) に "1" を書き込むことによりデバイスはタイムベースタイマモードに遷
移します。
タイムベースタイマモードへの遷移はデバイスのクロックモードがメインクロック
モード , メイン PLL クロックモード , メイン CR クロックモードまたはメイン CR PLL
クロックモードのときのみ可能です。
デバイスがタイムベースタイマモードに遷移したとき , スタンバイ制御レジスタの端
子状態設定ビット (STBC:SPL) が "0" の場合 , 外部端子の状態を保持し , SPL ビットが
"1" の場合には外部端子の状態はハイインピーダンスになります ( プルアップレジスタ
でプルアップ抵抗を選択している端子はプルアップ状態になります ) 。
● タイムベースタイマモードからの解除
リセット , タイムベースタイマ割込み , 外部割込みにより , デバイスはタイムベースタ
イマモードから解除されます。
システムクロック制御レジスタ 2 (SYCC2) のサブクロック発振許可ビット (SOSCE) と
サブ CR クロック発振許可ビット (SCRE) の設定により , サブクロック発振およびサブ
CR クロック発振を許可または禁止できます。サブクロックが発振する場合 , 時計プリ
スケーラからの割込みによりデバイスはタイムベースタイマモードから解除されま
す。
リセットまたは周辺機能からの割込みが発生した後でも , フラッシュリカバリ待ち時
間が経過するまでデバイスはスリープモードで動作を継続します。
ただし , RAM でプログラムを実行している場合は , フラッシュリカバリ待ち時間は発
52
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.5 低消費電力モード ( スタンバイモード ) の動作
Ha rdware
Manual
生しません。
フラッシュリカバリ待ち時間の詳細については , 図 3.5-1 を参照してください。
<注意事項>
デバイスが割込みによってタイムベースタイマモードから解除された場合 , 動作途中でタ
イムベースタイマモードとなった周辺機能は , タイムベースタイマモードに遷移した時点
の動作から再開します。そのため , インターバルタイマにおける初回のインターバル時間
などの周辺機能設定が不定になります。デバイスをタイムベースタイマモードから解除し
た後は必要に応じて周辺機能を初期化してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
53
第 3 章 クロック制御部
3.5 低消費電力モード ( スタンバイモード ) の動作
H ard war e
Ma nu al
時計モード
3.5.5
時計モードではサブクロック , サブ CR クロックおよび時計プリスケーラのみが動作
します。このモードでは CPU と周辺機能の動作クロックは停止となります。
■ 時計モードの動作
時計モードでは , デバイスは時計モードに遷移する直前にレジスタと RAM の内容を保
持しつつ , デバイスは外部割込みと低電圧検出リセットを除くすべての機能を停止し
ます。
スタンバイモード中に , 不揮発性レジスタによってハードウェアウォッチドッグタイ
マが許可されていると , 時計モードでサブ CR クロックは停止せず , ハードウェア
ウォッチドッグタイマは動作します。詳細は , 「第 28 章 不揮発性レジスタ (NVR) イ
ンタフェース」を参照してください。
● 時計モードへの遷移
システムクロック制御レジスタのシステムクロックモニタビット (SYCC:SCM[2:0]) が
"0b000" または "0b100" の場合 , スタンバイ制御レジスタの時計ビット (STBC:TMD) に
"1" を書き込むことによりデバイスは時計モードに遷移します。
時計モードへの遷移はデバイスのクロックモードがサブクロックモードまたはサブ
CR クロックモードのときのみ遷移できます。
デバイスが時計モードに遷移したとき , スタンバイ制御レジスタの端子状態設定ビッ
ト (STBC:SPL) が "0" の場合 , 外部端子の状態を保持し , SPL ビットが "1" の場合には外
部端子の状態はハイインピーダンスになります ( プルアップレジスタでプルアップ抵
抗を選択している端子はプルアップ状態になります ) 。
● 時計モードからの解除
リセット , 時計割込みまたは外部割込みによりデバイスは時計モードから解除されま
す。
リセットまたは周辺機能からの割込みが発生した後でも , フラッシュリカバリ待ち時
間が経過するまでデバイスはスリープモードで動作を継続します。
ただし , RAM でプログラムを実行している場合は , フラッシュリカバリ待ち時間は発
生しません。
フラッシュリカバリ待ち時間の詳細については , 図 3.5-1 を参照してください。
<注意事項>
デバイスが割込みによって時計モードから解除された場合 , 動作途中で時計モードとなっ
た周辺機能は , 時計モードに遷移した時点の動作から再開します。そのため , インターバ
ルタイマにおける初回のインターバル時間などの周辺機能設定が不定になります。デバイ
スを時計モードから解除した後は , 必要に応じて周辺機能を初期化してください。
54
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.6 クロック発振回路
Ha rdware
3.6
Manual
クロック発振回路
クロック発振回路はクロック発振端子に振動子を接続するかまたはクロック信号を
入力することによって内部クロックを生成します。
■ クロック発振回路
● 水晶振動子またはセラミック振動子の場合
図 3.6-1 のように水晶振動子またはセラミック振動子を接続してください。
図 3.6-1 水晶振動子とセラミック振動子の接続例
2系統の外部クロックに接続
メインクロック
発振回路
X0
C
X1
サブクロック
発振回路
X0A
X1A
C
C
C
● 外部クロックの場合
図 3.6-2 に示すように , クロック信号を外部クロックからメインクロックに供給する場
合 , 外部クロックを X0 端子に接続し , SYSC レジスタの PFSEL[1:0] ビットに "10" を書
き込んでください。また , クロック信号を外部クロックからサブクロックに供給する場
合 , 外部クロックを X0A 端子に接続し , SYSC レジスタの PGSEL[1:0] ビットに "10" を
書き込んでください。SYSC レジスタの詳細については , 「第 30 章 システム構成コン
トローラ」を参照してください。
図 3.6-2 外部クロックの接続例
X1 開放
メインクロック
発振回路
X0
April 4, 2014, MB95F718M_MN702-00014-3v0-J
サブクロック
発振回路
X0A
55
第 3 章 クロック制御部
3.7 プリスケーラの概要
H ard war e
3.7
Ma nu al
プリスケーラの概要
プリスケーラは , マシンクロック (MCLK) とタイムベースタイマから出力されるカウ
ントクロックより , 各種周辺機能へ供給するカウントクロックソースを生成します。
■ プリスケーラ
プリスケーラは CPU の動作するマシンクロック (MCLK) とタイムベースタイマから出
力されるカウントクロック (FCH/27, FCH/28, FCRH/26, FCRH/27, FPLL/26 または FPLL/27) よ
り , 各種周辺機能へ供給するカウントクロックソースを生成します。このカウントク
ロックソースはプリスケーラで分周されたクロックまたはバッファされたクロックで
す。下記の周辺機能はこのプリスケーラによって分周されたクロック周波数をカウン
トクロックソースとして使用しています。
なお , 本プリスケーラには制御用のレジスタはなく , マシンクロック (MCLK) およびタ
イムベースタイマのカウントクロック (FCH/27, FCH/28, FCRH/26, FCRH/27, FPLL/26 または
FPLL/27) にて常に動作します。
56
•
8/16 ビット複合タイマ
•
8/12 ビット A/D コンバータ
•
8/16 ビット PPG
•
16 ビットリロードタイマ
•
UART/SIO 専用ボーレートジェネレータ
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.8 プリスケーラの構成
Ha rdware
Manual
プリスケーラの構成
3.8
図 3.8-1 に , プリスケーラのブロックダイヤグラムを示します。
■ プリスケーラのブロックダイヤグラム
図 3.8-1 プリスケーラのブロックダイヤグラム
プリスケーラ
MCLK/2
MCLK/4
カウンタ値
MCLK(マシンクロック)
MCLK/8
5ビット
カウンタ
出力制御回路
タイムベースタイマから
FCH/27
FCRH/26
あるいは
FCH/28
FPLL/26
あるいは
FCRH/27
FPLL/27
MCLK
FCH
FCRH
FPLL
:マシンクロック(内部動作周波数)
:メインクロック周波数
:メインCRクロック周波数
:PLLクロック周波数
•
MCLK/16
MCLK/32
各周辺機能へ
カウントクロック
を供給する
FCH/27,FCRH/26 あるいは FPLL/26
FCH/28,FCRH/27 あるいは FPLL/27
5 ビットカウンタ
本カウンタは , マシンクロック (MCLK) をカウントし , 出力制御回路へカウンタ値
を出力します。
•
出力制御回路
本回路は , 5 ビットカウンタ値に基づき , マシンクロック (MCLK) を 2 分周 , 4 分周 ,
8 分周 , 16 分周 , 32 分周したクロックを各周辺機能へ供給する回路です。この回路
はタイムベースタイマ (FCH/27, FCH/28, FCRH/26, FCRH/27, FPLL/26 または FPLL/27) か
らのクロックをバッファリングして各周辺機能へ供給します。
■ 入力クロック
プリスケーラはマシンクロックまたはタイムベースタイマの出力クロックを入力ク
ロックとして使用します。
■ 出力クロック
プリスケーラは以下の周辺機能にクロックを供給します。
•
8/16 ビット複合タイマ
•
8/12 ビット A/D コンバータ
•
8/16 ビット PPG
•
16 ビットリロードタイマ
•
UART/SIO 専用ボーレートジェネレータ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
57
第 3 章 クロック制御部
3.9 プリスケーラの動作
H ard war e
3.9
Ma nu al
プリスケーラの動作
プリスケーラは , 各周辺機能へ供給するカウントクロックソースを生成します。
■ プリスケーラの動作
プリスケーラは , マシンクロック (MCLK) を分周して生成される周波数のクロックお
よびタイムベースタイマ (FCH/27, FCH/28, FCRH/26, FCRH/27, FPLL/26 または FPLL/27) の
バッファ信号からカウントクロックソースを生成し , 各周辺機能へ供給します。このプ
リスケーラはマシンクロックとタイムベースタイマからのクロックが供給されている
間は動作を継続します。
表 3.9-1, 表 3.9-2と表 3.9-3に, プリスケーラの生成するカウントクロックソースを示し
ます。
表 3.9-1
プリスケーラの生成するカウントクロックソース (FCH)
カウントクロック
ソース周波数
周波数
(FCH = 32.5 MHz,
MCLK = 16.25 MHz)
5 MHz
8 MHz
8.125 MHz
MCLK/4
2.5 MHz
4 MHz
4.0625 MHz
MCLK/8
1.25 MHz
2 MHz
2.0313 MHz
MCLK/16
0.625 MHz
1 MHz
1.0156 MHz
MCLK/32
0.3125 MHz
0.5 MHz
0.5078 MHz
FCH/27
156.25 kHz
250 kHz
253.9 kHz
/28
78.125 kHz
125 kHz
126.95 kHz
プリスケーラの生成するカウントクロックソース (FCRH)
カウントクロック
ソース周波数
58
周波数
(FCH = 32 MHz,
MCLK = 16 MHz)
MCLK/2
FCH
表 3.9-2
周波数
(FCH = 20 MHz,
MCLK = 10 MHz)
周波数
(FCRH = 4 MHz,
MCLK = 4 MHz)
MCLK/2
2 MHz
MCLK/4
1 MHz
MCLK/8
0.5 MHz
MCLK/16
0.25 MHz
MCLK/32
125 kHz
FCRH
/26
62.5 kHz
FCRH
/27
31.25 kHz
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 3 章 クロック制御部
3.9 プリスケーラの動作
Ha rdware
表 3.9-3
Manual
プリスケーラの生成するカウントクロックソース (FPLL)
カウントクロック
ソース周波数
周波数
(FPLL = 8 MHz,
MCLK = 8 MHz)
周波数
(FPLL = 10 MHz,
MCLK = 10 MHz)
周波数
(FPLL = 12 MHz,
MCLK = 12 MHz)
周波数
(FPLL = 16 MHz,
MCLK = 16 MHz)
MCLK/2
4 MHz
5 MHz
6 MHz
8 MHz
MCLK/4
2 MHz
2.5 MHz
3 MHz
4 MHz
MCLK/8
1 MHz
1.25 MHz
1.5 MHz
2 MHz
MCLK/16
0.5 MHz
0.625 MHz
0.75 MHz
1 MHz
MCLK/32
0.25 MHz
0.3125 MHz
0.375 MHz
0.5 MHz
FPLL/26
125 kHz
156.25 kHz
187.5 kHz
0.25 MHz
FPLL/27
62.5 kHz
78.125 kHz
93.75 kHz
125 kHz
April 4, 2014, MB95F718M_MN702-00014-3v0-J
59
第 3 章 クロック制御部
3.10 プリスケーラ使用上の注意
H ard war e
3.10
Ma nu al
プリスケーラ使用上の注意
プリスケーラ使用上の注意を示します。
プリスケーラは , マシンクロックとタイムベースタイマから発生するクロックにより
動作し , これらのクロックが供給されている間は動作を継続します。したがって , 周辺
機能が起動した直後の動作は , プリスケーラの出力値に応じて , 周辺機能のクロック取
込みに , 最大 1 クロックリソース分の誤差が発生します。
図 3.10-1 周辺機能起動直後に発生するクロック取込み誤差
プリスケーラ
の出力
周辺機能起動
周辺機能側の
クロック取込み
周辺機能起動直後の
クロック取込み誤差
以下の周辺機能は , プリスケーラのカウント値の影響を受けます。
60
•
8/16 ビット複合タイマ
•
8/12 ビット A/D コンバータ
•
8/16 ビット PPG
•
16 ビットリロードタイマ
•
UART/SIO 専用ボーレートジェネレータ
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第4章
リセット
リセットの動作について説明します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
4.1
リセット動作
4.2
レジスタ
4.3
使用上の注意
61
第 4 章 リセット
4.1 リセット動作
H ard war e
Ma nu al
リセット動作
4.1
リセット要因が発生すると, CPUは現在実行中の処理を直ちに中断してリセット解除
待ち状態になります。リセットが解除されると , CPU はフラッシュメモリからモード
データとリセットベクタを読み出します ( モードフェッチ )。電源投入時またはデバ
イスがサブクロックモード , サブ CR クロックモードおよびストップモードのリセッ
トから解除されると, CPUは発振安定待ち時間が経過した後にモードフェッチを行い
ます。
■ リセット要因
リセットには , 5 つのリセット要因があります。
表 4.1-1
リセット要因
リセット要因
リセット条件
外部リセット
外部リセット端子に "L" レベルを入力する。
ソフトウェアリセット
スタンバイ制御レジスタのソフトウェアリセットビット
(STBC:SRST) を "1" に設定する。
ウォッチドッグリセット
ウォッチドッグタイマのオーバフロー。
パワーオンリセット
電源の投入
低電圧検出リセット ( オプション )
供給電圧が検出電圧より低下する。
● 外部リセット
外部リセット端子 (RST) を "L" レベルにすることによって , 外部リセットを発生します。
外部から入力されたリセット信号は , 内部のノイズフィルタを通してマイコンの動作
クロックに非同期で受け付けられ , 内部回路を初期化するためにマシンクロックに同
期した内部リセット信号を発生します。したがって , 内部回路の初期化のためにマイコ
ンの動作クロックが必要です。ただし , 外部クロックで動作するためには , 外部クロッ
ク信号が入力されなければいけません。外部端子 (I/O ポートおよび周辺機能を含む ) は
非同期でリセットされます。また , 外部リセット入力には , パルス幅の標準値がありま
す。値が標準値を下回る場合は , リセット信号が受け付けられないことがあります。
なお , 規格値はデータシートに記載しているため , 規格値を満足するように外部のリ
セット回路を設計してください。
● ソフトウェアリセット
スタンバイ制御レジスタのソフトウェアリセットビット (STBC:SRST) を "1" に設定す
ることによって , ソフトウェアリセットが発生します。
● ウォッチドッグリセット
ウォッチドッグタイマの起動後 , 所定時間にウォッチドッグタイマのクリアが行われ
ないときには , ウォッチドッグリセットが発生します。
● パワーオンリセット
電源が投入されると , パワーオンリセットが発生します。
62
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 4 章 リセット
4.1 リセット動作
Ha rdware
Manual
● 低電圧検出リセット ( オプション )
低電圧検出リセット回路は特定の品種にのみ搭載されています。デバイスのデータ
シートでこの回路の有無を確認してください。
低電圧検出リセット回路は , 電源電圧が定められた電圧より低下したときにリセット
を発生します。
低電圧検出リセットの論理機能はパワーオンリセットと同じです。本マニュアルにお
けるパワーオンリセットに関するすべての記述は , 低電圧検出リセットにも適応され
ます。
ただし , 低電圧検出回路の LVD 制御レジスタ (LVDC) は低電圧検出リセットによって
はリセットされません。
低電圧検出リセットの詳細については「第 16 章 低電圧検出回路」を参照してください。
■ リセット中の時間
リセット中の時間はリセット要因により異なります。
•
ソフトウェアリセット , ウォッチドッグリセットまたは外部リセットの場合
リセット時間は , リセット前に選択したマシンクロックの周期 , RAM アクセス中の
リセットを抑止する RAM アクセス保護機能およびサブ CR クロック発振安定待ち
時間から影響を受けます。RAM アクセス保護機能はリセット前に選択したマシン
クロックの周期によって延長されることがあります。
システムクロック制御レジスタ 2 のサブ CR クロック発振安定ビット (SYCC2:
SCRDY) が "1" のときにリセットが発生した場合 , メイン CR クロック発振安定待ち
時間経過後 , リセット状態が解除されます。
システムクロック制御レジスタ 2 のサブ CR クロック発振安定ビット (SYCC2:
SCRDY) が "0" のときにリセットが発生した場合 , サブ CR クロック発振安定待ち時
間とメイン CR クロック発振安定待ち時間が経過した後に , リセット状態が解除さ
れます。
•
パワーオンリセットおよび低電圧検出リセットの場合
リセット状態は , サブ CR クロック発振安定待ち時間とメイン CR クロック発振安
定待ち時間が経過した後に , 解除されます。
■ リセット出力
RST端子は, リセット入力機能が有効であり, かつリセット出力機能が有効である場合,
リセット中に "L" レベルを出力します。ただし , 外部リセットの場合はリセット端子に
は "L" レベルを出力する機能はありません。
リセット入力機能 , リセット出力機能設定については ,「第 30 章 システム構成コント
ローラ」を参照してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
63
第 4 章 リセット
4.1 リセット動作
H ard war e
Ma nu al
■ リセット動作の概要
図 4.1-1 リセット動作フロー
ソフトウェアリセット
ウォッチドッグリセット
リセット中
RAMアクセス中
リセット抑止
パワーオンリセット/
低電圧検出リセット
外部リセット入力
RAMアクセス中
リセット抑止
サブCRクロックで動作中?
YES
サブCRクロックで動作中?
YES
NO
サブCRクロック
発振安定待ち時間
リセット状態
NO
サブCRクロック
発振安定待ち時間
リセット状態
外部リセット
解除?
サブCRクロック
発振安定待ち時間
リセット状態
NO
YES
メインCRクロック
発振安定待ち時間
モードフェッチ
モードデータ取込み
リセットベクタ取込み
リセットベクタが示すアドレスから
命令コードを取り込み, 命令を実行
通常動作
(Run 状態)
任意のリセットで , CPU はモードフェッチをメイン CR クロック発振安定待ち時間が
経過した後に実行します。
■ RAM 内容のリセットによる影響
リセットが発生した場合 , CPU は現在実行中の命令の動作を中断し , リセット状態にな
ります。ただし , RAM アクセス中は , RAM アクセスの保護のために RAM アクセスの
終了後にマシンクロックに同期して内部リセット信号を発生します。この機能は 2 バ
イトのデータの書込み中 , ワードデータの書込み動作がリセットにより割り込まれる
のを防止します。
64
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 4 章 リセット
4.1 リセット動作
Ha rdware
Manual
■ リセット中の端子の状態
リセットが発生すると I/O ポートまたは周辺機能端子は , リセット解除後ソフトウェア
による設定が行われるまで , ハイインピーダンスになります。
<注意事項>
デバイスの誤作動防止ため , リセット中はハイインピーダンスとなる端子に対してプル
アップ抵抗を接続してください。
リセット中の全端子の状態については , デバイスのデータシートを参照してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
65
第 4 章 リセット
4.2 レジスタ
H ard war e
Ma nu al
レジスタ
4.2
リセット用のレジスタについて説明します。
表 4.2-1
リセット用のレジスタ一覧
レジスタ略称
RSRR
66
レジスタ名
リセット要因レジスタ
参照先
4.2.1
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 4 章 リセット
4.2 レジスタ
Ha rdware
4.2.1
Manual
リセット要因レジスタ (RSRR)
リセット要因レジスタは , 発生したリセットの要因を示します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
—
EXTS
WDTR
PONR
HWR
SWR
属性
—
—
—
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
X
X
X
X
X
■ レジスタ機能
[bit7:5] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit4] EXTS: 外部リセットフラグビット
このビットが "1" になった場合 , 外部リセットが発生したことを示します。
それ以外のリセットでは , リセット発生前の値を保持します。
読出し動作または書込み動作 ("0" または "1" の書込み ) はこの ビットを "0" に設定します。
説明
bit4
読出し動作
このビットを "0" に設定します。
"1" に設定された場合
リセット要因が外部リセットであることを示します。
書込み動作
このビットを "0" に設定します。
[bit3] WDTR: ウォッチドッグリセットフラグビット
このビットが "1" になった場合 , ウォッチドッグリセットが発生したことを示します。
それ以外のリセットでは , リセット発生前の値を保持します。
読出し動作または書込み動作 ("0" または "1" の書込み ) はこの ビットを "0" に設定します。
説明
bit3
読出し動作
このビットを "0" に設定します。
"1" に設定された場合
リセット要因がウォッチドッグリセットであることを示します。
書込み動作
このビットを "0" に設定します。
[bit2] PONR: パワーオンリセットフラグビット
このビットが "1" になった場合 , パワーオンリセット / 低電圧検出リセット ( オプション ) が発生し
たことを示します。
それ以外のリセットでは , リセット発生前の値を保持します。
低電圧検出リセット回路は特定の品種にのみ搭載されています。デバイスのデータシートでこの回
路の有無を確認してください。
読出し動作または書込み動作 ("0" または "1" の書込み ) はこの ビットを "0" に設定します。
説明
bit2
読出し動作
このビットを "0" に設定します。
"1" に設定された場合
リセット要因がパワーオンリセット / 低電圧検出リセット ( オプション ) である
ことを示します。
書込み動作
このビットを "0" に設定します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
67
第 4 章 リセット
4.2 レジスタ
H ard war e
Ma nu al
[bit1] HWR: ハードウェアリセットフラグビット
このビットが "1" になった場合 , ハードウェアリセット ( パワーオンリセット , 低電圧検出リセット
( オプション ), 外部リセットまたは ウォッチドッグリセット ) が発生したことを示します。したがっ
て , bit4 ~ bit2 のいずれかのビットが "1" になった場合 , このビットも "1" になります。
ソフトウェアリセットが発生した場合は , リセット発生前の値を保持します。
読出し動作または書込み動作 ("0" または "1" の書込み ) はこの ビットを "0" に設定します。
説明
bit1
読出し動作
このビットを "0" に設定します。
"1" に設定された場合
リセット要因がハードウェアリセットであることを示します。
書込み動作
このビットを "0" に設定します。
[bit0] SWR: ソフトウェアリセットフラグビット
このビットが "1" になった場合 , ソフトウェアリセットが発生したことを示します。
ハードウェアリセットが発生した場合は , リセット発生前の値を保持します。
読出し動作または書込み動作 ("0" または "1" の書込み ) またはパワーオンリセットはこの ビットを
"0" に設定します。
説明
bit0
読出し動作
このビットを "0" に設定します。
"1" に設定された場合
リセット要因がソフトウェアリセットであることを示します。
書込み動作
このビットを "0" に設定します。
<注意事項>
リセット要因レジスタを読み出すとその内容がクリアされるため , レジスタの内容を演算
に使用する前に RAM に保存してください。
68
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 4 章 リセット
4.2 レジスタ
Ha rdware
Manual
■ リセット要因レジスタ (RSRR) の状態
表 4.2-2
リセット要因レジスタの状態
リセット要因
EXTS
WDTR
PONR
HWR
SWR
パワーオンリセット
×
×
1
1
0
低電圧検出リセット ( オプション )
×
×
1
1
0
ソフトウェアリセット
1
ウォッチドッグリセット
1
外部リセット
1
1
1
フラグセット
1:
:
×:
前の状態を保持
不定
EXTS: このビットが "1" に設定されたときには , 外部リセットが発生したことを示し
ています。
WDTR: このビットが "1" に設定されたときには , ウォッチドッグリセットが発生した
ことを示しています。
PONR: このビットが "1" に設定されたときには , パワーオンリセットまたは低電圧検
出リセット ( オプション ) が発生したことを示しています。
HWR:
このビットが"1"に設定されたときには, 外部リセット, ウォッチドッグリセッ
ト , パワーオンリセット , 低電圧検出リセット ( オプション ) のリセットのう
ちの 1 つが発生したことを示しています。
SWR:
このビットが "1" に設定されたときには , ソフトウェアリセットが発生したこ
とを示しています。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
69
第 4 章 リセット
4.3 使用上の注意
H ard war e
4.3
Ma nu al
使用上の注意
リセット使用上の注意を示します。
■ リセット使用上の注意
● リセットの要因によるレジスタおよびビットの初期化について
リセットが発生しても , 初期化されないレジスタやビットがあります。
•
リセット要因の種類により , リセット要因レジスタ (RSRR) のどのビットを初期化
するか決定されます。
•
クロック制御部の発振安定待ち時間設定レジスタ (WATR) はパワーオンリセットに
よってのみ初期化されます。
70
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第5章
割込み
割込みについて説明します。
5.1
April 4, 2014, MB95F718M_MN702-00014-3v0-J
割込み
71
第 5 章 割込み
5.1 割込み
H ard war e
5.1
Ma nu al
割込み
割込みについて説明します。
■ 割込みの概要
New 8FX ファミリには , 周辺機能に関連する 24 本の割込み要求入力があり , それぞれ
独立に割込みレベルを設定できます。
周辺機能で割込み要求が発生した場合 , この割込み要求は割込みコントローラに出力
されます。割込みコントローラは , その割込み要求の割込みレベルを判定し , CPU に割
込みの発生を伝えます。CPU は割込み受付け状態に従って割込み動作を行います。ま
た , スタンバイモード時の割込み要求によりデバイスはスタンバイモードから復帰し ,
命令実行を再開します。
■ 周辺機能からの割込み要求
CPU が割込み要求を受け付けると , 割込み要求に対応する割込みベクタテーブルアド
レスを分岐先アドレスとして , 割込みサービスルーチンへ分岐します。
各割込み要求の割込み処理優先順位は , 割込みレベル設定レジスタ (ILR0 ~ ILR5) によ
り , 割込み処理の優先順位を 4 段階に設定できます。
割込みサービスルーチンで割込みが処理されている間 , 同一またはそれ以下のレベル
の割込み要求が発生した場合は , 現在の割込みサービスルーチンが終了した後に , 処理
が実行されます。また, 複数の割込み要求が同一割込みレベルに設定された場合, IRQ00
が最優先順位になります。
割込み要因については , デバイスのデータシートの「■ 割込み要因のテーブル」を参照
してください。
72
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 5 章 割込み
5.1 割込み
Ha rdware
5.1.1
Manual
割込みレベル設定レジスタ (ILR0 ~ ILR5)
割込みレベル設定レジスタ (ILR0 ~ ILR5) には , 各周辺機能からの割込み要求に対応
した 2 ビットのデータが 24 組が割り当てられています。これら 2 ビットのデータ
( 割込みレベル設定ビット ) を使用して , 割込み要求の割込みレベルを設定します。
■ レジスタ構成
ILR0
bit
7
Field
6
5
L03[1:0]
4
3
L02[1:0]
2
1
L01[1:0]
0
L00[1:0]
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
1
1
1
1
1
1
1
1
6
5
4
3
2
1
ILR1
bit
7
Field
L07[1:0]
L06[1:0]
L05[1:0]
0
L04[1:0]
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
1
1
1
1
1
1
1
1
6
5
4
3
2
1
ILR2
bit
7
Field
L11[1:0]
L10[1:0]
L09[1:0]
0
L08[1:0]
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
1
1
1
1
1
1
1
1
6
5
4
3
2
1
ILR3
bit
7
Field
L15[1:0]
L14[1:0]
L13[1:0]
0
L12[1:0]
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
1
1
1
1
1
1
1
1
6
5
4
3
2
1
ILR4
bit
7
Field
L19[1:0]
L18[1:0]
L17[1:0]
0
L16[1:0]
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
1
1
1
1
1
1
1
1
6
5
4
3
2
1
ILR5
bit
7
Field
L23[1:0]
L22[1:0]
L21[1:0]
0
L20[1:0]
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
1
1
1
1
1
1
1
1
割込みレベル設定レジスタは, 各割込み要求に対し2ビットずつのデータを割り当てら
れています。これらレジスタの割込みレベル設定ビットの値が , 割込み処理における割
込み要求の優先順位を表します。( 割込みレベル:0 ~ 3)
割込みレベル設定ビットは , コンディションコードレジスタ (CCR:IL[1:0]) の割込みレ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
73
第 5 章 割込み
5.1 割込み
H ard war e
Ma nu al
ベルビットと比較されます。
割込み要求の割込みレベル 3 を設定した場合 , CPU は割込み要求を受け付けません。
表 5.1-1 に , 割込みレベル設定ビットと割込みレベルとの関係を示します。
表 5.1-1
割込みレベル設定ビットと割込みレベルとの関係
00
割込みレベル
0
01
1
10
2
11
3
LXX[1:0]
優先順位
高い
低い ( 割込みなし )
XX:00 ~ 23 割込み要求の番号
メインプログラム実行中は , コンディションコードレジスタの割込みレベルビット
(CCR:IL[1:0]) は , "0b11" です。
74
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 5 章 割込み
5.1 割込み
Ha rdware
5.1.2
Manual
割込み動作時の処理
周辺機能により割込み要求が発生すると , 割込みコントローラはその割込み要求の割
込みレベルを CPU に通知します。CPU が割込みを受け付けられる状態になっている
と , 現在実行中のプログラムを一時中断し , 割込みサービスルーチンを実行します。
■ 割込み動作時の処理
割込み処理の手順は , 周辺機能の割込み要因発生 , メインプログラムの実行 , 割込み要
求フラグビットの設定 , 割込み要求許可ビットの判定 , 割込みレベル (ILR0 ~ ILR5 お
よび CCR:IL[1:0]) の判定 , 同一割込みレベルの同時要求の確認 , 割込み許可フラグ
(CCR:I) の判定 , という順で行われます。
図 5.1-1 に , 割込み動作時の処理を示します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
75
第 5 章 割込み
5.1 割込み
H ard war e
Ma nu al
図 5.1-1 割込み動作時の処理
内部データバス
コンディションコードレジスタ(CCR)
I
CPU
IL
チェック
(7)
比較器
(5)
START
ストップモード解除
スリープモード解除
タイムベースタイマモード/
時計モード解除
RAM
(1) 周辺リソースの初期化
割込み要求フラグ
周辺リソースの
割込みあり?
NO
YES
(3)
周辺リソースの
割込み要求出力は許可されて
いるか?
NO
AND
割込み要求許可
(3)
(4)
レベル比較器
(6)
各周辺リソース
(4)
割込み
コント
ローラ
YES
割込みの優先順位を判定し
該当レベルをCPUへ転送
(5)
該当レベルとPS内の
ILビットを比較
該当レベル
がILより強い?
YES
NO
(2)
Iフラグ=1?
メインプログラム
の実行
YES
NO
割込みサービスルーチン
割込み要求クリア
(7)
割込み処理の実行
RETI
76
PCとPSをスタックに退避
PCとPSを復帰
(6)
PC←割込みベクタ
PS内のILの更新
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 5 章 割込み
5.1 割込み
Ha rdware
Manual
(1) リセット直後は , すべての割込み要求は禁止状態になっています。周辺機能の初期
化プログラムで , 割込みを発生する各周辺機能を初期化して , 該当する割込みレベ
ル設定レジスタ (ILR0 ~ ILR5) に割込みレベルを設定してから周辺機能を動作させ
ます。割込みレベルは , 0, 1, 2, 3 のいずれかを設定できます。レベル 0 が最も優先
され , レベル 1 がその次に優先されます。周辺機能にレベル 3 を設定した場合は ,
該当する周辺機能の割込みは禁止されます。
(2) メインプログラム ( 多重割込みの場合は , 割込みサービスルーチン ) を実行します。
(3) 周辺機能で割込み要因が発生したとき , 周辺機能の割込み要求フラグビットが "1"
に設定されます。このとき , 周辺機能の割込み要求許可ビットが許可されていると ,
割込み要求が割込みコントローラへ出力されます。
(4) 割込みコントローラは , 各周辺機能からの割込み要求を常に監視しており , 現在発
生している割込み要求の割込みレベルの中から , 最も優先された割込みレベルを
CPU に伝達します。このとき , 同一の割込みレベルで同時に要求があった場合の
優先順位も , 割込みコントローラにて比較されます。
(5) CPU は受け取った割込みレベルがコンディションコードレジスタの割込みレベル
ビット (CCR:IL[1:0]) に設定されているレベルより優先度が高い ( 割込みレベル番
号が低い ) 場合 , CPU は割込み許可フラグ (CCR:I) の内容をチェックし , 割込み許
可 (CCR:I=1) になっていれば割込みを受け付けます。
(6) CPU は , プログラムカウンタ (PC) およびプログラムステータス (PS) の内容をスタッ
クに退避し , 該当する割込みベクタテーブルアドレスから割込みサービスルーチン
の先頭アドレスを取り込み , コンディションコードレジスタの割込みレベルビット
(CCR:IL[1:0]) の値を受け付けた割込みレベルの値に変更した後 , 割込み処置ルーチ
ンを実行しはじめます。
(7) CPU は最後に , RETI 命令を実行し , スタックに退避しておいたプログラムカウンタ
(PC) およびプログラムステータス (PS) の値を復帰して , 割込みの直前に実行した命
令の次の命令から処理を実行します。
<注意事項>
周辺機能の割込み要求フラグビットは , 割込み要求が受け付けられても自動的には "0" に
なりません。したがって , 割込みサービスルーチンでプログラム ( 割込み要求フラグビッ
トへの "0" の書込み ) を使用して "0" にしてください。
低消費電力モード ( スタンバイモード ) は , 割込みによって解除されます。詳細は ,「3.5
低消費電力モード ( スタンバイモード ) の動作」を参照してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
77
第 5 章 割込み
5.1 割込み
H ard war e
5.1.3
Ma nu al
多重割込み
周辺機能からの複数の割込み要求に対し , 割込みレベル設定レジスタ (ILR0 ~ ILR5)
に異なる割込みレベルを設定することにより , 多重割込みを行います。
■ 多重割込み
割込みサービスルーチン実行中に , 優先レベルの高い割込みレベルに設定された割込
み要求が発生すると , CPU は現在の割込み処理を中断して , 順位の優先される割込み要
求を受け付けます。割込み要求の割込みレベルは 0 ~ 3 まで設定できますが , レベル 3
に設定した場合 , CPU は割込み要求を受け付けません。
[ 例:多重割込み ]
多重割込み処理の例として , タイマ割込みより外部割込みを優先させる場合を想定し ,
タイマ割込みのレベルを 2 に , 外部割込みレベルを 1 に設定します。このとき , タイマ
割込み処理中に外部割込みが発生後は , 図 5.1-2 に示す処理を行います。
図 5.1-2 多重割込みの例
メインプログラム
タイマ割込み処理
外部割込み処理
割込みレベル1
(CCR:IL[1:0]=0b01)
割込みレベル2
(CCR:IL[1:0]=0b10)
周辺リソース初期化(1)
タイマ割込み発生(2)
(3)外部割込み発生
(4)外部割込み処理
中断
再開
メインプログラム再開(8)
(6)タイマ割込み処理
(5)外部割込み復帰
(7)タイマ割込み復帰
• タイマ割込み処理中 , コンディションコードレジスタの割込みレベルビット (CCR:
IL1, IL0) は , タイマ割込みに対応する割込みレベル設定レジスタ (ILR0 ~ ILR5) の
値と同じ値 ( 上記の例ではレベル 2) になります。このとき , タイマ割込みの割込み
レベル ( 上記の例ではレベル 1) より優先されるレベルの割込み要求が発生後は , そ
の割込みが先に処理されます。
• タイマ割込み中に多重割込みを一時的に禁止したい場合は , コンディションコード
レジスタ (CCR:I) の割込み許可フラグを "0" にするかまたは , 割込みレベルビット
(CCR:IL[1:0]) を "0b00" にします。
• 割込み処理の終了後に割込み復帰命令 (RETI) が実行されると , プログラムカウンタ
(PC) およびプログラムステータス (PS) の値が復帰され , CPU は割り込まれたプログ
ラムを実行しはじめます。また , コンディションコードレジスタ (CCR) の値は , プ
ログラムステータス (PS) が復帰されることにより , 割込み前の値を示します。
78
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 5 章 割込み
5.1 割込み
Ha rdware
5.1.4
Manual
割込み処理時間
割込み要求の発生後に CPU が割込みサービスルーチンに移行するまでには , 割込み
要求が発生してから実行中の命令が終了するまでの時間と , 割込みハンドリング時間
( 割込み処理準備に要する時間 ) の合計時間を必要とします。割込み処理時間は , 最大
26 マシンクロック周期となります。
■ 割込み処理時間
割込み要求が発生して割込みサービスルーチンが実行される前に , CPU は , 割込み要求
サンプル待ち時間および割込みハンドリング時間が必要です。
● 割込み要求サンプル待ち時間
割込み要求が発生しているかどうかは , 各命令の最後のサイクルで割込み要求をサン
プリングして判断します。そのため , CPU は命令実行中には割込み要求を認識できま
せん。このサンプリング待ち時間は , 最も実行サイクルの長い DIVU 命令 (17 マシンク
ロック周期 ) の実行開始直後に割込み要求が発生した場合に最大となります。
● 割込みハンドリング時間
CPU は割込みを受け付けた後 , 以下の割込み処理準備を行うために , 9 マシンクロック
周期を必要します。
• プログラムカウンタ (PC) およびプログラムステータス (PS) の値をスタックに退避
する。
• 割込みサービスルーチンの先頭アドレス ( 割込みベクタ ) を PC に設定する。
• プログラムステータス (PS) 内の割込みレベルビット (CCR:IL[1:0]) を更新する。
図 5.1-3 割込み処理時間
通常命令実行
割込みハンドリング
割込みサービスルーチン
CPUの動作
割込み要求
サンプル待ち時間
割込み待ち時間
割込みハンドリング時間
(9マシンクロック周期)
割込み要求発生
: 命令最終サイクル, ここで割込み要求をサンプルする
最も実行サイクルの長い DIVU 命令 (17 マシンクロック周期 ) の実行開始直後に割込み
要求が発生した場合 , 割込み処理時間は 26 マシンクロック周期となります。
マシンクロック周期は , クロックモードおよびメインクロック速度の切換え ( ギア機能 )
によって変化します。詳細は , 「第 3 章 クロック制御部」を参照してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
79
第 5 章 割込み
5.1 割込み
H ard war e
Ma nu al
割込み処理時のスタック動作
5.1.5
割込み処理時のレジスタ内容の退避および復帰について説明します。
■ 割込み処理開始時のスタック動作
割込みが受け付けられると , CPU は現在のプログラムカウンタ (PC) およびプログラム
ステータス (PS) の内容を自動的にスタックに退避します。
図 5.1-4 に , 割込み処理開始時のスタック動作を説明します。
図 5.1-4 割込み処理開始時のスタック動作
割込み直前
割込み直後
アドレス メモリ
PS 0x0870
PC 0xE000
SP 0x0280
0x027C
0x027D
0x027E
0x027F
0x0280
0x0281
0xXX
0xXX
0xXX
0xXX
0xXX
0xXX
アドレス メモリ
SP 0x027C
PS 0x0870
PC 0xE000
0x027C 0x08
0x027D 0x70
0x027E 0xE0
0x027F 0x00
0x0280 0xXX
0x0281 0xXX
}
}
PS
PC
■ 割込みからの復帰時のスタック動作
CPU が割込み処理終了時に割込み復帰命令 (RETI) を実行後は , 最初にプログラムス
テータス (PS) の値 , 次いでプログラムカウンタ (PC) の値をスタックから復帰させます。
復帰するときの順序は 2 つの値をスタックに退避する順序とは逆の順序になります。復
帰後 , PS および PC は割込み処理開始直前の状態に戻ります。
<注意事項>
アキュムレータ (A) の値とテンポラリアキュムレータ (T) の値は自動的にスタックに退避
されないため , PUSHW および POPW 命令で A, T の値を退避 , 復帰させてください。
80
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 5 章 割込み
5.1 割込み
Ha rdware
Manual
割込み処理のスタック領域
5.1.6
割込み処理の実行には , RAM 上のスタック領域を使用します。スタックポインタ (SP)
にはスタック領域の先頭アドレスがあります。
■ 割込み処理のスタック領域
スタック領域は , サブルーチンコール命令 (CALL) またはベクタコール命令 (CALLV)
を実行するときのプログラムカウンタ (PC) の退避や復帰 , PUSHW, POPW 命令による
一時的なレジスタ類の退避や復帰にも使われます。
• スタック領域は , データ領域とともに RAM 上に確保されます。
• スタックポインタ (SP) は , RAM アドレスの最大値を示すよう初期化し , データ領域
は , RAM アドレスの小さい方から配置してください。
図 5.1-5 に , 割込み処理のスタック領域の設定例を説明します。
図 5.1-5 割込み処理のスタック領域の設定例
0x0000
I/0
0x0080
データ領域
RAM
0x0100
汎用
レジスタ
0x0200
スタック領域
SPの推奨設定値
例:RAMアドレスの最大値が0x0280の場合
0x0280
アクセス禁止
アドレスは品種によって異なります。詳細は,
デバイスのデータシートを参照してください。
フラッシュ
メモリ
0xFFFF
<注意事項>
スタック領域は , アドレス値の大きいほうから小さい方に向かって , 割込み , サブルーチ
ンコール , PUSHW 命令などにより使用されます。領域を開放する場合は , 小さい方から
大きい方に向かって , 復帰命令 (RETI, RET), POPW 命令などにより開放されます。多重
割込みやサブルーチンコールにより使用されるスタック領域のアドレス値が小さくなっ
た場合 , スタック領域をデータ領域や汎用レジスタ領域に重ねないでください。これら 2
つの領域にはほかのデータが保持されています。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
81
第 5 章 割込み
5.1 割込み
H ard war e
82
Ma nu al
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第6章
I/O ポート
I/O ポートの機能と動作について説明します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
6.1
概要
6.2
構成と動作
83
第 6 章 I/O ポート
6.1 概要
H ard war e
6.1
Ma nu al
概要
I/O ポートは , 汎用入出力端子を制御するときに使用します。
■ I/O ポートの概要
I/O ポートは , ポートデータレジスタ (PDR) によって , CPU からデータを出力したり ,
入力された信号を CPU に取り込んだりする機能があります。また , ポート方向レジスタ
(DDR) によって I/O 端子の入出力の方向をビット単位で任意に設定できます。
各製品の I/O ポート数は異なります。各製品の I/O ポート数はデバイスのデータシート
を参照してください。
本章において , レジスタ名にある "x" は I/O ポート番号を示します。実際のレジスタ名
とその略称は , 各製品のデータシートを参照してください。
表 6.1-1 にポートレジスタ一覧を示します。
表 6.1-1
ポートレジスタ一覧
レジスタ名
レジスタの略称
ポート x データレジスタ
PDRx
ポート x 方向レジスタ
DDRx
ポート x プルアップレジスタ
PULx
A/D 入力禁止レジスタ ( 上位 )*
AIDRH
A/D 入力禁止レジスタ ( 下位 )*
AIDRL
*: A/D 入力禁止レジスタ ( 上位 ) と A/D 入力禁止レジスタ ( 下位 ) の有無について , デバイス
のデータシートの「■ I/O マップ」を参照してください。
84
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 6 章 I/O ポート
6.2 構成と動作
Ha rdware
6.2
Manual
構成と動作
I/O ポートを汎用入出力ポートとして使用するときの構成と動作を中心に説明しま
す。
周辺機能の詳細については , それぞれの章を参照してください。
■ I/O ポートの構成
I/O ポートは以下の要素から構成されます。
•
汎用入出力端子 / 周辺機能入出力端子
•
ポート x データレジスタ (PDRx)
•
ポート x 方向レジスタ (DDRx)
•
ポート x プルアップレジスタ (PULx)
•
A/D 入力禁止レジスタ ( 上位 ) (AIDRH)
•
A/D 入力禁止レジスタ ( 下位 ) (AIDRL)
April 4, 2014, MB95F718M_MN702-00014-3v0-J
85
第 6 章 I/O ポート
6.2 構成と動作
H ard war e
Ma nu al
■ I/O ポートの動作
● 出力ポートとしての動作
•
端子に対応する DDRx レジスタのビットを "1" に設定すると , その端子は出力ポー
トになります。
•
端子を兼用する周辺機能においては , その出力を禁止してください。
•
端子が出力ポートとして使用されている時は , その端子から PDRx レジスタの値が
外部端子に出力されます。
•
PDRx レジスタにデータを書き込むと , その値は出力ラッチに保持され , そのまま出
力ポートとして設定した端子へ出力されます。
•
PDRx レジスタを読み出すと , PDRx レジスタの値が読み出されます。
•
LCDC セグメント / コモン出力端子と兼用する端子を出力ポートとして使用する場
合 , その端子に対応する , LCDC 許可レジスタの機能選択ビット (LCDC:COM/SEG)
を "0" に設定して , 汎用入出力ポート機能を選択し , LCDC 許可レジスタ 1 のポート
入力制御ビット (LCDCE1:PICTL) を "1" に設定してください。
•
LCD 駆動電源端子と兼用する端子を出力ポートとして使用する場合 , その端子に対
応する , LCDCE1 レジスタの VE[4:0] ビットを "0" に設定して , 汎用入出力ポート機
能を選択し , LCDCE1 レジスタの PICTL ビットを "1" に設定してください。
● 入力ポートとしての動作
•
端子に対応する DDRx レジスタのビットを "0" に設定すると , その端子は入力ポー
トになります。
•
端子を兼用する周辺機能においては , その出力を禁止してください。
•
アナログ入力機能兼用端子を入力ポートとして使用している時は , A/D 入力禁止レ
ジスタ ( 上位 / 下位 ) (AIDRH/AIDRL) の対応するビットを "1" に設定してください。
•
PDRx レジスタにデータを書き込むと , その値が出力ラッチに保持されますが , 入力
ポートとして設定した端子へは出力されません。
PDRx レジスタを読み出すと , 端子の値が読み出されます。ただし , リードモディ
ファイライト (RMW) 系命令を使用して PDRx レジスタを読み出す場合は , PDRx レ
ジスタの値を読み出します。
•
•
LCDC セグメント / コモン出力端子と兼用する端子を入力ポートとして使用する場
合 , その端子に対応する , LCDCE レジスタの機能選択ビット (COM/SEG) を "0" に
設定して , 汎用入出力ポート機能を選択し , LCDCE1 レジスタの PICTL ビットを "1"
に設定してください。
•
LCD 駆動電源端子と兼用する端子を入力ポートとして使用する場合 , その端子に対
応する , LCDCE1 レジスタの VE[4:0] ビットを "0" に設定して , 汎用入出力ポート機
能を選択し , LCDCE1 レジスタの PICTL ビットを "1" に設定してください。
● 周辺機能出力端子としての動作
86
•
端子に対応する周辺機能に出力許可ビットを設定し , 周辺出力機能を許可すると ,
その端子は , 周辺機能出力端子となります。
•
周辺機能出力を許可した場合でも , PDRx レジスタから端子の値を読み出せます。し
たがって , PDRx レジスタの読出し動作により , 周辺機能の出力値を読み出せます。
ただし , リードモディファイライト (RMW) 系命令を使用して PDRx レジスタを読
み出す場合は , PDRx レジスタの値を読み出します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 6 章 I/O ポート
6.2 構成と動作
Ha rdware
Manual
● 周辺機能入力端子としての動作
•
端子を入力ポートとして設定するには , 周辺機能の入力端子に対応する DDRx レジ
スタのビットを "0" に設定します。
•
アナログ入力機能兼用端子をその他の周辺機能入力端子として使用する場合は, AIDRH/
AIDRL レジスタのその端子に対応するビットを "1" に設定して , その端子を入力
ポートとして設定してください。
•
周辺機能がその端子を入力端子として使用しているかどうかに関係なく , PDRx レ
ジスタを読み出すと , 端子の値が読み出されます。ただし , リードモディファイライ
ト (RMW) 系命令を使用して PDRx レジスタを読み出す場合は , PDRx レジスタの値
を読み出します。
● LCDC セグメント出力端子としての動作
•
LCDC セグメント出力端子に対応する DDRx レジスタのビットを "0" に設定してく
ださい。
•
汎用入出力ポートと兼用する端子を LCDC セグメント出力端子として使用する場合 ,
その端子に対応する , LCDCE レジスタの機能選択ビット (SEG) を "1" に設定して
LCDC セグメント出力機能を選択し , LCDCE1 レジスタの PICTL ビットを "1" に設
定してください。
● LCDC コモン出力端子としての動作
•
LCDC コモン出力端子に対応する DDRx レジスタのビットを "0" に設定してくださ
い。
•
汎用入出力ポートと兼用する端子を LCDC コモン出力端子として使用する場合 , そ
の端子に対応する , LCDCE レジスタの機能選択ビット (COM) を "1" に設定して
LCDC コモン出力機能を選択し , LCDCE1 レジスタの PICTL ビットを "1" に設定し
てください。
● リセット時の動作
CPU がリセットされると , DDRx レジスタのすべてのビットが "0" に初期化され , ポー
ト入力が許可された状態になります。アナログ入力機能と兼用となる端子については ,
AIDRH/AIDRL レジスタ が "0" に初期化されるため , ポート入力は禁止されます。
● ストップモードおよび時計モード時の動作
•
スタンバイ制御レジスタの端子状態設定ビット (STBC:SPL) が "1" に設定され , デバ
イスがストップモードもしくは時計モードに移行すると , DDRx レジスタの値に関
係なく強制的に端子はハイインピーダンス状態になります。入力開放によるリーク
を防止するために , 端子入力は "L" レベルに固定され遮断されます。ただし , 外部割
込みによる割込み入力が許可されている場合 , 入力可能になり入力は遮断されませ
ん。
•
端子状態設定ビットが "0" の場合は , ポート入出力の状態または周辺機能入出力の
状態は変更されず , 出力レベルは維持されます。
● LCD 駆動電源端子としての動作
•
LCD 駆動電源端子に対応する DDRx レジスタのビットを "0" に設定してください。
•
汎用入出力ポートと兼用する端子を LCD 駆動電源端子として使用する場合 ,
LCDCE1 レジスタの VE[4:0] ビットにある , その端子に対応するビットを "1" に設
定して LCD 駆動電源機能を選択してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
87
第 6 章 I/O ポート
6.2 構成と動作
H ard war e
Ma nu al
● アナログ入力端子としての動作
•
アナログ入力端子に対応する DDRx レジスタのビットに "0" を , AIDRH/AIDRL レ
ジスタのその端子に対応するビットに "0" を設定してください。
•
ほかの周辺機能と兼用されている端子では , それらの周辺機能の出力を禁止してく
ださい。また , PULx レジスタの対応するビットを "0" に設定してください。
● 外部割込み入力端子としての動作
•
外部割込み入力端子に対応する DDRx レジスタのビットを "0" に設定します。
•
端子を兼用する周辺機能においては , その出力を禁止してください。
•
端子の値は常に外部割込み回路に入力されます。端子を割込み以外の機能に使用す
る場合は , その端子に対応する外部割込み機能を禁止にします。
● プルアップレジスタの動作
PULx レジスタのビットに "1" を設定すると , プルアップ抵抗は端子に内部接続されま
す。
端子出力が "L" レベルのときは , PULx レジスタの値にかかわらずに , プルアップ抵
抗は切断されます。
88
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第7章
タイムベースタイマ
タイムベースタイマの機能と動作について説明し
ます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
7.1
概要
7.2
構成
7.3
割込み
7.4
動作説明と設定手順例
7.5
レジスタ
7.6
使用上の注意
89
第 7 章 タイムベースタイマ
7.1 概要
H ard war e
7.1
Ma nu al
概要
タイムベースタイマは , メインクロックの 2 分周 , メイン CR クロックまたは PLL ク
ロックに同期してカウントダウンする 24 ビットのフリーランカウンタです。クロッ
クは , SYCC レジスタの SCS[2:0] ビットによって選択できます。このタイムベース
タイマには , 一定のインターバル時間で繰返し割込み要求を発生させるインターバル
タイマ機能があります。
■ インターバルタイマ機能
インターバルタイマ機能は , メインクロックの 2 分周 , メイン CR クロックまたは PLL
クロックをカウントクロックとして一定のインターバル時間で繰返し割込み要求を発
生させる機能です。
•
タイムベースタイマのカウンタがカウントダウンを行い , 選択したインターバル時
間が経過するごとに割込み要求を発生させます。
•
インターバル時間の長さは , 次の 16 種類の中から選択できます。
表 7.1-1 に , タイムベースタイマのインターバル時間を示します。
表 7.1-1
タイムベースタイマのインターバル時間
メインクロックを使用した
場合のインターバル時間
(2n2/FCH*1)
n=9
n=10
n=11
n=12
n=13
n=14
n=15
n=16
n=17
n=18
n=19
n=20
n=21
n=22
n=23
n=24
256 µs
512 µs
1.024 ms
2.048 ms
4.096 ms
8.192 ms
16.384 ms
32.768 ms
65.536 ms
131.072 ms
262.144 ms
524.288 ms
1.049 s
2.097 s
4.194 s
8.389 s
PLL 逓倍率 2 をかけたメインク
メイン CR クロックを使用し
ロックまたはメイン CR クロックを
た場合のインターバル時間
使用した場合のインターバル時間
(2n1/FCRH*2)
(2n1/FPLL*3)
128 µs
256 µs
512 µs
1.024 ms
2.048 ms
4.096 ms
8.192 ms
16.384 ms
32.768 ms
65.536 ms
131.072 ms
262.144 ms
524.288 ms
1.049 s
2.097 s
4.194 s
64 µs
128 µs
256 µs
512 µs
1.024 ms
2.048 ms
4.096 ms
8.192 ms
16.384 ms
32.768 ms
65.536 ms
131.072 ms
262.144 ms
524.288 ms
1.049 s
2.097 s
*1: FCH = 4 MHz
2/FCH = 0.5 µs
*2: FCRH = 4 MHz
1/FCRH = 0.25 µs
*3: FPLL = 8 MHz
PLL 逓倍率 = 2
(FCH または FCRH)  PLL 逓倍率 = 4 MHz  2 = 8 MHz
1/FPLL = 0.125 µs
90
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 7 章 タイムベースタイマ
7.2 構成
Ha rdware
Manual
構成
7.2
タイムベースタイマは , 以下のブロックから構成されます。
• タイムベースタイマカウンタ
• カウンタクリア回路
• インターバルタイマセレクタ
• タイムベースタイマ制御レジスタ (TBTC)
■ タイムベースタイマのブロックダイヤグラム
図 7.2-1 タイムベースタイマのブロックダイヤグラム
タイムベースタイマカウンタ
プリスケーラへ
ソフトウェアウォッチドッグタイマへ
FCHの2分周
×21 ×22 ×23 ×24 ×25 ×26 ×27 ×28 ×29 ×210 ×211 ×212 ×213 ×214 ×215 ×216 ×217 ×218 ×219 ×220 ×221 ×222 ×223 ×224
FCRH
FPLL
SCM2
SCM1
SCM0
SCS2
SCS1
SCS0
システムクロック制御レジスタ(SYCC)
DIV1
DIV0
カウンタクリア
ソフトウェアウォッチドッグタイマクリア
リセット
メインクロック, メインCRクロックの発振停止
カウンタクリア
回路
インターバルタイマ
セレクタ
タイムベースタイマ割込み
TBIF
TBIE
-
TBC3
TBC2
TBC1
TBC0
TCLR
タイムベースタイマ制御レジスタ (TBTC)
FCH : メインクロック
FCRH : メインCRクロック
FPLL : PLLクロック
April 4, 2014, MB95F718M_MN702-00014-3v0-J
91
第 7 章 タイムベースタイマ
7.2 構成
H ard war e
Ma nu al
● タイムベースタイマカウンタ
メインクロックの 2 分周 , メイン CR クロックまたは PLL クロックをカウントクロッ
クとする 24 ビットのダウンカウンタです。
● カウンタクリア回路
タイムベースタイマのカウンタのクリアを制御する回路です。
● インターバルタイマセレクタ
24ビットのタイムベースタイマカウンタの中の16ビットからインターバルタイマ用の
1 ビットを選択する回路です。
● タイムベースタイマ制御レジスタ (TBTC)
インターバル時間の選択 , カウンタのクリア , 割込み制御およびタイムベースタイマの
状態確認を行うレジスタです。
■ 入力クロック
タイムベースタイマは , メインクロックの 2 分周 , メイン CR クロックまたは PLL ク
ロックを入力クロック ( カウントクロック ) として使用します。
■ 出力クロック
タイムベースタイマは , クロックスーパバイザカウンタ , ソフトウェアウォッチドッグ
タイマとプリスケーラにクロックを供給しています。
92
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 7 章 タイムベースタイマ
7.3 割込み
Ha rdware
7.3
Manual
割込み
タイムベースタイマにより選択したインターバル時間が経過すると , 割込み要求が発
生します ( インターバルタイマ機能 )。
■ インターバル機能動作時の割込み
タイムベースタイマカウンタが内部カウントクロックでカウントダウンし , 選択され
たインターバル時間の経過により , タイムベースタイマカウンタがアンダフローする
と , タイムベースタイマの割込み要求フラグビット (TBTC:TBIF) が "1" に設定されま
す。そのとき , タイムベースタイマの割込み要求許可ビットを許可 (TBTC:TBIE = 1) に
した場合 , 割込み要求が発生し , 割込みコントローラへ送られます。
•
TBIE ビットの値に関係なく , 選択されたビットがアンダフローすると TBIF ビット
は , "1" に設定されます。
•
TBIF ビットが "1" に設定されているときには , TBIE ビットを禁止から許可 (0 → 1)
にすると , 直ちに割込み要求が発生します。
•
カウンタクリア (TBTC:TCLR = 1) とタイムベースタイマカウンタのアンダフローが
同時に発生した場合は , TBIF ビットは "1" に設定されません。
•
割込みサービスルーチンでは TBIF ビットに "0" を書き込んで割込み要求をクリア
してください。
<注意事項>
リセット解除後に割込み要求出力を許可 (TBTC:TBIE = 1) する場合は , 必ず TBIF ビット
を同時にクリア (TBTC:TBIF = 0) してください。
表 7.3-1
タイムベースタイマの割込み
項目
割込みの条件
説明
割込みフラグ
TBTC:TBC[3:0] で設定したインターバル時間が経過した。
TBTC:TBIF
割込み許可
TBTC:TBIE
April 4, 2014, MB95F718M_MN702-00014-3v0-J
93
第 7 章 タイムベースタイマ
7.4 動作説明と設定手順例
H ard war e
7.4
Ma nu al
動作説明と設定手順例
タイムベースタイマのインターバルタイマ機能の動作について説明します。
■ タイムベースタイマの動作
タイムベースタイマのカウンタは, リセット後"0xFFFFFF"に初期化され, メインクロッ
クの2分周, メインCRクロックまたは PLLクロックに同期してカウントを開始します。
タイムベースタイマは , メインクロック , メイン CR クロックまたは PLL クロックが発
振している限り , カウントダウンを続けます。メインクロック , メイン CR クロックま
たは PLL クロックが停止すると , カウンタは停止し , "0xFFFFFF" に初期化されます。
インターバルタイマ機能を使用するには , 図 7.4-1 に示した設定が必要です。
図 7.4-1 インターバルタイマ機能の設定
TBTC
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
TBIF
TBIE
-
TBC3
TBC2
TBC1
TBC0
TCLR
0
1
0
: 使用ビット
1 : "1"を設定
0 : "0"を設定
タイムベースタイマ制御レジスタのタイムベースタイマクリアビット (TBTC:TCLR) に
"1" を設定すると , タイムベースタイマのカウンタは "0xFFFFFF" に初期化され , カウン
トダウンを継続します。選択されたインターバル時間が経過すると , タイムベースタイ
マ制御レジスタのタイムベースタイマ割込み要求フラグビット (TBTC:TBIF) が "1" に
なります。つまり , 最後にカウンタがクリアされた時間を基準にして , 選択されたイン
ターバル時間ごとに割込み要求を発生します。
94
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 7 章 タイムベースタイマ
7.4 動作説明と設定手順例
Ha rdware
Manual
■ タイムベースタイマのクリア
タイムベースタイマの出力をほかの周辺機能で使用している際にタイムベースタイマ
をクリアすると , カウント時間が変化するなど動作に影響を与えます。
タイムベースタイマクリアビット (TBTC:TCLR) を使ってカウンタをクリアする場合は ,
このクリアによって予期せぬ影響が及ばないようにそのほかの周辺機能の設定を必要
に応じて変更してください。
なお , タイムベースタイマの出力がウォッチドッグタイマのカウントクロックとして
選択されているときにタイムベースタイマがクリアされると , 同時にウォッチドッグ
タイマもクリアされます。
タイムベースタイマは , TCLR ビットによってクリアされるだけでなく , メインクロッ
ク , メイン CR クロックまたは PLL クロックが停止し , 発振安定待ち時間のカウントが
必要になったときにもクリアされます。タイムベースタイマは以下の状況でクリアさ
れます。
•
デバイスが , メインクロックモード , メイン PLL クロックモード , メイン CR クロッ
クモードまたはメイン CR PLL クロックモードからストップモードへ遷移したとき
•
デバイスが , メインクロックモード , メイン PLL クロックモード , メイン CR クロッ
クモードまたはメイン CR PLL クロックモードからサブクロックモードまたはサブ
CR クロックモードへ遷移したとき
•
電源投入時
•
低電圧検出リセット時
April 4, 2014, MB95F718M_MN702-00014-3v0-J
95
第 7 章 タイムベースタイマ
7.4 動作説明と設定手順例
H ard war e
Ma nu al
■ タイムベースタイマの動作例
図 7.4-2 に , 以下の条件下の動作例を示します。
1. パワーオンリセットが発生した場合
2. デバイスが , メインクロックモード , メイン PLL クロックモード , メイン CR クロッ
クモードまたはメイン CR PLL クロックモードにおいてインターバルタイマ機能の
動作中に , スリープモードへ遷移した場合
3. デバイスが , メインクロックモード , メイン PLL クロックモード , メイン CR クロッ
クモードまたはメイン CR PLL クロックモード中に , ストップモードへ遷移した場
合
4. カウンタクリアの要求が発生した場合
デバイスがタイムベースタイマモードに遷移した場合 , スリープモードに遷移した際
と同様の動作が実行されます。
クロックモードがサブクロックモード , サブ CR クロックモード , メインクロックモー
ド , メイン PLL クロックモード , メイン CR クロックモードまたはメイン CR PLL ク
ロックモード時のストップモードでは , タイマ動作はクリアされ , メインクロックが停
止するために , タイマは動作を停止します。
図 7.4-2 タイムベースタイマの動作
カウント値
(カウントダウン)
0xFFFFFF
TBTC:TBC[3:0]で
検出するカウント値
インターバル周期
(TBTC:TBC[3:0]
= 0b0011)
ストップモードへの
遷移によるクリア
0x000000
発振安定待ち
時間
発振安定待ち時間
4) カウンタクリア
(TBTC:TCLR = 1)
1) パワーオンリセット
インターバル
設定時のクリア
割込みサービスルーチン
でクリア
TBIFビット
TBIEビット
スリープ
2) SLPビット
(STBCレジスタ)
3) STPビット
(STBCレジスタ)
ストップ
タイムベースタイマ割込み
によるスリープ解除
外部割込みによるストップモード解除
16
• タイムベースタイマ制御レジスタのインターバル時間選択ビット (TBTC:TBC[3:0]) に "0b0011"を設定した場合 (2 × 2/FCH)
•
•
•
•
•
•
96
TBTC:TBC[3:0] :
TBTC:TCLR
:
TBTC:TBIF
:
TBTC:TBIE
:
STBC:SLP
:
STBC:STP
:
タイムベースタイマ制御レジスタのインターバル時間選択ビット
タイムベースタイマ制御レジスタのタイムベースタイマ初期化ビット
タイムベースタイマ制御レジスタのタイムベースタイマ割込み要求フラグビット
タイムベースタイマ制御レジスタのタイムベースタイマ割込み要求許可ビット
スタンバイ制御レジスタのスリープビット
スタンバイ制御レジスタのストップビット
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 7 章 タイムベースタイマ
7.4 動作説明と設定手順例
Ha rdware
Manual
■ 設定手順例
タイムベースタイマの設定手順例を以下に示します。
● 初期設定
1. 割込みレベルを設定してください (ILR*)。
2. インターバル時間を設定してください (TBTC:TBC[3:0])。
3. 割込み許可を設定し , 割込み要求フラグをクリアしてください (TBTC:TBIE = 1,
TBTC:TBIF = 0)。
4. カウンタをクリアしてください (TBTC:TCLR = 1)。
*: 割込みレベル設定レジスタ (ILR) の詳細について , 本ハードウェアマニュアルの「第 5 章
割込み」とデバイスのデータシートの「■ 割込み要因のテーブル」を参照してください。
● 割込み処理
1. 割込み要求フラグをクリアしてください (TBTC:TBIF = 0)。
2. カウンタをクリアしてください (TBTC:TCLR = 1)。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
97
第 7 章 タイムベースタイマ
7.5 レジスタ
H ard war e
Ma nu al
レジスタ
7.5
タイムベースタイマのレジスタについて説明します。
表 7.5-1
タイムベースタイマのレジスタ一覧
レジスタ略称
TBTC
98
レジスタ名
タイムベースタイマ制御レジスタ
参照先
7.5.1
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 7 章 タイムベースタイマ
7.5 レジスタ
Ha rdware
7.5.1
Manual
タイムベースタイマ制御レジスタ (TBTC)
タイムベースタイマ制御レジスタ (TBTC) は , インターバル時間の選択 , カウンタの
クリア , 割込み制御およびタイムベースタイマの状態確認を行います。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
TBIF
TBIE
—
TBC3
TBC2
TBC1
TBC0
TCLR
属性
R/W
R/W
—
R/W
R/W
R/W
R/W
W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] TBIF: タイムベースタイマ割込み要求フラグビット
このビットはタイムベースタイマにより選択されたインターバル時間が経過すると, "1"に設定され
るフラグです。
このビットとタイムベースタイマ割込み要求許可ビット (TBIE) が "1" のとき , 割込み要求を出力し
ます。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit7
"0" が読み出された場合
インターバル時間がまだ経過していないことを示します。
"1" が読み出された場合
インターバル時間が経過したことを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit6] TBIE: タイムベースタイマ割込み要求許可ビット
このビットは割込みコントローラへの割込み要求の出力を許可または禁止します。
このビットとタイムベースタイマ割込み要求フラグビット (TBIF) が "1" のとき , 割込み要求を出力
します。
説明
bit6
"0" を書き込んだ場合
タイムベースタイマの割込み要求を禁止します。
"1" を書き込んだ場合
タイムベースタイマの割込み要求を許可します。
[bit5] 未定義ビット
読出し値は常に "0" です。このビットに値を書き込んでも動作に影響はありません。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
99
第 7 章 タイムベースタイマ
7.5 レジスタ
H ard war e
Ma nu al
[bit4:1] TBC[3:0]: インターバル時間選択ビット
これらのビットはインターバル時間を選択します。
bit4:1
インターバル時間
( メインクロック ,
FCH = 4 MHz)
インターバル時間
( メイン CR クロック ,
FCRH = 4 MHz)
インターバル時間
(PLL 逓倍率 2 をかけた
メイン PLL クロックまたは
メイン CR クロック ,
FPLL = 8 MHz)
"0100" を書き込んだ場合
292/FCH (256 µs)
291/FCRH (128 µs)
291/FPLL (64 µs)
"0000" を書き込んだ場合
2102/FCH (512 µs)
2101/FCRH (256 µs)
2101/FPLL (128 µs)
"0101" を書き込んだ場合
2112/FCH (1.024 ms)
2111/FCRH (512 µs)
2111/FPLL (256 µs)
"0001" を書き込んだ場合
2122/FCH (2.048 ms)
2121/FCRH (1.024 ms)
2121/FPLL (512 µs)
"0110" を書き込んだ場合
2132/FCH (4.096 ms)
2131/FCRH (2.048 ms)
2131/FPLL (1.024 ms)
"0010" を書き込んだ場合
2142/FCH (8.192 ms)
2141/FCRH (4.096 ms)
2141/FPLL (2.048 ms)
"0111" を書き込んだ場合
2152/FCH (16.384 ms)
2151/FCRH (8.192 ms)
2151/FPLL (4.096 ms)
"0011" を書き込んだ場合
2162/FCH (32.768 ms)
2161/FCRH (16.384 ms)
2161/FPLL (8.192 ms)
"1000" を書き込んだ場合
2172/FCH (65.536 ms)
2171/FCRH (32.768 ms)
2171/FPLL (16.384 ms)
"1001" を書き込んだ場合
2182/FCH (131.072 ms)
2181/FCRH (65.536 ms)
2181/FPLL (32.768 ms)
"1010" を書き込んだ場合
2192/FCH (262.144 ms)
2191/FCRH (131.072 ms)
2191/FPLL (65.536 ms)
"1011" を書き込んだ場合
2202/FCH (524.288 ms)
2201/FCRH (262.144 ms)
2201/FPLL (131.072 ms)
"1100" を書き込んだ場合
2212/FCH (1.049 s)
2211/FCRH (524.288 ms)
2211/FPLL (262.144 ms)
"1101" を書き込んだ場合
2222/FCH (2.097 s)
2221/FCRH (1.049 s)
2221/FPLL (524.288 ms)
"1110" を書き込んだ場合
2232/FCH (4.194 s)
2231/FCRH (2.097 s)
2231/FPLL (1.049 s)
"1111" を書き込んだ場合
2242/FCH (8.389 s)
2241/FCRH (4.194 s)
2241/FPLL (2.097 s)
[bit0] TCLR: タイムベースタイマクリアビット
このビットはタイムベースタイマのカウンタの全ビットを "1" にクリアします。
説明
bit0
読出し動作
読出し値は常に "0" です。
"0" を書き込んだ場合
動作に影響はありません。
"1" を書き込んだ場合
タイムベースタイマのカウンタの全ビットを "1" にクリアします。
( 注意事項 ) タイムベースタイマの出力が , ソフトウェアウォッチドッグタイマのカウントクロッ
クとして選択されている時には , このビットによりタイムベースタイマをクリアする
と , ソフトウェアウォッチドッグタイマもクリアされます。
100
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 7 章 タイムベースタイマ
7.6 使用上の注意
Ha rdware
7.6
Manual
使用上の注意
タイムベースタイマ使用上の注意を示します。
■ タイムベースタイマ使用上の注意
● プログラムで設定する場合
タイムベースタイマ割込み要求フラグビット (TBTC:TBIF) が "1"に設定され , 割込み要
求許可ビットが許可された (TBTC:TBIE = 1) とき , タイマは , 割込み処理から復帰でき
ません。割込みサービスルーチン内で TBIF ビットのクリアを必ず行ってください。
● タイムベースタイマのクリアについて
タイムベースタイマは , タイムベースタイマクリアビットによるクリア (TBTC:TCLR = 1)
以外に , メインクロックの発振安定待ち時間 , メイン CR クロックの発振安定待ち時間
または PLL クロックの発振安定待ち時間が必要となる場合にクリアされます。ソフト
ウェアウォッチドッグタイマ (WDTC:CS[1:0] = 0b00 または CS[1:0] = 0b01) のカウント
クロックとしてタイムベースタイマが選択されている場合 , タイムベースタイマがク
リアされるとソフトウェアウォッチドッグタイマもクリアされます。
● タイムベースタイマからクロックを供給される周辺機能について
メインクロックの原発振が停止するモードでは , カウンタはクリアされ , タイムベース
タイマは動作を停止します。また , タイムベースタイマの出力をほかの周辺機能で使用
している際にタイムベースタイマのカウンタをクリアすると , 動作周期が変化するな
ど , 周辺機能の動作に影響を与えます。
なお , タイムベースタイマのカウンタがクリアされた後 , タイムベースタイマから出力
されたソフトウェアウォッチドッグタイマ用のクロックは , 初期状態となります。ただ
し , ソフトウェアウォッチドッグタイマが初期状態に戻ると同時に , ソフトウェア
ウォッチドッグタイマのカウンタもクリアされるため , ソフトウェアウォッチドッグ
タイマは正常の周期で動作します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
101
第 7 章 タイムベースタイマ
7.6 使用上の注意
H ard war e
102
Ma nu al
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第8章
ハードウェア / ソフトウェア
ウォッチドッグタイマ
ウォッチドッグタイマの機能と動作について説明
します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
8.1
概要
8.2
構成
8.3
動作説明と設定手順例
8.4
レジスタ
8.5
使用上の注意
103
第 8 章 ハードウェア / ソフトウェアウォッチドッグタイマ
8.1 概要
H ard war e
8.1
Ma nu al
概要
ウォッチドッグタイマは , プログラム暴走対策用のカウンタです。
■ ウォッチドッグタイマ機能
ウォッチドッグタイマは , プログラム暴走対策用のカウンタです。ウォッチドッグタイ
マが一度起動すると , 一定時間内で定期的にウォッチドッグタイマのカウンタをクリ
アし続けてください。プログラムが無限ループに陥るなどして , 一定時間以上クリアさ
れない場合 , ウォッチドッグリセットを発生します。
● ソフトウェア / ハードウェアウォッチドッグタイマのカウントクロック
•
ソフトウェアウォッチドッグタイマでは , タイムベースタイマの出力 , 時計プリス
ケーラの出力またはサブ CR タイマの出力がカウントクロックとして選択できま
す。
•
ハードウェアウォッチドッグタイマでは , サブ CR タイマの出力のみがカウントク
ロックとして使用できます。
● ソフトウェア / ハードウェアウォッチドッグタイマの起動
104
•
ソフトウェア / ハードウェアウォッチドッグタイマは , フラッシュメモリ上にある
アドレス 0xFFBE, 0xFFBF の値にしたがって起動されます。また , これらの値は
ウォッチドッグタイマ選択 ID レジスタ ( 上位 / 下位 ) (WDTH/WDTL) (0x0FEB/
0x0FEC) へコピーされます。
•
ソフトウェア起動の場合 ( ソフトウェアウォッチドッグ ), ウォッチドッグタイマ機
能を開始するためには , ウォッチドッグタイマレジスタ (WDTC) を設定しなければ
なりません。
•
ハードウェア起動の場合 ( ハードウェアウォッチドッグ ), リセット後にウォッチ
ドッグタイマは自動的に起動します。ウォッチドッグタイマは , フラッシュメモリ
上にあるアドレス 0xFFBE, 0xFFBF の値にしたがって , ストップモードで停止また
は実行します。これらの値はウォッチドッグタイマ選択 ID レジスタ ( 上位 / 下位 )
(WDTH/WDTL) (0x0FEB/0x0FEC) へコピーされます。ウォッチドッグタイマ選択 ID
についての詳細は ,「第 28 章 不揮発性レジスタ (NVR) インタフェース」を参照して
ください。
•
表 8.1-1 に , ウォッチドッグタイマのインターバル時間を示します。ウォッチドッグ
タイマのカウンタがクリアされない場合 , 最小時間~最大時間の間にウォッチドッ
グリセットが発生します。インターバル時間の最小時間内にウォッチドッグタイマ
のカウンタをクリアしてください。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 8 章 ハードウェア / ソフトウェアウォッチドッグタイマ
8.1 概要
Ha rdware
表 8.1-1
Manual
ウォッチドッグタイマのインターバル時間
カウントクロックの種類
タイムベースタイマ出力
( メインクロック = 4 MHz)
時計プリスケーラ出力
( サブクロック = 32.768 kHz)
サブ CR タイマ
( サブ CR クロック = 50 ~ 150 kHz)
カウントクロック切換えビット CS[1:0], CSP
インターバル時間
最小時間
最大時間
0b000 ( ソフトウェアウォッチドッグタイマ )
524 ms
1.05 s
0b010 ( ソフトウェアウォッチドッグタイマ )
262 ms
524 ms
0b100 ( ソフトウェアウォッチドッグタイマ )
500 ms
1.00 s
0b110 ( ソフトウェアウォッチドッグタイマ )
250 ms
500 ms
0bXX1*1( ソフトウェアウォッチドッグタイマ )
または ハードウェアウォッチドッグタイマ *2
437 ms
2.62 s
*1: X = 0 または 1
*2: CS[1:0] = 0b00, CSP = 1 ( リードオンリ )
April 4, 2014, MB95F718M_MN702-00014-3v0-J
105
第 8 章 ハードウェア / ソフトウェアウォッチドッグタイマ
8.2 構成
H ard war e
8.2
Ma nu al
構成
ウォッチドッグタイマは , 以下のブロックで構成されます。
• カウントクロックセレクタ
• ウォッチドッグタイマカウンタ
• リセット制御回路
• ウォッチドッグタイマクリアセレクタ
• カウンタクリア制御回路
• ウォッチドッグタイマ制御レジスタ (WDTC)
■ ウォッチドッグタイマのブロックダイヤグラム
図 8.2-1 ウォッチドッグタイマのブロックダイヤグラム
ウォッチドッグタイマ制御レジスタ(WDTC)
CS1
221/FCH (または220/FCRHまたは220/FPLL),
220/FCH (または219/FCRHまたは219/FPLL)
(タイムベースタイマ出力)
214/FCL (または213/FCRL),
213/FCL (または212/FCRL)
(時計プリスケーラ出力)
CS0
CSP HWWDT WTE3 WTE2 WTE1 WTE0
ウォッチドッグタイマ
カウントクロック
セレクタ
クリア 起動
216/FCRL
(サブCRタイマ)
タイムベースタイマ
からのクリア信号
時計プリスケーラ
からのクリア信号
ウォッチドッグ
タイマ
クリアセレクタ
スリープモード開始
ストップモード開始
タイムベースタイマ/時計モード開始
ストップモードで停止中または動作中
FCH
FCRH
FPLL
FCL
FCRL
106
リセット
制御回路
ウォッチドッグ
タイマカウンタ
リセット
信号
オーバフロー
カウンタクリア
制御回路
: メインクロック
: メインCRクロック
: PLLクロック
: サブクロック
: サブCRクロック
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 8 章 ハードウェア / ソフトウェアウォッチドッグタイマ
8.2 構成
Ha rdware
Manual
● カウントクロックセレクタ
このセレクタは , ウォッチドッグタイマカウンタのカウントクロックを選択します。
● ウォッチドッグタイマカウンタ
このカウンタは , タイムベースタイマの出力 , 時計プリスケーラの出力またはサブ CR
タイマの出力をカウントクロックとする 1 ビットのカウンタです。
● リセット制御回路
この回路は , ウォッチドッグタイマカウンタのオーバフローによってリセット信号を
発生させます。
● ウォッチドッグタイマクリアセレクタ
ウォッチドッグタイマクリア信号を選択します。
● カウンタクリア制御回路
ウォッチドッグタイマカウンタのクリアと動作停止を制御する回路です。
● ウォッチドッグタイマ制御レジスタ (WDTC)
ウォッチドッグタイマカウンタの起動とクリアおよびカウントクロックの選択を設定
するレジスタです。
■ 入力クロック
ウォッチドッグタイマは , タイムベースタイマの出力クロック , 時計プリスケーラから
の出力クロックまたはサブ CR タイマからの出力クロックを入力クロック ( カウントク
ロック ) として使用します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
107
第 8 章 ハードウェア / ソフトウェアウォッチドッグタイマ
8.3 動作説明と設定手順例
H ard war e
8.3
Ma nu al
動作説明と設定手順例
ウォッチドッグタイマは , ウォッチドッグタイマカウンタのオーバフローによって
ウォッチドッグリセットを発生します。
■ ウォッチドッグタイマの動作
● ウォッチドッグタイマの起動方法
ソフトウェアウォッチドッグの場合
•
ウォッチドッグタイマ制御レジスタのウォッチドッグ制御ビット
(WDTC:WTE[3:0]) に , リセット後 , 1 回目の "0b0101" を書き込むとウォッチドッグ
タイマは起動します。このとき , ウォッチドッグタイマ制御レジスタのカウントク
ロック切換えビット (WDTC:CS[1:0], CSP) を同時に指定します。
•
ウォッチドッグタイマを一度起動すると , リセット以外にその動作を止める方法は
ありません。
ハードウェアウォッチドッグの場合
•
ハードウェアウォッチドッグタイマを起動するために , フラッシュメモリ上にある
アドレス 0xFFBE と 0xFFBF に "0xA596" 以外の任意の値を書き込んでください。リ
セット後, フラッシュメモリ上にあるアドレス0xFFBEと0xFFBFのデータは, ウォッ
チドッグタイマ選択 ID レジスタ ( 上位 / 下位 ) (WDTH/WDTL) (0x0FEB/0x0FEC) へ
コピーされます。フラッシュメモリ上にあるアドレス 0xFFBE および 0xFFBF に
"0xA597" を書き込むと , ハードウェアウォッチドッグタイマはスタンバイモードで
停止しますが, "0xA596" および "0xA597" 以外の任意の値を書き込むことで, ハード
ウェアウォッチドッグタイマはすべてのモードで動作します。
ウォッチドッグタイ
マ選択 ID についての詳細は ,「第 28 章 不揮発性レジスタ (NVR) インタフェース」を
参照してください。
•
リセット解除後に動作を開始します。
•
CS[1:0] および CSP は , "0b001" に固定されたリードオンリのビットです。
•
リセットによりタイマはクリアされ ,
す。
リセットが解除された後に動作は再開しま
● ウォッチドッグタイマのクリア
•
ウォッチドッグタイマのカウンタがインターバル時間内にクリアされない場合 , カ
ウンタはオーバフローし , ウォッチドッグリセットが発生します。
•
ウォッチドッグタイマ制御レジスタのウォッチドッグ制御ビット
(WDTC:WTE[3:0]) に , "0b0101" を書き込むと , ハードウェアウォッチドッグタイマ
のカウンタはクリアされます。ウォッチドッグタイマ制御レジスタのウォッチドッ
グ制御ビット (WDTC:WTE[3:0]) への , 2 回目以降の , "0b0101" の書込みによって ,
ソフトウェアウォッチドッグタイマのカウンタはクリアされます。
ウォッチドッグタイマは,カウントクロックとして選択しているタイマ(タイムベー
スタイマまたは時計プリスケーラ ) がクリアされると同時にクリアされます。
•
108
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 8 章 ハードウェア / ソフトウェアウォッチドッグタイマ
8.3 動作説明と設定手順例
Ha rdware
Manual
● スタンバイモード時の動作
•
ソフトウェアウォッチドッグタイマまたはスタンバイモード中の動作を禁止した
ハードウェアウォッチドッグタイマの起動時は , 選択されたクロックモードに関係
なく スタンバイモードに移行すると , ウォッチドッグタイマカウンタをクリアして
動作を停止します。また , スタンバイモードからの復帰により , ウォッチドッグタイ
マは動作を再開します。
•
スタンバイモード中の動作を許可したハードウェアウォッチドッグタイマの起動
時は , スタンバイモードへの移行およびスタンバイモードからの復帰時にウォッチ
ドッグタイマカウンタはクリアされず , 動作を継続します。
<注意事項>
ウォッチドッグタイマは , カウントクロックとして選択されているタイマ ( タイムベース
タイマまたは時計プリスケーラ ) のクリアと同時にクリアされます。このため , ウォッチ
ドッグタイマのカウントクロックとして選択されたタイマを , ウォッチドッグタイマ用に
選択されたインターバル時間内で繰返しクリアするようにソフトウェアが設定されてい
ると , ウォッチドッグタイマは機能できません。
● インターバル時間
インターバル時間は , ウォッチドッグタイマをクリアするタイミングによって変化し
ます。図 8.3-1 に , タイムベースタイマ出力 FCH/221 (FCH: メインクロック ) がカウント
クロックとして選択された場合 ( メインクロック = 4 MHz) の , ウォッチドッグタイマ
のクリアのタイミングとインターバル時間との関係を示します。
図 8.3-1 ウォッチドッグタイマのクリアのタイミングとインターバル時間
最小時間
524ms
タイムベースタイマ
カウントクロック出力
ウォッチドッグクリア
オ―バフロー
ウォッチドッグ
1ビットカウンタ
ウォッチドッグ
リセット
最大時間
1.05s
タイムベースタイマ
カウントクロック出力
ウォッチドッグクリア
オーバフロー
ウォッチドッグ
1ビットカウンタ
ウォッチドッグ
リセット
April 4, 2014, MB95F718M_MN702-00014-3v0-J
109
第 8 章 ハードウェア / ソフトウェアウォッチドッグタイマ
8.3 動作説明と設定手順例
H ard war e
Ma nu al
● サブクロックモード時の動作
サブクロックモードでウォッチドッグリセットが発生した場合 , タイマは発振安定待
ち時間の経過後にメインクロックモードで動作を開始します。この発振安定待ち時間
内にリセット信号が出力されます。
■ 設定手順例
以下に , ソフトウェアウォッチドッグタイマの設定手順を示します。
1. カウントクロックを選択してください (WDTC:CS[1:0], CSP)。
2. ウォッチドッグタイマを起動してください (WDTC:WTE[3:0] = 0b0101)。
3. ウォッチドッグタイマをクリアしてください (WDTC:WTE[3:0] = 0b0101)。
以下に , ハードウェアウォッチドッグタイマの設定手順を示します。
1. フラッシュメモリ上にあるアドレス 0xFFBE と 0xFFBF に "0xA596" 以外の任意の値
を書き込んでください。リセット後 , フラッシュメモリ上にあるアドレス 0xFFBE
と 0xFFBF のデータは , ウォッチドッグタイマ選択 ID レジスタ ( 上位 / 下位 ) (WDTH/
WDTL) (0x0FEB/0x0FEC) へコピーされます。フラッシュメモリ上にあるアドレス
0xFFBE および 0xFFBF に "0xA597" を書き込むと , ハードウェアウォッチドッグタ
イマはスタンバイモードで停止しますが , "0xA596" および "0xA597" 以外の任意の
値を書き込むことで , ハードウェアウォッチドッグタイマはすべてのモードで動作
します。ウォッチドッグタイマ選択 ID についての詳細は , 「第 28 章 不揮発性レジ
スタ (NVR) インタフェース」を参照してください。
2. ウォッチドッグタイマをクリアしてください (WDTC:WTE[3:0] = 0b0101)。
110
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 8 章 ハードウェア / ソフトウェアウォッチドッグタイマ
8.4 レジスタ
Ha rdware
Manual
レジスタ
8.4
ウォッチドッグタイマのレジスタについて説明します。
表 8.4-1
ウォッチドッグタイマのレジスタ一覧
レジスタ略称
WDTC
レジスタ名
ウォッチドッグタイマ制御レジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
参照先
8.4.1
111
第 8 章 ハードウェア / ソフトウェアウォッチドッグタイマ
8.4 レジスタ
H ard war e
Ma nu al
ウォッチドッグタイマ制御レジスタ (WDTC)
8.4.1
ウォッチドッグタイマ制御レジスタ (WDTC) は , ウォッチドッグタイマの起動とクリ
アを行うレジスタです。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
CS1
CS0
CSP
HWWDT
WTE3
WTE2
WTE1
WTE0
ソフトウェアウォッチドッグタイマ使用時の属性と初期値
属性
R/W
R/W
R/W
R
W
W
W
W
初期値
0
0
0
0
0
0
0
0
ハードウェアウォッチドッグタイマ使用時の属性と初期値
属性
R
R
R
R
W
W
W
W
初期値
0
0
1
1
0
0
0
0
■ レジスタ機能
[bit7:6] CS[1:0]: カウントクロック切換えビット
[bit5] CSP: カウントクロック選択サブ CR 選択ビット
これらのビットはウォッチドッグタイマのカウントクロックを選択します。
ウォッチドッグ制御ビットによってウォッチドッグタイマを起動すると同時に , これらのビットに
書き込んでください。
ウォッチドッグタイマを起動した後にはこれらのビットは変更できません。
説明
(FCH: メインクロック , FCRH: メイン CR クロック ,
bit7 bit6 bit5
FPLL: PLL クロック , FCL: サブクロック , FCRL: サブ CR クロック )
0
0
0
を書き込んだ場合
タイムベースタイマの出力周期 (221/FCH, 220/FCRH または 220/FPLL)
0
1
0
を書き込んだ場合
タイムベースタイマの出力周期 (220/FCH, 219/FCRH または 219/FPLL)
1
0
0
を書き込んだ場合
時計プリスケーラの出力周期 (214/FCL または 213/FCRL)
1
1
0
を書き込んだ場合
時計プリスケーラの出力周期 (213/FCL または 212/FCRL)
0/1
0/1
1
を書き込んだ場合
サブ CR タイマの出力周期 (216/FCRL)
( 注意事項 ) サブクロックモードまたはサブ CR クロックモードでは , タイムベースタイマが停止す
るため , 時計プリスケーラの出力を常に選択してください。
[bit4] HWWDT: ハードウェアウォッチドッグタイマ起動ビット
このビットはハードウェアウォッチドッグタイマの開始・停止を確認するために使用されるリード
オンリのビットです。
bit4
112
説明
"0" が読み出された場合
ハードウェアウォッチドッグタイマは停止されています ( ソフトウェアウォッ
チドッグタイマは起動できます )。
"1" が読み出された場合
ハードウェアウォッチドッグタイマは起動されています。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 8 章 ハードウェア / ソフトウェアウォッチドッグタイマ
8.4 レジスタ
Ha rdware
Manual
[bit3:0] WTE[3:0]: ウォッチドッグ制御ビット
これらのビットはウォッチドッグタイマを制御します。
これらのビットの読出し値は常に "0b0000" です。
説明
bit3:0
"0101" を書き込んだ場合
ウォッチドッグタイマを起動 ( リセット後の 1 回目の書込み ) ま
たはウォッチドッグタイマをクリア ( リセット後の 2 回目以降の
書込み ) します。
• ウォッチドッグタイマの起動
リセット後の1回目の書込みはソフトウェアウォッチドッグタイ
マを起動します。
• ウォッチドッグタイマのクリア
リセット後の1回目以降の書込みはハードウェアウォッチドッグ
タイマをクリアします。
リセット後の2回目以降の書込みはソフトウェアウォッチドッグ
タイマをクリアします。
"0101" 以外の値を書き込んだ場合
動作に影響はありません。
<注意事項>
本レジスタはリードモディファイライト (RMW) 系命令が使用できません。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
113
第 8 章 ハードウェア / ソフトウェアウォッチドッグタイマ
8.5 使用上の注意
H ard war e
8.5
Ma nu al
使用上の注意
ウォッチドッグタイマの使用に関する注意を示します。
■ ウォッチドッグタイマ使用上の注意
● ウォッチドッグタイマの停止について
ソフトウェアウォッチドッグの場合
ウォッチドッグタイマは , 一度起動すると , リセットが発生するまで停止できません。
● カウントクロックの選択について
ソフトウェアウォッチドッグの場合
カウントクロック切換えビット (WDTC:CS[1:0], CSP) は , ウォッチドッグタイマ起動後
に , ウォッチドッグ制御ビット (WDTC:WTE[3:0]) を "0b0101" にしたときのみ書換え可
能です。カウントクロック切換えビットは , ビット操作命令によって設定はできませ
ん。
また , 一度タイマが起動すると , ビット設定を変更できません。
サブクロックモードまたはサブ CR クロックモードでは , メインクロック , メイン CR
クロックまたは PLL クロックの発振が停止するため , タイムベースタイマは動作しま
せん。
ウォッチドッグタイマをサブクロックモードまたはサブ CR クロックモードで動作さ
せるためには , あらかじめカウントクロックとして時計プリスケーラを選択し ,
"WDTC:CS[1:0], CSP" を "0b100" または "0b110" または "0bXX1" (X = 0 または 1) に設
定してください。
● ウォッチドッグタイマのクリアについて
ウォッチドッグタイマのカウントクロックに使用しているカウンタ ( タイムベースタ
イマ , 時計プリスケーラまたはサブ CR タイマ ) をクリアすると , 同時にウォッチドッ
グタイマのカウンタもクリアされます。
ウォッチドッグタイマがスリープモード , ストップモードまたは時計モードに遷移す
ると , ウォッチドッグタイマのカウンタはクリアされます。ただし , スタンバイモード
中の動作を許可したハードウェアウォッチドッグタイマを起動している場合を除きま
す。
● プログラム作成上の注意
メインループの中で , 繰返しウォッチドッグタイマをクリアするようなプログラムを
作成する場合 , 割込み処理時間を含むメインループの処理時間が , ウォッチドッグタイ
マインターバル時間の最小時間以下となるように設定してください。
● ハードウェアウォッチドッグタイマ ( スタンバイモード中の動作を許可した場合 )
ハードウェアウォッチドッグタイマは , ストップモード , スリープモード , タイムベー
スタイマモードまたは時計モードでは停止しません。したがって , 内部クロックが停止
しても , ウォッチドッグタイマは , CPU によってクリアされることはありません ( ス
リープモード , ストップモード , タイムベースタイマモードまたは時計モード )。
定期的にデバイスをスタンバイモードから解除し , ウォッチドッグタイマをクリアし
ます。ただし , 発振安定待ち時間設定レジスタの設定に応じて , ウォッチドッグリセッ
トは , CPU がサブクロックモードまたはサブ CR クロックモード中のストップモード
から復帰した後に発生することがあります。
114
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 8 章 ハードウェア / ソフトウェアウォッチドッグタイマ
8.5 使用上の注意
Ha rdware
Manual
サブクロックを選択する際にはサブクロックの安定待ち時間の設定にも留意してくだ
さい。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
115
第 8 章 ハードウェア / ソフトウェアウォッチドッグタイマ
8.5 使用上の注意
H ard war e
116
Ma nu al
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第9章
時計プリスケーラ
時計プリスケーラの機能と動作について説明します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
9.1
概要
9.2
構成
9.3
割込み
9.4
動作説明と設定手順例
9.5
レジスタ
9.6
使用上の注意
117
第 9 章 時計プリスケーラ
9.1 概要
H ard war e
9.1
Ma nu al
概要
時計プリスケーラは , サブクロックの 2 分周またはサブ CR クロックの 2 分周に同期
してカウントダウンする 16 ビットのフリーランカウンタです。このプリスケーラに
は , 一定のインターバル時間で繰返し割込み要求を発生させるインターバルタイマ機
能があります。
■ インターバルタイマ機能
インターバルタイマ機能とは , サブクロックの 2 分周またはサブ CR クロックの 2 分周
をカウントクロックとして , 一定の時間間隔で繰返し割込み要求を発生させる機能で
す。
•
時計プリスケーラのカウンタがカウントダウンを行い , 選択したインターバル時間
が経過するごとに割込み要求を発生します。
•
インターバル時間は , 次の 8 種類の中から選択できます。
表 9.1-1 に , 時計プリスケーラのインターバル時間を示します。
表 9.1-1
時計プリスケーラのインターバル時間
インターバル時間
( サブ CR クロック )
(2n × 2/FCRL*1)
インターバル時間
( サブクロック )
(2n × 2/FCL*2)
n=10
20.48 ms
62.5 ms
n=11
40.96 ms
125 ms
n=12
81.92 ms
250 ms
n=13
163.84 ms
500 ms
n=14
327.68 ms
1s
n=15
655.36 ms
2s
n=16
1.311 s
4s
n=17
2.621 s
8s
*1: FCRL=100 kHz の場合 , 2/FCRL=20 s
*2: FCL=32.768 kHz の場合 , 2/FCL=61.035 s
<注意事項>
サブ CR の周波数の精度については , デバイスのデータシートを参照してください。
118
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 9 章 時計プリスケーラ
9.2 構成
Ha rdware
9.2
Manual
構成
時計プリスケーラは , 以下のブロックから構成されます。
• 時計プリスケーラカウンタ
• カウンタクリア回路
• インターバルタイマセレクタ
• 時計プリスケーラ制御レジスタ (WPCR)
■ 時計プリスケーラのブロックダイヤグラム
図 9.2-1 時計プリスケーラのブロックダイヤグラム
ソフトウェアウォッチドッグタイマ
時計プリスケーラカウンタ(カウンタ)
FCL の2分周
FCRL の2分周
X 21
X 22
X 23
X 24
X 25
X 26
X 27
X 28
X 29
X 210 X 211 X 212 X 213 X 214 X 215 X 216 X 217
カウンタクリア
SYCC:SCM[2:0]
SYCC2:SRDY,
SYCC2:SCRDY
ウォッチドッグタイマクリア
リセット,サブクロック発振の停止,
またはサブCRクロック発振の停止
インターバルタイマ
セレクタ
カウンタクリア
回路
時計プリスケーラ割込み
WTIF
WTIE
-
-
WTC2
WTC1
WTC0 WCLR
時計プリスケーラ制御レジスタ (WPCR)
FCL : サブクロック
FCRL : サブCRクロック
April 4, 2014, MB95F718M_MN702-00014-3v0-J
119
第 9 章 時計プリスケーラ
9.2 構成
H ard war e
Ma nu al
● 時計プリスケーラカウンタ ( カウンタ )
サブクロックの 2 分周またはサブ CR クロックの 2 分周をカウントクロックとする 16
ビットのダウンカウンタです。
● カウンタクリア回路
時計プリスケーラのクリアを制御する回路です。
● インターバルタイマセレクタ
時計プリスケーラカウンタ中にある 17 ビットの内の 8 ビットから , インターバルタイ
マ用の 1 ビットを選択する回路です。
● 時計プリスケーラ制御レジスタ (WPCR)
インターバル時間の選択 , カウンタのクリア , 割込み制御および状態の確認を行うレジ
スタです。
■ 入力クロック
時計プリスケーラは , サブクロックの 2 分周またはサブ CR クロックの 2 分周を入力ク
ロック ( カウントクロック ) として使用します。
■ 出力クロック
時計プリスケーラは , ソフトウェアウォッチドッグタイマにクロックを供給します。
120
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 9 章 時計プリスケーラ
9.3 割込み
Ha rdware
9.3
Manual
割込み
時計プリスケーラで選択されたインターバル時間が経過すると , 割込み要求が発生し
ます ( インターバルタイマ機能 )。
■ インターバルタイマ機能動作時の割込み ( 時計プリスケーラ割込み )
サブクロックモードまたはサブ CR クロックモード時のストップモード以外のモード
では , 時計プリスケーラ用カウンタがサブクロックの 2 分周またはサブ CR クロックの
2 分周でカウントダウンし , 設定したインターバル時間が経過すると , 時計プリスケー
ラ割込み要求フラグビットが "1" に設定 (WPCR:WTIF = 1) されます。そのとき , 割込み
要求許可ビットが許可 (WPCR:WTIE = 1) されている場合 , 時計プリスケーラから割込
みコントローラへ割込み要求が出力されます。
•
WTIF ビットは , WTIE ビットの値に関係なく , 時計プリスケーラ割込みインターバ
ル時間選択ビットで設定した時間が経過すると "1" に設定されます。
•
WTIF ビットが "1" に設定された場合 , WTIE ビットを禁止状態から許可状態
(WPCR:WTIE = 0 1) に変化させると , 直ちに割込み要求が発生します。
•
選択されたビットがオーバフローすると同時にカウンタがクリア (WPCR:WCLR =
1) した場合は , WTIF ビットは "1" に設定されません。
•
割込み要求をクリアするには , 割込みサービスルーチンで WTIF ビットに "0" を書
き込んでください。
<注意事項>
リセット解除後に , 割込み要求出力を許可 (WPCR:WTIE = 1) するには , 必ず同時に WTIF
ビットをクリアしてください。
表 9.3-1
時計プリスケーラの割込み
項目
説明
割込みの条件
WPCR: WTC[2:0] で設定したインターバル時間が経過した。
割込みフラグ
WPCR:WTIF
割込み許可
WPCR:WTIE
April 4, 2014, MB95F718M_MN702-00014-3v0-J
121
第 9 章 時計プリスケーラ
9.4 動作説明と設定手順例
H ard war e
9.4
Ma nu al
動作説明と設定手順例
時計プリスケーラは , インターバルタイマ機能として動作します。
■ インターバルタイマ機能の動作 ( 時計プリスケーラ )
時計プリスケーラのカウンタは , サブクロックまたはサブ CR クロックが発振している
間 , サブクロックの 2 分周またはサブ CR クロックの 2 分周をカウントクロックとして
カウントダウンを続けます。
カウンタがクリア (WPCR:WCLR = 1) されると , カウンタは "0xFFFF" からカウントダ
ウンを開始し , "0x0000" に達すると , "0xFFFF" に戻ってカウントを継続します。カウン
トダウン中に , 割込みインターバル時間選択ビットで設定した時間が経過すると , サブ
クロックモードまたはサブ CR クロックモード時のストップモード以外の場合 , 時計割
込み要求フラグビット (WPCR:WTIF) が "1" に設定されます。すなわち , カウンタが最
後にクリアされた時間を基準にして , 選択されたインターバル時間ごとに時計割込み
要求が発生します。
■ 時計プリスケーラのクリア
時計プリスケーラをクリアすると , 時計プリスケーラの出力を使用しているほかの周
辺機能は , カウント時間が変化するなど動作に影響を受けます。
時計プリスケーラ初期化ビット (WPCR:WCLR) によってカウンタをクリアする場合は ,
カウンタのクリアにより予期せぬ影響を及ぶことがないようにそのほかの周辺機能の
設定を必要に応じて変更してください。
なお , 時計プリスケーラの出力をカウントクロックとして選択しているとき , 時計プリ
スケーラがクリアされると , ウォッチドッグタイマもクリアされます。
時計プリスケーラは , 時計プリスケーラ初期化ビット (WPCR:WCLR) によるクリアに
加え , サブクロックまたはサブ CR クロックが停止し , 発振安定待ち時間が必要になっ
た場合クリアされます。時計プリスケーラは , 以下の状況でクリアされます。
•
デバイスが , サブクロックモードまたはサブ CR クロックモードからストップモー
ドへ移行したとき
•
メインクロックモード , メイン PLL クロックモード , メイン CR クロックモードま
たはメイン CR PLL クロックモードにおいて , システムクロック制御レジスタ 2 の
サブクロック発振許可ビットまたはサブ
CR
クロック発振許可ビット
(SYCC2:SOSCE または SCRE) を "0" に設定したとき
また , リセットが発生した場合 , 時計プリスケーラのカウンタはクリアされ , 動作を停
止します。
■ 時計プリスケーラの入力クロック選択について
時計プリスケーラの入力クロック選択は , 各クロックモードで以下のようになります。
•
メインクロックモード , メイン PLL クロックモード , メイン CR クロックモードと
メイン CR PLL クロックモードの場合
サブクロックの発振が許可され , サブクロック発振安定待ち時間が経過した場合 ,
サブクロックは時計プリスケーラの入力クロックとして選択されます。
サブ CR クロックの発振が許可され , サブ CR クロック発振安定待ち時間が経過し
た場合 , サブ CR クロックは時計プリスケーラの入力クロックとして選択されます。
122
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 9 章 時計プリスケーラ
9.4 動作説明と設定手順例
Ha rdware
Manual
サブクロックの発振とサブ CR クロックの発振が許可され , サブクロック発振安定
待ち時間とサブ CR クロック発振安定待ち時間が経過した場合 , サブクロックは時
計プリスケーラの入力クロックとして選択されます。
•
サブクロックモードの場合
時計プリスケーラの入力クロックはサブクロックに固定されます。
•
サブ CR クロックモードの場合
時計プリスケーラの入力クロックはサブ CR クロックに固定されます。
■ 時計プリスケーラの動作例
図 9.4-1 に , 以下の条件下の動作例を示します。
1. パワーオンリセットが発生した場合
2. デバイスが, サブクロックモードもしくはサブCRクロックモードにおいてインター
バルタイマ機能の動作中に , スリープモードへ移行した場合
3. デバイスが, サブクロックモードもしくはサブCRクロックモードにおいてインター
バルタイマ機能の動作中に , ストップモードへ移行した場合
4. カウンタクリアの要求が発生した場合
時計モードへの移行は , スリープモードへの移行と同じ動作で行います。
図 9.4-1 時計プリスケーラの動作例
カウンタ値
(カウントダウン)
0xFFFF
WPCR:WTC[2:0]で
検出するカウント値
インターバル時間
(WPCR:WTC[2:0] = 0b011)
0x0000
発振安定待ち時間
1) パワーオンリセット
4) カウンタクリア
(WPCR:WCLR = 1)
インターバル
設定時のクリア
ストップモードへの
遷移によるクリア
発振安定
待ち時間
割込みサービスルーチンで
クリア
WTIFビット
WTIEビット
2) SLPビット
(STBCレジスタ)
3) STPビット
(STBCレジスタ)
スリープ
時計割込みによる
スリープモード解除
ストップ
外部割込みによるストップモード解除
• 時計プリスケーラ制御レジスタのインターバル時間選択ビット(WPCR:WTC[2:0])に"0b011"を設定した場合(214 × 2/FCL)
• WPCR:WTC[2:0] : 時計プリスケーラ制御レジスタの時計プリスケーラ割込みインターバル時間選択ビット
• WPCR:WCLR : 時計プリスケーラ制御レジスタの時計プリスケーラクリアビット
: 時計プリスケーラ制御レジスタの時計プリスケーラ割込み要求フラグビット
• WPCR:WTIF
: 時計プリスケーラ制御レジスタの時計プリスケーラ割込み要求許可ビット
• WPCR:WTIE
: スタンバイ制御レジスタのスリープビット
• STBC:SLP
: スタンバイ制御レジスタのストップビット
• STBC:STP
April 4, 2014, MB95F718M_MN702-00014-3v0-J
123
第 9 章 時計プリスケーラ
9.4 動作説明と設定手順例
H ard war e
Ma nu al
■ 設定手順例
以下に , 時計プリスケーラの設定手順例を示します。
● 初期設定
1. 割込みレベルを設定してください (ILR*)。
2. インターバル時間を設定してください (WPCR:WTC[2:0])。
3. 割込み許可を設定し , 割込み要求フラグをクリアしてください (WPCR:WTIE = 1,
WPCR:WTIF = 0)。
4. カウンタをクリアしてください (WPCR:WCLR = 1)。
*: 割込みレベル設定レジスタ (ILR) の詳細について , 本ハードウェアマニュアルの「第 5 章 割
込み」とデバイスのデータシートの「■ 割込み要因のテーブル」を参照してください。
● 割込み処理
1. 割込み要求フラグをクリアしてください (WPCR:WTIF = 0)。
2. カウンタをクリアしてください (WPCR:WCLR = 1)。
124
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 9 章 時計プリスケーラ
9.5 レジスタ
Ha rdware
Manual
レジスタ
9.5
時計プリスケーラのレジスタについて説明します。
表 9.5-1
時計プリスケーラのレジスタ一覧
レジスタ略称
WPCR
レジスタ名
時計プリスケーラ制御レジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
参照先
9.5.1
125
第 9 章 時計プリスケーラ
9.5 レジスタ
H ard war e
9.5.1
Ma nu al
時計プリスケーラ制御レジスタ (WPCR)
時計プリスケーラ制御レジスタ (WPCR) は , インターバル時間の選択 , カウンタのク
リア , 割込み制御および時計プリスケーラの状態確認を行うレジスタです。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
WTIF
WTIE
—
—
WTC2
WTC1
WTC0
WCLR
属性
R/W
R/W
—
—
R/W
R/W
R/W
W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] WTIF: 時計プリスケーラ割込み要求フラグビット
時計プリスケーラにより選択されたインターバル時間が経過後は , このビットは "1" になります。
このビットと時計プリスケーラ割込み要求許可ビット (WTIE) が "1" に設定されたとき , 割込み要求
が発生します。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit7
"0" が読み出された場合
インターバル時間がまだ経過していないことを示します。
"1" が読み出された場合
インターバル時間が経過したことを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit6] WTIE: 時計プリスケーラ割込み要求許可ビット
このビットは割込みコントローラへの割込み要求出力を許可または禁止します。
このビットと時計プリスケーラ割込み要求フラグビット (WTIF) が "1" に設定されたとき , 割込み要
求が出力されます。
bit6
説明
"0" を書き込んだ場合
時計プリスケーラの割込み要求を禁止します。
"1" を書き込んだ場合
時計プリスケーラの割込み要求を許可します。
[bit5:4] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
126
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 9 章 時計プリスケーラ
9.5 レジスタ
Ha rdware
Manual
[bit3:1] WTC[2:0]: 時計プリスケーラ割込みインターバル時間選択ビット
これらのビットはインターバル時間を選択します。
説明
bit3:1
インターバル時間
( サブクロック , FCL = 32.768 kHz)
インターバル時間
( サブ CR クロック , FCRL = 100 kHz)
"100" を書き込んだ場合
210  2/FCL (62.5 ms)
210  2/FCRL (20.48 ms)
"000" を書き込んだ場合
211  2/FCL (125 ms)
211  2/FCRL (40.96 ms)
"001" を書き込んだ場合
212  2/FCL (250 ms)
212  2/FCRL (81.92 ms)
"010" を書き込んだ場合
213  2/FCL (500 ms)
213  2/FCRL (163.84 ms)
"011" を書き込んだ場合
214  2/FCL (1 s)
214  2/FCRL (327.68 ms)
"101" を書き込んだ場合
215  2/FCL (2 s)
215  2/FCRL (655.36 ms)
"110" を書き込んだ場合
216  2/FCL (4 s)
216  2/FCRL (1.311 s)
"111" を書き込んだ場合
217  2/FCL (8 s)
217  2/FCRL (2.621 s)
[bit0] WCLR: 時計プリスケーラクリアビット
このビットは時計プリスケーラのカウンタの全ビットを "1" にクリアします。
説明
bit0
読出し動作
読出し値は常に "0" です。
"0" を書き込んだ場合
動作に影響はありません。
"1" を書き込んだ場合
時計プリスケーラのカウンタの全ビットを "1" にクリアします。
( 注意事項 ) 時計プリスケーラの出力がソフトウェアウォッチドッグタイマのカウントクロックと
して選択されているときには , このビットで時計プリスケーラがクリアされるとソフ
トウェアウォッチドッグタイマもクリアされます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
127
第 9 章 時計プリスケーラ
9.6 使用上の注意
H ard war e
9.6
Ma nu al
使用上の注意
時計プリスケーラ使用上の注意を示します。
■ 時計プリスケーラ使用上の注意
● プログラムで割込み処理を設定する場合
時計プリスケーラ割込み要求フラグビット (WPCR:WTIF) が "1" に設定され , 割込み
要求 が許可 (WPCR:WTIE = 1) されている場合には , 時計プリスケーラは割込み処理か
ら復帰できません。必ず割込みルーチン内で WTIF ビットをクリアしてください。
● 時計プリスケーラのクリアについて
ソフトウェアウォッチドッグタイマのカウントクロックとして時計プリスケーラを選
択 (WDTC:CS[1:0], CSP = 0b100 または 0b110) した場合 , 時計プリスケーラをクリアす
るとソフトウェアウォッチドッグタイマもクリアされます。
● 時計プリスケーラ割込みについて
メインクロック , メイン PLL クロック , メイン CR クロックまたはメイン CR PLL ク
ロック使用時のストップモードでは , 時計プリスケーラはカウント動作を行い , 時計プ
リスケーラ割込みを発生できます。
● 時計プリスケーラからクロックを供給される周辺機能について
時計プリスケーラのカウンタをクリアすると , 時計プリスケーラの出力を使用してい
るほかの周辺機能は , 動作周期が変化するなど周辺機能の動作に影響を受けます。
なお , 時計プリスケーラのカウンタがクリアされた後 , 時計プリスケーラから出力され
たソフトウェアウォッチドッグタイマ用のクロックは , 初期状態となります。ソフト
ウェアウォッチドッグタイマのクロックが初期状態に戻ると同時に , ソフトウェア
ウォッチドッグタイマのカウンタがクリアされるため , ソフトウェアウォッチドッグ
タイマは正常な周期で動作します。
128
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 10 章
時計カウンタ
時計カウンタの機能と動作について説明します。
10.1 概要
10.2 構成
10.3 割込み
10.4 動作説明と設定手順例
10.5 レジスタ
10.6 使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
129
第 10 章 時計カウンタ
10.1 概要
H ard war e
10.1
Ma nu al
概要
時計カウンタは , 最小 40.96 ms から最大 63 s の範囲のインターバル時間によって割
込み要求を発生します。
■ 時計カウンタの機能
時計カウンタは , 選択されたカウントクロックを基に , 時計カウンタデータレジスタ
(WCDR) に特定された回数のカウントを実行し , 割込み要求を発生します。カウントク
ロックは表 10.1-1 に示される 8 種類から選択できます。カウント値として "0" から "63"
までの値が設定できます。"0" がカウント値として選択されると , 割込み要求が発生さ
れません。
カウントクロックとして "1 s" を設定し , カウント値として "60" を設定すると , 割込は
1 分ごとに発生します。
表 10.1-1 カウントクロックの種類
カウントクロック ( サブ CR クロック )
(2n2/FCRL*1)
カウントクロック ( サブクロック )
(2n2/FCL*2)
n = 11
40.96 ms
125 ms
n = 12
81.92 ms
250 ms
n = 13
163.84 ms
500 ms
n = 14
327.68 ms
1s
*1: FCRL = 100 kHz の場合 , 2/FCRL = 20 µs
*2: FCL = 32.768 kHz の場合 , 2/FCL = 61.035 µs
<注意事項>
サブ CR クロック周波数の精度について , デバイスのデータシートを参照してください。
130
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 10 章 時計カウンタ
10.2 構成
Ha rdware
10.2
Manual
構成
時計カウンタは以下のブロックで構成されています。
• カウンタ
• 時計カウンタ制御レジスタ (WCSR)
• 時計カウンタデータレジスタ (WCDR)
■ 時計カウンタのブロックダイヤグラム
図 10.2-1 時計カウンタのブロックダイヤグラム
時計カウンタ制御レジスタ(WCSR)
ISEL
WCFLG
CTR5
CTR4
CTR3
CTR2
CTR1
CTR0
カウンタ値
時計プリスケーラの割込み
時計カウンタの割込み
アンダフロー
内部バス
割込み許可
カウンタクリア
212/FCL (FCRL)
213/FCL (FCRL)
カウントクロック選択 14
2 /FCL (FCRL)
時計プリスケーラから
215/FCL (FCRL)
CS1
CS0
カウンタ
(6ビットカウンタ)
リロード値
RCTR5 RCTR4 RCTR3 RCTR2 RCTR1 RCTR0
時計カウンタデータレジスタ(WCDR)
FCL : サブクロック
FCRL : サブCRクロック
April 4, 2014, MB95F718M_MN702-00014-3v0-J
131
第 10 章 時計カウンタ
10.2 構成
H ard war e
Ma nu al
● カウンタ
時計プリスケーラの出力クロックをカウントクロックとして使用する 6 ビットダウン
カウンタです。
● 時計カウンタ制御レジスタ (WCSR)
割込みを制御し , 割込みステータスを確認し , カウント値を読み出します。
● 時計カウンタデータレジスタ (WCDR)
カウンタクロックを選択し , カウンタリロード値を設定します。
■ 入力クロック
時計カウンタは時計プリスケーラの出力クロックを入力クロック ( カウントクロック )
として使用します。
132
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 10 章 時計カウンタ
10.3 割込み
Ha rdware
10.3
Manual
割込み
時計カウンタは , カウンタがアンダフローするときに ( カウンタ値 = 0b000001) 割込
み要求を出力します。
■ 時計カウンタの割込み
時計カウンタのカウンタがアンダフローするときは , 時計カウンタ制御レジスタ
(WCSR) の時計カウンタ割込み要求フラグビット (WCFLG) は "1" に設定されます。
WCSR レジスタの時計カウンタ起動および割込み要求許可ビット (ISEL) も "1" に設定
されている場合 , 時計カウンタの割込み要求は割込みコントローラに対して出力され
ます。
表 10.3-1 に時計カウンタの割込み制御ビットと割込み発生要因を示します。
表 10.3-1 時計カウンタの割込み制御ビットと割込み発生要因
項目
説明
割込み要求フラグビット
WCSR:WCFLG
割込み要求許可ビット
WCSR:ISEL
割込み要因
カウンタのアンダフロー
April 4, 2014, MB95F718M_MN702-00014-3v0-J
133
第 10 章 時計カウンタ
10.4 動作説明と設定手順例
H ard war e
10.4
Ma nu al
動作説明と設定手順例
時計カウンタは , WCSR レジスタの ISEL ビットが "1" に設定されたとき , WCDR レ
ジスタの CS[1:0] ビットによって選択されたカウントクロックを使用して , WCDR レ
ジスタの RCTR[5:0] ビットに設定されたカウント値までカウントダウンします。カウ
ンタがアンダフローすると , WCSR レジスタの WCFLG ビットは "1" に設定され , 時
計カウンタは割込み要求を発生します。
■ 時計カウンタの設定手順
時計カウンタの設定手順を以下に示します。
1. カウントクロック (CS[1:0]) を選択し , カウンタのリロード値 (RCTR[5:0]) を設定し
てください。
2. ISEL ビットを "1" に設定してダウンカウントを開始し , 割込みを許可してください。
また , 時計プリスケーラの割込みを禁止してください。
時計カウンタは時計プリスケーラからの分周クロック ( 非同期性 ) を基にカウント
を実行します。これにより , ISEL ビットを "1" に設定するタイミングによっては ,
カウントサイクルの最初に , 最大 1 カウントクロックのエラーが発生することがあ
ります。
3. カウンタがアンダフローすると , WCFLG ビットは "1" に設定され , 割込みが発生し
ます。
4. WCFLG ビットに "0" を書き込んでこのビットをクリアしてください。
5. RCTR[5:0] ビットがカウント中に変更された場合 , リロード値はカウンタが "1" に
設定された後のリロード中に更新されます。
6. ISEL ビットに "0" が書き込まれると , カウンタは "0" になり動作を停止します。
図 10.4-1 時計カウンタの動作
ISEL
(2)
(6)
カウントクロック
CS[1:0]
0b11
(1)
RCTR[5:0]
7
9
(5)
CTR[5:0]
0
7
6
5
4
3
2
1
9
8
7
6
5
4
0
WCFLG
(3)
134
(4)
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 10 章 時計カウンタ
10.4 動作説明と設定手順例
Ha rdware
Manual
<注意事項>
ISEL ビットに "0" を書き込んでカウンタを停止した後に , カウンタを再起動させる場合 ,
WCSR レジスタの CTR[5:0] ビットを二度読み出して , CTR[5:0] ビットが "0b000000" に
クリアされたことを確認してからカウンタを再起動させてください。
■ サブストップモードとサブ CR クロックストップモードにおける動作
デバイスがサブストップモードまたはサブ CR クロックストップモードに入ったとき ,
時計カウンタはカウント動作を停止し , 時計プリスケーラもクリアされます。従って ,
時計カウンタは , サブストップモードまたはサブ CR クロックストップモードのクリア
後は正確なカウント値をカウントできません。サブストップモードまたはサブ CR ク
ロックストップモードのクリア後は , 常に WCSR レジスタの ISEL ビットを "0" に設定
してカウンタをクリアしなければなりません。サブストップモードとサブ CR クロッ
クストップモード以外のスタンバイモード時において , 時計カウンタは継続して動作
します。
■ メインストップモードとメイン CR クロックストップモードにおける動作
デバイスがメインストップモードまたはメイン CR クロックストップモードに入った
とき , 時計カウンタはカウント動作を継続しますが , 割込みは発生しません。システム
クロック制御レジスタ 2 (SYCC2) のサブクロック発振許可ビット (SOSCE) とサブ CR
クロック発振許可ビット (SCRE) がともに "0" に設定されたとき , 時計カウンタは停止
します。
■ 設定手順例
時計カウンタの設定手順例を以下に示します。
● 初期設定
1. 割込みレベルを設定してください (ILR*)。
2. カウントクロックを選択してください (WCDR:CS[1:0])。
3. カウンタリロード値を設定してください (WCDR:RCTR[5:0])。
4. 時計カウンタを起動し , 割込みを許可してください (WCSR:ISEL = 1)。
*: 割込みレベル設定レジスタ (ILR) の詳細について , 本ハードウェアマニュアルの「第 5 章 割
込み」とデバイスのデータシートの「■ 割込み要因のテーブル」を参照してください。
● 割込み処理
1. 割込み要求フラグをクリアしてください (WCSR:WCFLG = 0)。
2. 任意の割込みを処理してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
135
第 10 章 時計カウンタ
10.5 レジスタ
H ard war e
10.5
Ma nu al
レジスタ
時計カウンタのレジスタについて説明します。
表 10.5-1 時計カウンタのレジスタ一覧
レジスタ略称
136
レジスタ名
参照先
WCDR
時計カウンタデータレジスタ
10.5.1
WCSR
時計カウンタ制御レジスタ
10.5.2
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 10 章 時計カウンタ
10.5 レジスタ
Ha rdware
10.5.1
Manual
時計カウンタデータレジスタ (WCDR)
時計カウンタデータレジスタ (WCDR) はカウントクロックを選択し , カウンタリロー
ド値を設定します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
CS1
CS0
RCTR5
RCTR4
RCTR3
RCTR2
RCTR1
RCTR0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
1
1
1
1
1
1
■ レジスタ機能
[bit7:6] CS[1:0]: 時計カウンタカウントクロック選択ビット
これらのビットは時計カウンタのカウントクロックを選択します。
これらのビットを書き換える前に , WCSR レジスタの ISEL ビットが "0" に設定されていることを確
認してください。
説明
bit7:6
カウントクロック
( サブクロック , FCL = 32.768 kHz)
カウントクロック
( サブ CR クロック , FCRL = 100 kHz)
"00" を書き込んだ場合
212/FCL (125 ms)
212/FCRL (40.96 ms)
"01" を書き込んだ場合
213/FCL (250 ms)
213/FCRL (81.92 ms)
"10" を書き込んだ場合
214/FCL (500 ms)
214/FCRL (163.84 ms)
"11" を書き込んだ場合
215/FCL (1 s)
215/FCRL (327.68 ms)
[bit5:0] RCTR[5:0]: 時計カウンタカウンタリロード値設定ビット
これらのビットはカウンタリロード値を設定します。
カウンタ中にカウンタリロード値が変更された場合 , 新しいカウンタリロード値は , カウンタがア
ンダフローした後のリロードに有効になります。
RCTR[5:0] ビットが "0" に設定される場合 , 割込み要求が発生されません。
割込みの発生 (WCSR:WCFLG = 1) と同時にカウンタリロード値が変更された場合 , リロードされる
値が正確ではありません。したがって , カウンタリロード値の変更は , 割込み要求が発生される前
に行うべきです。すなわち , カウンタリロード値の変更は , 割込みサービスルーチン中または時計
カウンタの停止後 (WCSR:ISEL = 0) に行うべきです。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
137
第 10 章 時計カウンタ
10.5 レジスタ
H ard war e
10.5.2
Ma nu al
時計カウンタ制御レジスタ (WCSR)
時計カウンタ制御レジスタ (WCSR) は時計カウンタの動作と割込みを制御し , カウン
タ値を読み出します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
ISEL
WCFLG
CTR5
CTR4
CTR3
CTR2
CTR1
CTR0
属性
R/W
R/W
R
R
R
R
R
R
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] ISEL: 時計カウンタ起動および割込み要求許可ビット
このビットは時計カウンタを起動し , 時計カウンタの割込み要求と時計プリスケーラの割込み要求
を許可または禁止します。
このビットに "1" を書き込んで時計カウンタの割込み要求を許可する前に , 必ず時計プリスケーラ
の割込み要求を禁止してください。
時計カウンタは , 時計プリスケーラからの非同期クロックを使用してカウントを実行します。これ
により , ISEL ビットを "1" に設定するタイミングによっては , カウントサイクルの最初に , 最大 1 カ
ウントクロックのエラーが発生することがあります
説明
bit7
"0" を書き込んだ場合
時計カウンタを停止し , 時計カウンタの割込み要求を禁止します ( 時計プリス
ケーラの割込み要求を許可します )。
"1" を書き込んだ場合
時計カウンタを起動し , 時計カウンタの割込み要求を許可します ( 時計プリス
ケーラの割込み要求を禁止します )。
[bit6] WCFLG: 時計カウンタ割込み要求フラグビット
カウンタがアンダフローすると , このビットは "1" に設定されます。
このビットと ISEL ビットがともに "1" に設定されると , 時計カウンタ割込み要求が生成されます。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit6
"0" が読み出された場合
時計カウンタ割込み要求が生成されていないことを示します。
"1" が読み出された場合
時計カウンタ割込み要求が生成されていることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit5:0] CTR[5:0]: 時計カウンタカウンタ読出しビット
これらのビットはカウント中にカウンタ値を読み出します。
カウンタ値が変更されている間にこれらのビットの値を読み出す場合 , 正確なカウント値を読み出
せないことがあります。したがって , これらのビットが読み出すカウンタ値を使用する前に , これ
らのビットの値を二度読み出し , 二度とも同じ数値であることを確認してください。
これらのビットに値を書き込んでも動作に影響はありません。
138
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 10 章 時計カウンタ
10.6 使用上の注意
Ha rdware
10.6
Manual
使用上の注意
時計カウンタ使用上の注意を示します。
• 時計プリスケーラが時計カウンタの動作中にクリアされた場合 , 時計カウンタは通
常の動作ができないことがあります。時計プリスケーラをクリアする前に , WCSR
レジスタの ISEL ビットに "0" を書き込んで時計カウンタを停止してください。
• 時計カウンタを停止した後 , ISEL ビットに "1" を書き込んで時計カウンタを再起動
する前に , WCSR レジスタの CTR[5:0] ビットの値を 2 回読み出して , CTR[5:0] ビッ
トが "0b000000" にクリアされたことを確認してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
139
第 10 章 時計カウンタ
10.6 使用上の注意
H ard war e
140
Ma nu al
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 11 章
ワイルドレジスタ機能
ワイルドレジスタの機能と動作について説明しま
す。
11.1 概要
11.2 構成
11.3 動作説明
11.4 レジスタ
11.5 一般的なハードウェア接続例
April 4, 2014, MB95F718M_MN702-00014-3v0-J
141
第 11 章 ワイルドレジスタ機能
11.1 概要
H ard war e
11.1
Ma nu al
概要
ワイルドレジスタ機能を使うことで , 内蔵レジスタに設定したアドレスと修正データ
で , プログラムのバグにパッチをあてることができます。
ワイルドレジスタの機能について説明します。
■ ワイルドレジスタ機能
ワイルドレジスタは , 3 本のワイルドレジスタデータ設定レジスタ , 3 本のワイルドレ
ジスタアドレス設定レジスタ , 1 バイトのアドレス比較許可レジスタおよび 1 バイトの
ワイルドレジスタデータテスト設定レジスタから構成されます。これらのレジスタに
修正したいアドレスとデータを設定すると , ROM データはレジスタに設定した修正
データに置き換えることができます。最大 3 つの異なるアドレスのデータを修正できま
す。
ワイルドレジスタの機能を使用して , マスク生成後にプログラムのデバッグをするこ
とと , プログラムの不良箇所にパッチをあてることができます。
142
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 11 章 ワイルドレジスタ機能
11.2 構成
Ha rdware
Manual
構成
11.2
ワイルドレジスタのブロックダイヤグラムを示します。
ワイルドレジスタは , 以下のブ
ロックで構成されます。
• メモリ領域部
ワイルドレジスタデータ設定レジスタ (WRDR0 ~ WRDR2)
ワイルドレジスタアドレス設定レジスタ (WRAR0 ~ WRAR2)
ワイルドレジスタアドレス比較許可レジスタ (WREN)
ワイルドレジスタデータテスト設定レジスタ (WROR)
• 制御回路部
■ ワイルドレジスタ機能のブロックダイヤグラム
図 11.2-1 ワイルドレジスタ機能のブロックダイヤグラム
ワイルドレジスタ機能
制御回路部
アクセス制御回路
デコーダと
ロジック制御回路
アドレス
比較回路
メモリ領域部
内 部 バス
ワイルドレジスタ
アドレス設定レジスタ
(WRAR)
アクセス
制御回路
ワイルドレジスタ
データ設定レジスタ
(WRDR)
ワイルドレジスタ
アドレス比較許可レジスタ
(WREN)
●
●
●
ワイルドレジスタ
データテスト設定レジスタ
(WROR)
メモリ空間
April 4, 2014, MB95F718M_MN702-00014-3v0-J
143
第 11 章 ワイルドレジスタ機能
11.2 構成
H ard war e
Ma nu al
● メモリ領域部
メモリ領域部は , ワイルドレジスタデータ設定レジスタ (WRDR), ワイルドレジスタア
ドレス設定レジスタ (WRAR), ワイルドレジスタアドレス比較許可レジスタ (WREN) お
よびワイルドレジスタデータテスト設定レジスタ(WROR)より構成されます。ワイルド
レジスタ機能を使用して , 置き換えたいアドレスおよびデータを設定します。ワイルド
レジスタアドレス比較許可レジスタ (WREN) は , ワイルドレジスタデータ設定レジス
タ (WRDR) に対応するワイルドレジスタ機能を許可にします。また , ワイルドレジスタ
データテスト設定レジスタ (WROR) は , ワイルドレジスタデータ設定レジスタ (WRDR)
に対応する通常読出し機能を有効にします。
● 制御回路部
この回路は , ワイルドレジスタアドレス設定レジスタ (WRAR) に設定されているアド
レスと実際のアドレスデータとを比較します。一致している場合には , 制御回路部は ,
ワイルドレジスタデータ設定レジスタ(WRDR)からデータバスへデータを出力します。
制御回路部は , ワイルドレジスタアドレス比較許可レジスタ (WREN) により動作を制
御する回路です。
144
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 11 章 ワイルドレジスタ機能
11.3 動作説明
Ha rdware
11.3
Manual
動作説明
ワイルドレジスタ機能の設定順序について説明します。
■ ワイルドレジスタ機能の設定順序
ワイルドレジスタ機能を使用する前に , ユーザプログラム内にある , 外部メモリ ( 例え
ば , EEPROM や FRAM) からワイルドレジスタに設定する値を読み出すプログラムを準
備してください。以下に , ワイルドレジスタの設定方法を示します。
本節では , 外部メモリとデバイス間の通信方法については説明しません。
•
ワイルドレジスタアドレス設定レジスタ (WRAR0 ~ WRAR2) に , 変更する内蔵の
ROM コードのアドレスを書き込みます。
•
アドレスが書き込まれたワイルドレジスタアドレス設定レジスタに対応するワイ
ルドレジスタデータ設定レジスタ (WRDR0 ~ WRDR2) に , 新しいコードを書き込
みます。
•
ワイルドレジスタアドレス比較許可レジスタ (WREN) のワイルドレジスタ番号に対
応する EN ビットに , "1" を書き込み , ワイルドレジスタ機能を許可にします。
表 11.3-1 に , ワイルドレジスタ機能のレジスタの設定順序を示します。
表 11.3-1 ワイルドレジスタ機能のレジスタの設定手順
ステップ
動作
動作例
1
変更する内蔵 ROM コードがアドレス 0xF011 にあ
ある一定の通信方法を通じて , 外部周辺機
り , 変更するデータが 0xB5 である場合 , 変更する
能より , 置換データを読み出します。
内蔵 ROM コードは 3 つです。
2
置換アドレスをワイルドレジスタアドレ
ワイルドレジスタアドレス設定レジスタ
ス設定レジスタ (WRAR0 ~ WRAR2) へ書 (WRAR0 = 0xF011 , WRAR1 = ..., WRAR2 = ...) を設
き込みます。
定します。
3
ワイルドレジスタデータ設定レジスタ
(WRDR0 ~ WRDR2) に新しい ROM コー
ドを書き込みます ( 内蔵 ROM コードを置
き換えます )。
4
ワイルドレジスタアドレス比較許可レジ
スタ (WREN) のワイルドレジスタ番号に
対応する EN ビットを許可にします。
ワイルドレジスタデータ設定レジスタ
(WRDR0 = 0xB5 , WRDR1 = ..., WRDR2 =... ) を設定
します。
ワイルドレジスタ番号 0 のワイルドレジスタ機能を
許可するには , アドレス比較許可レジスタ (WREN)
の bit0 に "1" を設定します。もし , アドレスがワイ
ルドレジスタアドレス設定レジスタ (WRAR) に設
定されている値と一致すれば , ワイルドレジスタ
データ設定レジスタ (WRDR) の値は , 内蔵 ROM
コードに置き換えられます。複数の内蔵 ROM コー
ドを置き換える際は , それぞれの内蔵 ROM コード
に対応するワイルドレジスタアドレス比較許可レジ
スタ (WREN) の EN ビットを許可してください。
■ ワイルドレジスタ機能適用アドレス
ワイルドレジスタ機能が適用できるアドレス空間は , "0x0078" を除くすべての空間です。
アドレス "0x0078" はレジスタバンクポインタおよびダイレクトバンクポインタのミ
ラーアドレスとなっているため , このアドレスにパッチをあてることはできません。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
145
第 11 章 ワイルドレジスタ機能
11.4 レジスタ
H ard war e
Ma nu al
レジスタ
11.4
ワイルドレジスタ機能のレジスタについて説明します。
表 11.4-1
タイムベースタイマのレジスタ一覧
レジスタ略称
レジスタ名
参照先
WRDR0
ワイルドレジスタデータ設定レジスタ 0
11.4.1
WRDR1
ワイルドレジスタデータ設定レジスタ 1
11.4.1
WRDR2
ワイルドレジスタデータ設定レジスタ 2
11.4.1
WRAR0
ワイルドレジスタアドレス設定レジスタ 0
11.4.2
WRAR1
ワイルドレジスタアドレス設定レジスタ 1
11.4.2
WRAR2
ワイルドレジスタアドレス設定レジスタ 2
11.4.2
WREN
ワイルドレジスタアドレス比較許可レジスタ
11.4.3
WROR
ワイルドレジスタデータテスト設定レジスタ
11.4.4
■ ワイルドレジスタ番号
ワイルドレジスタ番号は , 各ワイルドレジスタアドレス設定レジスタ (WRAR) および
各ワイルドレジスタデータ設定レジスタ (WRDR) に割当てられます。
表 11.4-2 ワイルドレジスタアドレス設定レジスタおよびワイルドレジスタデータ設定レジスタに
対応するワイルドレジスタ番号
146
ワイルドレジスタ番号
ワイルドレジスタアドレス設定レジスタ
(WRAR)
ワイルドレジスタデータ設定レジスタ
(WRDR)
0
WRAR0
WRDR0
1
WRAR1
WRDR1
2
WRAR2
WRDR2
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 11 章 ワイルドレジスタ機能
11.4 レジスタ
Ha rdware
11.4.1
Manual
ワイルドレジスタデータ設定レジスタ
(WRDR0 ~ WRDR2)
ワイルドレジスタデータ設定レジスタ (WRDR0 ~ WRDR2) を使用して , ワイルドレ
ジスタ機能により修正するデータを指定します。
■ レジスタ構成
WRDR0
bit
7
6
5
4
3
2
1
0
Field
RD7
RD6
RD5
RD4
RD3
RD2
RD1
RD0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
WRDR1
bit
7
6
5
4
3
2
1
0
Field
RD7
RD6
RD5
RD4
RD3
RD2
RD1
RD0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
WRDR2
bit
7
6
5
4
3
2
1
0
Field
RD7
RD6
RD5
RD4
RD3
RD2
RD1
RD0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7:0] RD[7:0]: ワイルドレジスタデータ設定ビット
これらのビットはワイルドレジスタ機能により修正されるデータを指定します。
これらのビットを使い , ワイルドレジスタアドレス設定レジスタ (WRAR) で割り当てられたアドレ
スに修正データを設定します。それぞれのワイルドレジスタ番号に対応したアドレスにてデータが
有効になります。
これらのビットの読出しは , ワイルドレジスタデータテスト設定レジスタ (WROR) で対応するデー
タテスト設定ビットを "1" に設定した場合のみ許可となります。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
147
第 11 章 ワイルドレジスタ機能
11.4 レジスタ
H ard war e
11.4.2
Ma nu al
ワイルドレジスタアドレス設定レジスタ
(WRAR0 ~ WRAR2)
ワイルドレジスタアドレス設定レジスタ (WRAR0 ~ WRAR2) を使用して , ワイルド
レジスタ機能により修正するアドレスを設定します。
■ レジスタ構成
WRAR0
bit
15
14
13
12
11
10
9
8
Field
RA15
RA14
RA13
RA12
RA11
RA10
RA9
RA8
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
bit
7
6
5
4
3
2
1
0
Field
RA7
RA6
RA5
RA4
RA3
RA2
RA1
RA0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
bit
15
14
13
12
11
10
9
8
Field
RA15
RA14
RA13
RA12
RA11
RA10
RA9
RA8
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
WRAR1
bit
7
6
5
4
3
2
1
0
Field
RA7
RA6
RA5
RA4
RA3
RA2
RA1
RA0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
WRAR2
bit
15
14
13
12
11
10
9
8
Field
RA15
RA14
RA13
RA12
RA11
RA10
RA9
RA8
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
bit
7
6
5
4
3
2
1
0
Field
RA7
RA6
RA5
RA4
RA3
RA2
RA1
RA0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ動作
[bit15:0] RA[15:0]: ワイルドレジスタアドレス設定ビット
これらのビットはワイルドレジスタ機能により修正するアドレスを設定します。
修正データに割り当てられたアドレスを設定します。アドレスは , ワイルドレジスタアドレス設定
レジスタに対応するワイルドレジスタ番号に従って設定されます。
148
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 11 章 ワイルドレジスタ機能
11.4 レジスタ
Ha rdware
11.4.3
Manual
ワイルドレジスタアドレス比較許可レジスタ
(WREN)
ワイルドレジスタアドレス比較許可レジスタ (WREN) は , それぞれのワイルドレジス
タ番号に対応して , ワイルドレジスタ機能の動作を許可または禁止します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
予約
予約
予約
EN2
EN1
EN0
属性
—
—
W
W
W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7:6] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit5:3] 予約ビット
これらのビットは常に "0" に設定してください。
[bit2:0] EN[2:0]: ワイルドレジスタアドレス比較許可ビット
これらのビットはワイルドレジスタの動作を許可または禁止します。
• EN0 はワイルドレジスタ番号 0 に対応します。
• EN1 はワイルドレジスタ番号 1 に対応します。
• EN2 はワイルドレジスタ番号 2 に対応します。
説明
bit2/bit1/bit0
"0" を書き込んだ場合
ワイルドレジスタ機能の動作を禁止します。
"1" を書き込んだ場合
ワイルドレジスタ機能の動作を許可します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
149
第 11 章 ワイルドレジスタ機能
11.4 レジスタ
H ard war e
11.4.4
Ma nu al
ワイルドレジスタデータテスト設定レジスタ
(WROR)
ワイルドレジスタデータテスト設定レジスタ (WROR) は , 対応するワイルドレジスタ
データ設定レジスタ(WRDR0~WRDR2)より読出しデータを許可または禁止します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
予約
予約
予約
DRR2
DRR1
DRR2
属性
—
—
W
W
W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7:6] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit5:3] 予約ビット
これらのビットは常に "0" に設定してください。
[bit2:0] DRR[2:0]: ワイルドレジスタデータテスト設定ビット
これらのビットは対応するワイルドレジスタデータ設定レジスタからの読出しを許可または禁止
します。
• DRR0 はワイルドレジスタ番号 0 に対応します。
• DRR1 はワイルドレジスタ番号 1 に対応します。
• DRR2 はワイルドレジスタ番号 2 に対応します。
bit2/bit1/bit0
150
説明
"0" を書き込んだ場合
ワイルドレジスタデータ設定レジスタからの読出しを禁止します。
"1" を書き込んだ場合
ワイルドレジスタデータ設定レジスタからの読出しを許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 11 章 ワイルドレジスタ機能
11.5 一般的なハードウェア接続例
Ha rdware
11.5
Manual
一般的なハードウェア接続例
以下に , ワイルドレジスタ機能を使用するときのハードウェア間の一般的な接続につ
いて例示します。
■ ハードウェア接続例
図 11.5-1 一般的なハードウェア接続例
EEPROM
(修正プログラム格納)
MCU
SO
UI0
SI
UO0
SCK
April 4, 2014, MB95F718M_MN702-00014-3v0-J
UCK0
151
第 11 章 ワイルドレジスタ機能
11.5 一般的なハードウェア接続例
H ard war e
152
Ma nu al
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 12 章
8/16 ビット複合タイマ
8/16 ビット複合タイマの機能と動作について説明
します。
12.1 概要
12.2 構成
12.3 チャネル
12.4 端子
12.5 割込み
12.6 インターバルタイマ機能 ( ワンショットモード ) の動
作説明
12.7 インターバルタイマ機能 ( 連続モード ) の動作説明
12.8 インターバルタイマ機能 ( フリーランモード ) の動作
説明
12.9 PWM タイマ機能 ( 周期固定モード ) の動作説明
12.10 PWM タイマ機能 ( 周期可変モード ) の動作説明
12.11 PWC タイマ機能の動作説明
12.12 インプットキャプチャ機能の動作説明
12.13 ノイズフィルタの動作説明
12.14 レジスタ
12.15 使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
153
第 12 章 8/16 ビット複合タイマ
12.1 概要
H ard war e
12.1
Ma nu al
概要
8/16 ビット複合タイマは , 2 つの 8 ビットカウンタで構成されます。2 つの 8 ビット
タイマとして , 2 つのカウンタをカスケード接続して 1 つの 16 ビットタイマとしても
使用できます。
8/16 ビット複合タイマには , 以下の機能があります。
• インターバルタイマ機能
• PWM タイマ機能
• PWC タイマ機能 ( パルス幅測定 )
• インプットキャプチャ機能
■ インターバルタイマ機能 ( ワンショットモード )
インターバルタイマ機能 ( ワンショットモード ) が選択されると , タイマが起動した時
点でカウンタは "0x00" からカウント動作を開始します。カウンタの値が 8/16 ビット複
合タイマデータレジスタの値と一致すると , タイマ出力が反転し , 割込み要求が発生し
て , カウント動作が停止します。
■ インターバルタイマ機能 ( 連続モード )
インターバルタイマ機能 ( 連続モード ) が選択されると , タイマが起動した時点でカウ
ンタは "0x00" からカウント動作を開始します。カウンタの値が 8/16 ビット複合タイマ
データレジスタの値と一致すると , タイマ出力が反転し , 割込み要求が発生して , カウ
ンタは再び "0x00" からカウントします。この連続動作の結果 , タイマは方形波を出力
します。
■ インターバルタイマ機能 ( フリーランモード )
インターバルタイマ機能 ( フリーランモード ) が選択されると , カウンタは "0x00" から
カウント動作を開始します。カウンタの値が 8/16 ビット複合タイマデータレジスタの
値と一致すると , タイマ出力が反転し , 割込み要求が発生します。このような条件下で ,
カウント動作を継続し , カウント値が "0xFF" に達すると , 再度 "0x00" からカウント動
作を開始します。この連続動作の結果 , タイマは方形波を出力します。
■ PWM タイマ機能 ( 周期固定モード )
PWM タイマ機能 ( 周期固定モード ) が選択されると , 周期固定で "H" パルス幅可変の
PWM 信号が生成されます。この周期は , 8 ビット動作モードでは "0xFF" に , 16 ビット
動作モードでは "0xFFFF" に固定されます。カウントクロックを選択することによって
時間が決定されます。"H" パルス幅はレジスタを設定して指定します。
■ PWM タイマ機能 ( 周期可変モード )
PWM タイマ機能 ( 周期可変モード ) が選択されると , 2 つの 8 ビットカウンタを使用
して , 周期と "L" パルス幅をレジスタで指定することにより , 任意の周期とデューティ
の 8 ビット PWM 信号を生成します。
この動作モードでは , 2 つの 8 ビットカウンタが別々に使用されるため , 複合タイマは
16 ビットカウンタとして動作できません。
154
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.1 概要
Ha rdware
Manual
■ PWC タイマ機能
PWC タイマ機能が選択されると , 外部入力パルスの幅および周期を測定できます。
この動作モードでは , 外部入力信号のカウント開始エッジを検出した直後に , カウンタ
は "0x00" からカウント動作を開始します。
この後 , カウント終了エッジが検出されると ,
カウンタは , カウント値をレジスタに転送し , 割込みを発生させます。
■ インプットキャプチャ機能
インプットキャプチャ機能が選択されると , 外部入力信号のエッジを検出した直後に ,
カウンタ値をレジスタに格納します。
この機能には , カウント動作にフリーランモードとクリアモードがあります。
クリアモードでは , カウンタは "0x00" からカウント動作を開始し , エッジを検出すると ,
カウンタの値をレジスタに転送して割込みを発生させます。その後 , カウンタは "0x00"
からカウントを再開します。
フリーランモードでは , カウンタはエッジを検出した時点で , カウンタ値をレジスタに
転送して割込みを発生させます。この後 , クリアモードの場合とは異なり , カウンタは ,
"0x00" にクリアすることなく , そのままカウント動作を継続します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
155
第 12 章 8/16 ビット複合タイマ
12.2 構成
H ard war e
12.2
Ma nu al
構成
8/16 ビット複合タイマは , 以下のブロックで構成されます。
• 8 ビットカウンタ
• 8 ビットコンパレータ ( テンポラリラッチを含む )
• 8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR)
• 8/16 ビット複合タイマステータス制御レジスタ 0 (Tn0CR0/Tn1CR0)
• 8/16 ビット複合タイマステータス制御レジスタ 1 (Tn0CR1/Tn1CR1)
• 8/16 ビット複合タイマタイマモード制御レジスタ (TMCRn)
• アウトプットコントローラ
• 制御ロジック
• カウントクロックセレクタ
• エッジ検出器
• ノイズフィルタ
品種により , 8/16 ビット複合タイマの端子数およびチャネル数は異なります。詳細は ,
デバイスのデータシートを参照してください。
本章において , 端子名とレジスタ略称にある "n" はチャネル番号を示します。各品種の
端子名 , レジスタ名とレジスタ略称について , デバイスのデータシートを参照してくだ
さい。
156
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.2 構成
Ha rdware
Manual
■ 8/16 ビット複合タイマのブロックダイヤグラム
図 12.2-1 8/16 ビット複合タイマのブロックダイヤグラム
Tn0CR0 IFE C2 C1 C0 F3 F2 F1 F0
タイマn0
CK00
8ビットカウンタ
:
:
カウント
クロック
セレクタ
タイマ出力
制御回路部
プリスケーラ/
:
タイムベースタイマ :
からのクロック CK06
CK07
8ビットコンパレータ
TOn0
出力
コントローラ
ENn0
8ビットデータレジスタ
エッジ
検出器
ノイズ
フィルタ
ECn0
STA HO IE IR BF IF SO OE
Tn0CR1
TMCRn
TO1
TO0
TIS
MOD
IRQXX
16ビットモード制御信号
FE11 FE10 FE01 FE00
Tn1CR0 IFE C2 C1 C0 F3 F2 F1 F0
ECn
IRQXX
IRQ
回路部
タイマn1
16ビット
モードクロック
8ビットカウンタ
:
:
カウント
クロック
セレクタ
制御回路部
CK10
プリスケーラ/ :
タイムベース :
タイマ
CK16
からの
クロック
CK17
タイマ出力
8ビットコンパレータ
出力
コントローラ
TOn1
ENn1
8ビットデータレジスタ
外部入力
ノイズ
フィルタ
ECn1
エッジ
検出器
Tn1CR1 STA HO IE IR BF IF SO OE
● 8 ビットカウンタ
各種タイマ動作の基本となるカウンタです。2 つの 8 ビットカウンタとしてまたは 1 つ
の 16 ビットカウンタとして使用できます。
● 8 ビットコンパレータ
8/16 ビット複合タイマデータレジスタの値とカウンタの値を比較するコンパレータで
す。8/16 ビット複合タイマデータレジスタの値を一時的に格納するラッチを内蔵して
います。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
157
第 12 章 8/16 ビット複合タイマ
12.2 構成
H ard war e
Ma nu al
● 8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR)
このレジスタは , インターバルタイマ動作または PWM タイマ動作時にカウントされた
最大値の書込みおよびPWCタイマ動作またはインプットキャプチャ動作時のカウント
値の読出しを行います。
● 8/16 ビット複合タイマステータス制御レジスタ 0 (Tn0CR0/Tn1CR0)
タイマ動作モードの選択や , カウントクロックの選択および IF フラグ割込みの許可ま
たは禁止を行うレジスタです。
● 8/16 ビット複合タイマステータス制御レジスタ 1 (Tn0CR1/Tn1CR1)
割込みフラグの制御 , タイマ出力の制御およびタイマ動作の制御を行うレジスタです。
● 8/16 ビット複合タイマタイマモード制御レジスタ (TMCRn)
ノイズフィルタ機能の選択 , 8 ビットまたは 16 ビット動作モードの選択 , タイマ n0/n1
への信号入力の選択およびタイマ出力値の表示を行うレジスタです。
● アウトプットコントローラ
このアウトプットコントローラは , タイマ出力を制御します。端子出力が許可されてい
るとき , タイマ出力は外部端子に出力されます。
● 制御回路部
この制御回路部は , タイマ動作を制御します。
● カウントクロックセレクタ
このセレクタは , カウンタの動作クロック信号をプリスケーラの出力信号 ( マシンク
ロックの分周信号およびタイムベースタイマの出力信号 ) から選択します。
● エッジ検出器
エッジ検出器は , PWC タイマ動作やインプットキャプチャ動作時のイベントとして使
用される外部入力信号のエッジを選択します。
● ノイズフィルタ
このフィルタは , 外部入力信号のノイズフィルタとして動作します。"H" パルスノイズ
除去 , "L" パルスノイズ除去または "H"/"L" パルスノイズ除去から選択できます。
■ 入力クロック
8/16 ビット複合タイマは , プリスケーラからの出力クロックを入力クロック ( カウント
クロック ) として使用します。
158
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.3 チャネル
Ha rdware
12.3
Manual
チャネル
8/16 ビット複合タイマのチャネルについて説明します。
■ 8/16 ビット複合タイマのチャネル
1 チャネル内には , 8 ビットカウンタが 2 つあり , それらは 2 つの 8 ビットタイマとし
てまたは 1 つの 16 ビットタイマとしても使用できます。
表 12.3-1 に , チャネルの外部端子を示します。
表 12.3-1 チャネルの外部端子
端子名
端子機能
TOn0
タイマ n0 出力
TOn1
タイマ n1 出力
ECn
タイマ n0 入力およびタイマ n1 入力
April 4, 2014, MB95F718M_MN702-00014-3v0-J
159
第 12 章 8/16 ビット複合タイマ
12.4 端子
H ard war e
12.4
Ma nu al
端子
8/16 ビット複合タイマの端子について説明します。
■ 8/16 ビット複合タイマの端子
8/16 ビット複合タイマの外部端子は , TOn0, TOn1, ECn です。
● TOn0 端子
TOn0:
この端子は , 8 ビット動作時には , タイマ n0 のタイマ出力端子として , また 16 ビッ
ト動作時にはタイマ n0 とタイマ n1 のタイマ出力端子として機能します。インター
バルタイマ機能時 , PWM タイマ機能時または PWC タイマ機能時に出力を許可
(Tn0CR1:OE = 1) されているときには , ポート方向レジスタ (DDR) の設定に関係なく
自動的に出力端子となり , タイマ出力 TOn0 端子として機能します。
インプットキャプチャ機能の使用時に出力が許可されると , 出力は不定となります。
● TOn1 端子
TOn1:
この端子は , 8 ビット動作時のタイマ n1 のタイマ出力端子になります。インターバ
ルタイマ機能時 , PWM タイマ機能 ( 周期固定モード ) 時または PWC タイマ機能時に
出力を許可 (Tn1CR1:OE = 1) すると , ポート方向レジスタ (DDR) の設定に関係なく
自動的に出力端子となり , タイマ出力 TOn1 端子として機能します。
16ビット動作時は, PWMタイマ機能 (周期可変モード) またはインプットキャプチャ
機能の使用時に出力を許可すると , 出力は不定となります。
● ECn 端子
ECn 端子は , ECn0 内部端子および ECn1 内部端子に接続しています。
ECn0 内部端子 :
この端子は , インターバルタイマ機能または PWM タイマ機能が選択されている時に
は , タイマ n0 の外部カウントクロック入力端子として機能し , PWC タイマ機能また
はインプットキャプチャ機能が選択されているときには , タイマ n0 の信号入力端子
として機能します。PWC タイマ機能またはインプットキャプチャ機能が選択されて
いるときには , 外部カウントクロック入力端子として設定できません。
この入力機能を使用するときには, ECn端子に対応するポート方向レジスタのビット
を "0" に設定して , 入力ポートにしてくでさい。
ECn1 内部端子 :
この端子は , インターバルタイマ機能または PWM タイマ機能が選択されている時に
は , タイマ n1 の外部カウントクロック入力端子として機能し , PWC タイマ機能また
はインプットキャプチャ機能が選択されている時には , タイマ n1 の信号入力端子と
して機能します。PWC タイマ機能またはインプットキャプチャ機能が選択されてい
るときには , 外部カウントクロック入力端子として設定できません。
160
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.4 端子
Ha rdware
Manual
16 ビット動作時には , この端子の入力機能は使用されません。PWM タイマ機能 ( 周
期可変モード ) が選択されているときには , この端子の入力機能は使用可能です。
この入力機能を使用するときには, ECn端子に対応するポート方向レジスタのビット
を "0" に設定して , 入力ポートにしてください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
161
第 12 章 8/16 ビット複合タイマ
12.5 割込み
H ard war e
12.5
Ma nu al
割込み
8/16 ビット複合タイマは , 以下の割込みを発生します。それぞれの割込みには , 割込
み番号と割込みベクタが割り当てられます。
• タイマ n0 割込み
• タイマ n1 割込み
■ タイマ n0 の割込み
表 12.5-1 に , タイマ n0 の割込みおよびその要因を示します。
表 12.5-1 タイマ n0 の割込み
項目
説明
割込み発生の要因 インターバルタイマ動
作または PWM タイマ動
作 ( 周期可変モード ) の
ときの比較一致
Tn0CR1:IF
割込みフラグ
割込み許可
Tn0CR1:IE と
Tn0CR0:IFE
PWC タイマ動作または
インプットキャプチャ
動作のときのオーバフ
ロー
PWC タイマ動作のとき
の測定完了またはイン
プットキャプチャ動作
のときのエッジ検出
Tn0CR1:IF
Tn0CR1:IR
Tn0CR1:IE と
Tn0CR0:IFE
Tn0CR1:IE
■ タイマ n1 の割込み
表 12.5-2 に , タイマ n1 の割込みおよびその要因を示します。
表 12.5-2 タイマ n1 の割込み
項目
説明
割込み発生の要因 インターバルタイマ動
作または PWM タイマ動
作 ( 周期可変モード ) の
ときの比較一致。16
ビット動作時を除く。
Tn1CR1:IF
割込みフラグ
割込み許可
162
Tn1CR1:IE と
Tn1CR0:IFE
PWC タイマ動作または
インプットキャプチャ
動作のときのオーバフ
ロー。16 ビット動作時
を除く。
PWC タイマ動作のとき
の測定完了またはイン
プットキャプチャ動作
のときのエッジ検出。
16 ビット動作時を除く。
Tn1CR1:IF
Tn1CR1:IR
Tn1CR1:IE と
Tn1CR0:IFE
Tn1CR1:IE
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.6 インターバルタイマ機能 ( ワンショットモード ) の動作説
明
Ha rdware
12.6
Manual
インターバルタイマ機能 ( ワンショットモード ) の動作
説明
8/16 ビット複合タイマのインターバルタイマ機能 ( ワンショットモード ) の動作を説
明します。
■ インターバルタイマ機能 ( ワンショットモード ) の動作
インターバルタイマ機能 ( ワンショットモード ) として動作させるには , 図 12.6-1 に示
された設定をしてください。
図 12.6-1 インターバルタイマ機能 ( ワンショットモード ) の設定
Tn0CR0/Tn1CR0
Tn0CR1/Tn1CR1
TMCRn
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
IFE
C2
C1
C0
F3
F2
F1
F0
❍
❍
❍
❍
0
0
0
0
STA
HO
IE
IR
BF
IF
SO
OE
1
❍
❍
×
×
❍
❍
❍
TO1
TO0
TIS
MOD
FE11
FE10
FE01
FE00
❍
❍
×
❍
❍
❍
❍
❍
インターバル時間 ( カウンタコンペア値 )
Tn0DR/Tn1DR
❍: 使用ビット
×: 未使用ビット
1: "1" に設定
0: "0" に設定
インターバルタイマ機能 ( ワンショットモード ) では , タイマ動作を許可 (Tn0CR1/
Tn1CR1:STA=1) すると , 選択されたカウントクロック信号の立上りエッジでカウンタ
が "0x00" からカウント動作を開始します。カウンタの値が 8/16 ビット複合タイマデー
タレジスタ (Tn0DR/Tn1DR) の値と一致すると , タイマ出力 (TMCRn:TO0/TO1) が反転
して , 割込みフラグ (Tn0CR1/Tn1CR1:IF) が "1" に , タイマ動作許可ビット (Tn0CR1/
Tn1CR1: STA) が "0" になり , カウント動作が停止します。
8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) の値は , カウント動作開始時に
コンパレータ内部の一時格納用のラッチ ( 比較データ格納用ラッチ ) に転送されます。
8/16 ビット複合タイマデータレジスタに "0x00" を書き込まないでください。
図 12.6-2 に , 8 ビット動作時のインターバルタイマ機能の動作を示します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
163
第 12 章 8/16 ビット複合タイマ
12.6 インターバルタイマ機能 ( ワンショットモード ) の動作説
明
H ard war e
Ma nu al
図 12.6-2 8 ビット動作時のインターバルタイマ機能 ( ワンショットモード ) の動作
カウンタ値
0xFF
0x80
0x00
時間
Tn0DR/Tn1DR値
(0xFF)
タイマサイクル
Tn0DR/Tn1DR値変更(0xFF→0x80)*
プログラムにより
クリア
IFビット
STAビット
自動的にクリア
反転
再起動
自動的にクリア 再起動
出力初期値の変更なし(“0”)に再起動する
タイマ出力端子
初期値“1”で起動
*: Tn0DR/Tn1DRデータレジスタ値が動作中に変更された場合,新しい値が次のアクティブサイクルから使用されます。
164
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.7 インターバルタイマ機能 ( 連続モード ) の動作説明
Ha rdware
12.7
Manual
インターバルタイマ機能 ( 連続モード ) の動作説明
8/16 ビット複合タイマのインターバルタイマ機能 ( 連続モード ) を説明します。
■ インターバルタイマ機能 ( 連続モード ) の動作
インターバルタイマ機能 ( 連続モード ) として動作させるには , 図 12.7-1 に示された設
定をしてください。
図 12.7-1 インターバルタイマ機能 ( 連続モード ) の設定
Tn0CR0/Tn1CR0
Tn0CR1/Tn1CR1
TMCRn
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
IFE
C2
C1
C0
F3
F2
F1
F0
❍
❍
❍
❍
0
0
0
1
STA
HO
IE
IR
BF
IF
SO
OE
1
❍
❍
×
×
❍
❍
❍
TO1
TO0
TIS
MOD
FE11
FE10
FE01
FE00
❍
❍
×
❍
❍
❍
❍
❍
インターバル時間 ( カウンタコンペア値 )
Tn0DR/Tn1DR
❍: 使用ビット
×: 未使用ビット
1: "1" に設定
0: "0" に設定
インターバルタイマ機能 ( 連続モード ) では , タイマ動作を許可 (Tn0CR1/Tn1CR1:STA = 1)
すると , 選択されたカウントクロック信号の立上りエッジでカウンタが "0x00" からカ
ウント動作を開始します。カウンタの値が 8/16 ビット複合タイマデータレジスタ
(Tn0DR/Tn1DR) の値と一致すると , タイマ出力ビット (TMCRn:TO0/TO1) が反転し , 割
込みフラグ (Tn0CR1/Tn1CR1:IF) が "1" になり , カウンタは "0x00" に戻り再びカウント
動作を開始します。この連続動作の結果 , タイマは方形波を出力します。
8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) の値は , カウント動作を開始し
たときまたはカウンタ値の比較一致を検出したときに , コンパレータ内部の一時格納
用のラッチ ( 比較データ格納用ラッチ ) に転送されます。8/16 ビット複合タイマデータ
レジスタに "0x00" を書き込まないでください。
タイマ動作を停止すると, タイマ出力ビット (TMCRn:TO0/TO1) は最後の値を保持しま
す。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
165
第 12 章 8/16 ビット複合タイマ
12.7 インターバルタイマ機能 ( 連続モード ) の動作説明
H ard war e
Ma nu al
図 12.7-2 インターバルタイマ機能 ( 連続モード ) の動作図
コンペア値
コンペア値(0xE0)
コンペア値(0xFF)
コンペア値(0x80)
0xFF
0xE0
0x80
0x00
時間
Tn0DR/Tn1DR Tn0DR/Tn1DR値変更
Tn0DR/Tn1TDR値(0xE0)
値変更
(0xFF→0x80)*1
(0xE0→0xFF)*1 プログラムによるクリア
IFビット
STAビット
起動
一致
一致
一致
一致
一致
カウンタクリア*2
タイマ出力端子
*1: Tn0DR/Tn1DRデータレジスタ値が動作中に変更された場合, 新しい値が次のアクティブサイクルから使用されます。
*2: 動作中に一致が検出されるとカウンタはクリアされ, データレジスタの設定が比較データラッチにロードされます。
166
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.8 インターバルタイマ機能 ( フリーランモード ) の動作説明
Ha rdware
12.8
Manual
インターバルタイマ機能 ( フリーランモード ) の動作説
明
8/16 ビット複合タイマのインターバルタイマ機能 ( フリーランモード ) の動作を説明
します。
■ インターバルタイマ機能 ( フリーランモード ) の動作
インターバルタイマ機能 ( フリーランモード ) として動作させるには , 図 12.8-1 に示さ
れた設定をしてください。
図 12.8-1 インターバルタイマ機能 ( フリーランモード ) の設定
Tn0CR0/Tn1CR0
Tn0CR1/Tn1CR1
TMCRn
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
IFE
C2
C1
C0
F3
F2
F1
F0
❍
❍
❍
❍
0
0
1
0
STA
HO
IE
IR
BF
IF
SO
OE
1
❍
❍
×
×
❍
❍
❍
TO1
TO0
TIS
MOD
FE11
FE10
FE01
FE00
❍
❍
×
❍
❍
❍
❍
❍
インターバル時間 ( カウンタコンペア値 )
Tn0DR/Tn1DR
❍: 使用ビット
×: 未使用ビット
1: "1" を設定
0: "0" を設定
インターバルタイマ機能 ( フリーランモード ) では , タイマ動作を許可 (Tn0CR1/
Tn1CR1:STA = 1) すると , 選択されたカウントクロック信号の立上りエッジでカウンタ
が "0x00" からカウント動作を開始します。カウンタの値が 8/16 ビット複合タイマデー
タレジスタ (Tn0DR/Tn1DR) の値と一致すると , タイマ出力ビット (TMCRn:TO0/TO1)
が反転して割込みフラグ (Tn0CR1/Tn1CR1:IF) が "1" になります。上記の設定でカウン
ト動作を継続し , カウント値が "0xFF" に達すると , カウンタは再度 "0x00" からカウン
ト動作を継続します。この連続動作の結果 , タイマは方形波を出力します。
8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) の値は , カウンタがカウント動
作を開始したときまたはカウンタ値の比較一致を検出したときに , コンパレータ内部
の一時格納用のラッチ ( 比較データ格納用ラッチ ) に転送されます。8/16 ビット複合タ
イマデータレジスタに "0x00" を書き込まないでください。
タイマ動作を停止すると, タイマ出力ビット (TMCRn:TO0/TO1) は最後の値を保持しま
す。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
167
第 12 章 8/16 ビット複合タイマ
12.8 インターバルタイマ機能 ( フリーランモード ) の動作説明
H ard war e
Ma nu al
図 12.8-2 インターバルタイマ機能 ( フリーランモード ) の動作図
(0xE0)
カウンタ値
0xFF
0xE0
0x80
0x00
時間
Tn0DR/Tn1DR値(0xE0)
プログラムによるクリア
IFビット
STAビット
起動
一致
一致
一致
一致
カウンタ値一致*
タイマ出力端子
*: 動作中に一致が検出されても, カウンタはクリアされません。データレジスタの設定は比較データラッチにリロードされます。
168
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.9 PWM タイマ機能 ( 周期固定モード ) の動作説明
Ha rdware
12.9
Manual
PWM タイマ機能 ( 周期固定モード ) の動作説明
8/16 ビット複合タイマの PWM タイマ機能 ( 周期固定モード ) の動作を説明します。
■ PWM タイマ機能 ( 周期固定モード ) の動作
PWM タイマ機能 ( 周期固定モード ) として動作させるには , 図 12.9-1 に示された設定
をしてください。
図 12.9-1 PWM タイマ機能 ( 周期固定モード ) の設定
Tn0CR0/Tn1CR0
Tn0CR1/Tn1CR1
TMCRn
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
IFE
C2
C1
C0
F3
F2
F1
F0
×
❍
❍
❍
0
0
1
1
STA
HO
IE
IR
BF
IF
SO
OE
1
❍
×
×
×
×
×
×
TO1
TO0
TIS
MOD
FE11
FE10
FE01
FE00
❍
❍
×
❍
❍
❍
❍
❍
"H" パルス幅 ( コンペア値 ) の設定
Tn0DR/Tn1DR
❍: 使用ビット
×: 未使用ビット
1: "1" を設定
0: "0" を設定
PWM タイマ機能 ( 周期固定モード ) では , 周期固定で "H" パルス幅可変 PWM 信号を
タイマ出力端子 (TOn0/TOn1) から出力します。この周期は , 8 ビット動作モードでは
"0xFF", 16 ビット動作モードでは "0xFFFF" に固定されます。選択したカウントクロッ
クにより時間が決定されます。"H" パルス幅は 8/16 ビット複合タイマデータレジスタ
(Tn0DR/Tn1DR) の値で指定してください。
この機能は割込みフラグ (Tn0CR1/Tn1CR1:IF) には影響しません。また , 各周期は常に
"H" パルス出力から開始するため , タイマ出力初期値設定ビット (Tn0CR1/Tn1CR1:SO)
は動作に影響を与えません。
8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) の値は , カウンタがカウント動
作を開始したときまたはカウンタ値の比較一致を検出したときに , コンパレータ内部
の一時格納用のラッチ ( 比較データ格納用ラッチ ) に転送されます。
タイマ動作を停止すると, タイマ出力ビット (TMCRn:TO0/TO1) は最後の値を保持しま
す。
タイマ起動 (STA ビットに "1" を書き込む ) 直後の出力波形では , "H" パルスが , Tn0DR/
Tn1DR レジスタの設定値よりも , 1 カウントクロック少なくなります。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
169
第 12 章 8/16 ビット複合タイマ
12.9 PWM タイマ機能 ( 周期固定モード ) の動作説明
H ard war e
Ma nu al
図 12.9-2 PWM タイマ機能 ( 周期固定モード ) の動作図
Tn0DR/Tn1DR レジスタ値 : "0x00" (デューティ比 = 0%)
カウンタ値
PWM 波形
0x00
0xFF, 0x00
"H"
"L"
Tn0DR/Tn1DR レジスタ値 : "0x80" (デューティ比 = 50%)
カウンタ値
PWM 波形
0x00
0x80
0xFF, 0x00
"H"
"L"
Tn0DR/Tn1DR レジスタ値 : "0xFF" (デューティ比 = 99.6%)
カウンタ値
0x00
0xFF, 0x00
"H"
PWM 波形
"L"
1カウント幅
(注意事項) PWM機能が選択されているとき, タイマ出力端子はカウンタが停止した時点(Tn0CR1/Tn1CR1:STA=0)のレベルを維持します。
170
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.10 PWM タイマ機能 ( 周期可変モード ) の動作説明
Ha rdware
12.10
Manual
PWM タイマ機能 ( 周期可変モード ) の動作説明
8/16 ビット複合タイマの PWM タイマ機能 ( 周期可変モード ) の動作を説明します。
■ PWM タイマ機能 ( 周期可変モード ) の動作
PWM タイマ機能 ( 周期可変モード ) として動作させるには , 図 12.10-1 に示された設定
をしてください。
図 12.10-1 PWM タイマ機能 ( 周期可変モード ) の設定
Tn0CR0/Tn1CR0
Tn0CR1/Tn1CR1
TMCRn
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
IFE
C2
C1
C0
F3
F2
F1
F0
❍
❍
❍
❍
0
1
0
0
STA
HO
IE
IR
BF
IF
SO
OE
1
❍
❍
×
×
❍
×
×
TO1
TO0
TIS
MOD
FE11
FE10
FE01
FE00
❍
❍
×
×
❍
❍
❍
❍
Tn0DR
"L" パルス幅 ( コンペア値 ) を指定
Tn1DR
PWM 波形 の周期 ( コンペア値 ) を指定
❍: 使用ビット
×: 未使用ビット
1: "1" を設定
0: "0" を設定
PWM タイマ機能 ( 周期可変モード ) では , タイマ n0 とタイマ n1 の両方を使用します。
任意の周期と任意のデューティとの PWM 信号がタイマ出力端子 (TOn0) から出力され
ます。8/16 ビット複合タイマ n1 データレジスタ (Tn1DR) で周期を指定して , 8/16 ビッ
ト複合タイマ n0 データレジスタ (Tn0DR) で "L" パルス幅時間を指定してください。
この機能では , 2 つの 8 ビットカウンタを使用するため , 複合タイマは 16 ビットカウン
タを構成できません。
タイマ動作を許可 (Tn0CR1/Tn1CR1:STA = 1) すると , モードビット (TMCRn:MOD) は
"0" になります。また , 最初の周期は常に "L" パルス出力から開始するため , タイマ初
期値設定ビット (Tn0CR1/Tn1CR1:SO) は動作に影響を与えません。
割込みフラグ (Tn0CR1/Tn1CR1:IF) は , その割込みフラグに対応する 8 ビットカウンタ
が , 8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) の値と一致したときに設定
されます。
8/16 ビット複合タイマデータレジスタの値はカウンタがカウント動作を開始したとき
またはそれぞれのカウンタ値の比較一致を検出したときに , コンパレータ内部の一時
格納用のラッチ ( 比較データ格納用ラッチ ) に転送されます。
"L" パルス幅の設定値が周期の設定値より大きい場合は "H" は出力されません。
カウントクロックの選択は , タイマ n0 とタイマ n1 の両方に対してそれぞれ行ってくだ
さい。この際 , 2 つのタイマに対し異なるカウントクロックを選択することは禁止され
ます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
171
第 12 章 8/16 ビット複合タイマ
12.10 PWM タイマ機能 ( 周期可変モード ) の動作説明
H ard war e
Ma nu al
タイマ動作を停止したとき , タイマ出力ビット (TMCRn:TO0) は最後の出力値を保持し
ます。
動作中に 8/16 ビット複合タイマデータレジスタを書き換えた場合 , 書き込まれたデー
タは同期一致が検出された次のサイクルより有効となります。
図 12.10-2 PWM タイマ機能 ( 周期可変モード ) の動作図
Tn0DR レジスタ値 : "0x80", Tn1DR レジスタ値 : "0x80" (デューティ比 = 0%)
(タイマn0値≧タイマn1値)
カウンタタイマ00値
カウンタタイマ01値
0x00
0x00
"H"
0x80,0x00
0x80,0x00
0x80,0x00
0x80,0x00
PWM 波形
"L"
Tn0DR レジスタ値 : "0x40", Tn1DR レジスタ値 : "0x80" (デューティ比 = 50%)
カウンタタイマn0値
カウンタタイマn1値
0x00
0x00
0x40
0x00
0x40
0x00
0x80,0x00
0x80,0x00
"H"
PWM 波形
"L"
Tn0DR レジスタ値 : "0x00", Tn1DR レジスタ値 : "0xFF" (デューティ比 = 99.6%)
カウンタタイマn0値
カウンタタイマn1値
PWM 波形
0x00
0x00
"H"
"L"
172
0x00
0xFF,0x00
1カウント幅
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.11 PWC タイマ機能の動作説明
Ha rdware
12.11
Manual
PWC タイマ機能の動作説明
8/16 ビット複合タイマの PWC タイマ機能の動作を説明します。
■ PWC タイマ機能の動作
PWC タイマ機能として動作させるには , 図 12.11-1 に示された設定をしてください。
図 12.11-1 PWC タイマ機能の設定
Tn0CR0/Tn1CR0
Tn0CR1/Tn1CR1
TMCRn
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
IFE
C2
C1
C0
F3
F2
F1
F0
❍
❍
❍
❍
❍
❍
❍
❍
STA
HO
IE
IR
BF
IF
SO
OE
1
❍
❍
❍
❍
❍
❍
×
TO1
TO0
TIS
MOD
FE11
FE10
FE01
FE00
❍
❍
❍
❍
❍
❍
❍
❍
パルス幅測定値を保持
Tn0DR/Tn1DR
❍: 使用ビット
×: 未使用ビット
1: "1" を設定
PWC タイマ機能を選択しているときには , 外部入力パルスの幅および周期を測定でき
ます。カウント開始・終了のエッジはタイマ動作モード選択ビット (Tn0CR0/Tn1CR0:
F[3:0]) で選択してください。
この機能の動作では , 外部入力信号の指定されたカウント開始エッジを検出した直後
に , カウンタは "0x00" からカウント動作を開始します。指定されたカウント終了エッ
ジを検出すると , カウント値が 8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR)
に 転 送 さ れ , 割 込 み フ ラ グ (Tn0CR1/Tn1CR1:IR) と バ ッ フ ァ フ ル フ ラ グ (Tn0CR1/
Tn1CR1:BF) を "1" にします。バッファフルフラグは , 8/16 ビット複合タイマデータレ
ジスタ (Tn0DR/Tn1DR) が読み出されたとき , "0" になります。
バッファフルフラグが "1" の場合 , 8/16 ビット複合タイマデータレジスタはデータを保
持します。この間に次のエッジが検出されても , カウント値は 8/16 ビット複合タイマ
データレジスタに転送されないため , 次の測定結果を喪失します。
例外として , Tn0CR0/Tn1CR0 レジスタの F[3:0] ビットが "0b1001" に設定されていると
きは , BF ビットが "1" 状態でも "H" パルスの測定結果は 8/16 ビット複合タイマデータ
レジスタに転送されます。ただし , 周期の測定結果は 8/16 ビット複合タイマデータレ
ジスタに転送されません。したがって , 周期測定を行うためには周期が終了する前に
"H" パルス測定の結果を読み出してください。また , "H" パルス測定の結果および周期
測定の結果は , 次の "H" パルスが終了する前に読み出さないと喪失します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
173
第 12 章 8/16 ビット複合タイマ
12.11 PWC タイマ機能の動作説明
H ard war e
Ma nu al
カウンタの値を超える時間を測定する場合は , カウンタオーバフローの回数をソフト
ウェアでカウントすることにより , カウンタの値を超えた時間を求めることができま
す。すなわち , カウンタがオーバフローすると , 割込みフラグ (Tn0CR1/Tn1CR1:IF) が
"1" になるため , この割込みサービスルーチンによりオーバフローの回数をカウントし
ます。また , オーバフローによりタイマ出力は反転します。タイマ出力の初期値は , タイ
マ出力初期値ビット (Tn0CR1/Tn1CR1:SO) により設定できます。
タイマ動作を停止したとき, タイマ出力ビット (TMCRn:TO0/TO1) は最後の値を保持し
ます。
図 12.11-2 PWC タイマの動作図 (H パルス幅測定例 )
"H" 幅
パルス入力
(PWC端子への入力波形)
0xFF
カウンタ値
時間
STAビット
プログラムによるクリア
カウンタ動作
IRビット
BFビット
カウンタから
Tn0DR/Tn1DR
にデータ転送
174
Tn0DR/Tn1DR
データレジスタ
読出し
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.12 インプットキャプチャ機能の動作説明
Ha rdware
12.12
Manual
インプットキャプチャ機能の動作説明
8/16 ビット複合タイマのインプットキャプチャ機能の動作を説明します。
■ インプットキャプチャ機能の動作
インプットキャプチャ機能として動作させるには , 図 12.12-1 に示された設定をしてくだ
さい。
図 12.12-1 インプットキャプチャ機能の設定
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
Tn0CR0/Tn1CR0
IFE
C2
C1
C0
F3
F2
F1
F0
❍
❍
❍
❍
❍
❍
❍
❍
Tn0CR1/Tn1CR1
STA
HO
IE
IR
BF
IF
SO
OE
1
❍
❍
❍
×
❍
×
×
TMCRn
TO1
TO0
TIS
MOD
FE11
FE10
FE01
FE00
×
×
❍
❍
❍
❍
❍
❍
パルス幅測定値を保持
Tn0DR/Tn1DR
❍: 使用ビット
×: 未使用ビット
1: "1" を設定
インプットキャプチャ機能が選択されると , 外部信号入力のエッジ検出の直後に , カウ
ンタの値を , 8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) に格納します。検
出するエッジは , タイマ動作モード選択ビット (Tn0CR0/Tn1CR0:F[3:0]) により選択し
ます。
この機能には , フリーランモードとクリアモードがあり , タイマ動作モード選択ビット
により選択します。
クリアモードでは , カウンタは "0x00" からカウント動作を開始します。エッジを検出
すると , カウンタの値を 8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) に転送
して割込みフラグ (Tn0CR1/Tn1CR1:IR) が "1" になり , 再び "0x00" からカウント動作を
開始します。
フリーランモードでは , エッジが検出されると , カウンタの値を 8/16 ビット複合タイ
マデータレジスタ (Tn0DR/Tn1DR) に転送して , 割込みフラグ (Tn0CR1/Tn1CR1:IR) が
"1" になります。この場合には , カウンタはクリアされることなく , そのままカウント
動作を継続します。
この機能は , バッファフルフラグ (Tn0CR1/Tn1CR1:BF) に影響を与えません。
カウンタの値を超える時間を測定する場合は , カウンタオーバフローの回数をソフト
ウェアでカウントして求めることができます。すなわち , カウンタがオーバフローする
と , 割込みフラグ (Tn0CR1/Tn1CR1:IF) が "1" になるため , この割込みサービスルーチ
ンによりオーバフローの回数をカウントできます。また , オーバフローによりタイマ出
力 は 反 転 し ま す。タ イ マ 出 力 の 初 期 値 は ,
タ イ マ 出 力 初 期 値 ビ ッ ト (Tn0CR1/
Tn1CR1:SO) により設定できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
175
第 12 章 8/16 ビット複合タイマ
12.12 インプットキャプチャ機能の動作説明
H ard war e
Ma nu al
<注意事項>
インプットキャプチャ機能の使用上の注意については , 「12.15 使用上の注意」を参照し
てください。
図 12.12-2 インプットキャプチャ機能動作図
0xFF
0xBF
0x9F
0x7F
0x3F
Tn0DR/Tn1DRの
キャプチャ値
0xBF
キャプチャ立下りエッジ
0x3F
キャプチャ
立下りエッジ
外部入力
カウンタクリアモード
176
0x7F
キャプチャ立上りエッジ
0x9F
キャプチャ
立上りエッジ
カウンタフリーランモード
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.13 ノイズフィルタの動作説明
Ha rdware
12.13
Manual
ノイズフィルタの動作説明
8/16 ビット複合タイマのノイズフィルタの動作を説明します。
インプットキャプチャ機能または PWC タイマ機能が選択されているときには , 外部入
力端子 (ECn) からの信号のパルスノイズをノイズフィルタにより除去できます。
TMCRn レジスタの FE11, FE10, FE01 と FE00 ビットで "H" パルスノイズ除去 , "L" パ
ルスノイズ除去または "H/L" パルスノイズ除去のいずれかを選択してください。除去
できる最大のパルス幅は 3 マシンクロック周期です。ノイズフィルタ機能が作動中の
場合 , 信号入力に 4 マシンクロック周期の遅れが発生します。
図 12.13-1 ノイズフィルタの動作
サンプリング
フィルタクロック
外部入力信号
出力フィルタ
"H" ノイズ
出力フィルタ
"L" ノイズ
出力フィルタ
"H"/"L" ノイズ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
177
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
H ard war e
12.14
Ma nu al
レジスタ
8/16 ビット複合タイマのレジスタについて説明します。
表 12.14-1
8/16 ビット複合タイマのレジスタ一覧
レジスタ略称
178
レジスタ名
参照先
Tn0CR0
8/16 ビット複合タイマ n0 ステータス制御レジスタ 0
12.14.1
Tn1CR0
8/16 ビット複合タイマ n1 ステータス制御レジスタ 0
12.14.1
Tn0CR1
8/16 ビット複合タイマ n0 ステータス制御レジスタ 1
12.14.2
Tn1CR1
8/16 ビット複合タイマ n1 ステータス制御レジスタ 1
12.14.2
TMCRn
8/16 ビット複合タイマタイマモード制御レジスタ
12.14.3
Tn0DR
8/16 ビット複合タイマ n0 データレジスタ
12.14.4
Tn1DR
8/16 ビット複合タイマ n1 データレジスタ
12.14.4
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
Ha rdware
12.14.1
Manual
8/16 ビット複合タイマステータス制御レジスタ 0
(Tn0CR0/Tn1CR0)
8/16 ビット複合タイマステータス制御レジスタ 0 (Tn0CR0/Tn1CR0) は , タイマの動
作モードの選択 , カウントクロックの選択および IF フラグ割込みの許可または禁止を
行います。Tn0CR0 レジスタはタイマ n0 に , Tn1CR0 レジスタはタイマ n1 に対応し
ます。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
IFE
C2
C1
C0
F3
F2
F1
F0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] IFE: IF フラグ割込み許可ビット
このビットは IF フラグ割込みを許可または禁止します。
タイマ動作中 (Tn0CR1/Tn1CR1:STA = 1), このビットへの書込み動作は無効です。このビットを書き
換える前に , タイマが停止していることを確認してください。
このビットが "1" に設定されているとき , IE ビット (Tn0CR1/Tn1CR1:IE) と , IF フラグ (Tn0CR1/
Tn1CR1:IF) の両方 が "1" に設定されると , IF フラグ割込み要求が出力されます。
説明
bit7
"0" を書き込んだ場合
IF フラグ割込みを禁止します。
"1" を書き込んだ場合
IF フラグ割込みを許可します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
179
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
H ard war e
Ma nu al
[bit6:4] C[2:0] カウントクロック選択ビット
これらのビットはカウントクロックを選択します。
カウントクロックはプリスケーラにより生成されます。
「3.9 プリスケーラの動作」を参照してくだ
さい。
タイマ動作中 (Tn0CR1/Tn1CR1:STA = 1), これらのビットへの書込み動作は無効です。
16 ビット動作時には Tn1CR0 ( タイマ n1) のクロック選択は無効です。
PWC 機能またはインプットキャプチャ機能のとき , これらのビットは "0b111" に設定できません。
使用中の PWC 機能またはインプットキャプチャ機能で "0b111" を書き込むと , これらのビットは
"0b000" にリセットされます。
また , これらのビットが "0b111" の状態でインプットキャプチャ動作モードに遷移した場合も
"0b000" にリセットされます。
これらのビットを "0b110" に設定した場合 , タイムベースタイマからのカウントクロックがカウン
トクロックとして使用されます。タイムベースタイマからのカウントクロックは , SYCC レジスタ
の設定により , メインクロック , メイン CR クロックまたは PLL クロックから生成されます。タイ
ムベースタイマからのカウントクロックをカウントクロックとして使用する場合は , タイムベース
タイマ制御レジスタのタイムベースタイマクリアビット (TBTC:TCLR) に "1" を書き込んでタイム
ベースタイマをリセットすると , カウント時間が影響されます。
bit6:4
説明
(MCLK: マシンクロック , FCH: メインクロック , FCRH: メイン CR クロック ,
FPLL: PLL クロック )
"000" を書き込んだ場合
1 MCLK
"001" を書き込んだ場合
MCLK/2
"010" を書き込んだ場合
MCLK/4
"011" を書き込んだ場合
MCLK/8
"100" を書き込んだ場合
MCLK/16
"101" を書き込んだ場合
MCLK/32
"110" を書き込んだ場合
FCH/27, FCRH/26 または FPLL/26*
"111" を書き込んだ場合
外部クロック
*: カウントクロックとして使用される値は , SYCC レジスタの SCS[2:0] ビットにより決まります。
180
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
Ha rdware
Manual
[bit3:0] F[3:0]: タイマ動作モード選択ビット
これらのビットはタイマ動作モードを選択します。
PWM タイマ機能 ( 周期可変モード ) (F[3:0] = 0b0100) は , Tn0CR0 ( タイマ n0) または Tn1CR0( タイ
マ n1) のいずれか一方のレジスタから設定します。この場合 , 一方のタイマが作動すると (Tn0CR1/
Tn1CR1:STA = 1), 他方のタイマの F[3:0] ビットが自動的に "0b0100" に設定されます。
16 ビット動作モードを選択 (TMCRn:MOD = 1) した状態で , 複合タイマが PWM タイマ機能 ( 周期可
変モード ) で動作を開始 (Tn0CR1/Tn1CR1:STA = 1) すると , MOD ビットは自動的に "0" になります。
タイマ動作中 (Tn0CR1/Tn1CR1:STA = 1) のとき , これらのビットへの書込み動作は無効です。
説明
bit3:0
"0000" を書き込んだ場合
インターバルタイマ ( ワンショットモード )
"0001" を書き込んだ場合
インターバルタイマ ( 連続モード )
"0010" を書き込んだ場合
インターバルタイマ ( フリーランモード )
"0011" を書き込んだ場合
PWM タイマ ( 周期固定モード )
"0100" を書き込んだ場合
PWM タイマ ( 周期可変モード )
"0101" を書き込んだ場合
PWC タイマ (H パルス=立上りエッジ~立下りエッジ )
"0110" を書き込んだ場合
PWC タイマ (L パルス=立下りエッジ~立上りエッジ )
"0111" を書き込んだ場合
PWC タイマ ( 周期=立上りエッジ~立上りエッジ )
"1000" を書き込んだ場合
PWC タイマ ( 周期=立下りエッジ~立下りエッジ )
"1001" を書き込んだ場合
PWC タイマ (H パルス=立上りエッジ~立下りエッジ ; 周期=立上りエッジ~立
上りエッジ )
"1010" を書き込んだ場合
インプットキャプチャ ( 立上りエッジ , フリーランカウンタ )
"1011" を書き込んだ場合
インプットキャプチャ ( 立下りエッジ , フリーランカウンタ )
"1100" を書き込んだ場合
インプットキャプチャ ( 両エッジ , フリーランカウンタ )
"1101" を書き込んだ場合
インプットキャプチャ ( 立上りエッジ , カウンタクリア )
"1110" を書き込んだ場合
インプットキャプチャ ( 立下りエッジ , カウンタクリア )
"1111" を書き込んだ場合
インプットキャプチャ ( 両エッジ , カウンタクリア )
April 4, 2014, MB95F718M_MN702-00014-3v0-J
181
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
H ard war e
12.14.2
Ma nu al
8/16 ビット複合タイマステータス制御レジスタ 1
(Tn0CR1/Tn1CR1)
8/16 ビット複合タイマステータス制御レジスタ 1 (Tn0CR1/Tn1CR1) は , 割込みフラ
グの制御 , タイマ出力の制御およびタイマ動作を制御します。Tn0CR1 はタイマ n0
に , Tn1CR1 はタイマ n1 に対応します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
STA
HO
IE
IR
BF
IF
SO
OE
属性
R/W
R/W
R/W
R/W
R
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] STA: タイマ動作許可ビット
このビットはタイマ動作を許可または停止します。
"0" を書き込んだ場合:タイマ動作を停止し , カウント値は "0x00" になります。
• PWM タイマ機能 ( 周期可変モード ) (Tn0CR0/Tn1CR0:F[3:0] = 0b0100) のときは , Tn0CR1( タイマ
n0) または Tn1CR1 ( タイマ n1) のどちらかのレジスタの STA ビットを使いタイマ動作を許可また
は停止できます。この場合 , 一方のレジスタの STA ビットに "0" を書き込んだ場合 , 他方のレジ
スタの STA ビットは自動的に同じ値に設定されます。
• 16 ビット動作 (TMCRn:MOD = 1) のときには , Tn0CR1( タイマ n0) レジスタの STA ビットにより
タイマ動作の許可または停止を行ってください。この場合 , 一方のタイマの STA ビットにを "0"
を書き込んだ場合 , 他方のタイマの STA ビットは自動的に同じ値に設定されます。
"1" を書き込んだ場合:カウント値 "0x00" からタイマ動作を開始します。
• カウントクロック選択ビット (Tn0CR0/Tn1CR0:C[2:0]), タイマ動作モード選択ビット (Tn0CR0/
Tn1CR0:F[3:0]), タイマ出力初期値ビット (Tn0CR1/Tn1CR1:SO), 8 ビット / 16 ビット動作モード選
択ビット (TMCRn:MOD) およびフィルタ機能選択ビット (TMCRn:FEn1, FEn0) の設定は , このビッ
トを "1" に設定する前に行ってください。
説明
bit7
182
"0" を書き込んだ場合
タイマ動作を停止します。
"1" を書き込んだ場合
タイマ動作を許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
Ha rdware
Manual
[bit6] HO: タイマ一時停止ビット
このビットはタイマ動作を一時停止または再開します。
タイマ動作中にこのビットに "1" を書き込むと , タイマ動作は一時停止します。
タイマ動作が許可されている状態 (Tn0CR1/Tn1CR1:STA = 1) でこのビットに "0" を書き込むと , タ
イマ動作は再開します。
PWM タイマ機能 ( 周期可変モード ) (Tn0CR0/Tn1CR0:F[3:0] = 0b0100) が使用されている時 , Tn0CR1
( タイマ n0) または Tn1CR1 ( タイマ n1) のいずれかのレジスタの HO ビットによりタイマ一時停止
許可または動作再開が可能です。この場合 , 一方のレジスタの HO ビットに "0" または "1" を書き込
んだ場合 , 他方のレジスタの HO ビットは自動的に同じ値に設定されます。
16 ビット動作 (TMCRn:MOD = 1) のときは , Tn0CR1( タイマ n0) の HO ビットによりタイマ一時停
止・動作再開を行ってください。この場合 , 一方のレジスタの HO ビットに "0" または "1" を書き込
んだ場合 , 他方のレジスタの HO ビットは自動的に同じ値に設定されます。
説明
bit6
"0" を書き込んだ場合
タイマ動作を再開します。
"1" を書き込んだ場合
タイマ動作を一時停止します。
[bit5] IE: 割込み要求許可ビット
このビットは割込み要求を許可または禁止します。
"0" の書込みは 割込み要求を禁止します。
"1" の書込みは 割込み要求を許可します。
このビットが "1" のときに , パルス幅測定完了 / エッジ検出フラグ (Tn0CR1/Tn1CR1:IR) またはタイ
マリロード / オーバフローフラグ (Tn0CR1/Tn1CR1:IF) が "1" に設定されると , 複合タイマは割込み
要求を出力します。
ただし , タイマリロード / オーバフローフラグ (Tn0CR1/Tn1CR1:IF) からの割込み要求は , IF フラグ
割込み許可ビット (Tn0CR0/Tn1CR0:IFE) も "1" に設定しないと出力されません。
説明
bit5
"0" を書き込んだ場合
割込み要求を禁止します。
"1" を書き込んだ場合
割込み要求を許可します。
[bit4] IR: パルス幅測定完了 / エッジ検出フラグ
このビットはパルス幅測定の完了またはエッジが検出されたことを示します。
このビットに "0" を書き込むと , このビットは "0" になります。
"1" を書き込んでも動作に影響はありません。
PWC タイマ機能が使用されているときに , パルス幅測定の完了直後にこのビットは "1" に設定され
ます。
インプットキャプチャ機能が使用されているとき , エッジが検出された直後にこのビットは "1" に
設定されます。
選択された複合タイマの機能が , PWC タイマ機能やインプットキャプチャ機能以外のとき , この
ビットは "0" に設定されます。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
16 ビット動作のとき , Tn1CR1( タイマ n1) レジスタの IR ビットは "0" に設定されます。
説明
bit4
"0" が読み出された場合
パルス幅測定が完了していることまたはエッジが検出されていないことを示し
ます。
"1" が読み出された場合
パルス幅測定が完了していることまたはエッジ検出がされていることを示しま
す。
"0" を書き込んだ場合
このフラグをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
183
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
H ard war e
Ma nu al
[bit3] BF: データレジスタフルフラグ
PWC タイマ機能が使用されているときには , パルス幅測定の完了直後にカウント値が 8/16 ビット
複合タイマデータレジスタ (Tn0DR/Tn1DR) に格納されると , このビットは "1" に設定されます。
8 ビット動作のとき , Tn0DR/Tn1DR を読み出すとこのビットは "0" になります。
このビットが "1" に設定されると , Tn0DR/Tn1DR は , データを保持します。このビットが "1" のと
き , 次のエッジが検出されてもカウント値は Tn0DR/Tn1DR に転送されず , 次の測定結果は喪失され
ます。ただし , 例外として Tn0CR0/Tn1CR0 の F[3:0] ビットが "0b1001" に設定されているときは ,
BF ビットが "1" の状態でも "H" パルスの測定結果が Tn0DR/Tn1DR に転送されます。ただし , 周期
の測定結果は Tn0DR/Tn1DR に転送されません。したがって , 周期測定を行うためには周期が終了
する前に "H" パルス測定の結果を読み出してください。また , "H" パルス測定の結果または周期測
定の結果は次の "H" パルスが終了する前に読み出さないと喪失されます。
16 ビット動作のとき , Tn0CR1( タイマ n0) レジスタの BF ビットは , Tn1DR( タイマ n1) レジスタを
読み出すと "0" になります。
16 ビット動作のとき , Tn1CR1( タイマ n1) レジスタの BF ビットは "0" になります。
PWC タイマ機能以外のタイマ機能が選択されているとき , このビットは "0" になります。
このビットに値を書き込んでも動作に影響はありません。
説明
bit3
"0" が読み出された場合
8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) には測定データがないこ
とを示します。
"1" が読み出された場合
8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) には測定データがあるこ
とを示します。
[bit2] IF: タイマリロード / オーバフローフラグ
このビットはカウント値の一致またはカウントのオーバフローを検出します。
インターバルタイマ機能 ( ワンショットモードまたは連続モード ) または PWM タイマ機能 ( 周期可
変モード ) のとき , 8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) の値とカウント値が一致
すると , このビットは "1" になります。
インプットキャプチャ機能またはPWC機能が使用されているときには, カウンタがオーバフローす
るとこのビットは "1" になります。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
このビットに "0" を書き込むと , このビットは "0" になります。
このビットに "1" を書き込んでも 動作に影響はありません。
PWM 機能 ( 周期可変モード ) が選択されると , このビットは "0" になります。
16 ビット動作のとき , Tn1CR1( タイマ n1) レジスタの IF ビットは "0" になります。
説明
bit2
184
"0" が読み出された場合
タイマリロードまたはオーバフローがないことを示します。
"1" が読み出された場合
タイマリロードまたはオーバフローが発生したことを示します。
"0" を書き込んだ場合
このフラグをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
Ha rdware
Manual
[bit1] SO: タイマ出力初期値ビット
このビットに値を書き込むことによりタイマ出力 (TMCRn:TO1/TO0) 初期値が設定されます。この
ビットの値は , タイマ動作許可ビット (Tn0CR1/Tn1CR1:STA) が "0" から "1" に変化したときタイマ
出力に反映されます。
16 ビット動作モード (TMCRn:MOD = 1) で , Tn0CR1( タイマ n0) レジスタの SO ビットによりタイマ
出力初期値を設定してください。この場合 , 他方のレジスタの SO ビットの値は動作に影響を与え
ません。
タイマ動作中 (Tn0CR1/Tn1CR1:STA = 1), このビットへの書込みは無効です。ただし , 16 ビット動作
モードではタイマ動作中でも Tn1CR1( タイマ n1) レジスタの SO ビットへ値を書き込めますが , 書
き込まれた値はタイマ出力に直接的な影響を与えることはありません。
PWM タイマ機能 ( 周期固定モードまたは周期可変モード ) またはインプットキャプチャ機能が使用
されているときに , このビットの値は動作に影響を与えません。
説明
bit1
"0" を書き込んだ場合
タイマ出力初期値を "0" に設定します。
"1" を書き込んだ場合
タイマ出力初期値を "1" に設定します。
[bit0] OE: タイマ出力許可ビット
このビットはタイマ出力を許可または禁止します。
"0" の書込みは外部端子へのタイマ値 (TMCRn:TO1/TO0) 出力を禁止します。この場合 , 外部端子は
汎用ポートとして機能します。
"1" の書込みは外部端子へのタイマ値出力を許可します。
説明
bit0
"0" を書き込んだ場合
タイマ出力を禁止します。
"1" を書き込んだ場合
タイマ出力を許可します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
185
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
H ard war e
12.14.3
Ma nu al
8/16 ビット複合タイマタイマモード制御レジスタ
(TMCRn)
8/16 ビット複合タイマタイマモード制御レジスタ (TMCRn) は , フィルタ機能の選択 ,
8 ビットまたは 16 ビット動作モードの選択 , タイマ n0 への信号入力の選択およびタ
イマ出力値の表示を行います。このレジスタはタイマ n0 とタイマ n1 の両方に対応し
ます。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
TO1
TO0
TIS
MOD
FE11
FE10
FE01
FE00
属性
R
R
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] TO1: タイマ n1 出力ビット
このビットはタイマ n1 の出力値を示します。タイマ動作を開始 (Tn0CR1/Tn1CR1:STA = 1) すると ,
選択したタイマ機能に応じてこのビット値は変化します。
このビットに値を書き込んでも動作に影響はありません。
16 ビット動作のとき , PWM タイマ機能 ( 周期可変モード ) またはインプットキャプチャ機能が選択
されると , このビットの値は不定となります。
インターバルタイマ機能または PWC タイマ機能のとき , タイマ動作を停止 (Tn0CR1/Tn1CR1:STA =
0) すると , このビットは最後の値を保持します。
PWM タイマ機能 ( 周期可変モード ) が選択された状態で , タイマ動作を停止 (Tn0CR1/Tn1CR1:STA =
0) すると , このビットは最後の値を保持します。
タイマ動作モード選択ビット (Tn0CR0/Tn1CR0:F[3:0]) をタイマ動作停止中に変更したとき , この
ビットは , 過去に同じタイマ動作を行ったことがある場合にはそのタイマ動作の最後の値を示し ,
そうでない場合には初期値 "0" となります。
[bit6] TO0: タイマ n0 出力ビット
このビットはタイマ n0 の出力値を示します。タイマ動作を開始 (Tn0CR1/Tn1CR1:STA = 1) すると ,
選択したタイマ機能に応じてこのビット値は変化します。
このビットに値を書き込んでも動作に影響はありません。
インプットキャプチャ機能のとき , このビットの値は不定になります。
インターバルタイマ機能または PWC タイマ機能のとき , タイマ動作を停止 (Tn0CR1/Tn1CR1:STA =
0) すると , このビットは最後の値を保持します。
PWM タイマ機能 ( 周期可変モード ) のとき , タイマ動作を停止 (Tn0CR1/Tn1CR1:STA = 0) すると ,
このビットは最後の値を保持します。
タイマ動作モード選択ビット (Tn0CR0/Tn1CR0:F[3:0]) をタイマ動作停止中に変更したとき , この
ビットは , 過去に同じタイマ動作を行ったことがある場合にはそのタイマ動作の最後の値を示し ,
そうでない場合には初期値 "0" となります。
186
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
Ha rdware
Manual
[bit5] TIS: タイマ n0 内部信号選択ビット
このビットは , PWC タイマ機能またはインプットキャプチャ機能が選択されているときに , タイマ
n0 の信号入力を選択します。
説明
bit5
"0" を書き込んだ場合
外部信号 (ECn) をタイマ n0 の信号入力として選択します。
"1" を書き込んだ場合
設定禁止
[bit4] MOD: 8 ビット /16 ビット動作モード選択ビット
このビットは 8 ビットまたは 16 ビット動作モードを選択します。
このビットに"0"を書き込んだ場合,タイマn0とタイマn1は個別の8ビットタイマとして動作します。
このビットに"1"を書き込んだ場合,タイマn0とタイマn1は1つの16ビットタイマとして動作します。
このビットが "1" の状態で , PWM タイマ機能 ( 周期可変モード ) のタイマ動作を開始 (Tn0CR1/
Tn1CR1:STA = 1) すると , このビットは自動的に "0" になります。
タイマ動作中 (Tn0CR1/Tn1CR1:STA = 1) に , このビットへの書込みアクセスは無効です。
説明
bit4
"0" を書き込んだ場合
8 ビット動作モードを選択します。
"1" を書き込んだ場合
16 ビット動作モードを選択します。
[bit3:2] FE1[1:0]: タイマ n1 フィルタ機能選択ビット
これらのビットは , PWC タイマ機能またはインプットキャプチャ機能が選択されているとき , タイ
マ n1 への外部信号 (ECn) に対するフィルタ機能を選択します。
タイマ動作中 (Tn1CR1:STA = 1), このビットへの書込みアクセスは無効です。
インターバルタイマ機能または PWM タイマ機能が選択されているときには , これらのビットを設
定しても動作に影響しません ( フィルタ機能は動作しません )。
説明
bit3:2
"00" を書き込んだ場合
フィルタなし
"01" を書き込んだ場合
"H" パルスノイズ除去
"10" を書き込んだ場合
"L" パルスノイズ除去
"11" を書き込んだ場合
"H" と "L" パルスノイズ除去
April 4, 2014, MB95F718M_MN702-00014-3v0-J
187
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
H ard war e
Ma nu al
[bit1:0] FE0[1:0]: タイマ n0 フィルタ機能選択ビット
これらのビットは , PWC タイマ機能またはインプットキャプチャ機能が選択されているとき , タイ
マ n0 への外部信号 (ECn) に対するフィルタ機能を選択します。
タイマ動作中 (Tn0CR1:STA = 1), このビットへの書込みアクセスは無効です。
インターバルタイマ機能または PWM タイマ機能が選択されているときには , これらのビットを設
定しても動作に影響しません ( フィルタ機能は動作しません )。
説明
bit1:0
188
"00" を書き込んだ場合
フィルタなし
"01" を書き込んだ場合
"H" パルスノイズ除去
"10" を書き込んだ場合
"L" パルスノイズ除去
"11" を書き込んだ場合
"H" と "L" パルスノイズ除去
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
Ha rdware
12.14.4
Manual
8/16 ビット複合タイマデータレジスタ
(Tn0DR/Tn1DR)
8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) は , インターバルタイマ動作
または PWM タイマ動作時にカウント最大値を設定するレジスタです。また , PWC タ
イマ動作またはインプットキャプチャ動作時のカウント値の読出しを行います。
Tn0DR レジスタはタイマ n0 に , Tn1DR レジスタはタイマ n1 に対応します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
TDR7
TDR6
TDR5
TDR4
TDR3
TDR2
TDR1
TDR0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
● インターバルタイマ機能
8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) を使用してインターバル時間を
設定します。タイマが動作を開始 (Tn0CR1/Tn1CR1:STA = 1) すると , このレジスタの
値は 8 ビットコンパレータのラッチに転送され , カウントが開始されます。カウント値
と8ビットコンパレータのラッチの中にある値とが一致すると, このレジスタの値は再
びラッチに転送され , カウント値が "0x00" に戻ってカウントを継続します。
現在のカウント値は , このレジスタから読み出せます。
インターバルタイマ機能を使用するとき , このレジスタに "0x00" を書き込むことは禁
止されます。
16 ビット動作のときは , データの上位を Tn1DR, 下位を Tn0DR に書き込んでください。
また , 書込みまたは読出しは Tn1DR, Tn0DR の順番で行ってください。
● PWM タイマ機能 ( 周期固定 )
8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) を使用して "H" パルス幅時間を
設定します。タイマが動作を開始 (Tn0CR1/Tn1CR1:STA = 1) すると , このレジスタの値
は 8 ビットコンパレータのラッチに転送され , タイマ出力 "H" からカウントが開始さ
れます。
カウント値とラッチに転送された値が一致すると , タイマ出力は "L" になり ,
カウント値が "0xFF" に達するまでカウント動作を継続します。オーバフローが発生す
ると , このレジスタの値は再び 8 ビットコンパレータのラッチに転送され , 次のカウント
サイクルを実行します。
このレジスタから , 現在の値を読み出せます。16 ビット動作のときは , データの上位を
Tn1DR, 下位を Tn0DR に書き込んでください。また , 書込みまたは読出しは Tn1DR,
Tn0DR の順番で行ってください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
189
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
H ard war e
Ma nu al
● PWM タイマ機能 ( 周期可変 )
8/16 ビット複合タイマ n0 データレジスタ (Tn0DR) で , "L" パルス幅時間を , 8/16 ビッ
ト複合タイマ n1 データレジスタ (Tn1DR) で , 周期を設定します。タイマが動作を開始
(Tn0CR1/Tn1CR1:STA = 1) すると , それぞれのレジスタの値は 8 ビットコンパレータの
ラッチに転送され , 2 つのカウンタがタイマ出力 "L" からカウントを開始します。ラッ
チに転送された Tn0DR の値がタイマ n0 カウンタの値と一致すると , タイマ出力は "H"
になり , ラッチに転送された Tn1DR の値がタイマ n1 カウンタの値と一致するまでカウ
ント動作を継続します。8 ビットコンパレータのラッチに転送された Tn1DR の値がタ
イマ n1 カウンタの値と一致すると , Tn0DR および Tn1DR レジスタの値は再びラッチ
に転送され , 次の PWM 周期のカウント動作を継続します。
このレジスタから , 現在のカウント値を読み出せます。
16 ビット動作モードのときは , データの上位を Tn1DR, 下位を Tn0DR に書き込んでく
ださい。また , 読出しは Tn1DR, Tn0DR の順番で行ってください。
● PWC タイマ機能
8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) を使用して , PWC 測定結果を読
み出します。PWC 測定が完了するとカウンタ値がこのレジスタに転送されて BF ビッ
トが "1" になります。
8/16 ビット複合タイマデータレジスタを読むと , BF ビットは "0" になります。BF ビッ
トが"1"のとき, 8/16ビット複合タイマデータレジスタへのデータ転送は行われません。
例外として , Tn0CR0/Tn1CR0 レジスタにおける F[3:0] ビットが "0b1001" に設定されて
いる状態のとき , BF ビットが "1" に設定されていても , "H" パルスの測定結果は 8/16
ビット複合タイマデータレジスタに転送されますが , 周期の測定結果は 8/16 ビット複
合タイマデータレジスタに転送されません。したがって , 周期測定を行うためには周期
が完了する前に "H" パルス測定の結果を読み出してください。また , "H" パルス測定結
果または周期測定結果は次の "H" パルスが終了する前に読み出さないと喪失されます。
8/16 ビット複合タイマデータレジスタを読み込んでいるときに , BF ビットを誤ってク
リアしないように注意してください。
8/16 ビット複合タイマデータレジスタに新たなデータを書き込むと , 格納された測定
データが新たなデータと入れ替わります。したがって , データをレジスタに書き込まな
いでください。16 ビット動作モードのときは , データの上位を Tn1DR, 下位を Tn0DR
に書き込んでください。また , 読出しは Tn1DR, Tn0DR の順番で行ってください。
● インプットキャプチャ機能
8/16 ビット複合タイマデータレジスタ (Tn0DR/Tn1DR) は , インプットキャプチャ結果
の読出しに使用します。指定されたエッジが検出されると , カウンタ値が 8/16 ビット
複合タイマデータレジスタに転送されます。
8/16 ビット複合タイマデータレジスタに新たなデータを書き込むと , 格納された測定
データが新たなデータと入れ替わります。したがって , データをレジスタに書き込まな
いでください。16 ビット動作モードのときは , データの上位を Tn1DR, 下位を Tn0DR
に書き込んでください。また , 読出しは Tn1DR, Tn0DR の順番で行ってください。
190
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.14 レジスタ
Ha rdware
Manual
● 読出し , 書込み動作について
Tn0DR と Tn1DR の 16 ビット動作時および PWM タイマ機能 ( 周期可変 ) 時の読出し ,
書込み動作は以下のように行われます。
•
Tn1DR からの読出し : 同レジスタの読出し動作に加えて , Tn0DR の値を内部の読
出しバッファへ格納する動作も同時に行われます。
•
Tn0DR からの読出し : 内部の読出しバッファからの読出し動作が行われます。
•
Tn1DR への書込み
: 内部の書込みバッファへの書込み動作が行われます。
•
Tn0DR への書込み
: 同レジスタの書込み動作に加え , 内部の書込みバッファの
値を Tn1DR へ格納する動作も同時に行われます。
図 12.14-1 に , Tn0DR と Tn1DR レジスタの 16 ビット動作における読み書き動作を示し
ます。
図 12.14-1 Tn0DR と Tn1DR レジスタの 16 ビット動作におけるリードおよびライト動作
読出し
バッファ
Tn0DR
レジスタ
書込み
データ
書込み
バッファ
Tn1DR
書込み
April 4, 2014, MB95F718M_MN702-00014-3v0-J
読出し
データ
Tn1DR
レジスタ
Tn0DR
書込み
Tn1DR
読出し
Tn0DR
読出し
191
第 12 章 8/16 ビット複合タイマ
12.15 使用上の注意
H ard war e
12.15
Ma nu al
使用上の注意
8/16 ビット複合タイマ使用上の注意を示します。
■ 8/16 ビット複合タイマの使用上の注意
•
タイマ動作モード選択ビット (Tn0CR0/Tn1CR0:F[3:0]) によりタイマ機能を変更する
場合は , あらかじめタイマ動作を停止 (Tn0CR1/Tn1CR1:STA = 0) してから , 割込み
フラグ (Tn0CR1/Tn1CR1:IF, IR), 割込み許可ビット (Tn0CR1/Tn1CR1:IE, Tn0CR0/
Tn1CR0:IFE) およびバッファフルフラグ (Tn0CR1/Tn1CR1:BF) をクリアしてくださ
い。
•
インプットキャプチャ機能を使用しているとき , "H" レベル外部信号を入力中に , 外
部入力信号の両エッジ検出が8/16ビット複合タイマがカウンタ値をキャプチャする
タイミングとして選択される場合 (Tn0CR0/Tn1CR0:F[3:0] = 0b1100 または 0b1111),
最初の立下りエッジは無視されます。また , タイマカウンタ値のデータレジスタ
(Tn0DR/Tn1DR) への転送は行われず , 割込みフラグ (Tn0CR1/Tn1CR1:IR) はセット
されません。
- カウンタクリアモードでは最初の立下りエッジでカウンタはクリアされず , デー
タレジスタへのデータの転送は行われません。8/16 ビット複合タイマは次の立上
りエッジよりキャプチャ動作を開始します。
- カウンタフリーランモードでは最初の立下りエッジでデータレジスタへのデー
タ転送は行われません。8/16 ビット複合タイマは次の立上りエッジよりキャプ
チャ動作を開始します。
192
•
PWM 周期可変モードの 8 ビット動作 (TMCRn:MOD = 0) において , カウンタ動作中
に 8/16 ビット複合タイマデータレジスタ (Tn0DR と Tn1DR) を変更する場合 , 8/16
ビット複合タイマ n1 データレジスタ (Tn1DR) を変更した後に , 8/16 ビット複合タ
イマ n0 データレジスタ (Tn0DR) を変更してください。
•
イベントカウンタがイベントカウンタ動作モードで動作しているとき , 8/16 ビット
複合タイマ ch. 1 が使用されているため , 8/16 ビット複合タイマが 8/16 ビット複合
タイマ ch. 1 を使用できなくなります。イベントカウンタの詳細については ,「第 20
章 イベントカウンタ」を参照してください。
•
マイコンがストップモードまたは時計モードに遷移すると , カウンタは値を保持し
て動作を停止します。ストップモードまたは時計モードが割込みによって解除され
ると , カウンタは保持した値から動作を再開します ( 図 12.15-1 と図 12.15-2 を参照
してください )。このため , 初回のインターバル時間や初期外部クロックのカウント
数は正しい値ではありません。マイコンがストップモードまたは時計モードから解
除された後には , 必ずカウンタ値を初期化してください。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 12 章 8/16 ビット複合タイマ
12.15 使用上の注意
Ha rdware
Manual
図 12.15-1 スタンバイモードまたは一時停止時のカウンタの動作 (PWM タイマ機能以外 )
Tn0DR/Tn1DRデータレジスタ値 (0xFF)
カウンタ値
0xFF
0x80
0x00
タイマサイクル
時間
要求終了
HO要求
HO要求終了
発振安定待ち遅延時間
ストップモード(不確定)からの
起動後のインターバル時間
IFビット
プログラムに
よるクリア
動作停止
STAビット
動作再開
動作再起動
HOビット
IEビット
スリープモード
SLPビット
(STBCレジスタ)
外部割込みによるストップモードからの復帰
割込みによるスリープモードからの復帰
STPビット
(STBCレジスタ)
ストップモード
図 12.15-2 スタンバイモードおよび一時停止時のカウンタの動作 (PWM タイマ機能のとき )
カウンタ値
0xFF
(0xFF)
0x00
時間
発振安定待ち遅延時間
Tn0DR/Tn1DR値 (0xFF)
STA ビット
*
PWMタイマ出力端子
スリープモード
SLP ビット
(STBC レジスタ)
停止前のレベルを維持
一時停止前のレベルを維持
外部割込みによるストップモードからの復帰
割込みによるスリープモードからの復帰
STP ビット
(STBC レジスタ)
HO ビット
*: PWMタイマ出力はストップモードへの移行前の値を保持します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
193
第 12 章 8/16 ビット複合タイマ
12.15 使用上の注意
H ard war e
194
Ma nu al
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 13 章
外部割込み回路
外部割込み回路の機能と動作について説明します。
13.1 概要
13.2 構成
13.3 チャネル
13.4 端子
13.5 割込み
13.6 動作説明と設定手順例
13.7 レジスタ
13.8 使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
195
第 13 章 外部割込み回路
13.1 概要
H ard war e
13.1
Ma nu al
概要
外部割込み回路は , 外部割込み端子に入力された信号のエッジを検出し , 割込みコン
トローラへ割込み要求を出力します。
■ 外部割込み回路の機能
外部割込み回路は , 外部割込み端子に入力された信号の任意のエッジを検出し , 割込み
コントローラに対して割込み要求を発生します。この割込み要求によって , デバイスを
スタンバイモードから復帰させ , 通常の動作状態に戻せます。そのため , デバイスの動
作モードは , 外部割込み端子に信号が入力されたときに変更可能となります。
196
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 13 章 外部割込み回路
13.2 構成
Ha rdware
13.2
Manual
構成
外部割込み回路は , 以下のブロックで構成されます。
• エッジ検出回路
• 外部割込み制御レジスタ
■ 外部割込み回路のブロックダイヤグラム
図 13.2-1 に , 外部割込み回路のブロックダイヤグラムを示します。
図 13.2-1 外部割込み回路のブロックダイヤグラム
端子
INTn
エッジ検出回路1
01
10
01
外部割込み制御
レジスタ(EIC)
EIR1
SL11
SL10
11
EIE1
EIR0
SL01
SL00
EIE0
内部データバス
11
セレクタ
端子
INTn+1
セレクタ
10
エッジ検出回路0
IRQXX
IRQXX
<注意事項>
端子名および割込み要求番号は品種によって異なります。詳細は,
デバイスのデータシートの「■ 端子機能説明」と「■ 割込み要因
のテーブル」を参照してください。
● エッジ検出回路
外部割込み回路端子 (INT) への信号入力時に検出されたエッジの極性が , 割込み制御レ
ジスタ (EIC) で選択されているエッジの極性と一致すると , 対応する外部割込み要求フ
ラグビット (EIR) は "1" に設定されます。
● 外部割込み制御レジスタ (EIC)
このレジスタは , エッジの選択 , 割込み要求の許可または禁止 , 割込み要求の確認など
を行うために使用します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
197
第 13 章 外部割込み回路
13.3 チャネル
H ard war e
13.3
Ma nu al
チャネル
外部割込み回路のチャネルについて説明します。
■ 外部割込み回路のチャネル
表 13.3-1 に , 外部割込み回路の端子とそれに対応するレジスタを示します。
表 13.3-1 外部割込み回路の端子およびレジスタ
端子名
端子機能
INTn
外部割込み入力 ch. n
INTn+1
外部割込み入力 ch. n+1
INTn+2
外部割込み入力 ch. n+2
INTn+3
外部割込み入力 ch. n+3
対応するレジスタ
外部割込み制御レジスタ (EIC)
外部割込み回路のチャネル数は品種によって異なります。各品種のチャネル数につい
て , デバイスのデータシートを参照してください。
198
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 13 章 外部割込み回路
13.4 端子
Ha rdware
13.4
Manual
端子
外部割込み回路の端子について説明します。
■ 外部割込み回路の端子
● INT 端子
この端子は , 外部割込み入力端子および汎用 I/O ポートとして機能します。
INT 端子は , ポート方向レジスタ (DDR) によって対応する端子を入力ポートに設定し ,
外部割込み制御レジスタ (EIC) によって対応する外部割込み入力を許可すると , 外部割
込み入力端子 (INT) として機能します。
端子が入力ポートとして設定されている場合 , その端子の状態は , 常にポートデータレ
ジスタ (PDR) から読み出せます。PDR の値はリードモディファイライト (RMW) 系命令
で読み出せます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
199
第 13 章 外部割込み回路
13.5 割込み
H ard war e
13.5
Ma nu al
割込み
外部割込み回路の割込み要因としては , 外部割込み端子に入力された信号の指定エッ
ジの検出があります。
■ 外部割込み回路の動作中の割込み
外部割込み入力の指定されたエッジが検出された場合 , 対応する外部割込み要求フラ
グビット (EIC:EIR0 または EIR1) が "1" に設定されます。このとき , その外部割込み要
求フラグビットに対応する割込み要求許可ビット (EIC:EIE0 または EIE1 = 1) が許可さ
れていれば , 割込みコントローラへの割込み要求が発生します。割込みサービスルーチ
ンでは , 発生した割込み要求に対応する外部割込み要求フラグビットに "0" を書き込ん
で割込み要求をクリアしてください。
200
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 13 章 外部割込み回路
13.6 動作説明と設定手順例
Ha rdware
13.6
Manual
動作説明と設定手順例
外部割込み回路の動作について説明します。
■ 外部割込み回路の動作
外部割込み端子 (INTn, INTn+1) より入力された信号のエッジの極性が , 外部割込み制
御レジスタ (EIC:SL0[1:0] または SL1[1:0]) により選択されているエッジの極性と一致
した場合は , 対応する外部割込み要求フラグビット (EIC:EIR0 または EIR1) が "1" とな
り , 割込み要求が発生します。
デバイスのスタンバイモードからの復帰に外部割込みを使用しない場合は , 必ず割込
み要求許可ビットを "0" に設定してください。
エッジ極性選択ビット (SL0[1:0] または SL1[1:0]) を設定する際には , 誤って割込み要求
が発生することがないように , 割込み要求許可ビット (EIE0 または EIE1) を "0" に設定
してください。また , エッジ極性を変更した後には , 割込み要求フラグビット (EIR0 ま
たは EIR1) を "0" にクリアしてください。
図 13.6-1 に , INTn 端子を外部割込み入力に設定した際の動作を示します。
図 13.6-1 外部割込みの動作
INTn端子への
入力波形
プログラムにより
割込み要求ビットクリア
EIR0ビット
EIE0ビット
SL01ビット
SL00ビット
IRQ
エッジ検出なし
April 4, 2014, MB95F718M_MN702-00014-3v0-J
立上りエッジ
立下りエッジ
両エッジ
201
第 13 章 外部割込み回路
13.6 動作説明と設定手順例
H ard war e
Ma nu al
■ 設定手順例
以下に , 外部割込み回路の設定手順例を示します。
● 初期設定
1. 割込みレベルを設定してください (ILR*)。
2. エッジ極性を選択してください (EIC:SL0[1:0])。
3. 割込み要求を許可してください (EIC:EIE0 = 1)。
*: 割込みレベル設定レジスタ (ILR) の詳細について , 本ハードウェアマニュアルの「第 5 章 割
込み」とデバイスのデータシートの「■ 割込み要因のテーブル」を参照してください。
● 割込み処理
1. 割込み要求フラグをクリアしてください (EIC:EIR0 = 0)。
2. 割込み処理を行ってください。
<注意事項>
外部割込み入力ポートは , 汎用 I/O ポートと同一の端子を共用しています。したがって ,
この端子を外部割込み入力ポートとして使用する場合は , その端子に対応するポート方向
レジスタ (DDR) 内のビットを "0"( 入力 ) に設定してください。
202
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 13 章 外部割込み回路
13.7 レジスタ
Ha rdware
13.7
Manual
レジスタ
外部割込み回路のレジスタについて説明します。
表 13.7-1
外部割込み回路のレジスタ一覧
レジスタ略称
EIC
レジスタ名
外部割込み制御レジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
参照先
13.7.1
203
第 13 章 外部割込み回路
13.7 レジスタ
H ard war e
13.7.1
Ma nu al
外部割込み制御レジスタ (EIC)
外部割込み制御レジスタ (EIC) は , 外部割込み入力に対するエッジ極性の選択と , 割
込みを制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
EIR1
SL11
SL10
EIE1
EIR0
SL01
SL00
EIE0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] EIR1: 外部割込み要求フラグビット 1
エッジ極性選択ビット 1 (SL1[1:0]) により選択されているエッジが外部割込み端子 INTn+1 に入力さ
れた場合に , このフラグビットは "1" となります。
このビットと割込み要求許可ビット 1 (EIE1) が "1" になったとき , 割込み要求が出力されます。
このビットに "0" を書き込むと , このビットはクリアされます。"1" を書き込んでも動作に影響はあ
りません。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit7
"0" が読み出された場合
選択されたエッジが入力されていないことを示します。
"1" が読み出された場合
選択されたエッジが入力されたことを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit6:5] SL1[1:0]: エッジ極性選択ビット 1
これらのビットは外部割込み端子 INTn+1 に入力されるパルスのエッジ極性を選択します。
選択されたエッジが割込み要因となります。
これらのビットが "0b00" のとき , エッジ検出は実行されず , 割込み要求は発生しません。
これらのビットが "0b01" のとき , 立上りエッジが検出されます。"0b10" の場合には , 立下りエッジ
が検出されます。"0b11" の場合には , 両方のエッジが検出されます。
説明
bit6:5
204
"00" を書き込んだ場合
エッジ検出なし
"01" を書き込んだ場合
立上りエッジ
"10" を書き込んだ場合
立下りエッジ
"11" を書き込んだ場合
両エッジ
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 13 章 外部割込み回路
13.7 レジスタ
Ha rdware
Manual
[bit4] EIE1: 割込み要求許可ビット 1
このビットは , 割込みコントローラへの割込み要求の出力を許可または禁止します。このビットと
外部割込み要求フラグビット 1 (EIR1) が "1" のとき , 割込み要求が出力されます。
外部割込み端子を使用するには , ポート方向レジスタ (DDR) の対応するビットに "0" を書き込み ,
その端子を入力ポートとして設定してください。
外部割込み端子の状態は , 割込み要求許可ビットの状態にかかわらず , ポートデータレジスタから
直接読み出せます。
説明
bit4
"0" を書き込んだ場合
割込み要求出力を禁止します。
"1" を書き込んだ場合
割込み要求出力を許可します。
[bit3] EIR0: 外部割込み要求フラグビット 0
エッジ極性選択ビット 0 (SL0[1:0]) により選択されているエッジが外部割込み端子 INTn に入力され
た場合に , このフラグビットは "1" となります。
このビットと割込み要求許可ビット 0 (EIE0) が "1" になったとき , 割込み要求が出力されます。
このビットに "0" を書き込むと , このビットはクリアされます。"1" を書き込んでも動作に影響はあ
りません。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit3
"0" が読み出された場合
選択されたエッジが入力されていないことを示します。
"1" が読み出された場合
選択されたエッジが入力されたことを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit2:1] SL0[1:0]: エッジ極性選択ビット 0
これらのビットは外部割込み端子 INTn に入力されるパルスのエッジ極性を選択します。
選択されたエッジが割込み要因となります。
これらのビットが "0b00" のとき , エッジ検出は実行されず , 割込み要求は発生しません。
これらのビットが "0b01" のとき , 立上りエッジが検出されます。"0b10" の場合には , 立下りエッジ
が検出されます。"0b11" の場合には , 両方のエッジが検出されます。
説明
bit2:1
"00" を書き込んだ場合
エッジ検出なし
"01" を書き込んだ場合
立上りエッジ
"10" を書き込んだ場合
立下りエッジ
"11" を書き込んだ場合
両エッジ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
205
第 13 章 外部割込み回路
13.7 レジスタ
H ard war e
Ma nu al
[bit0] EIE0: 割込み要求許可ビット 0
このビットは , 割込みコントローラへの割込み要求の出力を許可または禁止します。このビットと
外部割込み要求フラグビット 0 (EIR0) が "1" のとき , 割込み要求が出力されます。
外部割込み端子を使用するには , ポート方向レジスタ (DDR) の対応するビットに "0" を書き込み ,
その端子を入力ポートとして設定してください。
外部割込み端子の状態は , 割込み要求許可ビットの状態にかかわらず , ポートデータレジスタから
直接読み出せます。
説明
bit0
206
"0" を書き込んだ場合
割込み要求出力を禁止します。
"1" を書き込んだ場合
割込み要求出力を許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 13 章 外部割込み回路
13.8 使用上の注意
Ha rdware
13.8
Manual
使用上の注意
外部割込み回路使用上の注意事項を示します。
■ 外部割込み回路使用上の注意
•
エッジ極性選択ビット (SL0[1:0] または SL1[1:0]) を設定する際には , 割込み要求
許可ビット (EIE0 または EIE1) を "0"( 割込み要求を禁止する ) に設定してくださ
い。また , エッジ極性を設定した後には , 外部割込み要求フラグビット (EIR0 また
は EIR1) を "0" にクリアしてください。
•
外部割込み要求フラグビットが "1" で , 割込み要求許可ビットが許可となっている
場合は , デバイスを割込みサービスルーチンから復帰させることはできません。割
込みサービスルーチンでは , 必ず外部割込み要求フラグビットをクリアしてくださ
い。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
207
第 13 章 外部割込み回路
13.8 使用上の注意
H ard war e
208
Ma nu al
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 14 章
割込み端子選択回路
割込み端子選択回路の機能と動作について説明し
ます。
14.1 概要
14.2 構成
14.3 端子
14.4 動作
14.5 レジスタ
14.6 使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
209
第 14 章 割込み端子選択回路
14.1 概要
H ard war e
14.1
Ma nu al
概要
割込み端子選択回路は , 複数の周辺機能入力端子の中から割込み入力端子を選択しま
す。
■ 割込み端子選択回路
割込み端子選択回路は , 複数の周辺機能入力 (EC0, INT00, UCK0 と UI0) の中から割込
み入力端子を選択します。各周辺機能端子の入力信号は , 本回路によって選択され , 外
部割込みの INT00 (ch.0) 入力として扱われます。これにより , 各周辺機能端子の入力信
号に外部割込み端子としての機能も持たせることができます。
210
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 14 章 割込み端子選択回路
14.2 構成
Ha rdware
14.2
Manual
構成
図 14.2-1 と図 14.2-2 に , 割込み端子選択回路のブロックダイヤグラムを示します。
■ 割込み端子選択回路のブロックダイヤグラム
図 14.2-1 割込み端子選択回路のブロックダイヤグラム (MB95710L シリーズ )
外部割込み回路
各周辺機能へ
INT01
P01
INT01
割込み端子選択回路
選択回路
UCK0
P14
INT00
(ユニット0)
内部データバス
INT00
P00
UI0
P10
EC0
P51
WICRレジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
211
第 14 章 割込み端子選択回路
14.2 構成
H ard war e
Ma nu al
図 14.2-2 割込み端子選択回路のブロックダイヤグラム (MB95770L シリーズ )
外部割込み回路
各周辺機能へ
INT01
P01
INT01
割込み端子選択回路
選択回路
UCK0
P14
INT00
(ユニット0)
内部データバス
INT00
P00
UI0
P10
EC0
P14
WICRレジスタ
•
WICR レジスタ ( 割込み端子選択回路制御レジスタ )
このレジスタにより , 割込み回路へ出力する周辺機能入力端子と , 割込み端子を選
択します。
•
選択回路
WICR レジスタにて選択された端子からの入力を外部割込み回路 (ch. 0) の INT00
入力へ出力する回路です。
212
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 14 章 割込み端子選択回路
14.3 端子
Ha rdware
14.3
Manual
端子
割込み端子選択回路の端子について説明します。
■ 割込み端子選択回路の端子
割込み端子選択回路の周辺機能端子として, EC0, INT00, UCK0 とUI0 端子があります。
これらの入力端子 (INT00 を除く ) は , 各周辺機能へも並行して接続されており , 本機
能とともに , 同時に使用が可能です。各周辺機能と周辺機能入力端子の対応を表 14.3-1
に示します。
表 14.3-1 各周辺機能と周辺機能入力端子の対応
周辺機能入力端子名
周辺機能名
EC0
8/16 ビット複合タイマ ( イベント入力 )
INT00
割込み端子選択回路
UCK0
UART/SIO ( クロック入出力 )
UI0
UART/SIO ( データ入力 )
April 4, 2014, MB95F718M_MN702-00014-3v0-J
213
第 14 章 割込み端子選択回路
14.4 動作
H ard war e
14.4
Ma nu al
動作
割込み端子は WICR レジスタの設定により選択されます。
■ 割込み端子選択回路の動作
WICR ( 割込み端子選択回路制御レジスタ ) の設定により , 外部割込み回路 (ch. 0) の
INT00 へ入力される入力端子を選択します。UCK0 端子を割込み端子として選択する
場合の , 割込み端子選択回路と外部割込み回路 (ch. 0) の設定手順を下記に示します。
1. ポート方向 (DDR) レジスタの対応するビットに "0" を書き込んで端子を入力に設
定する。
2. WICR レジスタにより UCK0 端子を割込み入力端子として選択する。
- WICR レジスタへ "0x02" を書き込む。このとき , 外部割込み回路は外部割込み回
路の EIC00 レジスタの EIE0 ビットへ "0" を書き込んで割込み禁止にしておく。
3. 外部割込み回路 (ch. 0) に INT00 の動作を許可する。
- 外部割込み回路の EIC00 レジスタの SL0[1:0] ビットへ "0b00" 以外を設定し,有効
エッジを選択するとともに , EIE0 ビットへ "1" を 書き込んで割込みを許可する。
4. 以降の割込み動作は外部割込み回路と同等となる。
- リセット解除後,WICR レジスタは "0x40" に初期化され, INT00 ビットのみ割込み
端子として選択された状態になります。INT00 端子以外の端子を外部割込み端子
として使用する場合は , 本レジスタを書き換えた後に , 外部割込み回路の動作を
許可してください。
214
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 14 章 割込み端子選択回路
14.5 レジスタ
Ha rdware
14.5
Manual
レジスタ
割込み端子選択回路のレジスタについて説明します。
表 14.5-1
割込み端子選択回路のレジスタ一覧
レジスタ略称
WICR
レジスタ名
割込み端子選択回路制御レジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
参照先
14.5.1
215
第 14 章 割込み端子選択回路
14.5 レジスタ
H ard war e
14.5.1
Ma nu al
割込み端子選択回路制御レジスタ (WICR)
このレジスタは周辺機能入力端子からのどの入力をどの割込み端子として割込み回
路へ出力するかを選択します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
INT00
—
—
EC0
UI0
UCK0
—
属性
—
R/W
—
—
R/W
R/W
R/W
—
初期値
0
1
0
0
0
0
0
0
■ レジスタ機能
[bit7] 未定義ビット
読出し値は常に "0" です。このビットに値を書き込んでも動作に影響はありません。
[bit6] INT00: INT00 割込み端子選択ビット
このビットは INT00 端子を割込み入力端子として選択するかどうかを設定します。
このビットに "0" が書き込まれた場合 , INT00 端子は割込み入力端子として非選択となり , 本回路は
INT00 端子への入力を "0" 固定として扱います。
このビットに "1" が書き込まれた場合 , INT00 端子は割込み入力端子として選択され , 本回路は
INT00 端子への入力を外部割込み回路の INT00 (ch. 0) へ出力します。このとき , 外部割込み回路の
INT00 (ch. 0) の動作が許可されていると , INT00 端子への入力信号により外部割込みが発生します。
bit6
説明
"0" を書き込んだ場合
INT00 は割込み入力端子として非選択となります。
"1" を書き込んだ場合
INT00 を割込み入力端子として選択します。
[bit5:4] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit3] EC0: EC0 割込み端子選択ビット
このビットは EC0 端子を割込み入力端子として選択するかどうかを設定します。
このビットに "0" が書き込まれた場合 , EC0 端子は割込み入力端子として非選択となり , 本回路は
EC0 端子への入力を "0" 固定として扱います。
このビットに "1" が書き込まれた場合 , EC0 端子は割込み入力端子として選択され , 本回路は EC0
端子への入力を外部割込み回路の INT00 (ch. 0) へ出力します。このとき , 外部割込み回路の INT00
(ch. 0) の動作が許可されていると , EC0 端子への入力信号により外部割込みが発生します。
bit3
216
説明
"0" を書き込んだ場合
EC0 は割込み入力端子として非選択となります。
"1" を書き込んだ場合
EC0 を割込み入力端子として選択します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 14 章 割込み端子選択回路
14.5 レジスタ
Ha rdware
Manual
[bit2] UI0: UI0 割込み端子選択ビット
このビットは UI0 端子を割込み入力端子として選択するかどうかを設定します。
このビットに "0" が書き込まれた場合 , UI0 端子は割込み入力端子として非選択となり , 本回路は
UI0 端子への入力を "0" 固定として扱います。
このビットに "1" が書き込まれた場合 , UI0 端子は割込み入力端子として選択され , 本回路は UI0 端
子への入力を外部割込み回路の INT00 (ch. 0) へ出力します。このとき , 外部割込み回路の INT00 (ch.
0) の動作が許可されていると , UI0 端子への入力信号により外部割込みが発生します。
説明
bit2
"0" を書き込んだ場合
UI0 は割込み入力端子として非選択となります。
"1" を書き込んだ場合
UI0 を割込み入力端子として選択します。
[bit1] UCK0: UCK0 割込み端子選択ビット
このビットは UCK0 端子を割込み入力端子として選択するかどうかを設定します。
このビットに "0" が書き込まれた場合 , UCK0 端子は割込み入力端子として非選択となり , 本回路は
UCK0 端子への入力を "0" 固定として扱います。
このビットに "1" が書き込まれた場合 , UCK0 端子は割込み入力端子として選択され , 本回路は
UCK0 端子への入力を外部割込み回路の INT00 (ch. 0) へ出力します。このとき , 外部割込み回路の
INT00 (ch. 0) の動作が許可されていると , UCK0 端子への入力信号により外部割込みが発生します。
説明
bit1
"0" を書き込んだ場合
UCK0 は割込み入力端子として非選択となります。
"1" を書き込んだ場合
UCK0 を割込み入力端子として選択します。
[bit0] 未定義ビット
読出し値は常に "0" です。このビットに値を書き込んでも動作に影響はありません。
デバイスの スタンバイモードで , 本レジスタの ( 未定義ビット以外の ) いずれかのビットが "1" に
設定されており , かつ外部割込み回路の INT00 (ch.0) の動作が許可されている場合 , 選択された端子
は入力動作の実行が許可された状態となります。端子への有効エッジパルス入力により , デバイス
はスタンバイモードからウェイクアップします。スタンバイモードについては , 「3.5 低消費電力
モード ( スタンバイモード ) の動作」を参照してください。
<注意事項>
外部割込み回路の INT00 (ch. 0) が動作許可されていない場合 ,これらのビットに "1" を書
き込んでも , 各周辺機能端子の入力信号で外部割込みは発生しません。
外部割込み回路の INT00 (ch. 0) が動作許可されている場合,これらのビットを書き換えな
いでください。もし書き換えた場合 , 該当端子の入力レベルによっては , 外部割込み回路
が有効エッジを検出してしまうことがあります。
WICR ( 割込み端子選択回路制御レジスタ ) により複数の割込み端子を同時に選択し , かつ
外 部 割 込 み 回 路 の INT00 (ch. 0) の 動 作 が 許 可 ( 外 部 割 込 み 回 路 の EIC レ ジ ス タ の
SL0[1:0] ビットに "0b00" 以外を書き込む ) されている場合 , 選択された端子はスタンバイ
モード時においても , 割込み受付けのために入力許可状態となります。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
217
第 14 章 割込み端子選択回路
14.6 使用上の注意
H ard war e
14.6
Ma nu al
使用上の注意
割込み端子選択回路使用上の注意を示します。
218
•
WICR レジスタにより , 複数の割込み端子を同時に選択し , かつ外部割込み回路の
INT00 (ch. 0) の動作が許可されている ( 外部割込み回路の EIC レジスタの SL0[1:0]
ビットに "0b00" 以外を書き込んで , 有効エッジを選択するとともに , EIE0 ビットに
"1" を書き込んで割込みを許可する ) 場合 , 選択された端子はスタンバイモードにお
いても , 割込み受付けのために入力許可状態となります。
•
WICR レジスタにより , 複数の割込み端子を同時に選択した場合 , それらの端子へ
入力された信号のいずれかが "H" のとき , 外部割込み回路の INT00 (ch. 0) への入力
は "H" として扱われます ( 選択された端子に入力された信号の "OR" となります )。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 15 章
8/12 ビット A/D コンバータ
8/12 ビット A/D コンバータの機能と動作について
説明します。
15.1 概要
15.2 構成
15.3 端子
15.4 割込み
15.5 8/12 ビット A/D コンバータの動作許可
15.6 動作説明と設定手順例
15.7 レジスタ
15.8 使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
219
第 15 章 8/12 ビット A/D コンバータ
15.1 概要
H ard war e
15.1
Ma nu al
概要
8/12 ビット A/D コンバータは , 12 ビット逐次比較型の 8/12 ビット A/D コンバータ
です。複数のアナログ入力端子から 1 つの入力信号を選択し, ソフトウェアと内部 ク
ロックによって起動できます。
■ A/D 変換機能
A/Dコンバータは, アナログ入力端子から入力されたアナログ電圧 (入力電圧) を8ビッ
トまたは 12 ビットのデジタル値に変換します。
•
入力信号は , 複数のアナログ入力端子から選択できます。
•
変換速度は , プログラムで設定可能です ( 動作電圧と周波数によって選択可能 )。
•
A/D 変換が完了すると割込みが発生します。
•
変換完了は , ADC1 レジスタの ADI ビットで確認できます。
A/D 変換機能を起動するには , 以下のいずれかの方法を使用します。
220
•
ADC1 レジスタの AD ビットによる起動
•
8/16 ビット複合タイマ出力 TO00 による連続起動
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 15 章 8/12 ビット A/D コンバータ
15.2 構成
Ha rdware
15.2
Manual
構成
8/12 ビット A/D コンバータは , 以下のブロックで構成されます。
• クロックセレクタ (A/D 変換起動用入力クロックセレクタ )
• アナログチャネルセレクタ
• サンプルアンドホールド回路
• 制御回路
• 8/12 ビット A/D コンバータ動作許可状態遷移時間カウンタ
• 8/12 ビット A/D コンバータデータレジスタ ( 上位 / 下位 ) (ADDH/ADDL)
• 8/12 ビット A/D コンバータ制御レジスタ 1 (ADC1)
• 8/12 ビット A/D コンバータ制御レジスタ 2 (ADC2)
• 8/12 ビット A/D コンバータ制御レジスタ 3 (ADC3)
品種により , 8/12 ビット A/D コンバータのアナログ入力端子数およアナログチャネル
数は異なります。詳細は , デバイスのデータシートを参照してください。
本章において , 端子名にある "n" はアナログ入力端子番号を示します。各品種の端子名
について , デバイスのデータシートを参照してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
221
第 15 章 8/12 ビット A/D コンバータ
15.2 構成
H ard war e
Ma nu al
■ 8/12 ビット A/D コンバータのブロックダイヤグラム
図 15.2-1 に , 8/12 ビット A/D コンバータのブロックダイヤグラムを示します。
図 15.2-1 8/12 ビット A/D コンバータのブロックダイヤグラム
8/12ビットA/Dコンバータ制御レジスタ2 (ADC2)
ADS
TIM1
TIM0
ADCK
ADIE
ADTG端子
CKDIV1
CKDIV0
起動信号
セレクタ
8/16ビット複合
タイマch. 0出力
端子 (TO00)
ANn端子
EXT
アナログ
チャネル
セレクタ
サンプルアンド
ホールド回路
制御回路
内部データバス
8/12ビットA/Dコンバータデータ
レジスタ(上位/下位)
(ADDH/ADDL)
8/12ビットA/Dコンバータ
動作許可状態遷移時間
カウンタ
ENTM4
ENTM3
ENTM2
ENTM1
8/12ビットA/Dコンバータ制御レジスタ3 (ADC3)
ANS3
ANS2
ANS1
ANS0
ADI
8/12ビットA/Dコンバータ制御レジスタ1 (ADC1)
ENTM0
ADMV
READY
ENBL
Reserved
AD
IRQ
● クロックセレクタ
このセレクタは , 連続起動を許可 (ADC2:EXT = 1) した状態で , A/D 変換クロックを選
択します。
● アナログチャネルセレクタ
このセレクタは , 複数のアナログ入力端子から入力チャネルを選択する回路です。
● サンプルアンドホールド回路
アナログチャネルセレクタにより選択された入力電圧を保持する回路です。この回路
は , A/D 変換を起動した直後の入力電圧をサンプルホールドすることにより , A/D 変換
中 ( 比較中 ) の入力電圧の変動の影響を受けずに変換できます。
● 制御回路
A/D 変換機能では , コンパレータからの電圧比較信号を基に , 12 ビットの A/D データ
レジスタの値を , 最上位ビット (MSB) から最下位ビット (LSB) に向かって順に決定し
222
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 15 章 8/12 ビット A/D コンバータ
15.2 構成
Ha rdware
Manual
ます。A/D 変換が完了すると , A/D 変換機能は割込み要求フラグビット (ADC1:ADI) を
"1" に設定します。
● 8/12 ビット A/D コンバータデータレジスタ ( 上位 / 下位 ) (ADDH/ADDL)
12 ビットの A/D データの上位 2 ビットが ADDH レジスタに , 下位 8 ビットが ADDL
レ ジスタに格納されます。
AD 変換精度ビット (ADC2:AD8) を "1" にすると , AD 変換精度は 8 ビット精度となり ,
ADDL レジスタに 10 ビット A/D データの上位 8 ビットが格納されます。
● 8/12 ビット A/D コンバータ制御レジスタ 1 (ADC1)
8/12 ビット A/D コンバータの各機能の許可と禁止 , アナログ入力端子の選択 , ステータ
スの確認を 行います。
● 8/12 ビット A/D コンバータ制御レジスタ 2 (ADC2)
入力クロックの選択 , 割込みの許可と禁止 , 8/12 ビット A/D コンバータの各機能の制
御を行います。
● 8/12 ビット A/D コンバータ制御レジスタ 3 (ADC3)
8/12 ビット A/D コンバータを動作許可状態と動作禁止状態の間に切り換えます。
● 8/12 ビット A/D コンバータ動作許可状態遷移時間カウンタ
8/12 ビット A/D コンバータの動作禁止状態から動作許可状態への遷移時間をカウント
する専用カウンタです。遷移時間は ADC3 レジスタの ENTM[4:0] ビットを書き換える
ことで調整できます。
■ 入力クロック
8/12 ビット A/D コンバータは , プリスケーラからの出力クロックを入力クロック ( 動
作クロック ) として使用します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
223
第 15 章 8/12 ビット A/D コンバータ
15.3 端子
H ard war e
15.3
Ma nu al
端子
8/12 ビット A/D コンバータの端子について説明します。
■ 8/12 ビット A/D コンバータの端子
アナログ入力端子は , 汎用入出力ポートとしても使用されます。
● ANn 端子
A/D 変換機能を使用する場合は , ANn 端子に変換したいアナログ電圧を入力します。
ANn 端子をアナログ入力端子として使用するには , 対象の端子に対応するポート方向
レジスタ (DDR) の端子ビットに "0" を , 8/12 ビット A/D コンバータ制御レジスタのア
ナログ入力端子選択ビット (ADC1:ANS[3:0]) にその端子に対応する値を書き込んでく
ださい。
アナログ入力端子として使用されていない端子は , 8/12 ビット A/D コンバータ
が使用されている場合も汎用入出力ポートとして使用できます。
● ADTG 端子
外部トリガで A/D 変換機能を起動するための端子です。外部トリガで A/D 変換起動に
ADTG 端子を使用する前に , ADTG 端子に対応する DDR レジスタを使用して , ADTG
端子を入力ポートとして設定してください。
224
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 15 章 8/12 ビット A/D コンバータ
15.4 割込み
Ha rdware
15.4
Manual
割込み
8/12 ビット A/D コンバータの割込み要因には , A/D 変換機能動作時の変換終了があり
ます。
■ 8/12 ビット A/D コンバータ動作中の割込み
A/D 変換が完了すると , 割込み要求フラグビット (ADC1:ADI) が "1" になります。この
とき割込み要求許可ビットが許可になっていると (ADC2:ADIE = 1), 割込みコントロー
ラへの割込み要求が発生します。割込み要求をクリアするには, 割込みサービスルーチ
ンなどで ADI ビットに "0" を書き込んでください。
ADI ビットは , ADIE ビットの値に関係なく , A/D 変換が完了すると "1" に設定されま
す。
割込み要求フラグビット (ADC1:ADI) が "1" で , 割込み要求が許可されている場合
(ADC2:ADIE = 1) は, CPU は割込み処理から復帰できません。必ず割込みサービスルー
チン内で ADI ビットをクリアしてください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
225
第 15 章 8/12 ビット A/D コンバータ
15.5 8/12 ビット A/D コンバータの動作許可
H ard war e
15.5
Ma nu al
8/12 ビット A/D コンバータの動作許可
8/12 ビット A/D コンバータの動作許可について説明します。
8/12 ビット A/D コンバータは A/D 変換を行う前に動作許可状態になっている必要があ
ります。ADC3 レジスタの ENBL ビットに "1" を書き込むことで , 8/12 ビット A/D コン
バータは動作許可状態遷移時間後 , 動作禁止状態から動作許可状態になります。また ,
ENBL ビットに "0" を書き込むことで , 8/12 ビット A/D コンバータは直ちに動作禁止状
態になります。
8/12 ビット A/D コンバータは , 動作許可状態のときのみ A/D 変換を行えます。
動作禁止状態中にすべての A/D 変換要求は無視されます。
ADC3 レジスタの READY ビットを読み出すことで動作許可状態になっているかを確
認できます。
図 15.5-1 に動作許可状態の設定手順を示します。
図 15.5-1 動作許可状態の設定手順
動作禁止状態
8/12ビットA/Dコンバータの動作を許可してください。
(ADC3:ENBLに“1”を書き込む)
動作許可遷移時間
8/12ビットA/Dコンバータが
動作許可状態になっている
かを確認してください。
ADC3:READY = 1?
No
Yes
動作許可状態
<注意事項>
動作許可遷移時間は ADC3 レジスタの ENTM[4:0] ビットを書き換えることで調整できま
す。デバイスのデータシートの「■ 電気的特性」の記載内容に従い , マシンクロック (MCLK)
周期に応じて適切な遷移時間を選択してください。
226
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 15 章 8/12 ビット A/D コンバータ
15.6 動作説明と設定手順例
Ha rdware
15.6
Manual
動作説明と設定手順例
8/12 ビット A/D コンバータは , ADC2 レジスタの EXT ビットにより A/D 変換のソフ
トウェア起動または連続起動を選択できます。
■ 8/12 ビット A/D コンバータ変換機能の動作
● ソフトウェア起動
ソフトウェアにより A/D 変換機能を起動するには , 図 15.6-1 の設定をしてください。
図 15.6-1 A/D 変換機能 ( ソフトウェア起動 ) の設定
ADC1
bit7
ANS3
bit6
ANS2
bit5
ANS1
bit4
ANS0
bit3
ADI
bit2
ADMV
ADC2
AD8
TIM1
TIM0
ADCK
×
ADIE
EXT
0
ADC3
0
ENTM4
ENTM3
ENTM2
ENTM1
ENTM0
ADDH
-
-
-
-
ADDL
bit1
予約
0
bit0
AD
1
CKDIV1 CKDIV0
READY
1
ENBL
1
A/D 変換値を保持
A/D 変換値を保持
:使用ビット
× :未使用ビット
0 :"0" に設定
1 :"1" に設定
A/D 変換機能が起動されると , A/D 変換が開始します。また , 変換中においても A/D 変
換機能を再起動できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
227
第 15 章 8/12 ビット A/D コンバータ
15.6 動作説明と設定手順例
H ard war e
Ma nu al
● 連続起動
A/D 変換機能を連続起動するには , 図 15.6-2 の設定をしてください。
図 15.6-2 A/D 変換機能 ( 連続起動 ) の設定
ADC1
bit7
ANS3
bit6
ANS2
bit5
ANS1
bit4
ANS0
bit3
ADI
bit2
ADMV
ADC2
AD8
TIM1
TIM0
ADCK
ADIE
EXT
1
ADC3
0
ENTM4
ENTM3
ENTM2
ENTM1
ENTM0
ADDH
-
-
-
-
ADDL
bit1
予約
0
bit0
AD
×
CKDIV1 CKDIV0
READY
1
ENBL
1
A/D 変換値を保持
A/D 変換値保持
:使用ビット
× :未使用ビット
0 :"0" に設定
1 :"1" に設定
連続起動が許可されると , 選択された入力クロックの立上りエッジで A/D 変換機能が
起動され , A/D 変換が開始します。連続起動が禁止されると (ADC2:EXT = 0), 連続起動
動作は停止します。
228
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 15 章 8/12 ビット A/D コンバータ
15.6 動作説明と設定手順例
Ha rdware
Manual
■ A/D 変換機能の動作
8/12 ビット A/D コンバータの動作について説明します。
1. A/D 変換が開始すると , 変換フラグビットが設定され (ADC1:ADMV = 1), 選択され
たアナログ入力端子がサンプルアンドホールド回路に接続されます。
2. アナログ入力端子の電圧をサンプリング期間中にサンプルアンドホールド回路内
のサンプルアンドホールド用コンデンサに取り込みます。この電圧は , A/D 変換が
終了するまで保持されます。
3. サンプルアンドホールド用コンデンサに取り込まれた電圧と , A/D 変換用のリファ
レンス電圧をコントロール回路内のコンパレータで最上位ビット (MSB) から最下
位ビット (LSB) まで比較し , 結果を ADDH レジスタと ADDL レジスタへ転送しま
す。
結果の転送が終わ ると , 変換中フラグビットがクリア (ADC1:ADMV = 0) され , 割
込み要求フラグビットが "1" に設定 (ADC1:ADI = 1) されます。
<注意事項>
•
ADDH レジスタと ADDL レジスタの内容は , A/D 変換終了時に保持されます。した
がって , A/D 変換中は前回変換した値が読み出されます。
•
A/D 変換機能の使用中は , アナログ入力端子選択ビット (ADC1:ANS[3:0]) を変更しな
いでください。特に連続起動中は , アナログ入力端子を変更する前に連続起動を禁止
(ADC2:EXT = 0) してください。
•
リセットが発生するか , あるいはストップモードまたは時計モードが開始すると , A/D
コンバータは停止して , ADMV ビットは "0" にクリアされます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
229
第 15 章 8/12 ビット A/D コンバータ
15.6 動作説明と設定手順例
H ard war e
Ma nu al
■ 設定手順例
以下に , 8/12 ビット A/D コンバータの設定手順例を示します。
● 初期設定
1. 入力ポートを設定してください (DDR)。
2. 割込みレベルを設定してください (ILR*)。
3. 8/12 ビット A/D コンバータを動作許可状態に設定してください (ADC3:ENTM[4:0],
ADC3:ENBL = 1)。
4. A/D 入力端子を選択してください (ADC1:ANS[3:0])。
5. サンプリング時間を設定してください (ADC2:TIM[1:0])。
6. クロックを選択してください (ADC2:CKDIV[1:0])。
7. A/D 変換精度を設定してください (ADC2:AD8)。
8. 動作モードを選択してください (ADC2:EXT)。
9. 起動トリガを選択してください (ADC2:ADCK)。
10. 割込みを許可してください (ADC2:ADIE = 1)。
11. 8/12 ビット A/D コンバータが動作許可状態になっていることを確認してください
(ADC3:READY = 1)。
12. A/D 変換機能を起動してください (ADC1:AD = 1)。
*: 割込みレベル設定レジスタ (ILR) の詳細について , 本ハードウェアマニュアルの「第 5 章 割
込み」とデバイスのデータシートの「■ 割込み要因のテーブル」を参照してください。
● 割込み処理
1. 割込み要求フラグを "0" にクリアしてください (ADC1:ADI = 0)。
2. 変換値を読み出してください (ADDH, ADDL)。
3. A/D 変換を起動してください (ADC1:AD = 1)。
230
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 15 章 8/12 ビット A/D コンバータ
15.7 レジスタ
Ha rdware
15.7
Manual
レジスタ
8/12 ビット A/D コンバータのレジスタについて説明します。
表 15.7-1
8/12 ビット A/D コンバータのレジスタ一覧
レジスタ略称
レジスタ名
参照先
ADC1
8/12 ビット A/D コンバータ制御レジスタ 1
15.7.1
ADC2
8/12 ビット A/D コンバータ制御レジスタ 2
15.7.2
ADC3
8/12 ビット A/D コンバータ制御レジスタ 3
15.7.3
ADDH
8/12 ビット A/D コンバータデータレジスタ ( 上位 )
15.7.4
ADDL
8/12 ビット A/D コンバータデータレジスタ ( 下位 )
15.7.4
April 4, 2014, MB95F718M_MN702-00014-3v0-J
231
第 15 章 8/12 ビット A/D コンバータ
15.7 レジスタ
H ard war e
15.7.1
Ma nu al
8/12 ビット A/D コンバータ制御レジスタ 1 (ADC1)
8/12 ビット A/D コンバータ制御レジスタ 1 (ADC1) は , 8/12 ビット A/D コンバータ
の各機能の許可 / 禁止 , アナログ入力端子の選択およびコンバータの状態の確認を行
います。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
ANS3
ANS2
ANS1
属性
R/W
R/W
R/W
ANS0
ADI
ADMV
予約
AD
R/W
R/W
R
W
W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7:4] ANS[3:0]: アナログ入力端子選択ビット
これらのビットは , 使用されるアナログ入力端子を選択し ます。
ソフトウェアにより A/D 変換が起動 (AD = 1) された場合は (ADC2:EXT = 0), これらのビットを同
時に変更できます。
説明 *
bit7:4
"0000" を書き込んだ場合
AN00 端子
"0001" を書き込んだ場合
AN01 端子
"0010" を書き込んだ場合
AN02 端子
"0011" を書き込んだ場合
AN03 端子
"0100" を書き込んだ場合
AN04 端子
"0101" を書き込んだ場合
AN05 端子
"0110" を書き込んだ場合
AN06 端子
"0111" を書き込んだ場合
AN07 端子
"1000" を書き込んだ場合
AN08 端子
"1001" を書き込んだ場合
AN09 端子
"1010" を書き込んだ場合
AN10 端子
"1011" を書き込んだ場合
AN11 端子
*: アナログ入力端子数は品種によって異なります。詳細は , デバイスのデータシートを参照してください。
( 注意事項 )
• 上記以外の値を ANS[3:0] に書き込まないでください。
• ADMV ビットが "1" の場合は , これらのビットを変更しないで ください。アナログ入力端子とし
て使用されない端子は , 汎用入出力ポートとして使用できます。
232
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 15 章 8/12 ビット A/D コンバータ
15.7 レジスタ
Ha rdware
Manual
[bit3] ADI: 割込み要求フラグビット
このビットは , A/D 変換の完了を検出します。
A/D 変換機能を使用している場合は , このビットは A/D 変換の完了直後に "1" に設定されます。
このビットと割込み要求許可ビット (ADC2: ADIE) が "1" になったとき , 割込み要求が出力されま
す。
このビットに "0" を書き込むと, このビットはクリアされます。このビットに "1" を書き込んでもこ
のビットは変化せず , ほかのビットにも影響はありませ ん。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit3
"0" が読み出された場合
A/D 変換がまだ完了していないことを示します。
"1" が読み出された場合
A/D 変換が完了していることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit2] ADMV: 変換中フラグビット
このビットは , A/D 変換が実行中であることを示します。
A/D 変換中 , このビットの値は "1" となります。
このビットはリードオンリです。このビットに値を書き込んでも意味はなく , 動作に影響はありま
せん。
説明
bit2
"0" が読み出された場合
A/D 変換が実行中ではないことを示します。
"1" が読み出された場合
A/D 変換が実行中であることを示します。
[bit1] 予約ビット
このビットは常に "0" に設定してください。
[bit0] AD: A/D 変換起動ビット
このビットは , ソフトウェアにより A/D 変換機能を起動します。
このビットに "1" 書き込むと , A/D 変換機能が起動します。
連続起動許可ビット (ADC2:EXT) が "1" のとき , このビットによる A/D 変換の起動は禁止されます。
EXT ビットが "0" に設定されている場合 , A/D 変換実行中にこのビットに "1" を書き込むと , A/D 変
換は再起動します。
説明
bit0
"0" を書き込んだ場合
動作に影響はありません。
"1" を書き込んだ場合
A/D 変換機能を起動します。
( 注意事項 ) このビットに "0" を書き込んでも , A/D 変換機能の動作を停止させることはできませ
ん。このビットの読出し値は常に "0" です。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
233
第 15 章 8/12 ビット A/D コンバータ
15.7 レジスタ
H ard war e
15.7.2
Ma nu al
8/12 ビット A/D コンバータ制御レジスタ 2 (ADC2)
8/12 ビット A/D コンバータ制御レジスタ 2 (ADC2) は , 8/12 ビット A/D コンバータ
の各機能の制御 , 入力クロックの選択および割込みの許可 / 禁止を行います。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
AD8
TIM1
TIM0
ADCK
ADIE
EXT
CKDIV1
CKDIV0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] AD8: 精度選択ビット
このビットは , A/D 変換の分解能を選択します。
このビットに "0" を書き込んだ場合 , 12 ビット精度が選択されます。
このビットに "1" を書き込んだ場合 , 8 ビット精度が選択されます。ADDL レジスタを読み出すこと
により , 8 ビットデータを取得できます。
説明
bit7
"0" を書き込んだ場合
12 ビット精度
"1" を書き込んだ場合
8 ビット精度
( 注意事項 ) 選択された分解能によって , 使用するデータビットが異なります。このビットを変更す
る前に , A/D コンバータの動作が停止していることを確認してください。
[bit6:5] TIM[1:0]: サンプリング時間選択ビット
このビットは , サンプリング時間を選択します。
動作条件 ( 電圧と周波数 ) に従ってサンプリング時間を変更してください。
CKIN の値はクロック選択ビット (ADC2:CKDIV[1:0]) によって決まります。
説明
bit6:5
"00" を書き込んだ場合
CKIN  2
"01" を書き込んだ場合
CKIN  5
"10" を書き込んだ場合
CKIN  8
"11" を書き込んだ場合
CKIN  14
( 注意事項 ) これらのビットを変更する前に, A/Dコンバータの動作が停止していることを確認して
ください。
[bit4] ADCK: 外部起動信号選択ビット
このビットは , 外部起動時の起動信号を選択します (ADC2:EXT = 1)。
bit4
234
説明
"0" を書き込んだ場合
ADTG 端子を A/D 変換機能起動端子として選択します。
"1" を書き込んだ場合
8/16 ビット複合タイマ出力端子 (TO00) を A/D 変換機能起動端子として選択しま
す。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 15 章 8/12 ビット A/D コンバータ
15.7 レジスタ
Ha rdware
Manual
[bit3] ADIE: 割込み要求許可ビット
このビットは , 割込みコントローラへの割込みの出力を許可または禁止します。
このビットと割込み要求フラグビット (ADC1:ADI) が "1" のとき , 割込み要求が出力されます。
説明
bit3
"0" を書き込んだ場合
割込み要求出力を禁止します。
"1" を書き込んだ場合
割込み要求出力を許可します。
[bit2] EXT: 連続起動許可ビット
このビットは , A/D 変換機能の起動をソフトウェアで行うか , 入力クロックの立上りエッジ検出で
連続的に行うかを選択します。
説明
bit2
"0" を書き込んだ場合
ADC1 レジスタの AD ビットで A/D 変換機能を起動します。
"1" を書き込んだ場合
ADC2 レジスタの ADCK ビットで選択されたクロックで A/D 変換機能を連続的
に起動します。
[bit1:0] CKDIV[1:0]: クロック選択ビット
これらのビットは , A/D 変換に使用するクロック (CKIN) を選択します。入力クロックはプリスケー
ラにより生成されます。詳細は , 「3.9 プリスケーラの動作」を参照してください。
サンプリング時間は , これらのビットで選択されたクロックによって異なります。
動作条件 ( 電圧と周波数 ) に従って , これらのビットを変更してください。
説明
bit1:0
"00" を書き込んだ場合
1 MCLK
"01" を書き込んだ場合
MCLK/2
"10" を書き込んだ場合
MCLK/4
"11" を書き込んだ場合
MCLK/8
( 注意事項 ) これらのビットを変更する前に, A/Dコンバータの動作が停止していることを確認して
ください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
235
第 15 章 8/12 ビット A/D コンバータ
15.7 レジスタ
H ard war e
15.7.3
Ma nu al
8/12 ビット A/D コンバータ制御レジスタ 3 (ADC3)
8/12 ビット A/D コンバータ制御レジスタ 3 (ADC3) は 8/12 ビット A/D コンバータを
動作許可状態に設定します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
ENTM4
ENTM3
ENTM2
ENTM1
ENTM0
READY
ENBL
属性
—
R/W
R/W
R/W
R/W
R/W
R
R/W
初期値
0
1
1
1
1
1
0
0
■ レジスタ機能
[bit7] 未定義ビット
読出し値は常に "0" です。このビットに値を書き込んでも動作に影響はありません。
[bit6:2] ENTM[4:0]: 動作許可状態遷移サイクル選択ビット
これらのビットは動作許可状態遷移時間サイクル数を選択します。
動作許可状態遷移時間 = マシンクロック (MCLK) サイクル  (ENTM[4:0] の値  1)
例:
MCLK = 16.25 MHz (61 ns)
ENTM[4:0] = 0x1F
動作許可状態遷移時間 = 61 ns  (31  1) = 1925 ns
[bit1] READY: A/D コンバータ動作許可状態ビット
このビットは 8/12 ビット A/D コンバータが動作許可状態になっているかを示します。
8/12 ビット A/D コンバータは , 動作許可状態のときのみ A/D 変換を行えます。
動作禁止状態中にすべての A/D 変換要求は無視されます。
A/D 変換中に , 8/12 ビット A/D コンバータが動作許可禁止状態に遷移した場合 , A/D 変換は変換シー
ケンス終了 (ADC1:ADMV = 0) 後に停止します。
bit1
説明
"0" を読み出した場合
8/12 ビット A/D コンバータが動作禁止状態になっていることを示します。
"1" を読み出した場合
8/12 ビット A/D コンバータが動作許可状態になっていることを示します。
[bit0] ENBL: A/D コンバータ動作許可 / 禁止ビット
このビットは 8/12 ビット A/D コンバータの動作を許可または禁止します。
このビットに "1" を書き込むことで , 動作許可状態遷移時間経過後に 8/12 ビット A/D コンバータは
動作許可状態になります。このビットに "0" を書き込むことで , 8/12 ビット A/D コンバータは動作
禁止状態になります。
bit0
236
説明
"0" を書き込んだ場合
8/12 ビット A/D コンバータの動作を禁止します。
"1" を書き込んだ場合
8/12 ビット A/D コンバータの動作を許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 15 章 8/12 ビット A/D コンバータ
15.7 レジスタ
Ha rdware
Manual
<注意事項>
•
ENBL ビットへの "1" の書込みから READY ビットが "1" になることまでの動作許可状
態遷移時間中に , ENTM[4:0] ビットの書換えは禁止されます。ENBL ビットに "1" が書
き込まれたとき , ENTM[4:0] ビットを書き換える場合 , READY ビットが "1" に設定さ
れていることを前もって確認しておいてください。
•
リセットが発生するか , あるいはストップモードまたは時計モードが開始すると , 8/
12 ビット A/D コンバータは直ちに停止し , ADMV ビット , READY ビットと ENBL ビッ
トは "0" にクリアされます。
•
A/D 変換中に ADC3 レジスタの ENBL ビットに "0" が書き込まれた場合 , A/D 変換はし
ばらく継続します。ENBL ビットに "1" を書き込むことで再度 8/12 ビット A/D コンバー
タの動作を許可する前に , ADC1 レジスタの ADMV ビットで前の A/D 変換動作が完了
していること (ADC1:ADMV = 0) を確認してください。
•
A/D 変換中に , ENBL ビットへの "0" の書込み , あるいはストップモードまたは時計モー
ドを設定することによって 8/12 ビット A/D コンバータが停止すると , ADC1 レジスタ
の ADI ビット (ADC1:ADI) が A/D 変換完了を示すこと (ADC1:ADI = 1) がありますが ,
そのとき 8/12 ビット A/D コンバータデータレジスタ ( 上位 ) (ADDH) と 8/12 ビット A/
D コンバータデータレジスタ ( 下位 ) (ADDL) に格納されている値は不定です。したがっ
て , 割込みシーケンスで , ADDH レジスタと ADDL レジスタの値を参照しないでくだ
さい。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
237
第 15 章 8/12 ビット A/D コンバータ
15.7 レジスタ
H ard war e
15.7.4
Ma nu al
8/12 ビット A/D コンバータデータレジスタ
( 上位 / 下位 ) (ADDH/ADDL)
8/12 ビット A/D コンバータデータレジスタ ( 上位 / 下位 ) (ADDH/ADDL) は , 12 ビッ
ト A/D 変換中に , 12 ビット A/D 変換結果を格納します。
12 ビットデータの上位 4 ビットが ADDH レジスタに , 下位 8 ビットが ADDL レジス
タに格納されます。
■ レジスタ構成
ADDH
bit
7
6
5
4
3
2
1
0
Field
—
—
—
—
SAR11
SAR10
SAR9
SAR8
属性
—
—
—
—
R
R
R
R
初期値
0
0
0
0
0
0
0
0
ADDL
bit
7
6
5
4
3
2
1
0
Field
SAR7
SAR6
SAR5
SAR4
SAR3
SAR2
SAR1
SAR0
属性
R
R
R
R
R
R
R
R
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
12 ビットの A/D データのうち , 上位 4 ビットが ADDH レジスタの bit3 ~ bit0 に , 下位
8 ビットが ADDL レジスタの bit7 ~ bit0 にそれぞれ対応します。
ADC2 レジスタの AD8 ビットに "1" が設定されている場合は , 8 ビット精度が選択さ
れます。ADDL レジスタを読み 出すことにより , 8 ビットデータを取得できます。
これらのレジスタはリードオンリです。データを書き込んでも動作に影響はありませ
ん。
8 ビット精度が選択された A/D 変換では , ADDH レジスタの SAR[11:8] ビット は "0"
にな ります。
● A/D 変換機能
A/D 変換を起動すると , レジスタの設定による変換時間の経過後に変換結果が確定し ,
ADDH レジスタと ADDL のレジスタに格納されます。A/D 変換完了後 , 次の A/D 変換
が完了する前に , A/D データレジスタ ( 変換結果 ) を読み出し , ADC1 レジスタの ADI
フラグビット (ADI) をクリアしてください。A/D 変換中に , ADDH レジスタと ADDL
レジスタの値は , 前回の A/D 変換結果となります。
238
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 15 章 8/12 ビット A/D コンバータ
15.8 使用上の注意
Ha rdware
15.8
Manual
使用上の注意
8/12 ビット A/D コンバータ使用上の注意を示します。
■ 8/12 ビット A/D コンバータ使用上の注意
● プログラムによる 8/12 ビット A/D コンバータの設定に関する注意事項
•
A/D 変換機能時 , ADDH, ADDL レジスタの内容は A/D 変換終了時に保持されます。
したがって , A/D 変換中は前回変換した値が読み出されます。
•
A/D 変換機能の使用中は , アナログ入力端子選択ビット (ADC1:ANS[3:0]) を変更し
ないでく ださい。特に連続起動中は , アナログ入力端子を変更する前に連続起動を
禁止 (ADC2:EXT = 0) してください。
•
リセットが発生するか , あるいはストップモードまたは時計モードが開始すると ,
8/12 ビット A/D コンバータは停止し , ADMV ビットは "0" にクリアされます。
•
割込み要求フラグビット (ADC1:ADI) が "1" で , 割込み要求が許可されている場合
(ADC2:ADIE = 1) は , CPU は割込み処理から復帰できません。必ず割込みサービス
ルーチン内で ADI ビットをクリアしてください。
● 割込み要求に関する注意事項
A/D 変換の再起動 (ADC1:AD = 1) と A/D 変換の完了が同時に発生した場合は , 割込み
要求フラグビット (ADC1:ADI) が "1" に設定されます。
● 誤差について
| Vcc - Vss | が小さくなるに従い , それに比例して A/D 変換の誤差は増大します。
● 8/12 ビット A/D コンバータのアナログ入力順序
アナログ入力 (ANn) とデジタル電源 (VCC) を同時に投入するかまたはデジ タル電源投
入後にアナログ入力を投入してください。
デジタル電源 (VCC) は , アナログ入力 (ANn) と同時に切断するかまたはア ナログ入力
(ANn) 切断後に切断してください。
8/12 ビット A/D コンバータの電源投入 / 切断時には , アナログ入力電圧がデジタル電
源の電圧を超えないでください。
● 変換時間
A/D 変換の変換速度は , クロックモード , メインクロック発振周波数 , メインクロック
の速度切換え ( ギア機能 ) に影響されます。
例:
サンプリング時間 = CKIN  (ADC2:TIM[1:0] 設定 )
比較 ( コンペア ) 時間 = CKIN  13 ( 固定値 ) + MCLK
8/12 ビット A/D コンバータ起動時間 : 最短時間 = MCLK  2 + CKIN  2
最長時間 = MCLK + CKIN  3
変換時間 = 8/12 ビット A/D コンバータ起動時間 + サンプリング時間 + 比較時間
April 4, 2014, MB95F718M_MN702-00014-3v0-J
239
第 15 章 8/12 ビット A/D コンバータ
15.8 使用上の注意
H ard war e
240
Ma nu al
•
A/D 変換が開始した時間によって , 変換時間には最大 (1 CKIN - 1 MCLK) の誤差が
生じることがあります。
•
ソフトウェアで 8/12 ビット A/D コンバータを設定する場合は , その設定がデバイス
のデータシートに記載された 8/12 ビット A/D コンバータの各タイミング仕様を満
たしていることを確認してください。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 16 章
低電圧検出回路
低電圧検出回路の機能と動作について説明します。
16.1 概要
16.2 構成
16.3 端子
16.4 割込み
16.5 動作説明
16.6 レジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
241
第 16 章 低電圧検出回路
16.1 概要
H ard war e
16.1
Ma nu al
概要
低電圧検出回路は , 電源電圧を監視し , 電源電圧が検出電圧より低下した場合に , リ
セット信号を発生します。また , 選択されたしきい値レベルをまたぐ電源電圧変動が
発生したときに割込みも発生できます。
■ 低電圧検出回路
低電圧検出回路は , 電源電圧を監視し , 電源電圧が検出電圧より低下したときにリセッ
ト信号を発生します。また , 電源電圧選択されたしきい値レベルをまたいで変動したと
きに割込みも発生できます。割込みのしきい値電圧は , LVD 制御レジスタ (LVDC) で
6 種類から選択できます。
電源投入時 , リセットしきい値電圧の最小値が LVDC レジスタで選択されます。
この回路は特定の品種にのみ搭載されています。デバイスのデータシートでこの回路
の有無を確認してください。
電気的特性の詳細についても , デバイスのデータシートを参照してください。
242
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 16 章 低電圧検出回路
16.2 構成
Ha rdware
16.2
Manual
構成
図 16.2-1 に , 低電圧検出回路のブロックダイヤグラムを示します。
■ 低電圧検出回路のブロックダイヤグラム
図 16.2-1 低電圧検出回路のブロックダイヤグラム
VCC
−
リセット信号
N-ch
+
Vref
LVD制御レジスタ(LVDC)
LVIIF
LVIEN
LVDLP
LVDSEL3
LVDSEL2
LVDSEL1
LVDSEL0
LVIF
VCC
IRQ
1100
動作モード制御
1010
1001
−
0111
+
0101
N-ch
Vref
0010
April 4, 2014, MB95F718M_MN702-00014-3v0-J
243
第 16 章 低電圧検出回路
16.3 端子
H ard war e
16.3
Ma nu al
端子
低電圧検出回路の端子について説明します。
■ 低電圧検出回路の端子
● VCC 端子
低電圧検出回路は , 本端子の電圧を監視します。
● VSS 端子
この端子は , 電圧検出の基準となる GND 端子です。
● RST 端子
低電圧検出リセット信号はマイコン内部と本端子へ出力されます。
244
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 16 章 低電圧検出回路
16.4 割込み
Ha rdware
16.4
Manual
割込み
低電圧検出回路は , 電源電圧が LVD 制御レジスタの低電圧割込みしきい値電圧選択
ビット (LVDC:LVDSEL[3:0]) で選択されたしきい値をまたいで変動した場合に , 割込
み要求を出力します。
■ 低電圧検出回路の割込み
表 16.4-1 に , 低電圧検出回路の割込み制御ビットと割込み要因を示します。
表 16.4-1 低電圧検出回路 の割込み制御ビットと割込み要因
項目
説明
割込み要求フラグビット
LVDC:LVIIF
割込み要求許可ビット
LVDC:LVIEN
割込み要因
LVD 制御レジスタの低電圧割込みしきい値電圧選択ビット (LVDC:LVDSEL[3:0]) で
選択されたしきい値をまたぐ電源電圧変動の発生。
低電圧割込み要求フラグビット (LVDC:LVIIF) が "1" に設定され , 低電圧割込み要求が
許可された (LVDC:LVIEN = 1) とき , CPU は割込み処理から復帰できません。必ず割込
みサービスルーチン内で LVIIF ビットをクリアしてください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
245
第 16 章 低電圧検出回路
16.5 動作説明
H ard war e
16.5
Ma nu al
動作説明
低電圧検出回路は , 電源電圧が検出電圧よりも低下したときにリセット信号を発生し
ます。また , 電源電圧が選択されたしきい値電圧をまたいで変動した場合に , 割込み
信号を発生します。
■ 割込みしきい値電圧の変更
LVDCレジスタに設定された割込みしきい値電圧が変更された場合, 新しく設定された
割込みしきい値電圧は , 割込みしきい値電圧遷移安定時間 (tstb) が経過してから有効に
なります。tstb の詳細について , デバイスのデータシートを参照してください。また ,
誤検出を避けるために , 割込みしきい値電圧を変更するとき , 以下の手順に従ってくだ
さい。
1. 低電圧割込み要求許可ビット (LVDC:LVIEN) に "0" を書き込んで , 割込みを禁止し
てください。
2. 低電圧割込みしきい値電圧選択ビット (LVDC:LVDSEL[3:0]) の値を変更してくださ
い。
3. 割込みしきい値電圧遷移安定時間 (tstb), 割込み検出遅延時間 (tdi2 または tdiL2) と割
込み解除遅延時間 (tdi1 または tdiL1) が経過するのを待って , 誤った低電圧検出をマ
スクします。
4. 低電圧割込み要求フラグビット (LVDC:LVIIF) に "0" を書き込んで , このビットをク
リアします。
5. LVIEN ビットに "1" を書き込んで , 割込みを許可します。
tdi1, tdiL1, tdi2 と tdiL2 の詳細について , デバイスのデータシートを参照してください。
■ 割込み用低電圧検出回路の動作モード変更
割込み用低電圧検出回路では , LVDC レジスタの割込み用 LVD 低消費電力切換えビッ
ト (LVDC:LVDLP) により通常モードと低消費電力モードとの間に切り換えられます。
低消費電力モードでは , 通常モードに比べ , 割込み検出電圧精度と割込み解除電圧精度
が劣り , かつ割込み検出遅延時間と割込み解除遅延時間がより長い替わりに , 消費電力
がより低いです。
動作モードが変更された場合 , 新しく設定された動作モードは , 割込み用低電圧検出
モード遷移時間 (tmdsw) が経過してから有効になります。
tmdsw の詳細について , デバイスのデータシートを参照してください。
246
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 16 章 低電圧検出回路
16.5 動作説明
Ha rdware
Manual
■ 低電圧検出リセット回路の動作
低電圧検出リセット回路は , 電源電圧が低電圧検出電圧よりも低下したときにリセッ
ト信号を発生します。その後 , 低電圧検出解除電圧を検出すると , 発振安定待ち時間の
間リセット信号を継続して出力し , リセットを解除します。
電気的特性の詳細については , デバイスのデータシートを参照してください。
図 16.5-1 低電圧検出リセット回路の動作
低電圧リセット検出/解除電圧
動作電圧の下限
Vcc
B
B
B
リセット信号
A
A
A
A
A
A: リセット検出/解除遅延時間
B: 発振安定待ち時間
April 4, 2014, MB95F718M_MN702-00014-3v0-J
247
第 16 章 低電圧検出回路
16.5 動作説明
H ard war e
Ma nu al
■ 低電圧検出割込み回路の動作
電源電圧がLVD制御レジスタの低電圧割込みしきい値電圧選択ビット(LVDC:LVDSEL[3:0])
で選択されたしきい値をまたいで変動すると , LVD 制御レジスタの低電圧割込み要求
フラグビット (LVDC:LVIIF) が "1" に設定されます。
図 16.5-2 低電圧検出割込み回路の動作
割込みしきいち設定電圧
Vcc
“0”の書込み
“0”の書込み
LVIIFビット
(割込みフラグ)
A
A
A
A: 割込み検出遅延時間
■ スタンバイモード時の動作
低電圧検出回路は , スタンバイモード ( ストップモード , スリープモード , サブクロッ
クモード , 時計モード ) においても常に動作します。
248
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 16 章 低電圧検出回路
16.6 レジスタ
Ha rdware
16.6
Manual
レジスタ
低電圧検出回路のレジスタについて説明します。
表 16.6-1
低電圧検出回路のレジスタ一覧
レジスタ略称
LVDC
レジスタ名
LVD 制御レジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
参照先
16.6.1
249
第 16 章 低電圧検出回路
16.6 レジスタ
H ard war e
16.6.1
Ma nu al
LVD 制御レジスタ (LVDC)
LVD 制御レジスタ (LVDC) は割込みしきい値電圧の選択 , 電圧条件の表示 , 割込みの
制御 , 低電圧割込みフラグステータスの確認を行います。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
LVIIF
LVIEN
LVDLP
LVDSEL3
LVDSEL2
LVDSEL1
LVDSEL0
LVIF
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R
初期値
0
0
0
0
0
1
0
0
■ レジスタ機能
[bit7] LVIIF: 低電圧割込み要求フラグビット
電源電圧が低電圧割込みしきい値選択ビット (LVDSEL[3:0]) で選択されたしきい値電圧をまたいで
変動すると , このフラグビットが "1" に設定されます。
このビットと低電圧割込み要求許可ビット (LVIEN) がともに "1" に設定されると , 低電圧割込み要
求が出力されます。
パワーオン後 , 電源電圧が最低割込み検出電圧を常に下回る場合 , このビットは "0" のままになりま
す。この場合 , LVIF ビットをポーリングして電源電圧を確認してください。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit7
"0" が読み出された場合
電源電圧が低電圧割込みしきい値選択ビット (LVDSEL[3:0]) で選択されたしき
い値電圧をまたいで変動したことがないことを示します。
"1" が読み出された場合
電源電圧が低電圧割込みしきい値選択ビット (LVDSEL[3:0]) で選択されたしき
い値電圧をまたいで変動したことを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit6] LVIEN: 低電圧割込み要求許可ビット
このビットは割込みコントローラへの低電圧割込み要求出力を許可または禁止します。
このビットと低電圧割込み要求フラグビット (LVIIF) がともに "1" に設定されると , 低電圧割込み要
求が出力されます。
bit6
250
説明
"0" を書き込んだ場合
低電圧割込み要求出力を禁止します。
"1" を書き込んだ場合
低電圧割込み要求出力を許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 16 章 低電圧検出回路
16.6 レジスタ
Ha rdware
Manual
[bit5] LVDLP: 割込み用 LVD 低消費電力切換えビット
このビットは割込み検出用低電圧検出回路の動作モード ( 通常モードまたは低消費電力モード ) を
選択します。
動作モード間の違いは以下のとおりです。
• 消費電力
通常モードは低消費電力モードに比べて消費電力が高くなります。
• 検出電圧と解除電圧との精度
通常モードは低消費電力モードに比べて精度がよくなります。
消費電力 , 検出電圧と解除電圧との精度についての詳細は , デバイスのデータシートを参照してく
ださい。
説明
bit5
"0" を書き込んだ場合
通常モードを選択します。
"1" を書き込んだ場合
低消費電力モードを選択します。
[bit4:1] LVDSEL[3:0]: 低電圧割込みしきい値電圧選択ビット
これらのビットは割込みしきい値電圧を選択します。
説明
bit4:1
電源電圧降下時
電源電圧上昇時
"0010" を書き込んだ場合
2.2 V
2.3 V
"0101" を書き込んだ場合
2.5 V
2.6 V
"0111" を書き込んだ場合
2.8 V
2.9 V
"1001" を書き込んだ場合
3.2 V
3.3 V
"1010" を書き込んだ場合
3.6 V
3.7 V
"1100" を書き込んだ場合
4V
4.1 V
( 注意事項 ) 上記以外の値を LVDSEL[3:0] ビットに書き込むことは禁止されます。
[bit0] LVIF: 低電圧ステータスビット
このビットは電源電圧としきい値電圧の関係を示します。
説明
bit0
"0" を読み出した場合
電源電圧が LVDSEL[3:0] ビットで設定されたしきい値電圧より高いことを示し
ます。
"1" を読み出した場合
電源電圧が LVDSEL[3:0] ビットで設定されたしきい値電圧より低いことを示し
ます。
<注意事項>
LVDC レジスタはパワーオンリセットでのみクリアされます。低電圧検出リセットはこの
レジスタに影響を与えません。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
251
第 16 章 低電圧検出回路
16.6 レジスタ
H ard war e
252
Ma nu al
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 17 章
クロックスーパバイザ
カウンタ
クロックスーパバイザカウンタの機能と動作につ
いて説明します。
17.1 概要
17.2 構成
17.3 動作説明
17.4 レジスタ
17.5 使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
253
第 17 章 クロックスーパバイザ カウンタ
17.1 概要
H ard war e
17.1
Ma nu al
概要
クロックスーパバイザカウンタは , 外部クロック周波数を調べて , 外部クロックの異
常状態を検出します。
■ クロックスーパバイザカウンタの概要
クロックスーパバイザカウンタは , 外部クロック周波数を調べて , 外部クロックの異常
状態を検出します。
クロックスーパバイザカウンタは, 8つのオプションから選ばれたタイムベースタイマの
インターバル時間内で , 外部クロック入力に基づいてカウンタを自動的にカウント
アップします。
このモジュールのカウントクロックは , メイン発振クロックとサブ発振クロックのど
ちらか選択できます。
<注意事項>
クロックスーパバイザカウンタは , メイン CR クロックモードで , ( スタンバイモードで動
作する ) ハードウェアウォッチドッグタイマとともに動作させてください。
上記以外の場合 , このカウンタは外部クロックの異常状態を正しく検出することはできず ,
外部クロックが停止するとハングアップしてしまいます。
( スタンバイモードで動作する ) ハードウェアウォッチドッグタイマについては ,「第 8 章
ハードウェア / ソフトウェアウォッチドッグタイマ」を参照してください。
254
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 17 章 クロックスーパバイザ カウンタ
17.2 構成
Ha rdware
17.2
Manual
構成
クロックスーパバイザカウンタは , 以下のブロックで構成されます。
• 制御回路
• クロック監視制御レジスタ (CMCR)
• クロック監視データレジスタ (CMDR)
• タイムベースタイマ出力セレクタ
• カウンタソースクロックセレクタ
■ クロックスーパバイザカウンタのブロックダイヤグラム
図 17.2-1 に , クロックスーパバイザカウンタのブロックダイヤグラムを示します。
図 17.2-1 クロックスーパバイザカウンタのブロックダイヤグラム
エッジ検出
タイムベースタイマ出力
タイムベース
タイマ出力
セレクタ
8ビットカウンタ
3
メイン発振クロック
サブ発振クロック
カウンタ
ソース
クロック
セレクタ
1回目: カウント開始
2回目: カウント停止
CLK
制御回路
カウンタ動作許可
クロック監視制御レジスタ(CMCR)
クロック監視データレジスタ(CMDR)
内部バス
April 4, 2014, MB95F718M_MN702-00014-3v0-J
255
第 17 章 クロックスーパバイザ カウンタ
17.2 構成
H ard war e
Ma nu al
● 制御回路
このブロックは , クロック監視制御レジスタ (CMCR) の設定に基づき , カウンタの開始
と停止 , カウンタクロックソースとカウンタ許可期間を制御します。
● クロック監視制御レジスタ (CMCR)
このレジスタは , カウンタソースクロックの選択 , 8 種類の異なるタイムベースタイマ
インターバルからのカウンタ許可期間の選択 , カウンタの開始およびカウンタが動作
中かどうかの確認を行います。
● クロック監視データレジスタ (CMDR)
このレジスタブロックは , カウンタ停止後にカウンタ値を読み出すために使用します。
ソフトウェアが , このレジスタの内容に従い , 外部クロック周波数が正しいかどうかを
判断します。
● タイムベースタイマインターバルセレクタ
このブロックは , 8 種類のタイムベースタイマインターバルからカウンタ許可期間を選
択するために使用します。
● カウンタソースクロックセレクタ
このブロックは , メイン発振クロックとサブ発振クロックからカウンタソースクロッ
クを選択するために使用します。
256
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 17 章 クロックスーパバイザ カウンタ
17.3 動作説明
Ha rdware
17.3
Manual
動作説明
クロックスーパバイザカウンタの動作について説明します。
■ クロックスーパバイザカウンタ
● クロックスーパバイザカウンタの動作 1
ソフトウェアによってクロックスーパバイザカウンタの動作が許可されると(CMCEN = 1),
クロックスーパバイザカウンタは , TBTSEL[2:0] ビットによって 8 種類から選択された
タイムベースタイマインターバルで動作します。選択されたタイムベースタイマイン
ターバルの2つの立上りエッジの間, 内部カウンタは外部クロックにより時間が計測さ
れます。
このモジュールのカウントクロックとして , メイン発振クロックとサブ発振クロック
とのどちらかを選択できます。
図 17.3-1 クロックスーパバイザカウンタの動作 1
選択したタイムベースタイマインターバル
メイン/サブ発振クロック
CMCEN
内部カウンタ
0
CMDRレジスタ
30
0
30
● クロックスーパバイザカウンタの動作 2
CMCEN ビットが "0" から "1" に変わると , CMDR レジスタがクリアされます。
図 17.3-2 クロックスーパバイザカウンタの動作 2
選択したタイムベースタイマインターバル
メイン/サブ発振クロック
CMCEN
内部カウンタ
CMDRレジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
クリア
0
10
0
10
10
0
0
10
257
第 17 章 クロックスーパバイザ カウンタ
17.3 動作説明
H ard war e
Ma nu al
● クロックスーパバイザカウンタの動作 3
カウント値が "255" に達すると , カウンタは停止します。それ以上カウントを続けるこ
とはできません。
図 17.3-3 クロックスーパバイザカウンタの動作 3
選択したタイムベースタイマインターバル
メイン/サブ発振クロック
CMCEN
内部カウンタ
0
CMDRレジスタ
255
0
255
● クロックスーパバイザカウンタの動作 4
選択されている外部クロックが停止すると , カウントを停止します。このカウンタ停止
により , ソフトウェアは選択されている外部クロックが異常状態にあることを認識し
ます。
図 17.3-4 クロックスーパバイザカウンタの動作 4
選択したタイムベースタイマインターバル
メイン/サブ発振クロック
CMCEN
内部カウンタ
0
CMDRレジスタ
0
● クロックスーパバイザカウンタの動作 5
カウンタの動作中に CMCEN に "0" が設定されると , カウンタはソフトウェアにより
"0" にクリアされます。
図 17.3-5 クロックスーパバイザカウンタの動作 5
選択したタイムベースタイマインターバル
メイン/サブ発振クロック
ソフトウェアにより設定
CMCEN
内部カウンタ
CMDRレジスタ
258
0
0
0
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 17 章 クロックスーパバイザ カウンタ
17.3 動作説明
Ha rdware
Manual
■ タイムベースタイマインターバルとクロックスーパバイザカウンタ値の対応表
表 17.3-1 に , 様々な外部クロックを測定するための各種のメイン CR クロック周波数に
対し , 適切なタイムベースタイマインターバルを示します。
表 17.3-1 TBTSEL 設定に対するカウンタ値の表
メイン メイン /
メイ
CR サブ水
測定
ン CR
(FCRH) 晶発振
誤差
[MHz] [MHz] 誤差
0.03277
0.5
1
4
4
6
10
20
32.5
+2%
-2%
+2%
-2%
+2%
-2%
+2%
-2%
+2%
-2%
+2%
-2%
+2%
-2%
+2%
-2%
-1
+1
-1
+1
-1
+1
-1
+1
-1
+1
-1
+1
-1
+1
-1
+1
TBTSEL[2:0]
"000"
"001"
"010"
"011"
"100"
"101"
"110"
"111"
(231/FCRH)
(251/FCRH)
(271/FCRH
(291/FCRH)
(2111/FCRH)
(2131/FCRH)
(2151/FCRH)
(2171/FCRH)
0
1
0
1
0
2
2
5
4
7
8
11
18
21
30
34
0
1
0
3
2
5
14
17
22
25
38
41
77
82
126
133
0
1
6
9
14
17
61
66
93
98
155
164
312
327
508
531
1
3
30
33
61
66
249
262
375
392
626
654
1253
1307
2038
2123
7
9
124
131
249
262
1002
1045
1504
1568
2508
2613
5018
5225
8155
8490
31
35
500
523
1002
1045
4014
4180
6022
6270
10038
10449
20077
20898
32626
33960
130
137
2006
2090
4014
4180
16061
16719
24093
25078
40155
41796
80312
83592
130508
135837
525
548
8030
8360
16061
16719
64249
66874
96375
100311
160626
167184
321253
334368
522038
543347
: 推奨設定
: カウンタ値は "0" または "255" になります。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
259
第 17 章 クロックスーパバイザ カウンタ
17.3 動作説明
H ard war e
Ma nu al
表 17.3-1 は , 以下の式により計算されています。
3
カウンタ値 =
2 × 1/FCRH(TBTSEL=000)
5
2 × 1/FCRH(TBTSEL=001)
7
2 × 1/FCRH(TBTSEL=010)
9
2 × 1/FCRH(TBTSEL=011)
11
2 × 1/FCRH(TBTSEL=100)
13
2 × 1/FCRH(TBTSEL=101)
15
2 × 1/FCRH(TBTSEL=110)
17
2 × 1/FCRH(TBTSEL=111)
× メイン/サブ発振クロック周波数
± 1 (測定誤差)
2
*カウンタ値の小数を切り捨ててください。
選択したタイムベースタイマインターバル
この間では, 上記の式のカウンタ値はメイン/サブ発振
クロックによりカウントされます。
発振が安定するまでクロックスーパバイザカウンタを待機させるために , タイムベー
スタイマ割込みを使用する場合は , 以下の条件を満たしてください。
タイムベースタイマインターバル > メイン / サブ発振安定時間  1.05
例:FCH = 4 MHz, FCRH = 1 MHz, MWT[3:0] = 0b1111 (WATR レジスタ内 )
14
タイムベースタイマインターバル >
----------------------2 – 2
 1.05  4.3 ms
6
4  10
TBC[3:0] = 0b0110 (213  1/FCRH)
<注意事項>
• タイムベースタイマインターバルの設定については ,「7.1 概要」を参照してください。
• メイン / サブ発振安定時間の設定については , 「3.3.3 発振安定待ち時間設定レジスタ
(WATR)」を参照してください。
260
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 17 章 クロックスーパバイザ カウンタ
17.3 動作説明
Ha rdware
Manual
■ クロックスーパバイザの動作フローチャート例
図 17.3-6 クロックスーパバイザの動作フローチャート例
クロック監視開始
発振安定待ち時間
経過
NO
メインCRクロックモードにて,タイムベースタイ
マ割込みやそのほかの方法を使用し, 設定した発
振安定待ち時間が経過するまで待ってください。
YES
メインクロック/
サブクロック
発振安定ビット*を
読み出す
“0”
“1”
CMCSEL,TBTSEL[2:0],CMCENを設定
CMCENを読み出す
“1”
“0”
CMDR値 = 予測値?
NO
YES
対象外部クロックを変更
(正常発振)
メインCRクロックモードを維持
します。
(外部クロックが異常周波数で
発振しています。)
メインCRクロックモードを維持し
ます。
(発振安定待ち時間が経過したにも
かかわらず, メインクロック/サブ
クロック発振安定ビットが"1"にな
っていないため, 外部クロックは
既に停止しているかまたは異常周
波数になっています。)
* : メインクロック発振安定ビット - SYCC2:MRDY
サブクロック発振安定ビット - SYCC2:SRDY
April 4, 2014, MB95F718M_MN702-00014-3v0-J
261
第 17 章 クロックスーパバイザ カウンタ
17.4 レジスタ
H ard war e
17.4
Ma nu al
レジスタ
クロックスーパバイザカウンタのレジスタについて説明します。
表 17.4-1
クロックスーパバイザカウンタのレジスタ一覧
レジスタ略称
262
レジスタ名
参照先
CMDR
クロック監視データレジスタ
17.4.1
CMCR
クロック監視制御レジスタ
17.4.2
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 17 章 クロックスーパバイザ カウンタ
17.4 レジスタ
Ha rdware
Manual
クロック監視データレジスタ (CMDR)
17.4.1
クロック監視データレジスタ (CMDR) は , クロックスーパバイザカウンタの停止後に
カウント値を読み出すために使用します。ソフトウェアが , このレジスタの内容に従
い , 外部クロック周波数が正しいかどうかを確認できます。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
CMDR7
CMDR6
CMDR5
CMDR4
CMDR3
CMDR2
CMDR1
CMDR0
属性
R
R
R
R
R
R
R
R
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
クロック監視データレジスタ (CMDR) は , クロックスーパバイザカウンタの停止後にカウンタ値を
読み出すために使用されます。
• カウンタ値は , このクロック監視データレジスタ (CMDR) から読み出せます。ソフトウェアは , 読
み出したカウンタ値と選択されているタイムベースタイマインターバルに従い , 外部クロック周
波数が正しいかどうかを確認できます。
[bit7:0] CMDR[7:0]: クロック監視データビット
これらのビットは , カウンタ停止後のクロックスーパバイザカウンタの値を示します。
以下のいずれかのイベントが発生すると , これらのビットはクリアされます。
• リセット
• ソフトウェアにより CMCR レジスタの CMCEN ビット (CMCR:CMCEN) が "0" から "1" に変更さ
れます。
• カウンタ動作中に , ソフトウェアにより CMCEN ビットが "1" から "0" に変更されます。
• 外部クロックの停止後 , 選択されているタイムベースタイマクロックの立下りエッジを 2 回検出
します ( 図 17.5-2 を参照してください )。
<注意事項>
カウンタが動作している間 (CMCR:CMCEN = 1) は , このレジスタの値は "0b00000000"
です。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
263
第 17 章 クロックスーパバイザ カウンタ
17.4 レジスタ
H ard war e
17.4.2
Ma nu al
クロック監視制御レジスタ (CMCR)
クロック監視制御レジスタ (CMCR) は , カウンタソースクロックの選択 , カウンタ許
可期間として使われるタイムベースタイマインターバルの選択 , カウンタの開始およ
びカウンタが動作中かどうかの確認を行うために使用します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
予約
CMCSEL
TBTSEL2
TBTSEL1
TBTSEL0
CMCEN
属性
—
—
W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7:6] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit5] 予約ビット
このビットは常に "0" に設定してください。
[bit4] CMCSEL: カウンタクロック選択ビット
このビットは , カウンタのソースクロックを選択します。
説明
bit4
"0" を書き込んだ場合
外部メイン発振クロックをカウンタのソースクロックとして選択します。
"1" を書き込んだ場合
外部サブ発振クロックをカウンタのソースクロックとして選択します。
[bit3:1] TBTSEL[2:0]: タイムベースタイマカウンタ出力選択ビット
これらのビットは , タイムベースタイマのインターバルを選択します。
クロックスーパバイザカウンタの動作は , これらのビットによって選択されたタイムベースタイマ
の出力にしたがって , 特定の時間に許可または禁止されます。
選択されたインターバルの最初の立上りエッジでカウンタ動作が許可され , 2 回目の立上りエッジ
でカウンタ動作が禁止されます。
説明
(FCRH: メイン CR クロック )
bit3:1
264
"000" を書き込んだ場合
23  1/FCRH
"001" を書き込んだ場合
25  1/FCRH
"010" を書き込んだ場合
27  1/FCRH
"011" を書き込んだ場合
29  1/FCRH
"100" を書き込んだ場合
211  1/FCRH
"101" を書き込んだ場合
213  1/FCRH
"110" を書き込んだ場合
215  1/FCRH
"111" を書き込んだ場合
217  1/FCRH
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 17 章 クロックスーパバイザ カウンタ
17.4 レジスタ
Ha rdware
Manual
[bit0] CMCEN: カウンタ許可ビット
このビットは , クロックスーパバイザカウンタの動作を許可または禁止します。
このビットに "0" を書き込んだ場合 , カウンタが停止し , CMDR レジスタが "0b00000000" にクリア
されます。
このビットへの "1" の書込みは カウンタの動作を許可します。カウンタは , タイムベースタイマイ
ンターバルの最初の立上りエッジを検出した時点で動作を開始します。同じインターバルの 2 回目
の立上りエッジを検出すると , 動作を停止します。
カウンタが停止すると , このビットが自動的に "0" に設定されます。
説明
bit0
"0" を書き込んだ場合
カウンタ動作を禁止します。
"1" を書き込んだ場合
カウンタ動作を許可します。
<注意事項>
• CMCEN ビットが "1" のときに , CMCSEL ビットの設定を変更しないでください。
• CMCEN ビットが "1" のときに , TBTSEL[2:0] ビットの設定を変更しないでください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
265
第 17 章 クロックスーパバイザ カウンタ
17.5 使用上の注意
H ard war e
17.5
Ma nu al
使用上の注意
クロックスーパバイザカウンタ使用上の注意を示します。
■ クロックスーパバイザカウンタの使用上の注意
● 制限事項
• クロックスーパバイザカウンタは , メイン CR クロックモードで , ( スタンバイモー
ドで動作する)ハードウェアウォッチドッグタイマとともに動作させてください。そ
うしないと , 外部クロックの異常状態を正しく検出することはできず , 外部クロッ
クが停止するとハングアップしてしまいます。( スタンバイモードで動作する ) ハー
ドウェアウォッチドッグタイマについては ,「第 8 章 ハードウェア / ソフトウェア
ウォッチドッグタイマ」を参照してください。
• メインCRクロックモードのみを使用してください。それ以外のクロックモードは使
用しないでください。
• タイムベースタイマが停止すると , 内部カウンタは動作を停止します。
クロックスー
パバイザカウンタが外部クロックによりカウントしている間は , タイムベースタイ
マをクリアしないでください。
• タイムベースタイマインターバルは , クロックスーパバイザカウンタの動作に対し
十分に余裕のあるものを選択してください。
タイムベースタイマのインターバルに
ついては , 表 17.3-1 を参照してください。
• CMDR レジスタは , CMCEN = 0 のときに読み出してください ( クロックスーパバイ
ザカウンタの動作中 (CMCEN = 1) は , CMDR の値は "0b00000000" のままです )。
• クロックスーパバイザカウンタを使用する場合は , 必ずマシンクロックサイクルが
選択されたタイムベースタイマインターバルの半分よりも短くなるようにしてく
ださい。マシンクロックサイクルが選択されたタイムベースタイマインターバルの
半分よりも長いと , クロックスーパバイザカウンタの停止後も CMCEN が "1" のま
まとなることがあります。
表 17.5-1 に , 各 TBTSEL 設定に対する適切なクロックギア設定を示します。
表 17.5-1 各 TBTSEL 設定に対する適切なクロックギア設定
TBTSEL[2:0]
DIV[1:0]
( クロックギア設定 )
000
001
010 ~ 111
231/FCRH
251/FCRH
271/FCRH ~ 2171/FCRH
00 (11/FCRH)
○
○
○
01 (41/FCRH)
×
○
○
10 (81/FCRH)
×
○
○
11 (161/FCRH)
×
×
○
○ : 推奨
×
266
: 設定禁止
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 17 章 クロックスーパバイザ カウンタ
17.5 使用上の注意
Ha rdware
Manual
● クロックスーパバイザカウンタの動作中に外部クロックが停止し , 選択されたタイムベー
スタイマインターバルの 2 回目の立上りエッジ後に再開した場合は , CMCEN は外部ク
ロック再開後に "0" になります。
図 17.5-1 クロックスーパバイザカウンタの動作 1
選択したタイムベースタイマインターバル
メイン/サブ発振クロック
CMCEN
内部カウンタ
0
5
6
0
CMDRレジスタ
6
● クロックスーパバイザカウンタの動作中に外部クロックが停止した場合 , 選択されたタイ
ムベースタイマインターバルにおいて 2 回目の立上りエッジ後に立下りエッジが検出され
ると , CMCEN が "0" になります。カウンタも同じ立下りエッジでクリアされます。
図 17.5-2 クロックスーパバイザカウンタの動作 2
選択したタイムベースタイマインターバル
メイン/サブ発振クロック
CMCEN
内部カウンタ
CMDRレジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
0
5
0
0
267
第 17 章 クロックスーパバイザ カウンタ
17.5 使用上の注意
H ard war e
268
Ma nu al
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 18 章
8/16 ビット PPG
8/16ビットPPGの機能と動作について説明します。
18.1 概要
18.2 構成
18.3 チャネル
18.4 端子
18.5 割込み
18.6 動作説明と設定手順例
18.7 レジスタ
18.8 使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
269
第 18 章 8/16 ビット PPG
18.1 概要
H ard war e
18.1
Ma nu al
概要
8/16 ビット PPG は , 8 ビットのリロードタイマモジュールです。タイマ動作に応じた
パルス出力制御によりPPG出力を行います。また, カスケード接続(8 ビット + 8 ビッ
ト ) により 16 ビット PPG として動作できます。
■ 8/16 ビット PPG の概要
品種により , 8/16 ビット PPG の端子数およびチャネル数は異なります。詳細は , デバイ
スのデータシートを参照してください。
本章において , 端子名とレジスタ略称にある "n" はチャネル番号を示します。各品種の
端子名 , レジスタ名とレジスタ略称について , デバイスのデータシートを参照してくだ
さい。
以下に 8/16 ビット PPG の機能概要を示します。
● 8 ビット PPG 独立モード
2 つの (PPG タイマ n0, PPG タイマ n1) の 8 ビット PPG として動作できます。
● 8 ビットプリスケーラ + 8 ビット PPG モード
PPG タイマ n1 の PPG 出力の両エッジ検出パルスを PPG タイマ n0 のダウンカウンタへ
入力することにより , PPG タイマ n0 に任意周期の 8 ビット PPG 出力が可能です。
● 16 ビット PPG モード
カスケード接続 (PPG タイマ n1 ( 上位 8 ビット ) + PPG タイマ n0 ( 下位 8 ビット )) によ
り 16 ビット PPG 出力として動作できます。
● PPG 出力動作
任意周期 , デューティ比のパルス波を出力します。
外付け回路により D/A コンバータとしても使用できます。
● 出力反転モード
PPG の出力値を反転できます。
270
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 18 章 8/16 ビット PPG
18.2 構成
Ha rdware
18.2
Manual
構成
8/16 ビット PPG のブロックダイヤグラムを示します。
■ 8/16 ビット PPG のブロックダイヤグラム
図 18.2-1 に , 8/16 ビット PPG のブロックダイヤグラムを示します。
図 18.2-1 8/16 ビット PPG のブロックダイヤグラム
CKS02
CKS01
デューティ設定レジスタ
CKS00
周期設定レジスタ
プリスケーラ
1 MCLK
MCLK/2
MCLK/4
MCLK/8
MCLK/16
MCLK/32
FCH/27またはFCRH/26またはFPLL/26
FCH/28またはFCRH/27またはFPLL/27
デューティ設定レジスタバッファ
PPG タイマ n0
01
CLK
00
10
11
PEN00
比較
回路
LOAD
REV00
8 ビットダウンカウンタ
(PPG タイマ n0)
STOP
0
S Q
R
1
端子
PPGn0
エッジ
検出
BORROW
START
0
1
0
1
PIE0
MD1
PUF0
POEN0
POEN0
MD0
IRQXX
各セレクタの選択信号として使用
CKS12
プリスケーラ
CKS11
周期設定レジスタ
デューティ設定レジスタ
周期設定
バッファレジスタ
デューティレジスタ
バッファ周期設定
CKS10
1 MCLK
MCLK/2
MCLK/4
MCLK/8
MCLK/16
MCLK/32
FCH/27またはFCRH/26またはFPLL/26
FCH/28またはFCRH/27またはFPLL/27
1
1
0
エッジ
検出
0
LOAD
エッジ
検出
比較
回路
0
1
PEN01
CLK
PPG タイマ n1
1
8 ビットダウンカウンタ
(PPG タイマ n1)
STOP
START
1
S Q
R
REV01
0
端子
PPGn1
BORROW
0
PIE1
PUF1
POEN1
POEN1
IRQXX
April 4, 2014, MB95F718M_MN702-00014-3v0-J
271
第 18 章 8/16 ビット PPG
18.2 構成
H ard war e
Ma nu al
● カウントクロックセレクタ
8 種類の内部カウントクロックから 8 ビットダウンカウンタのカウントダウン用ク
ロックを選択します。
● 8 ビットダウンカウンタ
カウントクロックセレクタで選択されたカウントクロックでカウントダウンします。
● 比較回路
8 ビットダウンカウンタの値が 8/16 ビット PPG 周期設定バッファレジスタの値から 8/
16 ビット PPG デューティ設定バッファレジスタの値に一致するまで出力 を "H" レベ
ルに保ちます。
その後 , カウンタ値が "1" になるまで出力を "L" レベルに保った後 , 8 ビットダウンカ
ウンタは 8/16 ビット PPG 周期設定の値からカウントを続けます。
● 8/16 ビット PPG タイマ n1 制御レジスタ (PCn1)
8/16 ビット PPG タイマの PPG タイマ n1 側の動作条件を設定します。
● 8/16 ビット PPG タイマ n0 制御レジスタ (PCn0)
8/16 ビット PPG タイマの動作モードと PPG タイマ n0 側の動作条件を設定します。
● 8/16 ビット PPG タイマ n1/n0 周期設定バッファレジスタ (PPSn1/PPSn0)
8/16 ビット PPG タイマの周期用コンペア値を設定します。
● 8/16 ビット PPG タイマ n1/n0 デューティ設定バッファレジスタ (PDSn1/PDSn0)
8/16 ビット PPG タイマの "H" 幅用コンペア値を設定します。
● 8/16 ビット PPG 起動レジスタ
8/16 ビット PPG タイマの起動または停止を設定します。
● 8/16 ビット PPG 出力反転レジスタ
8/16 ビット PPG タイマの出力を初期レベルも含めて反転させます。
■ 入力クロック
8/16 ビット PPG は , プリスケーラからの出力クロックを入力クロック ( カウントクロッ
ク ) として使用します。
272
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 18 章 8/16 ビット PPG
18.3 チャネル
Ha rdware
18.3
Manual
チャネル
8/16 ビット PPG のチャネルについて説明します。
■ 8/16 ビット PPG のチャネル
8/16 ビット PPG は 8 ビット PPG タイマ n0 と 8 ビット PPG タイマ n1 から構成されま
す。
それぞれ , 2 つの 8 ビット PPG としてまたは 1 つの 16 ビット PPG として使用でき
ます。
表 18.3-1 に 8/16 ビット PPG の端子を , 表 18.3-2 にそのレジスタを示します。
表 18.3-1 8/16 ビット PPG の端子
端子名
端子機能
PPGn0
PPG タイマ n0 出力 (8 ビット PPG (n0), 16 ビット PPG)
PPGn1
PPG タイマ n1 出力 (8 ビット PPG (n1), 8 ビットプリスケーラ )
表 18.3-2 8/16 ビット PPG のレジスタ
レジスタ略称
該当レジスタ ( 本マニュアル上の表記 )
PCn1
8/16 ビット PPG タイマ n1 制御レジスタ
PCn0
8/16 ビット PPG タイマ n0 制御レジスタ
PPSn1
8/16 ビット PPG タイマ n1 周期設定バッファレジスタ
PPSn0
8/16 ビット PPG タイマ n0 周期設定バッファレジスタ
PDSn1
8/16 ビット PPG タイマ n1 デューティ設定バッファレジスタ
PDSn0
8/16 ビット PPG タイマ n0 デューティ設定バッファレジスタ
PPGS
8/16 ビット PPG 起動レジスタ
REVC
8/16 ビット PPG 出力反転レジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
273
第 18 章 8/16 ビット PPG
18.4 端子
H ard war e
18.4
Ma nu al
端子
8/16 ビット PPG の端子について説明します。
■ 8/16 ビット PPG の端子
● PPGn0 端子と PPGn1 端子
この端子は汎用入出力ポートとしての機能と , 8/16 ビット PPG 出力としての機能を兼
用しています。
PPGn0 , PPGn1: この端子に PPG 波形が出力されます。8/16 ビット PPG タイマ n0/n1 制
御レジスタで出力を許可 (PCn0:POEN0 = 1, PCn1:POEN1 = 1) するこ
とにより , PPG 波形を出力できます。
274
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 18 章 8/16 ビット PPG
18.5 割込み
Ha rdware
18.5
Manual
割込み
8/16 ビット PPG はカウンタボロー検出時に割込み要求を出力します。
■ 8/16 ビット PPG の割込み
表 18.5-1 に , 8/16 ビット PPG の割込み制御ビットと割込み要因を示します。
表 18.5-1 8/16 ビット PPG の割込み制御ビットと割込み要因
説明
項目
PPG タイマ n1
(8 ビット PPG, 8 ビットプリスケーラ )
PPG タイマ n0
(8 ビット PPG, 16 ビット PPG)
割込み要求フラグビット
PCn1 の PUF1 ビット
PCn0 の PUF0 ビット
割込み要求許可ビット
PCn1 の PIE1 ビット
PCn0 の PIE0 ビット
割込み要因
PPG 周期ダウンカウンタのカウンタボロー
8/16 ビット PPG では , ダウンカウンタのカウンタボローにより , 8/16 ビット PPG タイ
マ n0/n1 制御レジスタ (PC) のカウンタボロー検出フラグビット (PUF) に "1" が設定さ
れます。割込み要求許可ビット (PIE = 1) を許可にしている場合 , 割込み要求を割込み
コントローラへ出力します。
16 ビット PPG モードの場合 , 8/16 ビット PPG タイマ n0 制御レジスタ (PCn0) が有効と
なります。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
275
第 18 章 8/16 ビット PPG
18.6 動作説明と設定手順例
H ard war e
18.6
Ma nu al
動作説明と設定手順例
8/16 ビット PPG の動作について説明します。
8/16 ビット PPG は以下の 3 つの動作モードがあります。
276
•
8 ビット PPG 独立モード
•
8 ビットプリスケーラ +8 ビット PPG モード
•
16 ビット PPG モード
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 18 章 8/16 ビット PPG
18.6 動作説明と設定手順例
Ha rdware
18.6.1
Manual
8 ビット PPG 独立モード
このモードは 8/16 ビット PPG を 2 チャネル (PPG タイマ n0, PPG タイマ n1) の 8
ビット PPG として動作させます。
■ 8 ビット PPG 独立モードの設定
8/16 ビット PPG を 8 ビット PPG 独立モードで動作させるには , レジスタを図 18.6-1 の
ように設定してください。
図 18.6-1 8 ビット PPG 独立モード
bit7
-
bit6
-
bit5
PIE1
bit4
bit3
bit2
bit1
bit0
PUF1 POEN1 CKS12 CKS11 CKS10
PCn0
MD1
0
MD0
0
PIE0
PUF0 POEN0 CKS02 CKS01 CKS00
PPSn1
PH7
PH6
PH5
PH4
PH3
PH2
PH1
PPG タイマ n1 の PPG 出力周期を設定
PH0
PPSn0
PL7
PL6
PL5
PL4
PL3
PL2
PL1
PPG タイマ n0 の PPG 出力周期を設定
PL0
PDSn1
DH7
DH6
DH5
DH4
DH3
DH2
DH1
PPG タイマ n1 の PPG 出力デューティ比を設定
DH0
PDSn0
DL7
DL6
DL5
DL4
DL3
DL2
DL1
PPG タイマ n0 の PPG 出力デューティ比を設定
DL0
PPGS
*
*
PEN21 PEN20 PEN11 PEN10 PEN01 PEN00
*
*
*
*
REVC
*
*
REV21 REV20 REV11 REV10 REV01 REV00
*
*
*
*
PCn1
:使用ビット
0 :"0" に設定
* :搭載するチャネル数によります。
■ 8 ビット PPG 独立モードの動作
•
8/16 ビット PPG タイマ n0 制御レジスタ (PCn0) の動作モード選択ビット (MD[1:0])
を "0b00" に設定すると本モードとなります。
•
8/16 ビット PPG 起動レジスタ (PPGS) の対応するパリティ制御ビット (PEN) に "1"
を設定すると , 8/16 ビット PPG 周期設定バッファレジスタ (PPS) の値をロードして ,
ダウンカウント動作が開始されます。カウント値が "1"に達したとき , 再び周期設定
レジスタの値がロードされ , カウント動作が繰り返されます。
•
ダウンカウンタの値と 8/16 ビット PPG タイマ n1/n0 デューティ比設定バッファレ
ジスタ (PDS) の値が一致したとき , カウントクロックに同期して PPG 出力に "H" を
出力します。デューティ比設定値分"H"を出力した後, PPG出力に"L"を出力します。
ただし , PPG 出力反転ビットが "1" の場合 , PPG 出力は上記の説明の逆になります。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
277
第 18 章 8/16 ビット PPG
18.6 動作説明と設定手順例
H ard war e
Ma nu al
図 18.6-2 に , 8 ビット PPG 独立モードの動作を示します。
図 18.6-2 8 ビット PPG 独立モードの動作
カウントクロック
(周期 T)
PEN
(カウンタ起動)
停止
周期設定 m=5
(PPS)
デューティ比設定
(PDS) n=4
PPG タイマ n0 カウンタ値
5
4
3
2
1
5
4
3
2
1
5
3
4
2
ダウンカウンタ値と
デューティ比設定値の一致
カウンタボロー
PPG 出力ソース
マシンクロックによる同期
停止
PPGn0 端子
(通常極性)
(反転極性)
(1)
α
(2)
(1) = n × T
(2) = m × T
T
m
n
α
: カウントクロック周期
: PPS レジスタ値
: PDS レジスタ値
: カウントクロック選択, 起動の
タイミングにより異なります。
デューティ比を 50% にする場合の例
PPS が "0x04" の場合 , PDS を "0x02" に設定すると , PPG 出力がデューティ比 50% に
なります (PPS 設定値 /2 を PDS に設定 ) 。
278
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 18 章 8/16 ビット PPG
18.6 動作説明と設定手順例
Ha rdware
18.6.2
Manual
8 ビットプリスケーラ + 8 ビット PPG モード
このモードでは , PPG タイマ n1 の PPG 出力の両エッジ検出パルスを PPG タイマ n0
のダウンカウンタのカウントクロックとすることで , PPG タイマ n0 に任意周期の 8
ビット PPG 出力が可能となります。
■ 8 ビットプリスケーラ+ 8 ビット PPG モードの設定
8/16 ビット PPG を 8 ビットプリスケーラ+ 8 ビット PPG モードで動作させるには , レ
ジスタを図 18.6-3 のように設定してください。
図 18.6-3 8 ビットプリスケーラ+ 8 ビット PPG モードの設定
bit7
-
bit6
-
bit5
PIE1
bit4
bit3
bit2
bit1
bit0
PUF1 POEN1 CKS12 CKS11 CKS10
PCn0
MD1
0
MD0
1
PIE0
PUF0 POEN0 CKS02 CKS01 CKS00
×
×
×
PPSn1
PH7
PH6
PH5
PH4
PH3
PH2
PH1
PPG タイマ n1 の PPG 出力周期を設定
PH0
PPSn0
PL7
PL6
PL5
PL4
PL3
PL2
PL1
PPG タイマ n0 の PPG 出力周期を設定
PL0
PDSn1
DH7
DH6
DH5
DH4
DH3
DH2
DH1
PPG タイマ n1 の PPG 出力デューティ比を設定
DH0
PDSn0
DL7
DL6
DL5
DL4
DL3
DL2
DL1
PPG タイマ n0 の PPG 出力デューティ比を設定
DL0
PPGS
*
*
PEN21 PEN20 PEN11 PEN10 PEN01 PEN00
*
*
*
*
REVC
*
*
REV21 REV20 REV11 REV10 REV01 REV00
*
*
*
*
PCn1
0
1
×
*
:使用ビット
:"0" に設定
:"1" に設定
:設定無効
:搭載するチャネル数によります。
■ 8 ビットプリスケーラ + 8 ビット PPG モードの動作
•
8/16 ビット PPG タイマ n0 制御レジスタ (PCn0) の動作モード選択ビット (MD[1:0])
を "0b01" に設定すると本モードとなります。PPG タイマ n1 を 8 ビットプリスケー
ラとして使用し , PPG タイマ n0 を 8 ビット PPG として使用します。
•
8 ビットプリスケーラ (PPG タイマ n1) は , PPG タイマ n1 (ch.0) ダウンカウンタ動作
許可ビット (PEN01) を "1" に設定したとき , 8/16 ビット PPG タイマ n1 周期設定バッ
ファレジスタ (PPS01) の値をロードしてダウンカウント動作を開始します。ダウン
カウンタの値と 8/16 ビット PPG タイマ n1 デューティ比設定バッファレジスタ
(PDSn1) の値が一致したとき , カウントクロックに同期して PPGn1 出力に "H" が設
April 4, 2014, MB95F718M_MN702-00014-3v0-J
279
第 18 章 8/16 ビット PPG
18.6 動作説明と設定手順例
H ard war e
Ma nu al
定され , デューティ比設定値分 "H" を出力した後 , PPGn1 出力に "L" が設定されま
す。出力反転ビット (REV01) が "0" の場合 , PPG のパルス波がこのままの極性で PPG
端子に出力されます。REV01 が "1" に設定される場合 , PPG のパルス波は , 極性が反
転されてから , PPGn1 端子に出力されます。
•
8 ビット PPG (PPG タイマ n0) は , PPG 動作許可ビット (PEN00) に "1" を設定したと
き , 8/16 ビット PPG タイマ n0 周期設定バッファレジスタ (PPSn0) の値をロードし
てダウンカウント動作を開始します ( カウントクロックは PPG タイマ n1 が動作許
可状態になった後の PPGn1 出力の両エッジ検出パルス ) 。カウント値が "1" に達し
たとき , 再び PPSn0 レジスタの値をロードし , カウント動作を繰り返します。ダウ
ンカウンタの値と 8/16 ビット PPG タイマ n0 デューティ設定バッファレジスタ
(PDSn0) の値が一致したとき , カウントクロックに同期して PPGn0 出力を "H" に設
定し , デューティ設定値分 "H" を出力した後 , PPGn0 出力を "L" にリセットします。
出力反転ビット (REV00) が "0" の場合 , PPG のパルス波がこのままの極性で PPGn0
端子に出力されます。REV00 が "1" に設定される場合 , PPG のパルス波は , 極性が反
転されてから , PPGn0 端子に出力されます。
•
8 ビットプリスケーラ (PPG タイマ n1) の出力のデューティは 50% となるように設
定してください。
•
PPG タイマ n0 を起動し , 8 ビットプリスケーラ (PPG タイマ n1) が停止している場
合 , PPG タイマ n0 はカウント動作を行いません。
•
8 ビットプリスケーラ (PPG タイマ n1) のデューティ設定を 0% または 100% にした
場合 , 8 ビットプリスケーラ (PPG タイマ n1) の出力はトグルしないため , PPG タイ
マ n0 はカウント動作を行いません。
図 18.6-4 に , 8 ビットプリスケーラ + 8 ビット PPG モードの動作を示します。
280
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 18 章 8/16 ビット PPG
18.6 動作説明と設定手順例
Ha rdware
Manual
図 18.6-4 8 ビットプリスケーラ + 8 ビット PPG モードの動作
カウントクロック
(周期 T)
PEN01
周期設定
(PPSn1)
デューティ比設定
(PDSn1)
PPG タイマ n1
カウンタ値
m1=4
n1=2
4
3
2
1
4
3
2
1
4
3
2
1
4
3
1
2
4
ダウンカウンタ値と
デューティ比設定値の
一致
カウンタボロー
PPG 出力ソース
マシンクロックによる同期
PPGn1
(通常極性)
(反転極性)
(1)
α
(2)
PEN00
周期設定
m0=3
(PPSn0)
デューティ比設定
n0=2
(PDSn0)
PPG タイマ 00
カウンタ値
ダウンカウンタ値と
デューティ比設定値の
一致
カウンタボロー
3
2
1
3
2
3
1
2
PPG 出力ソース
マシンクロックによる同期
PPGn0
(通常極性)
(反転極性)
(3)
β
(4)
(1) = n1 × T
(2) = m1 × T
(3) = (1) × n0
(4) = (1) × m0
April 4, 2014, MB95F718M_MN702-00014-3v0-J
T : カウントクロック周期
m0 : PPSn0 レジスタ値
n0 : PDSn0 レジスタ値
m1 : PPSn1 レジスタ値
n1 : PDSn1 レジスタ値
α : カウントクロック選択, PEN01 による
起動タイミングにより異なります。
β : PPGn1 出力 (ch. n) 波形, PEN00 による
起動のタイミングにより異なります。
281
第 18 章 8/16 ビット PPG
18.6 動作説明と設定手順例
H ard war e
18.6.3
Ma nu al
16 ビット PPG モード
このモードでは , PPG タイマ n1 を上位 , PPG タイマ n0 を下位に割り当てることで
8/16 ビット PPG は 16 ビット PPG として動作します。
■ 16 ビット PPG モードの設定
8/16 ビット PPG を 16 ビット PPG モードで動作させるには , レジスタを図 18.6-5 のよ
うに設定してください。
図 18.6-5 16 ビット PPG モードの設定
bit7
-
bit6
-
bit5
PIE1
bit4
bit3
bit2
bit1
bit0
PUF1 POEN1 CKS12 CKS11 CKS10
PCn0
MD1
0
MD0
0/1
PIE0
PUF0 POEN0 CKS02 CKS01 CKS00
PPSn1
PH7
PH6
PH5
PCn1
PH4
PH3
PH2
PH1
PH0
PPG タイマ n1 の PPG 出力周期を設定 ( 上位 8 ビット )
PPSn0
PL7
PL6
PL5
PL4
PL3
PL2
PL1
PL0
PPG タイマ n0 の PPG 出力周期を設定 ( 下位 8 ビット )
PDSn1
DH7
DH6
DH5
DH4
DH3
DH2
DH1
DH0
PPG タイマ n1 の PPG 出力デューティ比を設定 ( 上位 8 ビット )
PDSn0
DL7
DL6
DL5
DL4
DL3
DL2
DL1
DL0
PPG タイマ n0 の PPG 出力デューティ比を設定 ( 下位 8 ビット )
0
1
×
*
PPGS
*
*
PEN21 PEN20 PEN11 PEN10 PEN01 PEN00
*
*
*
*
×
REVC
*
*
REV21 REV20 REV11 REV10 REV01 REV00
*
*
*
*
×
:使用ビット
:"0 " に設定
:"1 " に設定
:設定無効
:搭載するチャネル数によります。
■ 16 ビット PPG モードの動作
282
•
PPG タイマ n0 制御レジスタ (PCn0) の動作モード選択ビット (MD[1:0]) を "0b10" ま
たは "0b11" に設定すると本モードとなります。
•
16 ビット PPG モードの場合 , 8 ビットダウンカウンタ (PPG タイマ n0) と 8 ビット
ダウンカウンタ (PPG タイマ n1) は , PPG 動作許可ビット (PEN00) を "1" に設定した
場合 , 8/16 ビット PPG タイマ n0/n1 周期設定バッファレジスタ (PPG タイマ n1 には
PPSn1, PPG タイマ n0 には PPSn0) の値をロードして , ダウンカウント動作を開始し
ます。カウント値が "1" に達したとき , 再び周期設定レジスタの値がロードされ , カ
ウント動作が繰り返されます。
•
ダウンカウンタの値と 8/16 ビット PPG タイマデューティ設定バッファレジスタの
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 18 章 8/16 ビット PPG
18.6 動作説明と設定手順例
Ha rdware
Manual
値が (PPG タイマ n1 は PDS01, PPG タイマ n0 は PDSn0 の値がともに ) 一致したと
き , カウントクロックに同期して PPGn0 端子に "H" を設定し , デューティ設定値分
"H" を出力した後 , PPGn0 端子を "L" に設定します。出力反転ビット (REV00) が "0"
の場合 , PPG のパルス波がこのままの極性で PPGn0 端子に出力されます。REV00 が
"1" に設定される場合 , PPG のパルス波は , 極性が反転されてから , PPGn0 端子 に出
力されます。
図 18.6-6 に , 16 ビット PPG モードの動作を示します。
図 18.6-6 16 ビット PPG モードの動作
カウントクロック
(周期 T)
PEN00
周期設定
(PPSn1 および PPSn0) m=256
デューティ比設定
(PDSn1 および PDSn0) n=2
カウンタ値
256
255
254
...
2
1
256
255
...
2
1
256
255
ダウンカウンタ値と
デューティ比設定値の一致
カウンタボロー
PPG 出力ソース
マシンクロックによる
同期
PPGn0 端子
(通常極性)
(反転極性)
(1)
α
(2)
(1) = n × T
(2) = m × T
April 4, 2014, MB95F718M_MN702-00014-3v0-J
T : カウントクロック周期
m : PPSn1 および PPSn0
n : PDSn1 および PDSn0
α : カウントクロック選択, 起動の
タイミングにより異なります。
283
第 18 章 8/16 ビット PPG
18.6 動作説明と設定手順例
H ard war e
Ma nu al
■ 設定手順例
以下に , 8/16 ビット PPG の設定手順例を示します。
● 初期設定
1. ポートの出力を設定してください (DDR)。
2. 割込みレベルを設定してください (ILR*)。
3. 動作クロック選択 , 出力許可および割込み許可を行ってください (PCn1)。
4. 動作クロック選択 , 出力許可 , 割込み許可および動作モード選択を行ってください
(PCn0)。
5. 周期を設定してください (PPS)。
6. デューティを設定してください (PDS)。
7. 8/16 ビット PPG 出力反転レジスタを設定してください (REVC)。
8. 8/16 ビット PPG を起動してください (PPGS)。
*: 割込みレベル設定レジスタ (ILR) の詳細について , 本ハードウェアマニュアルの「第 5 章 割
込み」とデバイスのデータシートの「■ 割込み要因のテーブル」を参照してください。
● 割込み処理
1. 任意の割込み処理を行ってください。
2. 割込み要求フラグをクリアしてください (PCn1:PUF1, PCn0:PUF0)。
3. 8/16 ビット PPG を起動してください (PPGS)。
284
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 18 章 8/16 ビット PPG
18.7 レジスタ
Ha rdware
18.7
Manual
レジスタ
8/16 ビット PPG のレジスタについて説明します。
表 18.7-1
8/16 ビット PPG のレジスタ一覧
レジスタ略称
レジスタ名
参照先
PCn1
8/16 ビット PPG タイマ n1 制御レジスタ
18.7.1
PCn0
8/16 ビット PPG タイマ n0 制御レジスタ
18.7.2
PPSn1
8/16 ビット PPG タイマ n1 周期設定バッファレジスタ
18.7.3
PPSn0
8/16 ビット PPG タイマ n0 周期設定バッファレジスタ
18.7.3
PDSn1
8/16 ビット PPG タイマ n1 デューティ設定バッファレジスタ
18.7.4
PDSn0
8/16 ビット PPG タイマ n0 デューティ設定バッファレジスタ
18.7.4
PPGS
8/16 ビット PPG 起動レジスタ
18.7.5
REVC
8/16 ビット PPG 出力反転レジスタ
18.7.6
April 4, 2014, MB95F718M_MN702-00014-3v0-J
285
第 18 章 8/16 ビット PPG
18.7 レジスタ
H ard war e
18.7.1
Ma nu al
8/16 ビット PPG タイマ n1 制御レジスタ (PCn1)
8/16 ビット PPG タイマ n1 制御レジスタ (PCn1) は PPG タイマ n1 側の動作条件を
設定します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
PIE1
PUF1
POEN1
CKS12
CKS11
CKS10
属性
—
—
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7:6] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit5] PIE1: 割込み要求許可ビット
このビットは PPG タイマ n1 の割込みを許可または禁止します。
カウンタボロー検出ビット (PUF1) が "1" で , かつ PIE1 ビットが "1" の場合 , 割込み要求 (IRQ) が出
力されます。
説明
bit5
"0" を書き込んだ場合
PPG タイマ n1 割込みを禁止します。
"1" を書き込んだ場合
PPG タイマ n1 割込みを許可します。
[bit4] PUF1: PPG 周期ダウンカウンタのカウンタボロー検出フラグビット
このビットは PPG タイマ n1 の PPG 周期ダウンカウンタのカウンタボロー検出フラグです。
8 ビット PPG 独立モードまたは 8 ビットプリスケーラ + 8 ビット PPG モードでカウンタボローが
発生した場合 , このビットは "1" となります。
16 ビット PPG モードで , カウンタボローが発生してもこのビットは "1" になりません。
このビットへの "1" の書込みは 動作に影響を与えません。"0" の書込みはこのビットをクリアしま
す。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit4
"0" が読み出された場合
PPG タイマ n1 のカウンタボローが検出されていないことを示します。
"1" が読み出された場合
PPG タイマ n1 のカウンタボローが検出されていることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit3] POEN1: 出力許可ビット
このビットは PPG タイマ n1 の端子の出力を許可または禁止します。
16 ビット PPG モードでこのビットに "1" を書き込んだ場合 , PPG タイマ n1 端子は出力固定となり
ます (REV01 の設定値が出力されます。REV01= 0 の場合は "L" が 出力されます。)。
bit3
286
説明
"0" を書き込んだ場合
PPG タイマ n1 端子は汎用ポートとして機能します。
"1" を書き込んだ場合
PPG タイマ n1 端子は PPG 出力端子として機能します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 18 章 8/16 ビット PPG
18.7 レジスタ
Ha rdware
Manual
[bit2:0] CKS1[2:0]: 動作クロック選択ビット
これらのビットは 8 ビットダウンカウンタ PPG タイマ n1 の動作クロックを選択します。
動作クロックはプリスケーラにより生成されます。詳細は ,「3.9 プリスケーラの動作」を参照して
ください。
16 ビット PPG モードでは , これらのビットの設定は動作に関係ありません。
説明
(MCLK: マシンクロック , FCH: メインクロック ,
bit2:0
FCRH: メイン CR クロック , FPLL: PLL クロック )
"000" を書き込んだ場合
1 MCLK
"001" を書き込んだ場合
MCLK/2
"010" を書き込んだ場合
MCLK/4
"011" を書き込んだ場合
MCLK/8
"100" を書き込んだ場合
MCLK/16
"101" を書き込んだ場合
MCLK/32
"110" を書き込んだ場合
FCH/27 または FCRH/26 または FPLL/26
"111" を書き込んだ場合
FCH/28 または FCRH/27 または FPLL/27
( 注意事項 ) サブクロックモードまたはサブ CR クロックモードで , タイムベースタイマが停止して
いるため , CKS1[2:0] ビットを "0b110" または "0b111" に設定することは禁止されます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
287
第 18 章 8/16 ビット PPG
18.7 レジスタ
H ard war e
18.7.2
Ma nu al
8/16 ビット PPG タイマ n0 制御レジスタ (PCn0)
8/16 ビット PPG タイマ n0 制御レジスタ (PCn0) は PPG タイマ n0 側の動作条件と
動作モードを設定します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
MD1
MD0
PIE0
PUF0
POEN0
CKS02
CKS01
CKS00
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7:6] MD[1:0]: 動作モード選択ビット
これらのビットは 8/16 ビット PPG の動作モードを選択します。
カウント動作中には , これらのビットの設定を変更しないでください。
説明
bit7:6
"00" を書き込んだ場合
8 ビット PPG 独立モード
"01" を書き込んだ場合
8 ビットプリスケーラ + 8 ビット PPG モード
"10" を書き込んだ場合
"11" を書き込んだ場合
16 ビット PPG モード
[bit5] PIE0: 割込み要求許可ビット
このビットは PPG タイマ n0 の割込みを許可または禁止します。
16 ビット PPG モードでは , このビットを使って 8/16 ビット PPG の割込み要求を制御してください。
カウンタボロー検出ビット (PUF0) が "1" で , かつ PIE0 ビットが "1" の場合 , 割込み要求 (IRQ) が出
力されます。
説明
bit5
"0" を書き込んだ場合
PPG タイマ n0 割込みを禁止します。
"1" を書き込んだ場合
PPG タイマ n0 割込みを許可します。
[bit4] PUF0: PPG 周期ダウンカウンタのカウンタボロー検出フラグビット
このビットは PPG タイマ n0 の PPG 周期ダウンカウンタのカウンタボロー検出フラグです。
16 ビット PPG モードでは , PUF0 ビットのみが有効な PPG 周期ダウンカウンタのカウンタボロー検
出フラグで , PCn1 レジスタの PUF1 ビットは無効です。
( 注意事項 ) 8 ビット PPG モードまたは 8 ビットプリスケーラ  8 ビット PPG モードでは , カウン
タボロー検出は常に許可されます。
このビットへの "1" の書込みは 動作に影響を与えません。"0" の書込みはこのビットをクリアしま
す。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit4
288
"0" が読み出された場合
PPG タイマ n0 のカウンタボローが検出されていないことを示します。
"1" が読み出された場合
PPG タイマ n0 のカウンタボローが検出されていることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 18 章 8/16 ビット PPG
18.7 レジスタ
Ha rdware
Manual
[bit3] POEN0: 出力許可ビット
このビットは PPG タイマ n0 端子の出力を許可または禁止します。
16 ビット PPG モードでは , 8/16 ビット PPG が PPG タイマ n0 端子よりパルス波を出力するため ,
POEN0 ビットは 8/16 ビット PPG の出力を制御します。
説明
bit3
"0" を書き込んだ場合
PPG タイマ n0 端子は汎用ポートとして機能します。
"1" を書き込んだ場合
PPG タイマ n0 端子は PPG 出力端子として機能します。
[bit2:0] CKS0[2:0]: 動作クロック選択ビット
これらのビットは 8 ビットダウンカウンタ PPG タイマ n0 の動作クロックを選択します。
動作クロックはプリスケーラにより生成されます。詳細は ,「3.9 プリスケーラの動作」を参照して
ください。
8 ビットプリスケーラ  8 ビット PPG モードでは , PPG タイマ n0 のカウント動作クロックは PPG
タイマ n1 の PPG 出力の両エッジ検出パルスとなります。そのため , 本ビットの設定は動作に関係
ありません。
16 ビット PPG モードでは , 動作クロックを選択するにはこれらのビットを使ってください。
説明
(MCLK: マシンクロック , FCH: メインクロック ,
bit2:0
FCRH: メイン CR クロック , FPLL: PLL クロック )
"000" を書き込んだ場合
1 MCLK
"001" を書き込んだ場合
MCLK/2
"010" を書き込んだ場合
MCLK/4
"011" を書き込んだ場合
MCLK/8
"100" を書き込んだ場合
MCLK/16
"101" を書き込んだ場合
MCLK/32
"110" を書き込んだ場合
FCH/27 または FCRH/26 または FPLL/26
"111" を書き込んだ場合
FCH/28 または FCRH/27 または FPLL/27
( 注意事項 ) サブクロックモードまたはサブ CR クロックモードで , タイムベースタイマが停止して
いるため , CKS0[2:0] ビットを "0b110" または "0b111" に設定することは禁止されます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
289
第 18 章 8/16 ビット PPG
18.7 レジスタ
H ard war e
18.7.3
Ma nu al
8/16 ビット PPG タイマ n1/n0 周期設定バッファレジ
スタ (PPSn1/PPSn0)
8/16 ビット PPG タイマ n1/n0 周期設定バッファレジスタ (PPSn1/PPSn0) は PPG 出
力の周期を設定します。
■ レジスタ構成
PPSn1
bit
7
6
5
4
3
2
1
0
Field
PH7
PH6
PH5
PH4
PH3
PH2
PH1
PH0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
1
1
1
1
1
1
1
1
PPSn0
bit
7
6
5
4
3
2
1
0
Field
PL7
PL6
PL5
PL4
PL3
PL2
PL1
PL0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
1
1
1
1
1
1
1
1
■ レジスタ機能
PPSn1 レジスタと PPSn0 レジスタは PPG 出力周期を設定します。
290
•
16 ビット PPG モードの場合 , PPSn1 が上位 8 ビット , PPSn0 が下位 8 ビットです。
•
16 ビット PPG モードの場合 , 上位 , 下位の順番に書き込んでください。上位のみの
書込みの場合は前回の書込み値が次のロードで再度使用されます。
•
8 ビットモード:周期は最大 255 (0xFF)  入力クロックの周期となります。
•
16 ビットモード:周期は最大 65535 (0xFFFF)  入力クロックの周期となります。
•
リセットで初期化されます。
•
8 ビット PPG 独立モードまたは 8 ビットプリスケーラモード + 8 ビット PPG モー
ドで使用する場合 , 周期を "0x00" または "0x01" に設定しないでください。
•
16 ビット PPG モードで使用する場合 , 周期を "0x0000" または "0x0001" に設定しな
いでください。
•
動作中に周期設定を変更した場合, 次の PPG 周期から変更した設定が有効となりま
す。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 18 章 8/16 ビット PPG
18.7 レジスタ
Ha rdware
18.7.4
Manual
8/16 ビット PPG タイマ n1/n0 デューティ設定バッ
ファレジスタ (PDSn1/PDSn0)
8/16 ビット PPG タイマ n1/n0 デューティ設定バッファレジスタ (PDSn1/PDSn0) は
PPG 出力のデューティを設定します。
■ レジスタ構成
PDSn1
bit
7
6
5
4
3
2
1
0
Field
DH7
DH6
DH5
DH4
DH3
DH2
DH1
DH0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
1
1
1
1
1
1
1
1
7
6
5
4
3
2
1
0
PDSn0
bit
Field
DL7
DL6
DL5
DL4
DL3
DL2
DL1
DL0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
1
1
1
1
1
1
1
1
■ レジスタ機能
PDSn1 レジスタと PDSn0 レジスタは PPG 出力のデューティ( 通常極性の場合は "H" パ
ルス幅 ) を設定します。
•
16 ビット PPG モードの場合 , PDSn1 が上位 8 ビット , PDSn0 が下位 8 ビットです。
•
16 ビット PPG モードの場合 , 上位 , 下位の順番に書き込んでください。上位のみの
書込みの場合は前回の書込み値が次のロードで再度使用されます。PDSn0 の書込み
により PDSn1 も反映されます。
•
リセットで初期化されます。
•
デューティを 0% にする場合は , "0x00" を設定してください。
•
デューティを 100% にする場合は , 8/16 ビット PPG タイマ n1/n0 周期設定バッファ
レジスタ (PPSn0, PPSn1) と同じ値を設定してください。
•
8/16 ビット PPG タイマ n1/n0 デューティ設定バッファレジスタ (PDS) に 8/16 ビッ
ト PPG 周期設定バッファレジスタ (PPS) の設定値より大きな値を設定すると , PPG
出力は通常極性 (8/16 ビット PPG 出力反転レジスタの出力レベル反転ビットが "0"
の場合 ) で "L" 出力になります。
•
動作中にデューティ設定を変更した場合 , 次の PPG 周期から変更した値が有効とな
ります。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
291
第 18 章 8/16 ビット PPG
18.7 レジスタ
H ard war e
18.7.5
Ma nu al
8/16 ビット PPG 起動レジスタ (PPGS)
8/16 ビット PPG 起動レジスタ (PPGS) は , ダウンカウンタを起動または停止します。
各チャネルの動作許可ビットが PPGS レジスタに配置されているため , PPG 各チャ
ネルの同時起動が可能です。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
PEN21*
PEN20*
PEN11*
PEN10*
PEN01
PEN00
属性
—
—
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
*: 品種によって 8/16 ビット PPG のチャネル数が異なるため , 一部の品種ではこれらのビットが未定義ビットに
なることがあります。チャネル数に関しては , デバイスのデータシートを参照してください。
■ レジスタ機能
[bit7:6] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit5] PEN21: PPG タイマ 21 (ch. 2) ダウンカウンタ動作許可ビット
このビットは PPG タイマ 21 (ch. 2) ダウンカウンタ動作を許可または停止します。
bit5
説明
"0" を書き込んだ場合
PPG タイマ 21 (ch. 2) ダウンカウンタ動作を停止します。
"1" を書き込んだ場合
PPG タイマ 21 (ch. 2) ダウンカウンタ動作を許可します。
[bit4] PEN20: PPG タイマ 20 (ch. 2) ダウンカウンタ動作許可ビット
このビットは PPG タイマ 20 (ch. 2) ダウンカウンタ動作を許可または停止します。
bit4
説明
"0" を書き込んだ場合
PPG タイマ 20 (ch. 2) ダウンカウンタ動作を停止します。
"1" を書き込んだ場合
PPG タイマ 20 (ch. 2) ダウンカウンタ動作を許可します。
[bit3] PEN11: PPG タイマ 11 (ch. 1) ダウンカウンタ動作許可ビット
このビットは PPG タイマ 11 (ch. 1) ダウンカウンタ動作を許可または停止します。
bit3
説明
"0" を書き込んだ場合
PPG タイマ 11 (ch. 1) ダウンカウンタ動作を停止します。
"1" を書き込んだ場合
PPG タイマ 11 (ch. 1) ダウンカウンタ動作を許可します。
[bit2] PEN10: PPG タイマ 10 (ch. 1) ダウンカウンタ動作許可ビット
このビットは PPG タイマ 10 (ch. 1) ダウンカウンタ動作を許可または停止します。
bit2
292
説明
"0" を書き込んだ場合
PPG タイマ 10 (ch. 1) ダウンカウンタ動作を停止します。
"1" を書き込んだ場合
PPG タイマ 10 (ch. 1) ダウンカウンタ動作を許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 18 章 8/16 ビット PPG
18.7 レジスタ
Ha rdware
Manual
[bit1] PEN01: PPG タイマ 01 (ch. 0) ダウンカウンタ動作許可ビット
このビットは PPG タイマ 01 (ch. 0) ダウンカウンタ動作を許可または停止します。
説明
bit1
"0" を書き込んだ場合
PPG タイマ 01 (ch. 0) ダウンカウンタ動作を停止します。
"1" を書き込んだ場合
PPG タイマ 01 (ch. 0) ダウンカウンタ動作を許可します。
[bit0] PEN00: PPG タイマ 00 (ch. 0) ダウンカウンタ動作許可ビット
このビットは PPG タイマ 00 (ch. 0) ダウンカウンタ動作を許可または停止します。
説明
bit0
"0" を書き込んだ場合
PPG タイマ 00 (ch. 0) ダウンカウンタ動作を停止します。
"1" を書き込んだ場合
PPG タイマ 00 (ch. 0) ダウンカウンタ動作を許可します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
293
第 18 章 8/16 ビット PPG
18.7 レジスタ
H ard war e
18.7.6
Ma nu al
8/16 ビット PPG 出力反転レジスタ (REVC)
8/16 ビット PPG 出力反転レジスタ (REVC) は PPG 出力を初期レベルも含めて反転
させます。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
REV21*
REV20*
REV11*
REV10*
REV01
REV00
属性
—
—
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
*: 品種によって 8/16 ビット PPG のチャネル数が異なるため , 一部の品種ではこれらのビットが未定義ビットに
なることがあります。チャネル数に関しては , デバイスのデータシートを参照してください。
■ レジスタ機能
[bit7:6] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit5] REV21: PPG タイマ 21 (ch. 2) 出力レベル反転ビット
このビットは PPG タイマ 21 (ch. 2) 出力レベルの極性を選択します。
説明
bit5
"0" を書き込んだ場合
通常極性を選択します。
"1" を書き込んだ場合
反転極性を選択します。
[bit4] REV20: PPG タイマ 20 (ch. 2) 出力レベル反転ビット
このビットは PPG タイマ 20 (ch. 2) 出力レベルの極性を選択します。
説明
bit4
"0" を書き込んだ場合
通常極性を選択します。
"1" を書き込んだ場合
反転極性を選択します。
[bit3] REV11: PPG タイマ 11 (ch. 1) 出力レベル反転ビット
このビットは PPG タイマ 11 (ch. 1) 出力レベルの極性を選択します。
説明
bit3
"0" を書き込んだ場合
通常極性を選択します。
"1" を書き込んだ場合
反転極性を選択します。
[bit2] REV10: PPG タイマ 10 (ch. 1) 出力レベル反転ビット
このビットは PPG タイマ 10 (ch. 1) 出力レベルの極性を選択します。
説明
bit2
294
"0" を書き込んだ場合
通常極性を選択します。
"1" を書き込んだ場合
反転極性を選択します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 18 章 8/16 ビット PPG
18.7 レジスタ
Ha rdware
Manual
[bit1] REV01: PPG タイマ 01 (ch. 0) 出力レベル反転ビット
このビットは PPG タイマ 01 (ch. 0) 出力レベルの極性を選択します。
説明
bit1
"0" を書き込んだ場合
通常極性を選択します。
"1" を書き込んだ場合
反転極性を選択します。
[bit0] REV00: PPG タイマ 00 (ch. 0) 出力レベル反転ビット
このビットは PPG タイマ 00 (ch. 0) 出力レベルの極性を選択します。
説明
bit0
"0" を書き込んだ場合
通常極性を選択します。
"1" を書き込んだ場合
反転極性を選択します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
295
第 18 章 8/16 ビット PPG
18.8 使用上の注意
H ard war e
18.8
Ma nu al
使用上の注意
8/16 ビット PPG 使用上の注意を示します。
■ 8/16 ビット PPG 使用上の注意
● 動作上の注意
PPG の起動時とカウントクロックのタイミングによって , 起動後 1 周期目の PPG 出力
の周期に誤差が生じることがあります。また , その誤差はカウントクロックの選択によ
り異なります。2 周期目以降は正常に出力されます。
● 割込みに関する注意
割込み許可ビット (PIE1/PIE0) に "1" を設定している場合 , 8/16 ビット PPG タイマ n1/
n0 制御レジスタ (PCn1/PCn0) の割込み要求フラグビット (PUF1/PUF0) が "1" に設定さ
れると , PPG 割込みが発生します。割込みサービスルーチン内では , 割込み要求フラグ
ビット (PUF1/PUF0) は必ず "0" にクリアしてください。
296
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 19 章
16 ビットリロードタイマ
16 ビットリロードタイマの機能と動作について説
明します。
19.1 概要
19.2 構成
19.3 チャネル
19.4 端子
19.5 割込み
19.6 動作説明と設定手順例
19.7 レジスタ
19.8 使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
297
第 19 章 16 ビットリロードタイマ
19.1 概要
H ard war e
19.1
Ma nu al
概要
16ビットリロードタイマは, 2 つのクロックモードにおいて 2 つのカウンタ動作モー
ドが選択できます。
16 ビットリロードタイマのアンダフローが発生した場合に割込みを発生させること
により , インターバルタイマとして利用できます。
■ 16 ビットリロードタイマの動作モード
16 ビットリロードタイマの動作モードを表 19.1-1 に示します。
表 19.1-1 16 ビットリロードタイマの動作モード
クロックモード
内部クロックモード
カウンタ動作モード
トリガ動作モード
リロードモード
ソフトウェアトリガ動作
外部トリガ入力動作
外部ゲート入力動作
ワンショットモード
イベントカウントモード
( 外部クロックモード )
リロードモード
ワンショットモード
ソフトウェアトリガ動作
■ 内部クロックモード
16 ビットリロードタイマ制御ステータスレジスタ ( 上位 ) ch. n (TMCSRHn) のカウント
クロック設定ビット (CSL[2:0]) に "0b111" 以外を設定した場合は, 内部クロックモード
になります。
内部クロックモード時には , 以下の 3 種類のトリガ動作モードを選択できます。
● ソフトウェアトリガ動作
16 ビットリロードタイマ制御ステータスレジスタ ( 下位 ) ch. n (TMCSRLn) のカウント
許可ビット (CNTE) に "1" が設定されている場合に , ソフトウェアトリガビット (TRG)
を "1" に設定すると , カウントを開始します。
● 外部トリガ入力動作
16 ビットリロードタイマ制御ステータスレジスタ ( 下位 ) ch. n (TMCSRLn) のカウント
許可ビット (CNTE) に "1" が設定されている場合に , 動作モード選択ビット (MOD[2:0])
によって設定されている有効エッジ ( 立上り , 立下り , 両エッジから設定可能 ) が TIn
端子へ入力されると , カウントを開始します。
● 外部ゲート入力動作
16 ビットリロードタイマ制御ステータスレジスタ ( 下位 ) ch. n (TMCSRLn) のカウント
許 可 ビ ッ ト (CNTE) に "1" が 設 定 さ れ て い る 場 合 に , 動 作 モ ー ド 選 択 ビ ッ ト
(MOD[2:0]) によって設定されている有効なトリガ入力レベル ("L" または "H" を設定
可能 ) が TIn 端子へ入力されると , カウントを開始します。
■ イベントカウントモード ( 外部クロックモード )
16 ビットリロードタイマ制御ステータスレジスタ ( 上位 ) ch. n (TMCSRHn) のカウント
クロック設定ビット (CSL[2:0]) に "0b111" を設定した場合に , 動作モード選択ビット
(MOD[2:0]) によって設定されているトリガ入力の有効エッジ ( 立上り , 立下り , 両エッ
ジから設定可能 ) が TIn 端子へ入力されると , カウントを開始します。一定周期の外部
298
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 19 章 16 ビットリロードタイマ
19.1 概要
Ha rdware
Manual
クロックを入力する場合は , インターバルタイマとしても使用できます。
■ カウンタ動作モード
● リロードモード
16 ビットダウンカウンタでアンダフロー ("0x0000""0xFFFF") により , 16 ビットリ
ロードタイマリロードレジスタ ch. n (TMRLRHn/TMRLRLn) の値を 16 ビットダウンカ
ウンタへロードし , カウントを継続します。また , アンダフローにより割込み要求が出
力されるため , インターバルタイマとして使用できます。
● ワンショットモード
16 ビットダウンカウンタでアンダフローが発生した場合に割込みが生成されます。
カウンタ動作中 , カウンタが進行中であることを示す矩形波が TOn 端子から出力され
ます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
299
第 19 章 16 ビットリロードタイマ
19.2 構成
H ard war e
19.2
Ma nu al
構成
16 ビットリロードタイマは , 以下のブロックで構成されます。
• カウントクロック生成回路
• リロード制御回路
• 出力制御回路
• 動作制御回路
• 16 ビットリロードタイマタイマレジスタ ch. n (TMRHn, TMRLn)
• 16 ビットリロードタイマリロードレジスタ ch. n (TMRLRHn, TMRLRLn)
• 16 ビットリロードタイマ制御ステータスレジスタ ch. n (TMCSRHn, TMCSRLn)
品種により , 16 ビットリロードタイマの端子数およびチャネル数は異なります。 詳細
は , デバイスのデータシートを参照してください。
本章において , 端子名とレジスタ略称にある "n" はチャネル番号を示します。各品種の
端子名 , レジスタ名とレジスタ略称について , デバイスのデータシートを参照してくだ
さい。
■ 16 ビットリロードタイマのブロックダイヤグラム
16 ビットリロードタイマのブロックダイヤグラムを図 19.2-1 に示します。
図 19.2-1 16 ビットリロードタイマのブロックダイヤグラム
内部バス
16 ビットリロードタイマリロードレジスタch. n
(TMRLRHn/TMRLRLn)
リロード
リロード
制御回路
16 ビットリロードタイマタイマレジスタch. n
(TMRHn/TMRLn)
CLK
カウントクロック生成回路
端子
出力制御回路
入力制御回路
有効クロック
判定回路
TIn
反転
出力信号
生成回路
端子
許可
内部クロック
クロック選択
CLK
待ち
動作
制御回路
選択
機能選択
16ビットリロードタイマ
状態制御レジスタ(上位) ch. n
(TMCSRHn)
TOn
16ビットリロードタイマ
CSL2
CSL1 CSL0 MOD2 MOD1 MOD0
OUTE OUTL RELD INTE
UF CNTE TRG 状態制御レジスタ(下位) ch. n
(TMCSRLn)
割込み要求信号
内部バス
300
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 19 章 16 ビットリロードタイマ
19.2 構成
Ha rdware
Manual
● カウントクロック生成回路
内部クロックまたは TIn 端子の入力信号から 16ビットリロードタイマ用のカウントク
ロックを生成します。
● リロード制御回路
タイマ起動またはアンダフロー発生時にリロード動作を制御します。
● 出力制御回路
16 ビットダウンカウンタのアンダフローによる TOn 端子出力の反転制御と , TOn 端子
出力の許可 / 禁止を制御します。
● 動作制御回路
16 ビットダウンカウンタの起動 / 停止を制御します。
● 16 ビットリロードタイマタイマレジスタ ( 上位 / 下位 ) ch. n (TMRHn/TMRLn)
TMRHn と TMRLn が 16 ビットダウンカウンタを形成します。このレジスタの読出し
は , 現在のカウンタ値となります。
● 16 ビットリロードタイマリロードレジスタ ( 上位 / 下位 ) ch. n (TMRLRHn/TMRLRLn)
16 ビットダウンカウンタへのロード値を設定するレジスタです。16 ビットリロードタ
イマリロードレジスタの設定値を 16 ビットダウンカウンタにロードし , ダウンカウン
トします。
● 16ビットリロードタイマ制御ステータスレジスタ(上位/下位) ch. n (TMCSRHn/TMCSRLn)
このレジスタは 16 ビットリロードタイマのカウントクロック , 動作モード , クロック
選択 , 割込みなどを制御するとともに , 現在の動作状態を示します。
■ 入力クロック
16 ビットリロードタイマは , プリスケーラからの出力クロックまたは TIn 端子からの
入力信号を入力クロック ( カウントクロック ) として使用します。
イベントカウンタモード時にイベントカウンタが起動すると , TIn 端子からの外部ク
ロック入力は 8/16 ビット複合タイマ ch. 1 の PWM 出力信号によってゲート制御され ,
カウントクロックとして 16 ビットリロードタイマへ入力されます。詳細については ,
「第 20 章 イベントカウンタ」を参照してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
301
第 19 章 16 ビットリロードタイマ
19.3 チャネル
H ard war e
19.3
Ma nu al
チャネル
16 ビットリロードタイマのチャネルについて説明します。
■ 16 ビットリロードタイマのチャネル
16 ビットリロードタイマの端子とレジスタを表 19.3-1 および表 19.3-2 にそれぞれ示し
ます。
表 19.3-1 16 ビットリロードタイマの端子
端子名
端子機能
TOn
タイマ出力
TIn
タイマ入力
表 19.3-2 16 ビットリロードタイマのレジスタ
レジスタ略称
302
該当レジスタ ( 本マニュアル上の表記 )
TMCSRHn
16 ビットリロードタイマ制御ステータスレジスタ ( 上位 ) ch. n
TMCSRLn
16 ビットリロードタイマ制御ステータスレジスタ ( 下位 ) ch. n
TMRHn
16 ビットリロードタイマタイマレジスタ ( 上位 ) ch. n
TMRLn
16 ビットリロードタイマタイマレジスタ ( 下位 ) ch. n
TMRLRHn
16 ビットリロードタイマリロードレジスタ ( 上位 ) ch. n
TMRLRLn
16 ビットリロードタイマリロードレジスタ ( 下位 ) ch. n
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 19 章 16 ビットリロードタイマ
19.4 端子
Ha rdware
19.4
Manual
端子
16 ビットリロードタイマの端子について説明します。
■ 16 ビットリロードタイマの端子
16 ビットリロードタイマの端子は TIn 端子と TOn 端子 です。
● TIn 端子
この端子は , 汎用入出力ポートおよびカウンタに対する外部パルス入力端子 (TIn) とし
て使用されます。
TIn: カウンタ動作時にこの端子に入力されたパルスの任意エッジをカウントしま
す。カウンタ動作で TIn 端子として使用するときは , ポート方向レジスタ (DDR)
を "0" に設定して入力ポートにしてください。
● TOn 端子
この端子は , 汎用入出力ポートおよび 16 ビットリロードタイマの出力端子 (TOn) とし
て使用されます。
TOn: 16 ビットリロードタイマの波形が出力されます。
この端子を 16 ビットリロードタイマの TOn 端子として使用するとき , タイマ出
力を許可 (TMCSRLn:OUTE = 1) すると , ポート方向レジスタ (DDR) の設定にか
かわらず自動的に出力が実行され , 端子はタイマ出力の TOn 端子としての機能
をします。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
303
第 19 章 16 ビットリロードタイマ
19.5 割込み
H ard war e
19.5
Ma nu al
割込み
16 ビットリロードタイマは , 16 ビットダウンカウンタでのアンダフロー発生時に割
込み要求を出力します。
■ 16 ビットリロードタイマの割込み
16 ビットリロードタイマの割込み制御ビットと割込み要因を表 19.5-1 に示します。
表 19.5-1 16 ビットリロードタイマの割込み制御ビットと割込み要因
項目
説明
割込み要求フラグビット
TMCSRLn レジスタの UF ビット
割込み要求許可ビット
TMCSRLn レジスタの INTE ビット
割込み要因
ダウンカウンタ ch. n (TMRHn/TMRLn) のアンダフロー
16 ビットリロードタイマは , 16 ビットダウンカウンタにアンダフローが発生すると
("0x0000""0xFFFF"), 16 ビットリロードタイマ制御ステータスレジスタ ( 下位 ) ch. n
(TMCSRLn) のアンダフロー割込み要求フラグビット (UF) を "1" に設定します。アン
ダフロー割込み要求許可ビットが許可 (INTE = 1) に設定されている場合 , 割込み要求
が割込みコントローラに出力されます。
304
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 19 章 16 ビットリロードタイマ
19.6 動作説明と設定手順例
Ha rdware
19.6
Manual
動作説明と設定手順例
16 ビットリロードタイマカウンタの動作状態について説明します。
■ カウンタの動作状態
カウンタの状態は, 16ビットリロードタイマ制御ステータスレジスタ ch. n (TMCSRLn)
のカウント許可ビット (CNTE) の値と内部信号の起動トリガ待ち信号値 (WAIT) で決
まります。STOP 状態 ( 停止状態 ), WAIT 状態 ( 起動トリガ待ち状態 ) および RUN 状態
( 動作状態 ) の設定が可能です。
これらのカウンタの状態遷移を図 19.6-1 に示します。
図 19.6-1 カウンタ状態遷移図
リセット
STOP 状態 CNTE = 0, WAIT = 1
TIn端子 : 入力禁止
TOn端子 : 汎用出入力ポート
16 ビットリロードタイマタイマレジスタ :
停止時の値を保持
リセット直後の値 = 0x0000
CNTE = 0
CNTE = 0
CNTE = 0
CNTE = 1
TRG = 0
CNTE = 1
TRG = 1
WAIT 状態 CNTE = 1, WAIT = 1
TIn端子 : トリガ入力のみ有効
RUN 状態
TOn端子 : 16 ビットリロードタイマリロードレジスタ出力
16 ビットリロードタイマタイマレジスタ :
停止時の値を保持
リセット後ロードされるまで = 0x0000
UF=1 &
RELD=0
(ワンショット
モード)
TOn端子 : 16 ビットリロードタイマリロードレジスタ出力
16 ビットリロードタイマタイマレジスタ :
カウント動作
UF=1 &
RELD=1
(リロードモード)
TRG=1
(ソフトウェアトリガ)
TOn端子からの外部トリガ
WAIT
TRG
CNTE
UF
RELD
CNTE = 1, WAIT = 0
TIn端子 : 16 ビットリロードタイマ入力
LOAD
TRG=1
(ソフトウェアトリガ)
CNTE = 1, WAIT = 0
16 ビットリロードタイマタイマ
レジスタにロードされた 16 ビット
リロードタイマリロードレジスタ値
TIn端子からの外部トリガ
ロード完了
: ハードウェアによる状態遷移
: レジスタアクセスによる状態遷移
: WAIT 信号 (内部信号)
: ソフトウェアトリガビット (TMCSRLn)
: タイマ動作許可ビット (TMCSRLn)
: アンダフロー発生フラグビット (TMCSRLn)
: リロード選択ビット (TMCSRLn)
April 4, 2014, MB95F718M_MN702-00014-3v0-J
305
第 19 章 16 ビットリロードタイマ
19.6 動作説明と設定手順例
H ard war e
Ma nu al
■ 設定手順例
16 ビットリロードタイマの設定手順例を示します。
● 初期設定
1. 割込みレベルを設定してください (ILR*)。
2. リロード値を設定してください (TMRHn/TMRLn)。
3. クロックを選択してください (TMCSRHn:CSL[2:0])。
4. 動作モードを選択してください (TMCSRHn:MOD[2:0])。
5. 出力を許可してください (TMCSRLn:OUTE = 1)。
6. 出力レベルを選択してください (TMCSRLn:OUTL)。
7. リロードを選択してください (TMCSRLn:RELD)。
8. カウントを許可してください (TMCSRLn:CNTE = 1)。
9. ソフトウェアトリガを実行してください (TMCSRLn:TRG = 1)。
10. アンダフロー割込みを許可 してください (TMCSRLn:INTE = 1)。
*: 割込みレベル設定レジスタ (ILR) の詳細について , 本ハードウェアマニュアルの「第 5 章 割
込み」とデバイスのデータシートの「■ 割込み要因のテーブル」を参照してください。
● 割込み処理
1. アンダフロー割込み要求フラグをクリアしてください (TMCSRLn:UF=0)。
2. アンダフロー割込みを禁止してください (TMCSRLn:INTE = 0)。
3. 任意の割込み処理を行ってください。
4. アンダフロー割込みを許可してください (TMCSRLn:INTE = 1)。
306
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 19 章 16 ビットリロードタイマ
19.6 動作説明と設定手順例
Ha rdware
19.6.1
Manual
内部クロックモード
このモードでは, 16ビットダウンカウンタは内部カウントクロックと同期している間
カウントダウンし , アンダフローが発生 ("0x0000""0xFFFF") するたびに割込み要
求を割込みコントローラに出力します。また , TOn 端子はトグル波形を出力できま
す。
■ 内部クロックモードの設定
インターバルタイマとして動作させるには , レジスタを図 19.6-2 のように設定してく
ださい。
図 19.6-2 内部クロックモードの設定
TMCSRHn
bit7
-
bit6
-
bit5
CSL2
bit4
CSL1
bit3
CSL0
"0b111" 以外
TMCSRLn
TMRLRHn
bit2
bit1
bit0
MOD2 MOD1 MOD0
0
bit7
0
bit6
OUTE
bit5
OUTL
bit4
RELD
bit3
INTE
bit2
UF
bit1
CNTE
1
bit0
TRG
bit7
D15
bit6
D14
bit5
D13
bit4
D12
bit3
D11
bit2
D10
bit1
D9
bit0
D8
カウンタの初期値 ( リロード値 ) を設定 ( 上位 )
TMRLRLn
bit7
D7
bit6
D6
bit5
D5
bit4
D4
bit3
D3
bit2
D2
bit1
D1
bit0
D0
カウンタの初期値 ( リロード値 ) を設定 ( 下位 )
: 使用ビット
0 : "0" に設定
1 : "1" に設定
■ 内部クロックモード ( リロードモード ) の動作
カウント許可ビット (CNTE) に "1" を設定してカウントを許可している場合 , ソフト
ウェアトリガビット (TRG) に "1" を設定するかまたは外部トリガによってタイマが開
始されると , 16 ビットリロードタイマリロードレジスタ ch. n (TMRLRHn/TMRLRLn)
に設定した値が 16 ビットダウンカウンタにリロードされ , ダウンカウントが開始され
ます。カウント許可ビット (CNTE) とソフトウェアトリガビット (TRG) を同時に "1"
に設定し , カウント動作を許可すると , 同時にカウントを開始します。
リロード選択ビット (RELD) が "1" の場合 , 16 ビットカウンタでアンダフローが発生す
ると("0x0000""0xFFFF"),16ビットリロードタイマリロードレジスタch. n (TMRLRHn/
TMRLRLn) の値が 16 ビットダウンカウンタにリロードされ , カウントが継続します。
アンダフロー割込み要求フラグビット (UF) が "1" の場合 , アンダフロー割込み要求許
可ビット (INTE) を "1" に設定すると , 割込み要求が出力されます。
TOn 端子は , アンダフローの発生ごとに反転するトグル波形を出力できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
307
第 19 章 16 ビットリロードタイマ
19.6 動作説明と設定手順例
H ard war e
Ma nu al
● ソフトウェアトリガ動作
カウント許可ビット (CNTE) の設定が "1" の場合に , ソフトウェアトリガビット (TRG)
に "1" を設定すると , カウントを開始します。
リロードモードにおけるソフトウェアトリガ動作を図 19.6-3 に示します。
図 19.6-3 リロードモードのカウント動作 ( ソフトウェアトリガ動作 )
カウントクロック
-1
カウンタ
0000
リロードデータ
データロード信号
-1
0000
リロードデータ
-1
-1
0000
リロードデータ
リロードデータ
UF ビット
CNTE ビット
TRG ビット
TOn 端子
● 外部トリガ入力動作
カウント許可ビット (CNTE) の設定が "1" の場合に , 動作モード選択ビット (MOD[2:0])
で設定しているトリガ入力の有効エッジ ( 立上り , 立下り , 両エッジから選択可能 ) が
TIn 端子に入力されると , カウントを開始します。
なお , ソフトウェアトリガによるタイマ起動も , 外部トリガによる起動と同様に有効と
なります。
リロードモードにおける外部トリガ入力動作を図 19.6-4 に示します。
図 19.6-4 リロードモードのカウント動作 ( 外部トリガ入力動作 )
カウントクロック
-1
カウンタ
データロード信号
リロードデータ
0000
-1
リロードデータ
0000
-1
0000
リロードデータ
-1
リロードデータ
UF ビット
CNTE ビット
TIn 端子
TOn 端子
● ゲート入力動作
カウント許可ビット (CNTE) の設定" が1" の場合に, ソフトウェアトリガビット (TRG)
も "1" に設定すると , カウントを開始します。
動作モード選択ビット (MOD[2:0]) で設定されたゲート入力の有効レベル ("L" または
"H" が設定可能 ) が TIn 端子に入力されている間 , タイマはカウントを継続します。
なお , ソフトウェアトリガによるタイマ起動も , 外部トリガによる起動と同様に有効と
なります。
リロードモードにおけるゲート入力動作を図 19.6-5 に示します。
308
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 19 章 16 ビットリロードタイマ
19.6 動作説明と設定手順例
Ha rdware
Manual
図 19.6-5 リロードモードのカウント動作 ( 外部ゲート入力動作 )
カウントクロック
カウンタ
-1
リロードデータ
-1
-1
-1
0000
-1
リロードデータ
データロード信号
UF ビット
CNTE ビット
TRG ビット
TIn 端子
TOn 端子
■ 内部クロックモード ( ワンショットモード ) の動作
カウント許可ビット (CNTE) の設定が "1" の場合に , ソフトウェアトリガビット (TRG)
に "1" が設定されるか , 動作モード選択ビット (MOD[2:0]) で選択された有効エッジ ( 立
上り , 立下り , 両エッジから選択可能 ) が TIn 端子に入力されると , 16 ビットリロード
タイマリロードレジスタ ch. n に設定した値が 16 ビットダウンカウンタにリロードさ
れ , ダウンカウントを開始します。カウント許可ビット (CNTE) とソフトウェアトリガ
ビット (TRG) が同時に "1" に設定され , カウント動作が許可されると , 同時にカウント
を開始します。
リロード選択ビット (RELD) が "0" の場合, 16ビットカウンタでアンダフローが発生す
ると ("0x0000""0xFFFF"), 16 ビットカウンタは "0xFFFF" の状態でカウントを停止し
ます。このとき , アンダフロー割込み要求フラグビット (UF) が "1" に設定され , アンダ
フロー割込み要求許可ビット (INTE) が "1" の場合 , 割込み要求を出力します。
TOn 端子からは , カウント中を示す矩形波を出力できます。
● ソフトウェアトリガ動作
カウント許可ビット (CNTE) の設定が "1" の場合に , ソフトウェアトリガビット (TRG)
が "1" に設定されると , カウントを開始します。
ワンショットモードにおけるソフトウェアトリガ動作を図 19.6-6 に示します。
図 19.6-6 ワンショットモードのカウント動作 ( ソフトウェアトリガ動作 )
カウントクロック
カウンタ
データロード信号
-1
0000 FFFF
リロードデータ
-1
0000 FFFF
リロードデータ
UF ビット
CNTE ビット
TRG ビット
TOn 端子
起動トリガ入力待ち
April 4, 2014, MB95F718M_MN702-00014-3v0-J
309
第 19 章 16 ビットリロードタイマ
19.6 動作説明と設定手順例
H ard war e
Ma nu al
● 外部トリガ入力
カ ウ ン ト 許 可 ビ ッ ト (CNTE) の 設 定 が "1" の 場 合 に , 動 作 モ ー ド 選 択 ビ ッ ト
(MOD[2:0]) で設定しているトリガ入力の有効エッジ ( 立上り , 立下り , 両エッジから設
定可能 ) が TIn 端子に入力されると , カウントを開始します。
ワンショットモードにおける外部トリガ入力動作を図 19.6-7 に示します。
図 19.6-7 ワンショットモードのカウント動作 ( 外部トリガ入力動作 )
カウントクロック
-1
カウンタ
データロード信号
-1
0000 FFFF
リロードデータ
0000 FFFF
リロードデータ
UF ビット
CNTE ビット
TIn 端子
TOn 端子
起動トリガ入力待ち
● ゲート入力動作
カウント許可ビット (CNTE) の設定が "1" の場合に , ソフトウェアトリガビット (TRG)
が "1" に設定されると , カウントを開始します。
動作モード選択ビット (MOD[2:0]) で設定しているトリガ入力の許可レベル ("L" また
は "H" が設定可能 ) が TIn 端子に入力されている間 , タイマはカウントを継続します。
ワンショットモードにおける外部ゲート入力動作を図 19.6-8 に示します。
図 19.6-8 ワンショットモードのカウント動作 ( 外部ゲート入力動作 )
カウントクロック
カウンタ
リロードデータ
-1
0000 FFFF
-1
-1
リロードデータ
データロード信号
UF ビット
CNTE ビット
TRG ビット
TIn 端子
TOn 端子
起動トリガ入力待ち
310
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 19 章 16 ビットリロードタイマ
19.6 動作説明と設定手順例
Ha rdware
19.6.2
Manual
イベントカウントモード
このモードでは , TIn 端子に入力されたパルスで有効エッジが検出されるごとに 16 ビット
ダウンカウンタをダウンカウントし , アンダフローが発生すると ("0x0000" "0xFFFF"),
割込みコントローラに割込み要求を出力します。また , TOn 端子からトグル波形または矩
形波を出力できます。
■ イベントカウントモードの設定
イベントカウンタとして動作させるには , レジスタを図 19.6-9 のように設定してくだ
さい。
図 19.6-9 イベントカウントモードの設定
TMCSRHn
bit7
-
bit6
-
bit5
CSL2
1
bit4
CSL1
1
bit3
CSL0
1
bit2
bit1
bit0
MOD2 MOD1 MOD0
TMCSRLn
bit7
-
bit6
OUTE
bit5
OUTL
bit4
RELD
bit3
INTE
bit2
UF
bit1
CNTE
1
bit0
TRG
TMRLRHn
bit7
D15
bit6
D14
bit5
D13
bit4
D12
bit3
D11
bit2
D10
bit1
D9
bit0
D8
カウンタの初期値 ( リロード値 ) を設定 ( 上位 )
TMRLRLn
bit7
D7
bit6
D6
bit5
D5
bit4
D4
bit3
D3
bit2
D2
bit1
D1
bit0
D0
カウンタの初期値 ( リロード値 ) を設定 ( 下位 )
: 使用ビット
1 : "1" を設定
■ イベントカウントモード
カウント許可ビット (CNTE) の設定が "1" の場合に , ソフトウェアトリガビット (TRG)
に "1" を設定すると , 16 ビットリロードタイマリロードレジスタ ch. n (TMRLRHn/
TMRLRLn) に設定した値が 16 ビットカウンタにリロードされます。TIn 端子に入力さ
れたパルス ( 外部カウントクロック ) の有効エッジ ( 立上り , 立下り , 両エッジから選
択可能 ) を検出するごとにカウントします。
● リロードモードの動作
リロード選択ビット (RELD) が "1" の場合, 16ビットカウンタにアンダフローが発生す
ると("0x0000""0xFFFF"),16ビットリロードタイマリロードレジスタch. n (TMRLRHn/
TMRLRLn) に設定した値が 16 ビットカウンタにリロードされ , カウントを継続しま
す。
16ビットカウンタにアンダフローが発生すると ("0x0000""0xFFFF"), 16ビットリロー
ドタイマ制御ステータスレジスタ ( 下位 ) ch. n (TMCSRLn) のアンダフロー割込み要求
フラグビット (UF) に "1" が設定されます。
アンダフロー割込み許可ビット (INTE) に
"1" を設定している場合は割込み要求を出力します。
TOn 端子からは , アンダフローの発生ごとに反転するトグル波形を出力できます。リ
ロードモードにおけるカウント動作を図 19.6-10 に示します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
311
第 19 章 16 ビットリロードタイマ
19.6 動作説明と設定手順例
H ard war e
Ma nu al
図 19.6-10 リロードモードのカウント動作 ( イベントカウントモード )
TIn 端子
-1
カウンタ
データロード信号
-1
0000
リロードデータ
0000
リロードデータ
-1
-1
0000
リロードデータ
リロードデータ
UF ビット
CNTE ビット
TRG ビット
TOn 端子
● ワンショットモードの動作
リロード選択ビット (RELD) が "0" の場合, 16ビットカウンタでアンダフローが発生す
ると ("0x0000""0xFFFF"), 16 ビットカウンタの値は "0xFFFF" の状態で停止します。
16 ビットリロードタイマ制御ステータスレジスタ ( 下位 ) ch. n (TMCSRLn) のアンダフ
ロー要求フラグビット (UF) に "1" が設定され , アンダフロー割込み許可ビット (INTE)
の設定が "1" の場合には割込み要求を出力します。
TOn 端子はカウント中を示す矩形波を出力します。ワンショットモードにおけるカウ
ント動作を図 19.6-11 に示します。
図 19.6-11 ワンショットモードのカウント動作 ( イベントカウントモード )
TIn 端子
カウンタ
データロード信号
-1
0000 FFFF
リロードデータ
-1
0000 FFFF
リロードデータ
UF ビット
CNTE ビット
TRG ビット
TOn 端子
起動トリガ入力待ち
312
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 19 章 16 ビットリロードタイマ
19.7 レジスタ
Ha rdware
19.7
Manual
レジスタ
16 ビットリロードタイマのレジスタについて説明します。
表 19.7-1
16 ビットリロードタイマのレジスタ一覧
レジスタ略称
レジスタ名
参照先
TMCSRHn
16 ビットリロードタイマ制御ステータスレジスタ ( 上位 ) ch. n
19.7.1
TMCSRLn
16 ビットリロードタイマ制御ステータスレジスタ ( 下位 ) ch. n
19.7.2
TMRHn
16 ビットリロードタイマタイマレジスタ ( 上位 ) ch. n
19.7.3
TMRLn
16 ビットリロードタイマタイマレジスタ ( 下位 ) ch. n
19.7.3
TMRLRHn
16 ビットリロードタイマリロードレジスタ ( 上位 ) ch. n
19.7.4
TMRLRLn
16 ビットリロードタイマリロードレジスタ ( 下位 ) ch. n
19.7.4
April 4, 2014, MB95F718M_MN702-00014-3v0-J
313
第 19 章 16 ビットリロードタイマ
19.7 レジスタ
H ard war e
19.7.1
Ma nu al
16 ビットリロードタイマ制御ステータスレジスタ
( 上位 ) ch. n (TMCSRHn)
16 ビットリロードタイマ制御ステータスレジスタ ( 上位 ) ch. n (TMCSRHn) は , 16
ビットリロードタイマの動作モードと動作条件を設定します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
CSL2
CSL1
CSL0
MOD2
MOD1
MOD0
属性
—
—
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7:6] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit5:3] CSL[2:0]: カウントクロック選択ビット
これらのビットは 16 ビットリロードタイマのカウントクロックを選択します。
"0b000" ~ "0b110" のいずれの値がこれらのビットに書き込まれた場合 , 16 ビットリロードタイマは
内部クロックでカウントします (内部クロックモード) 。内部クロックはプリスケーラにより生成さ
れます。詳細は ,「 3.9 プリスケーラの動作」を参照してください。
"0b111" がこれらのビットに書き込まれた場合 , 16 ビットリロードタイマは外部イベントクロック
のエッジでカウントします ( イベントカウントモード ) 。
説明
bit5:3
カウントクロック *
動作モード
"000" を書き込んだ場合
1 MCLK
"001" を書き込んだ場合
MCLK/2
"010" を書き込んだ場合
MCLK/4
"011" を書き込んだ場合
内部クロックモード
MCLK/8
"100" を書き込んだ場合
MCLK/16
"101" を書き込んだ場合
MCLK/32
"110" を書き込んだ場合
FCH/27 または FCRH/26 または FPLL/26
"111" を書き込んだ場合
イベントカウントモード
外部クロック
*: MCLK: マシンクロック
FCH: メインクロック
FCRH: メイン CR クロック
FPLL: PLL クロック
314
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 19 章 16 ビットリロードタイマ
19.7 レジスタ
Ha rdware
Manual
[bit2:0] MOD[2:0]: 動作モード選択ビット
これらのビットは 16 ビットリロードタイマの動作条件を設定します。
• 内部クロックモード (CSL[2:0] = 0b000 ~ 0b110 のいずれかの値 )
MOD2 ビットで入力端子の機能を選択してください。
MOD2 ビットが "0" の場合:
- TIn 端子はトリガ入力端子として機能します。
- MOD[1:0] ビットで検出されるエッジを選択してください。
- MOD[1:0] で選択されたエッジが検出されると , 16 ビットリロードタイマリロードレジスタ ( 上
位 / 下位 ) ch. n (TMRLRHn/TMRLRLn) に設定された値が 16 ビットリロードタイマタイマレジス
タ ( 上位 / 下位 ) ch. n (TMRHn/TMRLn) にリロードされ , 16 ビットリロードタイマ ch. n は TMRHn/
TMRLn でカウント動作を開始します。
MOD2 ビットが "1" の場合:
- TIn 端子はゲート入力として機能します。
- MOD1 ビットの設定は無効となります。
- MOD0 ビットで有効とする信号レベル ("H" または "L") を選択してください。 有効な信号レベ
ルが入力されている間のみ , 16 ビットリロードタイマは TMRHn/TMRLn でカウント動作を行い
ます。
( 注意事項 ) MOD[2:0] が "0b000" の場合は外部端子からの入力が無効となります。その場合 , TRG
ビットを使用して, ソフトウェアにより16ビットリロードタイマを起動してください。
説明 ( 内部クロックモード )
bit2:0
"000" を書き込んだ場合
TIn 端子機能
有効なエッジ / レベル
外部端子からの入力が無効になります。
—
"001" を書き込んだ場合
"010" を書き込んだ場合
立上りエッジ
トリガ入力
立下りエッジ
"011" を書き込んだ場合
両エッジ
"100" を書き込んだ場合
"L" レベル
"101" を書き込んだ場合
"110" を書き込んだ場合
"H" レベル
ゲート入力
"L" レベル
"111" を書き込んだ場合
"H" レベル
• イベントカウントモード (CSL[2:0] = 0b111)
- MOD2 ビットは常に "0" に固定されます。
- 外部イベントクロックは TIn 端子から入力されます。
- MOD[1:0] ビットで検出されるエッジを選択してください。
説明 ( イベントカウントモード )
bit2:0
"000" を書き込んだ場合
TIn 端子機能
有効なエッジ
外部端子からの入力が無効になります。
—
"001" を書き込んだ場合
"010" を書き込んだ場合
立上りエッジ
トリガ入力
"011" を書き込んだ場合
立下りエッジ
両エッジ
"100" を書き込んだ場合
"101" を書き込んだ場合
"110" を書き込んだ場合
設定禁止
"111" を書き込んだ場合
April 4, 2014, MB95F718M_MN702-00014-3v0-J
315
第 19 章 16 ビットリロードタイマ
19.7 レジスタ
H ard war e
19.7.2
Ma nu al
16 ビットリロードタイマ制御ステータスレジスタ
( 下位 ) ch. n (TMCSRLn)
16 ビットリロードタイマ制御ステータスレジスタ ( 下位 ) ch. n (TMCSRLn) は , 16
ビットリロードタイマの動作条件の設定 , カウント動作の許可 / 禁止の設定 , 割込み
制御および割込み要求状態の確認などを行います。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
OUTE
OUTL
RELD
INTE
UF
CNTE
TRG
属性
—
R/W
R/W
R/W
R/W
R/W
R/W
W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] 未定義ビット
読出し値は常に "0" です。このビットに値を書き込んでも動作に影響はありません。
[bit6] OUTE: タイマ出力許可ビット
このビットは 16 ビットリロードタイマの TOn 端子機能を設定します。
説明
bit6
"0" を書き込んだ場合
TOn 端子は汎用入出力ポートとして機能します。
"1" を書き込んだ場合
TOn 端子は 16 ビットリロードタイマの出力端子として機能します。
[bit5] OUTL: 端子出力レベル選択ビット
このビットは 16 ビットリロードタイマの出力端子の出力レベルを選択します。
説明
bit5
316
ワンショットモード
(TMCSRLn:RELD = 0)
リロードモード
(TMCSRLn:RELD = 1)
"0" を書き込んだ場合
出力端子は 16 リロードタイマの起動時
出力端子は 16 リロードタイマのカウン
に "L" を出力し , アンダフロー発生のた
ト中に "H" の矩形波を出力します。
びにトグルします。
"1" を書き込んだ場合
出力端子は 16 リロードタイマの起動時
出力端子は 16 リロードタイマのカウン
に "H" を出力し , アンダフロー発生の
ト中に "L" の矩形波を出力します。
たびにトグルします。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 19 章 16 ビットリロードタイマ
19.7 レジスタ
Ha rdware
Manual
[bit4] RELD: リロード選択ビット
このビットはアンダフロー発生時のリロード動作を選択します。
このビットに "0" が書き込まれた場合 , 16 ビットリロードタイマはワンショットモードに入ります。
このワンショットモードでは , アンダフローが発生すると , 16 ビットリロードタイマはカウントを
停止します。
このビットに "1" が書き込まれた場合 , 16 ビットリロードタイマはリロードモードに入ります。こ
のリロードモードでは , アンダフローが発生すると , 16 ビットリロードタイマリロードレジスタ
ch. n (TMRLRHn/TMRLRLn) にあらかじめ設定された値が 16 ビットリロードタイマタイマレジスタ
ch. n (TMRHn/TMRLn) にロードされ , 16 ビットリロードタイマはカウントを続行します。
説明
bit4
"0" を書き込んだ場合
ワンショットモード
"1" を書き込んだ場合
リロードモード
[bit3] INTE: アンダフロー割込み要求許可ビット
このビットはアンダフロー割込みを許可または禁止します。
説明
bit3
"0" を書き込んだ場合
アンダフロー割込み要求を禁止します。
"1" を書き込んだ場合
アンダフロー割込み要求を許可します。
[bit2] UF: アンダフロー割込み要求フラグビット
このビットは 16 ビットリロードタイマでアンダフローが発生しているかを示します。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit2
"0" が読み出された場合
アンダフローが発生していないことを示します。
"1" が読み出された場合
アンダフローが発生していることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit1] CNTE: カウント許可ビット
このビットは 16 ビットリロードタイマのカウント動作を許可または停止します。
このビットに "0" が書き込まれた場合 , 16 ビットリロードタイマはカウントを停止します。
このビットに "1" が書き込まれた場合 , 16 ビットリロードタイマは起動トリガ待ち状態に入ります。
起動トリガが入力されると , 16 ビットリロードタイマはカウントを開始します。
説明
bit1
"0" を書き込んだ場合
16 ビットリロードタイマのカウント動作を停止します。
"1" を書き込んだ場合
16 ビットリロードタイマのカウント動作を許可します ( 起動トリガ待ち状態 )。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
317
第 19 章 16 ビットリロードタイマ
19.7 レジスタ
H ard war e
Ma nu al
[bit0] TRG: ソフトウェアトリガビット
このビットは , ソフトウェアによる 16 ビットリロードタイマの起動を許可します。
16 ビットリロー
ドタイマ動作が許可されている場合 (CNTE=1) にのみ有効です。
このビットへの "0" の書込みは動作に影響を与えません。
このビットに "1" が書き込まれた場合 , 16 ビットリロードタイマリロードレジスタ ch. n (TMRLRHn/
TMRLRLn) に設定された値が 16 ビットリロードタイマタイマレジスタ ch. n (TMRHn/TMRLn) にリ
ロードされ , 16 ビットリロードタイマが次のカウントクロック入力からカウントを開始します。
( 注意事項 ) このビットに CNTE ビットと同時に "1" を書き込んでも動作に影響はありません。
このビットの読出し値は常に "0" です。ただし , "1" の書込みで 16 ビットリロードタイマが起動し
た後 , 16 ビットリロードタイマがカウントを開始するまでは , このビットは "1" を読み出します。
説明
bit0
318
読出し動作
読出し値は常に "0" です。
"0" を書き込んだ場合
動作に影響はありません。
"1" を書き込んだ場合
TMRLRHn/TMRLRLn の値がリロードされた後 , 16 ビットリロードタイマがカウ
ントを開始します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 19 章 16 ビットリロードタイマ
19.7 レジスタ
Ha rdware
Manual
16 ビットリロードタイマタイマレジスタ
( 上位 / 下位 ) ch. n (TMRHn/TMRLn)
19.7.3
16 ビットリロードタイマタイマレジスタ ( 上位 / 下位 ) ch. n (TMRHn/TMRLn) は , 16
ビットダウンカウンタのカウント値を読み出します。
■ レジスタ構成
TMRHn
bit
7
6
5
4
3
2
1
0
Field
D15
D14
D13
D12
D11
D10
D9
D8
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
TMRLn
bit
7
6
5
4
3
2
1
0
Field
D7
D6
D5
D4
D3
D2
D1
D0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
16 ビットリロードタイマタイマレジスタ ch. n は 16 ビットダウンカウンタのカウント
値を読み出します。
16 ビットリロードタイマがカウント開始する時に , 16 ビットリロードタイマのカウン
ト動作が既に許可 (TMCSRLn:CNTE = 1) されている場合 , 16 ビットリロードタイマリ
ロードレジスタに設定された値が 16 ビットリロードタイマタイマレジスタ ch. n にリ
ロードされ , 16 ビットリロードタイマはダウンカウントを開始します。
<注意事項>
•
このレジスタはカウント中でもカウント値を読み出すことが可能です。 読み出すとき
は , ワード転送命令を使用するか , 上位  下位の順に読出しを行ってください。この
レジスタは上位を読み出した時点で下位の値を保持するような回路構成となっていま
す。
•
このレジスタはリードオンリであり , 16 ビットリロードタイマリロードレジスタ ch. n
と同一のアドレスに配置されています。したがって , このレジスタへの書込みは 16
ビットリロードタイマリロードレジスタ ch. n への書込みとなります。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
319
第 19 章 16 ビットリロードタイマ
19.7 レジスタ
H ard war e
Ma nu al
16 ビットリロードタイマリロードレジスタ
( 上位 / 下位 ) ch. n (TMRLRHn/TMRLRLn)
19.7.4
16ビットリロードタイマリロードレジスタ(上位/下位) ch. n (TMRLRHn/TMRLRLn)
は 16 ビットダウンカウンタへのリロード値を設定します。16 ビットリロードタイマ
リロードレジスタ ch. n に設定された値が 16 ビットダウンカウンタにリロードされ ,
ダウンカウントに使用されます。
■ レジスタ構成
TMRLRHn
bit
7
6
5
4
3
2
1
0
Field
D15
D14
D13
D12
D11
D10
D9
D8
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
TMRLRLn
bit
7
6
5
4
3
2
1
0
Field
D7
D6
D5
D4
D3
D2
D1
D0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
16 ビットリロードタイマリロードレジスタ ch. n は 16 ビットダウンカウンタ ch. n へリ
ロードされるリロード値を設定します。
16 ビットリロードタイマリロードレジスタ ch. n に設定された値が起動時もしくはアン
ダフロー発生時に 16 ビットリロードタイマタイマレジスタ ch. n にリロードされ , ダウ
ンカウントに使用されます。なお , 16 ビットリロードタイマのカウント中に 16 ビット
リロードタイマリロードレジスタ ch. n の値を変更できます。
<注意事項>
320
•
カウント中でもこのレジスタに値を書き込むことが可能です。 書込み時はワード転送
命令を使用するか , 上位  下位の順に書込みを行ってください。このレジスタは下位
を書き込んだ時点で上位の値を有効にするような回路構成となっています。
•
このレジスタは書込み専用のレジスタであり , 16 ビットリロードタイマタイマレジス
タ ch. n と同一のアドレスに配置されています。したがって , このレジスタからの読出
しは 16 ビットリロードタイマタイマレジスタ ch. n からの読出しとなります。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 19 章 16 ビットリロードタイマ
19.8 使用上の注意
Ha rdware
19.8
Manual
使用上の注意
16 ビットリロードタイマ使用上の注意を示します。
■ 16 ビットリロードタイマ使用上の注意
● プログラム設定上の注意
•
16 ビットリロードタイマタイマレジスタ ch. n (TMRHn/TMRLn) はカウント中でも
値を読み出せます。読出し時はワード転送命令を使用するか , 上位  下位の順に読
み出してください。
•
16 ビットリロードタイマリロードレジスタ ch. n (TMRLRHn/TMRLRLn) はカウント
中でも値を書き込めます。書込み時はワード転送命令を使用するか , 上位  下位の
順に書き込んでください。
● 割込みに関する注意
割込み要求が許可されている場合 (TMCSRLn:INTE = 1) は ,16 ビットリロードタイマ制
御ステータスレジスタ ( 下位 ) ch. n (TMCSRLn) のアンダフロー割込み要求フラグビッ
ト(UF)が"1" に設定されると, CPU は割込み処理から復帰できません。必ず割込みサー
ビスルーチン内で UF ビットをクリアしてください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
321
第 19 章 16 ビットリロードタイマ
19.8 使用上の注意
H ard war e
322
Ma nu al
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 20 章
イベントカウンタ
イベントカウンタの機能と動作について説明しま
す。
20.1 概要
20.2 構成
20.3 イベントカウンタ動作モードの動作説明
20.4 設定手順例
20.5 周波数の測定範囲および測定精度
20.6 レジスタ
20.7 使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
323
第 20 章 イベントカウンタ
20.1 概要
H ard war e
20.1
Ma nu al
概要
イベントカウンタは , 主に測定周期の設定が可能な外部クロックの周波数を測定しま
す。16 ビットリロードタイマおよび 8/16 ビット複合タイマ ch.1 は , イベントカウン
タの動作モードを機能させるために構成されます。
■ イベントカウンタの動作モード
このモード時には , 8/16 ビット複合タイマ ch.1 は H パルス信号を生成するために使用
します。H パルス信号の生成方法は , 品種により異なります。詳細は , 20.3 イベントカ
ウンタ動作モードの動作説明を参照してください。
次に , 外部クロックがこの H パルス信号によってゲート制御され , カウントクロックと
して 16 ビットリロードタイマへ入力されます。16 ビットリロートタイマは , 外部ク
ロックモード ( リロードモード ) 時に動作します。外部クロックの周波数は , 8/16 ビッ
ト複合タイマ ch.1 の割込みサービスサブルーチンによって設定された測定周期を基に
算出されます。
<注意事項>
以降の項目において , 「複合タイマ」は「8/16 ビット複合タイマ ch.1」を表し , 「リロー
ドタイマ」は「16 ビットリロードタイマ」を表します。
324
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 20 章 イベントカウンタ
20.2 構成
Ha rdware
20.2
Manual
構成
コンパレータモジュール全体は以下のブロックで構成されます。
• リロードタイマのカウントクロック生成回路
• 複合タイマのカウントクロック (CK06) 選択回路
• イベントカウンタ制御レジスタ (EVCR)
■ イベントカウンタのブロックダイヤグラム
図 20.2-1 イベントカウンタのブロックダイヤグラム
EVCR
-
-
-
-
SEL1 SEL0 MD
-
外部クロック
複合タイマからの
H パルス信号
タイムベースタイマ
からのクロック
FCH/27
FCRH/26
FCH/29 または
FCRH/28
FCH/211
FCRH/210
リロードタイマの
カウントクロック
生成回路
複合タイマの
カウントクロック
セレクタ
リロードタイマのカウントクロック(TI)
複合タイマのカウントクロック(CK06)
FCH: メインクロック
FCRH: メインCRクロック
*: メインクロックモードで, SYCC:SCS[2:0]が“0b010”に設定された場合, メインクロックの2分周 (FCH/2) がカウントクロックとして使用され,
SYCC:SCS[2:0]が“0b011”に設定された場合, メインPLLクロックがカウントクロックとして使用されます。
● リロードタイマのカウントクロック生成回路
EVCR レジスタの MD ビットを "1" に設定するとき , 外部クロック入力は複合タイマか
らの H パルス出力によってゲート制御され , カウントクロックとしてリロードタイマ
へ出力されます。MD ビットを "0" に設定するとき , 外部クロックは外部クロックとし
て直接リロードタイマへ出力します。
● 複合タイマのカウントクロック (CK06) 選択回路
イベントカウンタは , EVCR レジスタの SEL[1:0] ビットの設定にしたがって , 下記のタ
イムベースタイマ出力信号 ( 分周マシンクロック信号 ) から CK06 のカウントクロック
として使用します。
1. FCH/27, FCH/29, FCH/211 ( メインクロックモード )
2. PLLC レジスタの MPMC[1:0] ビットの設定で逓倍されたメイン PLL クロック
3. FCRH/26, FCRH/28, FCRH/210 ( メイン CR クロックモード )
4. PLLC レジスタの MPMC[1:0] ビットの設定で逓倍されたメイン CR PLL クロック
● イベントカウンタ制御レジスタ (EVCR)
イベントカウンタ制御レジスタは , イベントカウンタの動作モードの許可 / 禁止を設
定し , 複合タイマのカウントクロックソース (CK06) を選択します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
325
第 20 章 イベントカウンタ
20.3 イベントカウンタ動作モードの動作説明
H ard war e
20.3
Ma nu al
イベントカウンタ動作モードの動作説明
イベントカウンタ動作モードの動作について説明します。
リロードタイマと複合タイマをイベントカウンタ ( 周波数測定用 ) として動作させるに
は , 図 20.3-1 に示された設定をしてください。
図 20.3-1 イベントカウンタ動作モードの設定
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
-
-
-
-
SEL1
SEL0
MD
○
○
1
イベントカウンタのレジスタ
EVCR
リロードタイマのレジスタ
TMCSRHn
TMCSRLn
-
-
CSL2
CSL1
CSL0
MOD2
MOD1
MOD0
1
1
1
OUTE
OUTL
RELD
INTE
○
UF
○
CNTE
○
TRG
×
×
1
○
○
1
○
TMRLRHn
リロード値 ( 上位 ) をセット
TMRLRLn
リロード値 ( 下位 ) をセット
複合タイマのレジスタ
T10CR0/T11CR0
IFE
C2
C1
C0
F3
F2
F1
F0
1
0
T10CR1/T11CR1
○
STA
1
HO
IE
IR
○
BF
○
IF
○
SO
○
OE
○
TIS
×
×
MOD
FE11
○
FE10
0
TO1
○
TO0
×
TMCR1
FE01
FE00
○
○
×
0
×
×
×
×
1
*1
T10DR
比較値を設定
T11DR
比較値を設定 *1
○ : 使用ビット
× : 未使用ビット
1
: "1" に設定
0
: "0" に設定
*1 インターバルタイマモード ( 連続モード ) を選択した場合は
T10DR にインターバル時間を設定してください。
PWM タイマ動作モード ( 可変周期モード ) を選択した場合は
T10DR に L 幅時間 , T11DR に周期を設定してください。
イベントカウンタ動作モードでは , リロードタイマおよび複合タイマが使用されるた
め , それらをほかの機能に使用できません。
リロードタイマは , イベントカウントモード ( リロードモード ) がリロードタイマの動
作モードとして選択されたときに動作します。イベントカウントモード ( リロードモー
ド ) を選択するには , TMCSRLn レジスタの MOD[2:0] ビットを "0b001", "0b010" または
"0b011" に , 同じレジスタの RELD ビットを "1" に設定してください。また , リロード
タイマのアンダフローの回数を記録するために , リロードタイマの割込みを許可して
ください。
複合タイマは MB95710L/770L シリーズ (MB95F714E/F714L/F716E/F716L/F718E/F718L/
F774E/F774L/F776E/F776L/F778E/F778L) の場合 , インターバルタイマ動作モード ( 連続
モード ) を複合タイマの動作モードとして選択したとき , MB95710M/770M シリーズ
(MB95F714J/F714M/F716J/F716M/F718J/F718M/F774J/F774M/F776J/F776M/F778J/
F778M) の場合 , インターバルタイマ動作モード ( 連続モード ) か PWM タイマ動作モー
ド ( 可変周期モード ) を複合タイマの動作モードとして選択したときに動作します。
326
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 20 章 イベントカウンタ
20.3 イベントカウンタ動作モードの動作説明
Ha rdware
Manual
インターバルタイマ動作モード ( 連続モード ) を選択するには , T10CR0 レジスタの
F[3:0] ビットを "0b0001" に , PWM タイマ動作モード ( 可変周期モード ) を選択するに
は , 同ビットを "0b0100" に設定してください。また , 同レジスタの C[2:0] ビットを
"0b110" に設定し , 複合タイマカウントクロックソース (CK06) を選択してください。ま
た , 外部クロックの周波数を計算するためにインターバルタイマ動作モード ( 連続モー
ド ) の場合は , タイマ 00 の割り込みを , PWM タイマ動作モード ( 可変周期モード ) の
場合は , タイマ 01 の割込みを許可してください。
リロードタイマがアンダフローしたときには , アンダフロー回数を記録し , リロードタ
イマの割込みサービスサブルーチンにおいてはアンダフローフラグ (UF) をクリアして
ください。インターバルタイマ動作モード ( 連続モード ) の場合は , タイマ 10 の割り
込みが複合タイマにおいて発生した際には 1 回目は T10CR1 レジスタの IF ビットをク
リアしインターバル時間の設定 , 2 回目は T10CR1 レジスタの IF ビットをクリアしリ
ロードタイマのカウント値を読み出し , かつ割り込みサービスサブルーチンにおける
外部クロック周波数を算出してください。PWM タイマ動作モード ( 可変周期モード )
の場合は , タイマ 11 の割込みが複合タイマにおいて発生した際には , T11CR1 レジスタ
の IF ビットをクリアし , リロードタイマのカウント値を読み出し , かつ割込みサービ
スサブルーチンにおける外部クロック周波数を算出してください。
図 20.3-2 に , イベントカウンタ動作モードの動作を示します。
図 20.3-2 イベントカウンタ動作モードの動作
外部クロック
Hパルス信号
リロードタイマの
カウントクロック
リロード
タイマカウンタ
リロ-ド値
カウントダウン
0000
リロ-ド値 カウントダウン
リロードタイマの
アンダフロー割込み
タイマ割込み
注意事項:
・リロードタイマのアンダフロー割込みサービスサブルーチンにおいて,IFフラグをクリア,
アンダフロー回数をカウント,およびリロ-ドレジスタへリロ-ド値を書き込んでください。
・インターバルタイマ動作モード (連続モード) 使用時は,
タイマ10 (複合タイマch.0) 2回目のコンペア
マッチ割込みサービスサブルーチンにおいて,
IFフラグをクリア,
リロード値の読み出し,
および
周波数を算出してください。
・PWMタイマ動作モード (可変周期モード) 使用時は,
タイマ11 (割込みタイマch.1 )コンペアマッチ
割込みサービスサブルーチンにおいて,
IFフラグをクリア,
リロード値の読み出し,
および周波数を
算出してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
327
第 20 章 イベントカウンタ
20.3 イベントカウンタ動作モードの動作説明
H ard war e
Ma nu al
図 20.3-3, 図 20.3-4 は外部クロック周波数の計算式を示します。
図 20.3-3 外部クロック周波数の計算式 ( インターバルタイマ動作モード ( 連続モード ) 使用時 )
外部クロック周波数 =
リロードタイマのカウント値 Hパルス幅
上記の説明:
(リロードタイマのカウント値) = (TMRLRHn/TMRLRLn設定値) × (アンダフロー回数) + (TMRLRHn/TMRLRLn設定値) − (TMRHn/TMRLnの読出し値)
(Hパルス幅) =
(T10DR設定値 + 1)
(複合タイマのカウントクロックソースの周波数)
図 20.3-4 外部クロック周波数の計算式 (PWM タイマ動作モード ( 可変周期モード ) 使用時 )
外部クロック周波数 =
リロードタイマのカウント値 PWM信号のHパルス幅
上記の説明:
(リロードタイマのカウント値) = (TMRLRHn/TMRLRLn設定値) × (アンダフロー回数) + (TMRLRHn/TMRLRLn設定値) − (TMRHn/TMRLnの読出し値)
(PWM信号のHパルス幅) =
328
(T11DR設定値 − T10DR設定値)
(複合タイマのカウントクロックソースの周波数)
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 20 章 イベントカウンタ
20.4 設定手順例
Ha rdware
20.4
Manual
設定手順例
各イベントカウンタの機能を設定する手順を示します。
インターバルタイマ動作モード ( 連続モード ) を使用する場合
(MB95710L/770L シリーズ , MB95710M/770M シリーズ共通 )
■ 初期設定
1. イベントカウンタモードを選択してください。(EVCR:MD)
2. 複合タイマカウントクロック CK06 を選択してください。(EVCR:SEL[1:0])
3. リロードタイマおよび複合タイマそれぞれの割込みレベルを設定してください。
(ILR)
4. リロードタイマのリロード値を設定してください。(TMRLRHn/TMRLRLn)
5. リロードタイマのカウントクロックを選択してください。(TMCSRHn:CSL[2:0])
6. リロードタイマの動作モードを選択してください。(TMCSRHn:MOD[2:0]
7. リロードモードを選択してください。(TMCSRLn:RELD)
8. アンダフロー割込みを許可してください。(TMCSRLn:INTE)
9. リロードタイマのカウントを許可してください。(TMCSRLn:CNTE)
10. ソフトウェアトリガを発生させてください。(TMCSRLn:TRG=1)
11. 複合タイマの動作モードを選択してください。(T10CR0:F[3:0])
12. 複合タイマのカウントクロックを選択してください。(T10CR0:C[2:0])
13. 複合タイマのインターバル時間を設定してください。(T10DR)*(L 幅設定 )
14. タイマ 10 割込みを許可してください。(T10CR1:IE)
15. 複合タイマの動作を開始してください。(T10CR1:STA)
■ リロードタイマの割込み処理
1. アンダフロー割込み要求フラグをクリアしてください。(TMCSRLn:UF)
2. アンダフロー割込みを禁止してください。(TMCSRLn:INTE)
3. アンダフロー回数を記録してください。
4. アンダフロー割込みを許可してください。(TMCSRLn:INTE)
■ 複合タイマの割込み 1 回目処理 ( タイマ 10)
1. 割込み要求フラグをクリアしてください。(T10CR1:IF)
2. 割込みを禁止してください。(T10CR1:IE)
3. 複合タイマのインターバル時間を設定してください。(T10DR)*(H 幅設定 )
4. 割込みを許可してください。(T10CR1:IE)
■ ■複合タイマの割込み 2 回目処理 ( タイマ 10)
1. 割込み要求フラグをクリアしてください。(T10CR1:IF)
2. 割込みを禁止してください。(T10CR1:IE)
3. リロードタイマのカウンタ値を読み出してください。(TMRHn,TMRLn)
4. 外部クロック周波数を計算してください。
5. 複合タイマのインターバル時間を設定してください。(T10DR)*(L 幅設定 )
6. 割込みを許可してください。(T10CR1:IE)
April 4, 2014, MB95F718M_MN702-00014-3v0-J
329
第 20 章 イベントカウンタ
20.4 設定手順例
H ard war e
Ma nu al
<注意事項>
初期設定のインターバル時間設定は , 複合タイマ割込み 1 回目処理の割込みサービスサブ
ルーチン内の処理ができる時間に設定してください。
H パルス幅の設定は複合タイマ割込み 1 回目処理のインターバル時間設定で行ってくださ
い。
複合タイマ割込み 2 回目処理のインターバル時間設定は , 割込みサービスサブルーチン内
で外部クロック周波数を計算できる時間に設定してください。
連続して周波数を測定する場合は , 複合タイマの割込み 1 回目処理を奇数回目の処理 , 複
合タイマの割込み 2 回目処理を偶数回目の処理と読み替えてください。
タイマ出力初期値ビット (T10CR1:SO) は "0" を設定してください。1 を設定した場合 , H
パルス期間が最大で 1 カウントクロック分短くなる可能性があります。
330
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 20 章 イベントカウンタ
20.4 設定手順例
Ha rdware
Manual
PWM タイマ動作モード ( 可変周期モード ) を使用する場合
(MB95710M/770M シリーズのみ )
■ 初期設定
1. イベントカウンタモードを選択してください。(EVCR:MD)
2. 複合タイマカウントクロック CK06/CK16 を選択してください。(EVCR:SEL[1:0])
3. リロードタイマおよび複合タイマのそれぞれの割込みレベルを設定してください。
(ILR)
4. リロードタイマのリロード値を設定してください。(TMRLRHn/TMRLRLn)
5. リロードタイマのカウントクロックを選択してください。(TMCSRHn:CSL[2:0])
6. リロードタイマの動作モードを選択してください。(TMCSRHn:MOD[2:0])
7. リロードモードを選択してください。(TMCSRLn:RELD)
8. アンダフロー割込みを許可してください。(TMCSRLn:INTE)
9. リロードタイマのカウントを許可してください。(TMCSRLn:CNTE)
10. ソフトウェアトリガを発生させてください。(TMCSRLn:TRG = 1)
11. 複合タイマの動作モードを選択してください。(T10CR0/T11CR0:F[3:0])
12. 複合タイマのカウントクロックを選択してください。(T10CR0/T11CR0:C[2:0])
13. PWM タイマの L 幅および周期を設定してください。(T10DR/T11DR)
14. タイマ 11 割込みを許可してください。(T11CR1:IE)
15. 複合タイマの動作を開始してください。(T10CR1/T11CR1:STA)
■ リロードタイマの割込み処理
1. アンダフロー割込み要求フラグをクリアしてください。(TMCSRLn:UF)
2. アンダフロー割込みを禁止してください。(TMCSRLn:INTE)
3. アンダフロー回数を記録してください。
4. アンダフロー割込みを許可してください。(TMCSRLn:INTE)
■ 複合タイマの割込み処理 ( タイマ 11)
1. 割込み要求フラグをクリアしてください。(T11CR1:IF)
2. 割込みを禁止してください。(T11CR1:IE)
3. リロードタイマのカウンタ値を読み出してください。(TMRHn, TMRLn)
4. 外部クロック周波数を計算してください。
5. 割込みを許可してください。(T11CR1:IE)
April 4, 2014, MB95F718M_MN702-00014-3v0-J
331
第 20 章 イベントカウンタ
20.5 周波数の測定範囲および測定精度
H ard war e
20.5
Ma nu al
周波数の測定範囲および測定精度
イベントカウンタの周波数の測定範囲および測定精度について説明します。
■ 周波数の測定範囲
測定可能な最大周波数は , 周辺機能クロックによって制限されます。周辺機能クロック
の周波数が FPCLK のとき , 測定可能な最大周波数は FPCLK/4 です。
測定可能な最小周波数は , 周波数の測定精度を確保するために , 測定期限が制限されて
います。
■ 周波数の測定精度
周波数の測定精度は , メインクロックの周波数とリロードタイマのカウント値の精度
によって決まります。リロードタイマのカウンタがカウントを進めるにしたがい , 算出
される周波数は正確になります。
332
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 20 章 イベントカウンタ
20.6 レジスタ
Ha rdware
20.6
Manual
レジスタ
イベントカウンタのレジスタについて説明します。
表 20.6-1 イベントカウンタのレジスタ一覧
レジスタ略称
EVCR
レジスタ名
イベントカウンタ制御レジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
参照先
20.6.1
333
第 20 章 イベントカウンタ
20.6 レジスタ
H ard war e
20.6.1
Ma nu al
イベントカウンタ制御レジスタ (EVCR)
イベントカウンタ制御レジスタ (EVCR) はイベントカウンタ動作モードを許可または
禁止し , 複合タイマの CK06 クロックソースからカウントクロック選択します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
—
—
—
SEL1
SEL0
MD
属性
—
—
—
—
—
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7:3] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit2:1] SEL[1:0]: 複合タイマカウントクロック (CK06) 選択ビット
これらのビットは複合タイマカウントクロック (CK06) を選択します。
カウントクロックはプリスケーラによって生成されます。
「3.9 プリスケーラの動作」を参照してく
ださい。
複合タイマの動作とリロードタイマのカウント動作が許可されている場合 (T10CR1/T11CR1:STA =
1, TMCSRLn:CNTE = 1), SEL[1:0] ビットへの書込み動作は禁止されます。
EVCR レジスタの MD ビットが "0" に設定されても , SEL[1:0] ビットの設定は有効です。
タイムベースタイマからのカウントクロックが複合タイマのカウントクロックとして使用されま
す。SYCC レジスタの設定しだいで , タイムベースタイマからのカウントクロックがメインクロッ
クまたはメイン CR クロックから生成されます。タイムベースタイマからのカウントクロックが複
合タイマのカウントクロックとして使用される場合は , タイムベースタイマ制御レジスタのタイム
ベースタイマ初期化ビット (TBTC:TCLR) に "1" を書き込んでタイムベースタイマをリセットするこ
とにより , カウント時間が影響されます。
説明
(FCH: メインクロック , FCRH: メイン CR クロック )
bit2:1
"00" を書き込んだ場合
FCH/27 または FCRH/26*
"01" を書き込んだ場合
FCH/29 または FCRH/28*
"10" を書き込んだ場合
FCH/211 または FCRH/210*
"11" を書き込んだ場合
FCH/27 または FCRH/26*
*: 複合タイマのカウントクロックとして使用されるクロックは , SYCC レジスタによって決ま
ります。メインクロックまたはメイン PLL クロックが複合タイマのカウントクロックとし
て使用される場合 , PLLC:MPMC[1:0] の設定によって , メインクロックの 2 分周 (FCH/2) かメ
イン PLL クロックがカウントクロックとして使用されるかは決まります。
334
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 20 章 イベントカウンタ
20.6 レジスタ
Ha rdware
Manual
[bit0] MD: イベントカウンタ動作モード選択ビット
このビットはイベントカウンタ動作モードを許可または禁止します。
このビットに "0" が書き込まれた場合 , イベントカウンタ動作モードが禁止されます。イベントカ
ウンタ動作モードが禁止される場合 , 複合タイマとリロードタイマは独自に機能します。
このビットに "0" が書き込まれた場合 , イベントカウンタ動作モードが許可されます。イベントカ
ウンタ動作モードが許可される場合 , イベントカウンタ機能を実行するために複合タイマとリロー
ドタイマの両方が共に機能します。
複合タイマの動作とリロードタイマのカウント動作が許可されている場合 (T10CR1/T11CR1:STA =
1, TMCSRLn:CNTE = 1), MD ビットへの書込み動作は禁止されます。
説明
bit0
"0" を書き込んだ場合
イベントカウンタ動作モードを禁止します。
"1" を書き込んだ場合
イベントカウンタ動作モードを許可します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
335
第 20 章 イベントカウンタ
20.7 使用上の注意
H ard war e
20.7
Ma nu al
使用上の注意
イベントカウンタ使用上の注意を示します。
•
EVCR レジスタの MD ビットによってイベントカウンタ動作モードを切り換える前
に , 以下の動作を実行してください。
(1) 複合タイマとリロードタイマを停止してください。(T10CR1/T11CR1:STA = 0,
TMCSRLn:CNTE = 0)
(2) 複合タイマの割込みフラグビット (T10CR1/T11CR1:IF, IR), リロードタイマの割
込みフラグビット(TMCSRLn:UF), 複合タイマの割込み要求許可ビット(T10CR0/
T11CR0:IFE, T10CR1/T11CR1:IE) とリロードタイマの割込み要求許可ビット
(TMCSRLn:UF) をクリアしてください。
336
•
複合タイマの L レベルを出力時間は , 割込みサービスサブルーチン内で外部クロッ
ク周波数を計算出来る幅に設定してください。
•
MB95710L/770L シリーズではイベントカウンタへの H パルス出力機能として PWM
タイマ動作モード ( 可変周期モード ) を選択しないでください。
•
H パルス出力機能としてインターバルタイマモード ( 連続モード ) を選択した場合
は , タイマ出力初期値ビット (T10CR1:SO) は "0" を設定してください。1 を設定し
た場合 , H パルス期間が最大で 1 カウントクロック分短くなる可能性があります。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 21 章
UART/SIO
UART/SIO の機能と動作について説明します。
21.1 概要
21.2 構成
21.3 チャネル
21.4 端子
21.5 割込み
21.6 動作説明と設定手順例
21.7 レジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
337
第 21 章 UART/SIO
21.1 概要
H ard war e
Ma nu al
概要
21.1
UART/SIO は , 汎用のシリアルデータ通信インタフェースです。クロック同期 ( シン
クロナス ) またはクロック非同期 ( アシンクロナス ) で , 可変データ長のシリアルデー
タ転送ができます。転送フォーマットは ,NRZ 方式で , 転送レートは専用ボーレート
ジェネレータまたは外部クロック ( クロック同期モード (SIO) のとき ) から設定でき
ます。
■ UART/SIO の機能
UART/SIO は , ほかの CPU や周辺装置とシリアルデータの送受信 ( シリアル入出力 ) を
行う機能があります。
• 全二重ダブルバッファがあり , 全二重で双方向通信ができます。
• 同期転送モード ( シンクロナス ) と非同期転送モード ( アシンクロナス ) を選択でき
ます。
• 専用のボーレートジェネレータによって最適なボーレートを選択できます。
• データ長は可変で , パリティなしの場合は 5 ビット~ 8 ビット , パリティありの場
合は 6 ビット~ 9 ビットの設定ができます ( 表 21.1-1 を参照 )。
• シリアルデータの方向 ( エンディアン ) を選択できます。
• データ転送フォーマットは , NRZ (Non Return to Zero) 方式です。
• 2 種類の動作モード ( 動作モード 0,1) があります。
動作モード 0 は , クロック非同期モード (UART) として動作します。
動作モード 1 は , クロック同期モード (SIO) として動作します。
表 21.1-1 UART/SIO の動作モード
動作モード
0
1
338
データ長
パリティなし
パリティあり
5
6
6
7
7
8
8
9
5
6
7
8
-
同期モード
ストップビット長
非同期
1 ビットまたは 2 ビット
同期
-
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.2 構成
Ha rdware
21.2
Manual
構成
UART/SIO は , 以下のブロックで構成されます。
• UART/SIO シリアルモード制御レジスタ 1 ch. n (SMC1n)
• UART/SIO シリアルモード制御レジスタ 2 ch. n (SMC2n)
• UART/SIO シリアルステータスアンドデータレジスタ ch. n (SSRn)
• UART/SIO シリアル入力データレジスタ ch. n (RDRn)
• UART/SIO シリアル出力データレジスタ ch. n (TDRn)
品種により , UART/SIO の端子数およびチャネル数は異なります。詳細は , デバイスの
データシートを参照してください。
本章において , 端子名とレジスタ略称にある "n" はチャネル番号を示します。各品種の
端子名 , レジスタ名とレジスタ略称について , デバイスのデータシートを参照してくだ
さい。
■ UART/SIO のブロックダイヤグラム
図 21.2-1 UART/SIO のブロックダイヤグラム
PER
各部から
状態
受信状態
判定回路
OVE
FER
RDRF
RIE
専用ボーレートジェネレータ
1/4
外部クロック入力
UCKn
各部から
状態
クロック
セレクタ
端子
受信割込み
TDRE
送信状態
判定回路
TEIE
TCPL
送信割込み
TCIE
シリアルクロック出力
スタート
ビット
検出
端子
受信用
シフト
レジスタ
データサンプルクロック入力
シリアルデータ出力
UOn
端子
UART/SIOシリアル
ステータスアンドデ
ータレジスタch. n
パリティ
演算
送信用
シフト
レジスタ
パリティ
演算
UART/SIOシリアル
入力データレジスタ
ch. n
内部バス
シリアルデータ入力
UIn
受信
ビット
カウント
UART/SIOシリアル
出力データレジスタ
ch. n
送信
ビット
カウント
UART/SIOシリアルモ
ード制御レジスタ1, 2
ch. n
ポート制御
各部へ設定
April 4, 2014, MB95F718M_MN702-00014-3v0-J
339
第 21 章 UART/SIO
21.2 構成
H ard war e
Ma nu al
● UART/SIO シリアルモード制御レジスタ 1 ch. n (SMC1n)
UART/SIO の動作モードを制御するレジスタです。シリアルデータの方向 (エンディア
ン ), パリティの有無と極性 , ストップビット長 , 動作モード ( 同期 / 非同期 ), データ長
およびシリアルクロックを設定します。
● UART/SIO シリアルモード制御レジスタ 2 ch. n (SMC2n)
UART/SIO の動作モードを制御するレジスタです。シリアルクロック出力の許可 / 禁
止 , シリアルデータ出力の許可 / 禁止 , 送信受信の許可 / 禁止 , 受信エラーフラグクリ
アおよび割込みの許可 / 禁止を設定します。
● UART/SIO シリアルステータスアンドデータレジスタ ch. n (SSRn)
UART/SIO の送受信やエラーの状態を示します。
● UART/SIO シリアル入力データレジスタ ch. n (RDRn)
受信データを保持するレジスタです。シリアル入力が変換されてこのレジスタに格納
されます。
● UART/SIO シリアル出力データレジスタ ch. n (TDRn)
送信データを設定するレジスタです。このレジスタに書き込まれたデータがシリアル
変換されて出力されます。
■ 入力クロック
UART/SIO は , 専用ボーレートジェネレータからの出力クロック ( 内部クロック ) また
は UCKn 端子からの入力信号 ( 外部クロック ) を入力クロック ( シリアルクロック ) と
して使用します。
340
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.3 チャネル
Ha rdware
21.3
Manual
チャネル
UART/SIO のチャネルについて説明します。
■ UART/SIO のチャネル
UART/SIO の端子とレジスタを表 21.3-1 および表 21.3-2 にそれぞれ示します。
表 21.3-1 UART/SIO の端子
端子名
UCKn
UOn
UIn
端子機能
クロック入出力
データ出力
データ入力
表 21.3-2 UART/SIO のレジスタ
レジスタ対応 ( 本マニュアル上の表記 )
レジスタ略称
SMC1n
UART/SIO シリアルモード制御レジスタ 1 ch. n
SMC2n
UART/SIO シリアルモード制御レジスタ 2 ch. n
SSRn
UART/SIO シリアルステータスアンドデータレジスタ ch. n
TDRn
UART/SIO シリアル出力データレジスタ ch. n
RDRn
UART/SIO シリアル入力データレジスタ ch. n
April 4, 2014, MB95F718M_MN702-00014-3v0-J
341
第 21 章 UART/SIO
21.4 端子
H ard war e
21.4
Ma nu al
端子
UART/SIO の端子を示します。
■ UART/SIO の端子
UART/SIO の端子は,クロック入出力端子 (UCKn),シリアルデータ出力端子 (UOn) およ
びシリアルデータ入力端子 (UIn) です。
● UCKn
UART/SIO のクロック入出力端子です。
クロック出力を許可 (SMC2n:SCKE = 1) すると,対応するポート方向レジスタの値に関
係なく ,UART/SIO のクロック出力端子 (UCKn) として機能します。このとき , 外部ク
ロックは選択しないでください (SMC1n:CKS = 0 に設定 ) 。
UART/SIO のクロック入力端子として使用する場合は , クロック出力を禁止 (SMC2n:
SCKE = 0) し , 対応するポート方向レジスタによって入力ポートに設定してください。
このとき , 必ず外部クロックを選択 (SMC1n:CKS = 0 に設定 ) してください。
● UOn
UART/SIO のシ リア ルデ ータ出 力端 子で す。シ リア ルデ ータ 出力 を許 可 (SMC2n:
TXOE = 1) すると , 対応するポート方向レジスタの値に関係なく ,UART/SIO のシリア
ルデータ出力端子 (UOn) として機能します。
● UIn
UART/SIO のシリアルデータ入力端子です。UART/SIO のシリアルデータ入力端子と
して使用する場合は,対応するポート方向レジスタによって入力ポートに設定してくだ
さい。
342
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.5 割込み
Ha rdware
21.5
Manual
割込み
UART/SIO には , 割込みに関連したエラーフラグビット (PER,OVE,FER), 受信データ
レジスタフルフラグビット (RDRF), 送信データレジスタエンプティフラグビット
(TDRE) および送信完了フラグビット (TCPL) の 6 つのビットがあります。
■ UART/SIO の割込み
表 21.5-1 に , UART/SIO の割込み制御ビットと割込み要因を示します。
表 21.5-1 UART/SIO の割込み制御ビットと割込み要因
項目
割込み要求フラ
グビット
割込み要求許可
ビット
説明
割込み要因
SSRn:TDRE
SSRn:TCPL
SSRn:RDRF
SSRn:PER
SSRn:OVE
SSRn:FER
SMC2n:TEIE
SMC2n:TCIE
SMC2n:RIE
SMC2n:RIE
SMC2n:RIE
SMC2n:RIE
送信データレ
ジスタエンプ
ティ
送信完了
受信データフ
ル
パリティエ
ラー
オーバランエ
ラー
フレーミング
エラー
■ 送信割込み
送信データが UART/SIO シリアル出力データレジスタ ch. n (TDRn) に書き込まれると,
書き込まれたデータが送信用シフトレジスタに転送されます。次のデータの書込みが
可能な状態になると , TDRE ビットが "1" に設定されます。このとき , 送信データレジ
スタエンプティ割込み許可ビットが許可 (SMC2n:TEIE = 1) されていると , 割込みコン
トローラへの割込み要求が発生します。
また , すべての送信データの送信が完了すると ,TCPL ビットが "1" に設定されます。こ
のとき , 送信完了割込み許可ビットが許可 (SMC2n:TCIE = 1) されていると , 割込みコ
ントローラへの割込み要求が発生します。
■ 受信割込み
データがストップビットまで正常に入力されると RDRF ビットが "1" に設定されま
す。
また , オーバラン , パリティまたはフレーミングエラーが発生した場合には , 各エ
ラーフラグビット (PER, OVE, FER) が "1" に設定されます。
これらのビットは , ストップビット検出時に設定され , 受信割込み許可ビットが許可
(SMC2n:RIE = 1) されていると , 割込みコントローラへの割込み要求が発生します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
343
第 21 章 UART/SIO
21.6 動作説明と設定手順例
H ard war e
21.6
Ma nu al
動作説明と設定手順例
UART/SIO には , シリアル通信機能 ( 動作モード 0,1) があります。
■ UART/SIO の動作
● 動作モード
UART/SIO には , 2 種類の動作モードがあります。クロック同期モード (SIO) とクロッ
ク非同期モード (UART) を選択できます ( 表 21.6-1 を参照 )。
表 21.6-1 UART/SIO の動作モード
動作モード
0
1
データ長
パリティなし
パリティあり
5
6
6
7
7
8
8
9
5
6
7
8
-
同期モード
ストップビット長
非同期
1 ビットまたは 2
ビット
同期
-
■ 設定手順例
UART/SIO の設定手順例を以下に示します。
● 初期設定
1. ポートの入力を設定してください (DDR)。
2. 割込みレベルを設定してください (ILR*)。
3. プリスケーラを設定してください (PSSRn)。
4. ボーレートを設定してください (BRSRn)。
5. クロックを選択してください (SMC1n:CKS)。
6. 動作モードを設定してください (SMC1n:MD)。
7. シリアルクロック出力を許可または 禁止してください (SMC2n:SCKE)。
8. 受信動作を許可してください (SMC2n:RXE = 1)。
9. 割込みを許可してください (SMC2n:RIE = 1)。
*: 割込みレベル設定レジスタ (ILR) の詳細について , 本ハードウェアマニュアルの「第 5 章 割
込み」とデバイスのデータシートの「■ 割込み要因のテーブル」を参照してください。
● 割込み処理
受信データを読み出してください (RDRn)。
344
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.6 動作説明と設定手順例
Ha rdware
21.6.1
Manual
動作モード 0 の動作説明
動作モード 0 は , クロック非同期モード (UART) として動作します。
■ UART/SIO の動作モード 0 の動作説明
UART/SIO シリアルモード制御レジスタ 1 ch. n (SMC1n) の MD ビットを "0" に設定す
ると , クロック非同期モード (UART) が選択されます。
● ボーレート
UART/SIO の SMC1n レジスタの CKS ビットで UART/SIO 専用ボーレートジェネレー
タをシリアルクロックとして選択してください。
ボーレートは専用ボーレートジェネレータの出力クロック周波数の 4 分周になりま
す。UART は選択されたボーレートの 3% から 3% までの範囲で通信可能です。
専用ボーレートジェネレータによるボーレート算出式を以下に示します ( 専用ボー
レートジェネレータについては ,「第 22 章 UART/SIO 専用 ボーレートジェネレータ」も
参照してください 。
図 21.6-1 専用ボーレートジェネレータ使用時のボーレート算出
マシンクロック (MCLK)
ボーレート値=
1
2
4
8
4

[bps]
2
:
255
UART 専用ボーレートジェネレータプリスケーラ UART 専用ボーレートジェネレータボーレート
選択レジスタ ch. n (PSSRn)
設定レジスタ ch. n (BRSRn)
プリスケーラ選択 (PSS[1:0])
ボーレート設定 (BRS[7:0])
表 21.6-2
専用ボーレートジェネレータによるクロック非同期モード (UART) における転送レートの例
( マシンクロック:10 MHz, 16 MHz, 16.25 MHz の場合 )
専用ボーレートジェネレータの設定
UART 内 トータル分周比
プリスケーラ選択 ボーレートカウン
部分周 (PSS  BRS×4)
PSS[1:0]
タ設定 BRS[7:0]
ボーレート
(10 MHz 
トータル
分周比 )
ボーレート
(16 MHz 
トータル
分周比 )
ボーレート
(16.25 MHz 
トータル
分周比 )
1 ( 設定値 : 0, 0)
20
4
80
125000
200000
203125
1 ( 設定値 : 0, 0)
22
4
88
113636
181818
184659
1 ( 設定値 : 0, 0)
44
4
176
56818
90909
92330
1 ( 設定値 : 0, 0)
87
4
348
28736
45977
46695
1 ( 設定値 : 0, 0)
130
4
520
19231
30769
31250
2 ( 設定値 : 0, 1)
130
4
1040
9615
15385
15625
4 ( 設定値 : 1, 0)
130
4
2080
4808
7692
7813
8 ( 設定値 : 1, 1)
130
4
4160
2404
3846
3906
April 4, 2014, MB95F718M_MN702-00014-3v0-J
345
第 21 章 UART/SIO
21.6 動作説明と設定手順例
H ard war e
Ma nu al
また , クロック非同期モード (UART) におけるボーレート設定が可能な範囲は以下のと
おりです。
表 21.6-3 クロック非同期モード (UART) におけるボーレート設定可能範囲
PSS[1:0]
BRS[7:0]
0b00 ~ 0b11
0x02(2) ~ 0xFF(255)
● 転送データフォーマット
UART は,NRZ (Non Return to Zero) 形式のデータのみを扱えます。
図 21.6-2 に,転送デー
タフォーマットを示します。
キャラクタビット長は , SMC1n:CBL[1:0] ビット の設定により 5 ビット~ 8 ビットを選
択できます。
ストップビット長は SMC1n:SBL ビットの設定により 1 ビットもしくは 2 ビットに設
定できます。
パリティの有無 , パリティの極性は SMC1n レジスタの PEN ビットと TDP ビット によ
り設定できます。
図 21.6-2 に示すように , 転送データは必ずスタートビット ("L" レベル ) より始まり ,
MSBファーストもしくは LSBファースト(SMC1nレジスタのBDS ビットでLSB ファー
スト /MSB ファーストの選択可能 ) で指定されたデータビット長転送が行われ , ストッ
プビット ("H" レベル ) で終了します。アイドル時は "H" レベルになります。
図 21.6-2 転送データフォーマット
ST
D0
D1
D2
D3
D4
SP
ST
D0
D1
D2
D3
D4
SP
ST
D0
D1
D2
D3
D4
P
SP
ST
D0
D1
D2
D3
D4
P
SP
P なし
SP
データ 5 ビット
P あり
SP
注意事項: 6ビット長のデータと7ビット長のデータは5ビット長のデータと同じフォーマットを持ちます。
ST
D0
D1
D2
D3
D4
D5
D6
D7
SP
P なし
ST
D0
D1
D2
D3
D4
D5
D6
D7
SP
SP
データ 8 ビット
ST
D0
D1
D2
D3
D4
D5
D6
D7
P
SP
ST
D0
D1
D2
D3
D4
D5
D6
D7
P
SP
P あり
SP
ST : スタートビット
SP : ストップビット
P : パリティビット
D0 ~ D7: データ。順序は方向制御レジスタ(BDSビット)によりLSBファースト/MSBファーストの
選択が可能です。
346
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.6 動作説明と設定手順例
Ha rdware
Manual
● クロック非同期モード (UART) の受信動作
UART/SIO シリアルモード制御レジスタ 1 ch. n (SMC1n) により , シリアルデータの方
向 ( エンディアン ), パリティの有無 , パリティの極性 , ストップビット長 , キャラクタ
ビット長およびクロックを選択します。
受信動作許可ビット (SMC2n:RXE) が "1" に設定されていると常に受信動作が行われ
ます。
RXE ビットが "1" の場合 , 受信データのスタートビットを検出すると ,UART/SIO シリ
アルモード制御レジスタ 1 ch. n (SMC1n) に設定されているデータフォーマットに従っ
て 1 フレームのデータを受信します。
1 フレームのデータ受信が完了すると,受信データを UART/SIO シリアル入力データレ
ジスタ ch. n (RDRn) に転送し , 次のシリアルデータを受信できるようになります。
RDRn レジスタにデータが格納されると , 受信データレジスタフルフラグビット
(SSRn:RDRF) が "1" に設定されます。
受信割込み許可ビット (SMC2n:RIE) が "1" に設定されている場合は , RDRF ビットが
"1" に設定されると受信割込みが発生します。
受信データを読み出す場合は , UART/SIO シリアルステータスアンドデータレジスタ
ch. n (SSRn) の各エラーフラグビット (PER, OVE, FER) を確認し , RDRn レジスタを読
み出します。
受信データが RDRn レジスタから読み出されると , RDRF ビットが "0" にクリアされま
す。
なお , 受信動作中に SMC1n レジスタが変更された場合の動作は保証されません。また ,
受信動作中に RXE ビットを "0" にした場合 , 直ちに受信動作が禁止され , 初期化され
ます。途中まで受信したデータはシリアル入力データレジスタには転送されません。
図 21.6-3 クロック非同期モード (UART) の受信動作
RXE
UIn
St
D0 D1 D2 D3 D4 D5 D6 D7 Sp Sp St
D0 D1 D2
RDRn
のリード
RDRF
April 4, 2014, MB95F718M_MN702-00014-3v0-J
347
第 21 章 UART/SIO
21.6 動作説明と設定手順例
H ard war e
Ma nu al
● クロック非同期モード (UART) 時の受信エラー
以下の 3 つのエラーフラグビット (PER, FER, OVE) があるときは , 受信データは
UART/SIO シリアル入力データレジスタ ch. n (RDRn) に転送されず , 受信データレジス
タフルフラグビット (RDRF) も "1" に設定されません。
• パリティエラー (PER)
パリティ制御ビット (PEN) が "1" に設定されている場合,受信シリアルデータのパリ
ティビットがパリティ極性ビット (TDP) と異なったとき , パリティエラーフラグ
ビット (PER) が "1" に設定されます。
• フレーミングエラー (FER)
設定されているキャラクタビット長 (CBL), パリティ制御 (PEN) により , シリアル
データの受信を行った結果,シリアルデータの最初のストップビットの位置に "1" を
検出しなかった場合 , フレーミングエラーフラグビット (FER) が "1" に設定されま
す。
なお , 2 ビット目以降のストップビットに対してはチェックを行いません。
• オーバランエラー (OVE)
シリアルデータの受信が完了したとき , 前回の受信データが読み出される前に次の
受信が行われた場合 , オーバランエラーフラグビット (OVE) が "1" に設定されます。
また , 各フラグビットは最初のストップビットの位置で設定されます。
図 21.6-4 受信エラーフラグビットの設定タイミング
UIn
D5
D6
D7
P
SP
SP
PER
OVE
FER
受信割込み
348
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.6 動作説明と設定手順例
Ha rdware
Manual
● 受信動作時のスタートビットの検出と受信データの確定
受信動作許可ビット (RXE) が "1" に設定されてから専用ボーレートジェネレータのク
ロック (BRCLK) によってシリアルデータ入力をサンプリングし , シリアル入力の立下
りと連続した 3 回の "L" によりスタートビットは検出されます。したがって , BRCLK
のサンプリングにおいて , 最初に "H","L","L","L" が検出されたとき , そのビットをス
タートビットとみなします。
スタートビット検出から 4 分周回路を起動し ,BRCLK の 4 周期ごとにシリアルデータ
を受信用シフトレジスタに取り込みます。
データの受信は , ボーレートクロック (BRCLK) とデータサンプリングクロック
(DSCLK) の 3 箇所でサンプリングして 3 ビット中 2 ビット一致の多数決で受信データ
を確定します。
図 21.6-5 スタートビット検出とシリアルデータの取込み
RXE
スタートビット
シリアルデータ入力
(UIn)
D1
D0
ボーレートクロック
(BRCLK)
"H"
"L"
"L"
"L"
"L"
スタートビット検出
4 分周カウンタ
X
0
1
2
3
0
1
2
3
データサンプリングクロック
(DSCLK)
3 箇所サンプリングし, 3 ビット中 2 ビット一致の多数決で
“0” または “1” を判定する
受信用シフトレジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
X
D0
D1
349
第 21 章 UART/SIO
21.6 動作説明と設定手順例
H ard war e
Ma nu al
● クロック非同期モード (UART) の送信動作
UART/SIO シリアルモード制御レジスタ 1 ch. n (SMC1n) により , シリアルデータの方
向 ( エンディアン ), パリティの有無 , パリティの極性 , ストップビット長 , キャラクタ
ビット長およびクロックを選択します。
送信動作の起動は次の 2 種類の手順で行えます。
• 送信動作許可ビット (TXE) を "1" に設定してから UART/SIO シリアル出力データレ
ジスタ ch. n (TDRn) へ送信データを書き込むことによって送信を開始する。
• TDRn レジスタに送信データを書き込んだ後 , 送信動作許可ビット (TXE) を "1" に設
定することによって送信を開始する。
送信データは , 送信データレジスタエンプティフラグビット (TDRE) が "1" になってい
ることを確認してから , TDRn レジスタに書き込みます。
送信データが TDRn レジスタに書き込まれると TDRE ビットが "0" に設定されます。
送信データが TDRn レジスタから送信用シフトレジスタに転送され , TDRE ビット が
"1" に設定されます。
送信割込み許可ビット (TIE) を "1" に設定している場合は , TDRE ビットが "1" に設定
されると送信割込みを発生します。これにより , 割込み処理において次の送信データを
TDRn レジスタに書き込めます。
シリアル送信が完了したことを送信割込みによって検知する場合は送信完了割込み許
可ビットの設定を TEIE=0, TCIE=1 にしてください。送信が完了すると送信完了フラグ
ビット (SSRn:TCPL) が "1" に設定されて送信割込みが発生します。
TCPL ビットと , 連続送信時の TDRE ビットは , 図 21.6-6 に示すように , 最終ビットの
送信が完了した位置 ( データ長 , パリティ許可 , ストップビット長設定により異なる )
において設定されます。
送信動作中に UART/SIO シリアルモード制御レジスタ 1 ch. n (SMC1n) が変更された
場合の動作は保証されません。
図 21.6-6 クロック非同期モード (UART) の送信動作
UOn
D5
D6
D7
P
SP
SP
TCPL
TDRE
送信割込み
ストップビット長を 1 ビットに設定した場合
350
ストップビット長を 2 ビットに設定した場合
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.6 動作説明と設定手順例
Ha rdware
Manual
TDRE ビットは , 前の送信データが送信シフトレジスタにない場合は , 図 21.6-7 または
図 21.6-8 の位置で設定されます。
図 21.6-7 送信データレジスタエンプティフラグビット (TDRE) の設定タイミング 1
(TXE が "1" の場合 )
TXE = 1
送信データの
書込み
UOn
D0
D1
D2
D3
TDRE
送信割込み
UART/SIOシリアル出力データレジスタch.n (TDRn)から送信シフトレジスタへの
転送は1マシンクロック(MCLK) 周期で行われます。
図 21.6-8 送信データレジスタエンプティフラグビット (TDRE) の設定タイミング 2
(TXE を "0" → "1" にした場合 )
TXE
送信データの
書込み
UOn
D0
D1
D2
D3
TDRE
送信割込み
● 送受信同時動作
クロック非同期モード (UART) では , 送信と受信は独立して動作できます。したがって ,
送信と受信が同時または位相がずれて送信フレームと受信フレームが重なり合う場合
であっても動作します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
351
第 21 章 UART/SIO
21.6 動作説明と設定手順例
H ard war e
21.6.2
Ma nu al
動作モード 1 の動作説明
動作モード 1 は , クロック同期モード (SIO) として動作します。
■ UART/SIO の動作モード 1 の動作説明
UART/SIO シリアルモード制御レジスタ 1 ch. n (SMC1n) の MD ビットを "1" に設定す
るとクロック同期モード (SIO) が選択されます。
クロック同期モード (SIO) におけるキャラクタビット長は 5 ビット~ 8 ビットの可変
長になります。
ただし , パリティは禁止 , ストップビットはなしになります。
シリアルクロックは , SMC1n レジスタの CKS ビットで選択します。専用ボーレート
ジェネレータか外部クロックかを選択します。SIO は選択されたシリアルクロックを
シフトクロックとしてシフト動作を行います。
外部クロックを入力するときは , SMC2n:SCKE ビットは "0" にしてください。
専用ボーレートジェネレータの出力をシフトクロックとして出力するときは , SCKE
ビットを "1" にしてください。この場合のシリアルクロックは , 専用ボーレートジェネ
レータからのクロックを 2 分周して作られます。SIO モードにおけるボーレート設定
が可能な範囲は以下のとおりです ( 専用ボーレートジェネレータについては「
, 第 22 章
UART/SIO 専用 ボーレートジェネレータ」も参照 )。
表 21.6-4 クロック同期モード (SIO) におけるボーレート設定可能範囲
PSS[1:0]
BRS[7:0]
0b00 ~ 0b11
0x01(1) ~ 0xFF(255), 0x00(256)
( 最速となる設定は 0x01 最も遅い設定は 0x00 です。)
外部クロックによるボーレート算出式と , 専用ボーレートジェネレータ使用時のボー
レート算出式を以下に示します。
図 21.6-9 外部クロックによるボーレート算出式
1
ボーレート値=
[bps]
外部クロック *
4 マシンクロック以上
*: 外部クロック
4 マシンクロック以上
352
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.6 動作説明と設定手順例
Ha rdware
Manual
図 21.6-10 専用ボーレートジェネレータ使用時のボーレート算出式
マシンクロック (MCLK)
ボーレート値=
2×
1
2
4
8
×
[bps]
1
:
256
UART 専用ボーレートジェネレータプリスケーラ UART 専用ボーレートジェネレータボーレート
選択レジスタ ch. n (PSSRn)
設定レジスタ ch. n (BRSRn)
プリスケーラ選択 (PSS[1:0])
ボーレート設定 (BRS[7:0])
● シリアルクロックについて
シリアルクロックは送信データの出力制御に合わせて出力されます。そのため , 受信の
み行う場合であっても , 送信動作を許可 (SMC2n:TXE = 1) してダミーの送信データを
UART/SIO シリアル出力レジスタ ch. n に書き込んでください。また , UCKn のクロック
値はデバイスのデータシートを参照してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
353
第 21 章 UART/SIO
21.6 動作説明と設定手順例
H ard war e
Ma nu al
● UART/SIO 動作モード 1 受信動作
動作モード 1 の受信では , 各レジスタを図 21.6-11 のように使用します。
図 21.6-11 動作モード 1 の受信時使用レジスタ
SMC1n (UART/SIO シリアルモード制御レジスタ 1)
bit7
bit6
bit5
bit4
BDS
PEN
TDP
SBL
×
×
×
bit3
CBL1
bit2
CBL0
bit1
CKS
bit0
MD
1
SMC2n (UART/SIO シリアルモード制御レジスタ 2)
bit7
bit6
bit5
bit4
SCKE TXOE RERC
RXE
0
bit3
TXE
bit2
RIE
bit1
TCIE
×
bit0
TEIE
×
bit2
RDRF
bit1
TCPL
×
bit0
TDRE
×
SSRn (UART/SIO シリアルステータスアンドデータレジスタ )
bit7
bit6
bit5
bit4
bit3
PER
OVE
FER
×
×
×
×
TDRn (UART/SIO シリアル出力データレジスタ )
bit7
bit6
bit5
bit4
TD7
TD6
TD5
TD4
×
×
×
×
bit3
TD3
×
bit2
TD2
×
bit1
TD1
×
bit0
TD0
×
RDRn (UART/SIO シリアル入力データレジスタ )
bit7
bit6
bit5
bit4
RD7
RD6
RD5
RD4
bit3
RD3
bit2
RD2
bit1
RD1
bit0
RD0
:使用ビット
× :未使用ビット
1 :"1" に設定
0 :"0" に設定
受信動作は , シリアルクロックが外部クロック / 内部クロックのどちらかに設定されて
いるかによります。
<外部クロックの場合>
受信動作許可ビット (RXE) が "1" に設定されていると , 常に外部クロックの立上り
エッジでシリアルデータを受信します。
<内部クロックの場合>
シリアルクロックは送信動作に合わせて出力されます。そのため , 受信であっても送
信動作を行わなければなりません。以下の 2 種類の手順で行えます。
• 送信動作許可ビット (TXE) を "1" に設定してから ,UART/SIO シリアル出力データ
レジスタ ch. n (TDRn) へ送信データを書き込むことによってシリアルクロックを発
生させて受信を開始する。
• TDRn レジスタに送信データを書き込んだ後 , TXE ビットを "1" に設定することに
よってシリアルクロックを発生させて受信を開始する。
354
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.6 動作説明と設定手順例
Ha rdware
Manual
受信用シフトレジスタに 5 ビット~ 8 ビットのシリアルデータが受信されると , 受信
データを UART/SIO シリアル入力データレジスタ ch. n (RDRn) へ転送し , 次のシリア
ルデータの受信を可能にします。
RDRn レジスタにデータが格納されると , 受信データレジスタフルフラグビット
(RDRF) が "1" に設定されます。
受信割込み許可ビット (RIE) が "1" に設定されている場合は , RDRF ビットが "1" に設
定されると受信割込みが発生します。
受信データを読み出す場合は ,UART/SIO シリアルステータスアンドデータレジスタ
ch. n (SSRn) のオーバランエラーフラグビット (OVE) を確認し , RDRn レジスタから読
み出します。
受信データが RDRn レジスタから読み出されると , RDRF ビットが "0" にクリアされま
す。
図 21.6-12 クロック同期モード (SIO) の 8 ビット受信動作
UCKn
UIn
D0 D1 D2 D3 D4 D5 D6 D7
RDRnへのリード
RDRF
割込みコントローラへの割込み
受信エラー時の動作
オーバランエラー (OVE = 1) があるときは , 受信データは RDRn レジスタには転送さ
れません。
オーバランエラー (OVE = 1)
シリアルデータの受信が完了したとき , 前回の受信によって RDRF ビットが "1" に設
定されていた場合 , OVE ビット が "1" に設定されます。
図 21.6-13 オーバランエラー
UCKn
UIn
...
...
...
D0 D1 ... D6 D7
D0 D1 ... D6 D7
D0 D1 ... D6 D7
RDRnへの
リード
RDRF
OVE
April 4, 2014, MB95F718M_MN702-00014-3v0-J
355
第 21 章 UART/SIO
21.6 動作説明と設定手順例
H ard war e
Ma nu al
● UART/SIO 動作モード 1 送信動作
動作モード 1 の送信では , 各レジスタを図 21.6-14 のように使用します。
図 21.6-14 動作モード 1 の送信時使用レジスタ
SMC1n (UART/SIO シリアルモード制御レジスタ 1)
bit7
bit6
bit5
bit4
BDS
PEN
TDP
SBL
×
×
×
bit3
CBL1
bit2
CBL0
bit1
CKS
bit0
MD
1
SMC2n (UART/SIO シリアルモード制御レジスタ 2)
bit7
bit6
bit5
bit4
SCKE TXOE RERC
RXE
1
×
×
bit3
TXE
bit2
RIE
×
bit1
TCIE
bit0
TEIE
bit2
RDRF
×
bit1
TCPL
bit0
TDRE
SSRn (UART/SIO シリアルステータスアンドデータレジスタ )
bit7
bit6
bit5
bit4
bit3
PER
OVE
FER
×
×
×
×
×
TDRn (UART/SIO シリアル出力データレジスタ )
bit7
bit6
bit5
bit4
TD7
TD6
TD5
TD4
bit3
TD3
bit2
TD2
bit1
TD1
bit0
TD0
RDRn (UART/SIO シリアル入力データレジスタ )
bit7
bit6
bit5
bit4
RD7
RD6
RD5
RD4
×
×
×
×
bit3
RD3
×
bit2
RD2
×
bit1
RD1
×
bit0
RD0
×
:使用ビット
× :未使用ビット
1 :"1" に設定
0 :"0" に設定
送信動作の起動は次の 2 種類の手順で行えます。
• 送信動作許可ビット (TXE) を "1" に設定してから, TDRnレジスタへ送信データを書
き込むことによって送信を開始する。
• TDRn レジスタに送信データを書き込んだ後 , TXE ビットを "1" に設定することに
よって送信を開始する。
送信データは , 送信データレジスタエンプティフラグビット (TDRE) が "1" になってい
ることを確認してから , TDRn レジスタに書き込んでください。
送信データが TDRn レジスタに書き込まれると , TDRE ビットが "0" に設定されます。
送信データが TDRn レジスタから送信用シフトレジスタに転送されてシリアル送信が
開始されると , TDRE ビットが "1" に設定されます。
356
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.6 動作説明と設定手順例
Ha rdware
Manual
外部クロックを使用する設定では,送信動作が起動した最初のシリアルクロックの立下
りからシリアルデータが送信されます。
送信割込み許可ビット (TIE) が "1" に設定されている場合は , TDRE ビットが "1" に設
定されると送信完了割込みが発生します。このとき , 次の送信データを TDRn レジスタ
に書き込めます。また , TXE ビットが "1" に設定されたままであれば , 連続してシリア
ル送信を行えます。
シリアル送信が完了したことを送信完了割込みによって検知する場合は,送信完了割込
み出力許可の設定を TEIE = 0,TCIE = 1 にしてください。送信が完了すると送信完了フ
ラグ ビット (SSRn:TCPL) が "1" に設定されて送信完了割込みが発生します。
図 21.6-15 クロック同期モード (SIO) の 8 ビット送信動作
TDRnへの
書込み
UCKn
UIn
D0 D1 D2 D3 D4 D5 D6 D7
TDRE
TCPL
割込み
コントローラ
への割込み
外部クロックの
場合は, UCKnの
立下り後です。
割込み
コントローラ
への割込み
内部クロックの
場合は, 最終 1 ビット
周期後です。
● 送受信同時動作
<外部クロックの場合>
送信と受信はそれぞれ独立して動作できます。したがって , 送信と受信が同時または
位相がずれて重なり合う場合でも動作します。
<内部クロックの場合>
送信側がシリアルクロックを発生しているため , 受信は送信の影響を受けます。
受信途中に送信が終了してしまった場合 , 受信側は停止した状態となります。 受信
は , 送信側が再起動されたときに継続されます。
シリアルクロックを出力および入力して使用する方法については , 「21.4 端子」を
参照してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
357
第 21 章 UART/SIO
21.7 レジスタ
H ard war e
21.7
Ma nu al
レジスタ
UART/SIO のレジスタについて説明します。
表 21.7-1
UART/SIO のレジスタ一覧
レジスタ略称
358
レジスタ名
参照先
SMC1n
UART/SIO シリアルモード制御レジスタ 1 ch. n
21.7.1
SMC2n
UART/SIO シリアルモード制御レジスタ 2 ch. n
21.7.2
SSRn
UART/SIO シリアルステータスアンドデータレジスタ ch. n
21.7.3
RDRn
UART/SIO シリアル入力データレジスタ ch. n
21.7.4
TDRn
UART/SIO シリアル出力データレジスタ ch. n
21.7.5
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.7 レジスタ
Ha rdware
21.7.1
Manual
UART/SIO シリアルモード制御レジスタ 1 ch. n
(SMC1n)
UART/SIO シリアルモード制御レジスタ 1 ch. n (SMC1n) は , UART/SIO の動作モー
ドを制御します。シリアルデータの方向 ( エンディアン ), パリティの有無と極性 , ス
トップビット長 , 動作モード ( クロック同期モード / クロック 非同期モード ), データ
長およびシリアルクロックを設定します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
BDS
PEN
TDP
SBL
CBL1
CBL0
CKS
MD
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] BDS: シリアルデータ方向制御ビット
このビットはシリアルデータの方向 ( エンディアン ) を制御します。
説明
bit7
"0" を書き込んだ場合
UART/SIO シリアル入力 / 出力データレジスタ ch. n (RDRn/TDRn) の LSB 側から
順に送受信します。
"1" を書き込んだ場合
UART/SIO シリアル入力 / 出力データレジスタ ch. n (RDRn/TDRn) の MSB 側から
順に送受信します。
[bit6] PEN: パリティ制御ビット
このビットはクロック非同期モード (UART) におけるパリティの有無を制御します。
説明
bit6
"0" を書き込んだ場合
パリティなし
"1" を書き込んだ場合
パリティあり
[bit5] TDP: パリティ極性制御ビット
このビットは偶数 / 奇数パリティを制御します。
説明
bit5
"0" を書き込んだ場合
偶数パリティ
"1" を書き込んだ場合
奇数パリティ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
359
第 21 章 UART/SIO
21.7 レジスタ
H ard war e
Ma nu al
[bit4] SBL: ストップビット長制御ビット
このビットはクロック非同期モード (UART) におけるストップビット長を制御します。
説明
bit4
"0" を書き込んだ場合
1 ビット
"1" を書き込んだ場合
2 ビット
( 注意事項 ) 本ビットの設定はクロック非同期モード (UART) の送信動作のみに対して有効です。受
信動作において , 本ビットの設定にかかわらず , UART/SIO は , ストップビット (1 ビッ
ト ) を検出すると , 受信を完了し , 受信データレジスタフルフラグビット (SSRn:RDRF)
を "1" に設定します。
[bit3:2] CBL[1:0]: キャラクタビット長選択ビット
これらのビットはキャラクタビット長を選択します。
これらのビットの設定はクロック非同期モード (UART) とクロック同期モード (SIO) の両方に有効
です。
説明
bit3:2
"00" を書き込んだ場合
5 ビット
"01" を書き込んだ場合
6 ビット
"10" を書き込んだ場合
7 ビット
"11" を書き込んだ場合
8 ビット
[bit1] CKS: クロック選択ビット
このビットは外部クロックと UART/SIO 専用ボーレートジェネレータからシリアルクロックを選択
します。
説明
bit1
"0" を書き込んだ場合
UART/SIO 専用ボーレートジェネレータ
"1" を書き込んだ場合
外部クロック
( 注意事項 ) 本ビットに "1" を書き込んだ場合は , 強制的に UCKn 端子の出力が禁止されます。ク
ロック非同期モード (UART) では外部クロックは使用できません。
[bit0] MD: 動作モード選択ビット
このビットはクロック非同期モード (UART) とクロック同期モード (SIO) から動作モードを選択し
ます。
説明
bit0
"0" を書き込んだ場合
クロック非同期モード (UART)
"1" を書き込んだ場合
クロック同期モード (SIO)
<注意事項>
シリアルデータの送受信中にUART/SIO シリアルモード制御レジスタ 1 ch. n (SMC1n)の
設定 を変更しないでください。
360
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.7 レジスタ
Ha rdware
21.7.2
Manual
UART/SIO シリアルモード制御レジスタ 2 ch. n
(SMC2n)
UART/SIO シリアルモード制御レジスタ 2 ch. n (SMC2n) は , UART/SIO の動作モー
ドを制御します。シリアルクロック出力の許可 / 禁止,シリアルデータ出力の許可 / 禁
止 , 送信受信の許可 / 禁止 , 受信エラーフラグクリアおよび割込みの許可 / 禁止を設定
します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
SCKE
TXOE
RERC
RXE
TXE
RIE
TCIE
TEIE
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
1
0
0
0
0
0
■ レジスタ機能
[bit7] SCKE: シリアルクロック出力許可ビット
このビットはクロック同期モード (SIO) におけるシリアルクロック端子 (UCKn) の入出力を制御し
ます。
説明
bit7
"0" を書き込んだ場合
シリアルクロック出力を禁止し , UCKn 端子を汎用入出力ポートとして使用しま
す。
"1" を書き込んだ場合
シリアルクロック出力を許可し , UCKn 端子をシリアルクロック出力端子として
使用します。
( 注意事項 ) クロック選択ビット (SMC1n:CKS) が "1" のとき , 本ビットが "1" に設定されても内部
クロックは出力されません。
動作モード選択ビット (SMC1n:MD) が "0" のとき ( クロック非同期モード (UART)) は ,
本ビットが "1" に設定されると , UCKn からの出力は常に "H" になります。
[bit6] TXOE: シリアルデータ出力許可ビット
このビットはシリアルデータ端子 (UOn) の出力を制御します。
説明
bit6
"0" を書き込んだ場合
シリアルデータ出力を禁止し , UOn 端子を汎用入出力ポートとして使用します。
"1" を書き込んだ場合
シリアルデータ出力を許可し , UOn 端子をシリアルデータ出力端子として使用
します。
[bit5] RERC: 受信エラーフラグクリアビット
このビットは受信エラーフラグをクリアします。
このビットの読出し値は常に "1" です。
説明
bit5
"0" を書き込んだ場合
SSRn レジスタの各受信エラーフラグビット (PER, OVE, FER) をクリアします。
"1" を書き込んだ場合
動作に影響はありません。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
361
第 21 章 UART/SIO
21.7 レジスタ
H ard war e
Ma nu al
[bit4] RXE: 受信動作許可ビット
このビットはシリアルデータの受信を許可または禁止します。
受信動作中にこのビットが "0" に設定された場合 , 直ちに受信動作が禁止され , 初期化されます。途
中まで受信したデータは UART/SIO シリアル入力データレジスタ ch. n には転送されません。
説明
bit4
"0" を書き込んだ場合
シリアルデータの受信を禁止します。
"1" を書き込んだ場合
シリアルデータの受信を許可します。
( 注意事項 ) RXE ビット に "0" を書き込んだ場合 , 初期化されるのは受信動作です。SSRn レジスタ
のエラーフラグビット (SSRn:PER, OVE, FER, RDRF) は影響されません。
[bit3] TXE: 送信動作許可ビット
このビットはシリアルデータの送信を許可または禁止します。
送信動作中にこのビットが "0" に設定された場合 , 直ちに送信動作が禁止され , 初期化されます。送
信完了フラグビット (SSRn:TCPL) が "1" に設定され , 送信データレジスタエンプティフラグビット
(SSRn:TDRE) も "1" に設定されます。
説明
bit3
"0" を書き込んだ場合
シリアルデータの送信を禁止します。
"1" を書き込んだ場合
シリアルデータの送信を許可します。
[bit2] RIE: 受信割込み許可ビット
このビットは受信割込みを許可または禁止します。
このビットが "1"( 受信割込み許可 ) のときに , 受信データレジスタフルフラグビット (SSRn:RDRF)
およびそのほかの受信エラーフラグビット (SSRn:PER, OVE, FER) のいずれかが "1" になると , 直ち
に受信割込みが発生します。
説明
bit2
"0" を書き込んだ場合
受信割込みを禁止します。
"1" を書き込んだ場合
受信割込みを許可します。
[bit1] TCIE: 送信完了割込み許可ビット
このビットは送信完了割込みを許可または禁止します。
このビットが "1"( 送信完了割込み許可 ) のときに , 送信完了フラグビット (SSRn:TCPL) が "1" にな
ると , 直ちに送信完了割込みが発生します。
説明
bit1
"0" を書き込んだ場合
送信完了割込みを禁止します。
"1" を書き込んだ場合
送信完了割込みを許可します。
[bit0] TEIE: 送信データレジスタエンプティ割込み許可ビット
このビットは送信データレジスタエンプティ割込みを許可または禁止します。
このビットが "1"( 送信データレジスタエンプティ割込み許可 ) のときに , 送信データレジスタエン
プティフラグビット (SSRn:TDRE) が "1" になると , 直ちに送信データレジスタエンプティ割込みが
発生します。
bit0
362
説明
"0" を書き込んだ場合
送信データレジスタエンプティ割込みを禁止します。
"1" を書き込んだ場合
送信データレジスタエンプティ割込みを許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.7 レジスタ
Ha rdware
21.7.3
Manual
UART/SIO シリアルステータスアンドデータ
レジスタ ch. n (SSRn)
UART/SIO シリアルステータスアンドデータレジスタ ch. n (SSRn) は , UART/SIO の
送受信やエラーの状態を示します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
PER
OVE
FER
RDRF
TCPL
TDRE
属性
—
—
R
R
R
R
R/W
R
初期値
0
0
0
0
0
0
0
1
■ レジスタ機能
[bit7:6] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit5] PER: パリティエラーフラグビット
このビットは受信データのパリティエラーを検出します。
受信時にパリティエラーが発生すると , このビットが "1" に設定され , SMC2n レジスタの RERC ビッ
トに "0" を書き込むことによって , このビットがクリアされます。
パリティエラーの検出と RERC ビットによるクリアが同時に発生する場合は , このパリティエラー
フラグの設定が優先されます。
説明
bit5
"0" が読み出された場合
パリティエラーなし
"1" が読み出された場合
パリティエラーあり
[bit4] OVE: オーバランエラーフラグビット
このビットは受信データのオーバランエラーを検出します。
受信時にオーバランエラーが発生すると , このビットが "1" に設定され , SMC2n レジスタの RERC
ビットに "0" を書き込むことによって , このビットがクリアされます。
オーバランエラーの検出と RERC ビットに "0" を書き込むことによるクリアが同時に発生する場合
は , このオーバランエラーフラグの設定が優先されます。
説明
bit4
"0" が読み出された場合
オーバランエラーなし
"1" が読み出された場合
オーバランエラーあり
April 4, 2014, MB95F718M_MN702-00014-3v0-J
363
第 21 章 UART/SIO
21.7 レジスタ
H ard war e
Ma nu al
[bit3] FER: フレーミングエラーフラグビット
このビットは受信データのフレーミングエラーを検出します。
受信時にフレーミングエラーが発生すると , このビットが "1" に設定され , SMC2n レジスタの RERC
ビットに "0" を書き込むことによって , このビットがクリアされます。
フレーミングエラーの検出と RERC ビットに "0" を書き込むことによるクリアが同時に発生する場
合は , このフレーミングエラーフラグの設定が優先されます。
説明
bit3
"0" が読み出された場合
フレーミングエラーなし
"1" が読み出された場合
フレーミングエラーあり
[bit2] RDRF: 受信データレジスタフルフラグビット
このビットは UART/SIO シリアル入力データレジスタ ch. n (RDRn) の状態を示します。
RDRn レジスタへ受信データがロードされると , このビットが "1" に設定されます。
RDRn レジスタのデータが読み出されると , このビットが "0" にクリアされます。
説明
bit2
"0" が読み出された場合
RDRn レジスタに受信データがないことを示します。
"1" が読み出された場合
RDRn レジスタに受信データがあることを示します。
[bit1] TCPL: 送信完了フラグビット
このビットはデータの送信状態を示します。
シリアル送信が完了したとき , このビットが "1" に設定されます。ただし , 連続して送信されるデー
タが UART/SIO シリアル出力データレジスタ ch. n (TDRn) にある場合 ,1 回の送信が完了しても , こ
のビットは "1" に設定されません。
このビットへの "0" の書込みはこのビットをクリアします。
送信完了によりこのビットが "1" に設定されることと , "0" の書込みによりこのビットがクリアされ
ることが同時に発生する場合は , 前者が優先されます。
このビットに "1" を書き込んでも動作に影響はありません。
説明
bit1
"0" が読み出された場合
データの送信が完了していないことを示します。
"1" が読み出された場合
データの送信が完了していることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit0] TDRE: 送信データレジスタエンプティフラグビット
このビットは UART/SIO シリアル出力データレジスタ ch. n (TDRn) の状態を示します。
TDRn レジスタへ送信データが書き込まれると , このビットが "0" に設定されます。
送信用シフトレジスタに送信データがロードされて送信が開始されると , このビットが "1" に設定
されます。
bit0
364
説明
"0" が読み出された場合
TDRn レジスタに送信データがあることを示します。
"1" が読み出された場合
TDRn レジスタに送信データがないことを示します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 21 章 UART/SIO
21.7 レジスタ
Ha rdware
21.7.4
Manual
UART/SIO シリアル入力データレジスタ ch. n
(RDRn)
UART/SIO シリアル入力データレジスタ ch. n (RDRn) は , シリアルデータの入力 ( 受
信 ) 用レジスタです。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
RD7
RD6
RD5
RD4
RD3
RD2
RD1
RD0
属性
R
R
R
R
R
R
R
R
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
このレジスタは受信したデータを格納します。 シリアルデータ入力端子 (UIn) に送ら
れてきたシリアルデータ信号がシフトレジスタで変換されて,このレジスタに格納され
ます。
受信データが正常にこのレジスタに設定されると , 受信データレジスタフルフラグ
ビット (SSRn:RDRF) が "1" に設定されます。このとき , 受信割込み要求が許可されてい
れば割込みが発生します。プログラムによる RDRF ビットチェックまたは割込みでこ
のレジスタに格納された受信データが示されていれば,このレジスタの内容を読み出す
ことにより , RDRF ビットが "0" にクリアされます。
キャラクタビット長 (SMC1n:CBL[1:0]) を 8 ビット未満に設定した場合 , 不要となる上
位のビット ( 設定したビット長以外のビット ) は "0" になります。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
365
第 21 章 UART/SIO
21.7 レジスタ
H ard war e
21.7.5
Ma nu al
UART/SIO シリアル出力データレジスタ ch. n
(TDRn)
UART/SIO シリアル出力データレジスタ ch. n (TDRn) は , シリアルデータの出力 ( 送
信 ) 用レジスタです。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
TD7
TD6
TD5
TD4
TD3
TD2
TD1
TD0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
このレジスタには送信するデータが書き込まれます。送信データレジスタエンプティ
フラグビット (TDRE) が "1" の場合 , 書込みができます。"0" の場合 , 書込みは無視され
ます。
送信データが UART/SIO シリアル出力データレジスタ ch. n (TDRn) に書き込まれると,
TDRE ビットは "0" に設定されます。送信用シフトレジスタに送信データの転送が終了
すれば , TDRE ビットは "1" に設定され , 次の送信用データを TDRn レジスタに書き込
めます。このとき, 送信データレジスタエンプティ割込みが許可されていれば割込みが
発生します。次の送信データの書込みは , 送信データレジスタエンプティの発生のとき
に行うか , TDRE ビットが "1" のときに行ってください。
キャラクタビット長 (SMC1n:CBL[1:0]) を 8 ビット未満に設定した場合 , 上位のビット
( 設定したビット長以外のビット ) は無視されます。
<注意事項>
UART/SIO シリアルステータスアンドデータレジスタch. n (SSRn)の TDRE ビットが "0"
のとき , このレジスタのデータは更新できません。
既に送信データが書き込まれ ,TDRE ビットが "0" のときに , このレジスタを更新する場合
は (SMC2n レジスタの TXE ビット の設定にかかわらず ) TXE ビット に "0" を書き込むこ
とにより送信動作が初期化され ,TDRE ビット が "1" となり , このレジスタを更新できる
ようになります。
また , 送信が開始されていないとき (TDRn レジスタ に送信データを書き込んで ,TXE ビッ
ト をまだ "1" に設定していないとき ) に TXE ビットに "0" を書き込む場合は , SSRn レジ
スタの TCPL ビット は "1" に設定されません。データを変更する場合は ,TXE ビット に "0"
を書き込むことにより , 一度 TDRE ビット を "1" にしてからデータを変更してください。
366
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 22 章
UART/SIO 専用 ボーレート
ジェネレータ
UART/SIO 専用ボーレートジェネレータの機能と
動作について説明します。
22.1 概要
22.2 チャネル
22.3 動作説明
22.4 レジスタ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
367
第 22 章 UART/SIO 専用 ボーレートジェネレータ
22.1 概要
H ard war e
22.1
Ma nu al
概要
UART/SIO 専用ボーレートジェネレータは ,UART/SIO のボーレートを発生します。
UART/SIO 専用ボーレートジェネレータプリスケーラ選択レジスタ ch. n (PSSRn)
と UART/SIO 専用ボーレートジェネレータボーレート設定レジスタ ch. n (BRSRn)
から構成されます。
品種により, UART/SIO専用ボーレートジェネレータの端子数およびチャネル数は異な
ります。
詳細は , デバイスのデータシートを参照してください。
本章において , 端子名とレジスタ略称にある "n" はチャネル番号を示します。各品種の
端子名 , レジスタ名とレジスタ略称について , デバイスのデータシートを参照してくだ
さい。
■ UART/SIO 専用ボーレートジェネレータのブロックダイヤグラム
図 22.1-1 UART/SIO 専用ボーレートジェネレータのブロックダイヤグラム
ボーレートジェネレータ
PSS[1:0]
MCLK
(マシンクロック)
BRS[7:0]
CLK
MCLK/2
プリスケーラ
UART/SIO
MCLK/4
8ビット
ダウンカウンタ
BRCLK
1/4
MCLK/8
■ 入力クロック
UART/SIO 専用ボーレートジェネレータは,プリスケーラからの出力クロックまたはマ
シンクロックを入力クロックとして使用します。
■ 出力クロック
UART/SIO 専用ボーレートジェネレータは , UART/SIO にクロックを供給しています。
368
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 22 章 UART/SIO 専用 ボーレートジェネレータ
22.2 チャネル
Ha rdware
22.2
Manual
チャネル
UART/SIO 専用ボーレートジェネレータのチャネルについて説明します。
■ UART/SIO 専用ボーレートジェネレータのチャネル
表 22.2-1 に ,UART/SIO 専用ボーレートジェネレータのレジスタを示します。
表 22.2-1 UART/SIO 専用ボーレートジェネレータのレジスタ
レジスタ略称
該当レジスタ ( 本マニュアル上の表記 )
PSSRn
UART/SIO 専用ボーレートジェネレータプリスケーラ選択レジスタ ch. n
BRSRn
UART/SIO 専用ボーレートジェネレータボーレート設定レジスタ ch. n
April 4, 2014, MB95F718M_MN702-00014-3v0-J
369
第 22 章 UART/SIO 専用 ボーレートジェネレータ
22.3 動作説明
H ard war e
22.3
Ma nu al
動作説明
UART/SIO 専用ボーレートジェネレータは,クロック非同期モード(UART)のボーレー
トジェネレータとして動作します。
■ ボーレート設定
UART/SIO の SMC1n レジスタの CKS ビットで UART/SIO 専用ボーレートジェネレー
タをシリアルクロックとして選択してください。
クロック 非同期モード (UART) では , CKS ビットで選択されたシフトクロックの 4 分
周になり , 選択されたボーレートの 3% から 3% までの範囲で転送可能です。UART/
SIO 専用ボーレートジェネレータによるボーレート算出式を以下に示します。
図 22.3-1 UART/SIO 専用ボーレートジェネレータ使用時のボーレート算出式
マシンクロック (MCLK)
ボーレート値=
1
2
4
8
4
UART 専用ボーレートジェネレータプリスケー
ラ選択レジスタ ch. n (PSSRn)
プリスケーラ選択 (PSS[1:0])

[bps]
2
:
255
UART 専用ボーレートジェネレータボーレート
設定レジスタ ch. n (BRSRn)
ボーレート設定 (BRS[7:0])
表 22.3-1 ボーレートジェネレータによるクロック非同期モード (UART) における転送レートの例
( マシンクロック:10 MHz,16 MHz,16.25 MHz の場合 )
UART/SIO 専用ボーレートジェネレー
タの設定
UART 内 トータル分周比
プリスケーラ選択 ボーレート カウン 部分周 (PSS  BRS  4)
PSS[1:0]
タ設定 BRS[7:0]
ボーレート
(10 MHz 
トータル
分周比 )
ボーレート
(16 MHz 
トータル
分周比 )
ボーレート
(16.25 MHz 
トータル
分周比 )
1 ( 設定値 : 0,0)
20
4
80
125000
200000
203125
1 ( 設定値 : 0,0)
22
4
88
113636
181818
184659
1 ( 設定値 : 0,0)
44
4
176
56818
90909
92330
1 ( 設定値 : 0,0)
87
4
348
28736
45977
46695
1 ( 設定値 : 0,0)
130
4
520
19231
30769
31250
2 ( 設定値 : 0,1)
130
4
1040
9615
15385
15625
4 ( 設定値 : 1,0)
130
4
2080
4808
7692
7813
8 ( 設定値 : 1,1)
130
4
4160
2404
3846
3906
また , クロック非同期モード (UART) におけるボーレート設定が可能な範囲は以下のと
おりです。
表 22.3-2 クロック非同期モード (UART) におけるボーレート設定可能範囲
370
PSS[1:0]
BRS[7:0]
0b00 ~ 0b11
0x02(2) ~ 0xFF(255)
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 22 章 UART/SIO 専用 ボーレートジェネレータ
22.4 レジスタ
Ha rdware
22.4
Manual
レジスタ
UART/SIO 専用ボーレートジェネレータのレジスタについて説明します。
表 22.4-1
UART/SIO 専用ボーレートジェネレータのレジスタ一覧
レジスタ略称
レジスタ名
参照先
PSSRn
UART/SIO 専用ボーレートジェネレータプリスケーラ選択レジスタ
ch. n
BRSRn
UART/SIO 専用ボーレートジェネレータボーレート設定レジスタ ch. n 22.4.2
April 4, 2014, MB95F718M_MN702-00014-3v0-J
22.4.1
371
第 22 章 UART/SIO 専用 ボーレートジェネレータ
22.4 レジスタ
H ard war e
22.4.1
Ma nu al
UART/SIO 専用ボーレートジェネレータプリスケー
ラ選択レジスタ ch. n (PSSRn)
UART/SIO 専用ボーレートジェネレータプリスケーラ選択レジスタ ch. n (PSSRn)
は , ボーレートクロックの出力とプリスケーラを制御するレジスタです。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
—
—
—
BRGE
PSS1
PSS0
属性
—
—
—
—
—
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7:3] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit2] BRGE: ボーレートクロック出力許可ビット
このビットはボーレートクロック "BRCLK" の出力を許可または禁止します。
このビットに "1" が書き込まれた場合 , BRSRn レジスタの BRS[7:0] ビットの値が 8 ビットダウンカ
ウンタにロードされ , UART/SIO に供給される BRCLK が出力されます。
このビットに "0" が書き込まれた場合 , BRCLK の出力が停止します。
説明
bit2
"0" を書き込んだ場合
ボーレートクロックの出力を禁止します。
"1" を書き込んだ場合
ボーレートクロックの出力を許可します。
[bit1:0] PSS[1:0]: プリスケーラ選択ビット
これらのビットはプリスケーラを選択します。
説明
bit1:0
372
"00" を書き込んだ場合
1
"01" を書き込んだ場合
1/2
"10" を書き込んだ場合
1/4
"11" を書き込んだ場合
1/8
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 22 章 UART/SIO 専用 ボーレートジェネレータ
22.4 レジスタ
Ha rdware
22.4.2
Manual
UART/SIO 専用ボーレートジェネレータボーレート
設定レジスタ ch. n (BRSRn)
UART/SIO 専用ボーレートジェネレータボーレート設定レジスタ ch. n (BRSRn) は ,
ボーレートの設定を制御するレジスタです。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
BRS7
BRS6
BRS5
BRS4
BRS3
BRS2
BRS1
BRS0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
このレジスタは 8 ビットダウンカウンタの周期を設定します。このレジスタにより任
意のボーレートクロック (BRCLK) が設定できます。このレジスタへの書込みは UART/
SIO の動作停止中に行ってください。
クロック非同期モード (UART) では , BRS[7:0] を "0x00" または "0x01" に設定しないで
ください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
373
第 22 章 UART/SIO 専用 ボーレートジェネレータ
22.4 レジスタ
H ard war e
374
Ma nu al
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 23 章
I2C バスインタフェース
I2C バスインタフェース の機能と動作について説
明します。
23.1 概要
23.2 構成
23.3 チャネル
23.4 端子
23.5 割込み
23.6 動作説明と設定手順例
23.7 レジスタ
23.8 使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
375
第 23 章 I2C バスインタフェース
23.1 概要
H ard war e
23.1
Ma nu al
概要
I2C バスインタフェースは, マスタ / スレーブモードの送信と受信, アービトレーショ
ンロスト検出, スレーブアドレス / ゼネラルコールアドレス検出, スタート / ストップ
条件の発生と検出 , バスエラー検出および MCU スタンバイウェイクアップ機能を提
供します。
■ I2C バスインタフェースの機能
I2C バスインタフェースは双方向バスで , シリアルデータライン (SDAn) とシリアルク
ロックライン (SCLn) の 2 本のワイヤから構成されます。この 2 本のワイヤによってバ
スに接続される各装置は , 互いに情報伝達が行われ , 各装置にある固有のアドレスを認
識することにより , それぞれの装置の機能に応じて送信装置および受信装置として動
作が可能となります。装置間にはマスタとスレーブという関係が成り立ちます。
I2C バスインタフェースはバスのキャパシタンスの上限値が 400 pF を超えなければ ,
バスに複数の装置を接続できます。複数のマスタが同時にデータ転送を開始しようと
した場合でも , データの破壊を防ぐために , 衝突検出および通信調整手順を備えている
本格的なマルチマスタバスです。
通信調整手順とは複数のマスタが同時にバスを制御しようとした場合に, 1 つのマスタ
だけがバスを制御できるようにし , さらにメッセージが失われたり , 内容が変更された
りしないようにする手順です。また , マルチマスタとはメッセージを失うことなく , 複
数のマスタが同時にバスを制御しようとすることです。
本 I2C バスインタフェースは , MCU スタンバイモードウェイクアップ機能を内蔵して
います。
図 23.1-1 I2C バスインタフェースの構成例
マイクロコントローラA
LCDドライバ
スタティックRAM/
EEPROM
SDAn
SCLn
ゲートアレイ
376
A/Dコンバータ
マイクロコントローラB
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.2 構成
Ha rdware
23.2
Manual
構成
I2C バスインタフェース は , 以下のブロックで構成されます。
• クロックセレクタ
• クロック分周器
• シフトクロック発生器
• スタート / ストップ条件発生回路
• スタート / ストップ条件検出回路
• アービトレーションロスト検出回路
• スレーブアドレス比較回路
• IBSRn レジスタ
• IBCR0n レジスタ
• IBCR1n レジスタ
• ICCRn レジスタ
• IAARn レジスタ
• IDDRn レジスタ
品種により , I2C バスインタフェースの端子数およびチャネル数は異なります。詳細は ,
デバイスのデータシートを参照してください。
本章において , 端子名とレジスタ略称にある "n" はチャネル番号を示します。各品種の
端子名 , レジスタ名とレジスタ略称について , デバイスのデータシートを参照してくだ
さい。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
377
第 23 章 I2C バスインタフェース
23.2 構成
H ard war e
Ma nu al
■ I2C バスインタフェースのブロックダイヤグラム
図 23.2-1 I2C バスインタフェースのブロックダイヤグラム
I2Cバスインタフェース許可
ICCRn
5
EN
6
7
8
クロックセレクタ 1
CS4
CS3
CS2
CS1
CS0
マシンクロック
クロック分周器 1
DMBP
クロック分周器 2
4
8
22 38
98
128
256
512
クロックセレクタ 2
IBSRn
BB
RSC
LRB
Sync
シフトクロック
発生器
シフトクロックエッジ
バスビジー
リピートスタート
スタート / ストップ
条件検出回路
ラストビット
送信 / 受信
エラー
TRX
第 1 バイト
FBT
F2 MC-8FX 内部バス
アービトレーションロスト検出回路
IBCR1n
BER
BEIE
転送割込み
INTE
INT
SCC
MSS
DACKE
終了
スタート
マスタ
ACK 許可
スタート / ストップ
条件発生回路
GC-ACK 許可
アドレス ACK 許可
GACKE
INT タイミング選択
IDDRnレジスタ
IBSRn
AAS
GCA
IBCR0n
スレーブ
ゼネラル
コール
スレーブアドレス
比較回路
IAARnレジスタ
AACKX
INTS
SCLnライン
ALF
SDAnライン
ALE
SPF
ストップ割込み
SPE
WUF
WUE
378
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.2 構成
Ha rdware
Manual
● クロックセレクタ・クロック分周器・シフトクロック発生器
この回路はマシンクロックを使用し , I2C バスのシフトクロックを発生します。
● スタート / ストップ条件発生回路
バス開放時 (SCLn と SDAn が "H" レベルの場合 ), スタート条件を送信することによっ
てマスタは通信を開始します。SCLn="H" の場合に , SDAn ラインを "H" → "L" にすると
スタート条件になります。マスタはストップ条件を発生することによって通信を終了
できます。SCLn="H" の場合に , SDAn ラインが "L" → "H" にするとストップ条件になり
ます。
● スタート / ストップ条件検出回路
この回路は , データ転送のスタート / ストップ条件を検出します。
● アービトレーションロスト検出回路
このインタフェース回路はマルチマスタシステムに対応しています。複数のマスタが
同時送信すると , アービトレーションロスト (SDAn ラインが "L" レベルのときに論理
レベル "1" を送信した場合 ) が発生します。アービトレーションロストを検出すると ,
IBCR0n:ALF が "1" になり , マスタは自動的にスレーブに変わります。
● スレーブアドレス比較回路
スレーブアドレス比較回路は , スタート条件後 , スレーブアドレスを受信して自己のス
レーブアドレスと比較します。このアドレスは 7 ビットのデータで , その後部に 8 ビッ
ト目のデータ方向ビット (R/W) が続きます。受信したアドレスが自己のスレーブアド
レスと一致した場合にアクノリッジを送信します。
● IBSRn レジスタ
IBSRn レジスタ は I2C バスインタフェースのステータスを表します。
● IBCR0n レジスタと IBCR1n レジスタ
IBCR0n レジスタと IBCR1n レジスタはオペレーティングモードの選択 , 割込みの許可 /
禁止 , アクノリッジの許可 / 禁止 , ゼネラルコールアクノリッジの許可 / 禁止および
MCU スタンバイモードウェイクアップ機能の許可 / 禁止時に使用されます。
● ICCRn レジスタ
ICCRn レジスタは I2C バスインタフェースの動作許可とシフトクロック周波数の選択
に使用されます。
● IAARn レジスタ
IAARn レジスタはスレーブアドレスの設定に使用されます。
● IDDRn レジスタ
IDDRn レジスタは , 送受信されるシフトデータ / アドレスを保持するレジスタです。送
信のとき , このレジスタに書かれたデータ / アドレスが MSB ファーストからバスに転
送されます。
■ 入力クロック
I2C バスインタフェースは , マシンクロックを入力クロック ( シフトクロック ) として
使用します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
379
第 23 章 I2C バスインタフェース
23.3 チャネル
H ard war e
23.3
Ma nu al
チャネル
I2C バスインタフェースのチャネルについて説明します。
■ I2C バスインタフェースのチャネル
I2C バスインタフェース の端子とレジスタを表 23.3-1 および表 23.3-2 にそれぞれ示し
ます。
表 23.3-1 I2C バスインタフェースの端子
端子名
SDAn
SCLn
端子機能
I2C バスインタフェース I/O
表 23.3-2 I2C バスインタフェースのレジスタ
レジスタ略称
380
レジスタ対応 ( 本マニュアル上の表記 )
IBCR0n
I2C バス制御レジスタ 0 ch. n
IBCR1n
I2C バス制御レジスタ 1 ch. n
IBSRn
I2C バスステータスレジスタ ch. n
IDDRn
I2C データレジスタ ch. n
IAARn
I2C アドレスレジスタ ch. n
ICCRn
I2C クロック制御レジスタ ch. n
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.4 端子
Ha rdware
23.4
Manual
端子
I2C バスインタフェースの端子について説明します。
■ I2C バスインタフェースの端子
I2C バスインタフェースの端子には , SDAn 端子および SCLn 端子があります。
● SDAn 端子
SDAn 端子は , I2C バスインタフェースのデータ入出力端子です。
I2C バスインタフェース が許可 (ICCRn:EN = 1) された場合 , 自動的にデータ入出力端
子になり , SDAn 端子として機能します。
● SCLn 端子
SCLn 端子は , I2C バスインタフェースのシフトクロック入出力端子です。
I2C バスインタフェースが許可 (ICCRn:EN = 1) された場合 , 自動的にシフトクロック
入出力端子になり , SCLn 端子として機能します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
381
第 23 章 I2C バスインタフェース
23.5 割込み
H ard war e
23.5
Ma nu al
割込み
I2C バスインタフェースは , 転送割込みとストップ割込みがあり , 次に示す要因で割込
みを発生します。
• 転送割込み
データ転送が完了した場合またはバスエラーが発生した場合
• ストップ割込み
ストップ条件を検出した場合 , アービトレーションロストを検出した場合または
ストップモード / 時計モードで I2C バスインタフェースにアクセスがあった場合
■ 転送割込み
表 23.5-1 に, 転送割込みの制御ビットと I2Cバスインタフェースの割込み要因について
示します。
表 23.5-1 転送割込みの制御ビットと I2C バスインタフェースの割込み要因
割込み要求 フラグビット
項目
転送完了
IBCR1n:INT = 1
バスエラー
IBCR1n:BER = 1
割込み要求許可ビット
IBCR1n:INTE = 1
IBCR1n:BEIE = 1
割込み要因
データ転送完了
バスエラー発生
• 転送完了時の割込み
データ転送が完了して転送完了割込み要求許可ビットが許可 (IBCR1n:INTE = 1) さ
れている場合 , CPU に割込み要求を出力します。
割込みサービスルーチン内で転送
完了割込み要求フラグビット (IBCR1n:INT) に "0" を書き込んで割込み要求をクリ
アしてください。
IBCR1n:INTE ビット値にかかわらず , データ転送を完了した場合
は , IBCR1n:INT ビットが "1" に設定されます。
• バスエラー時の割込み
以下の条件が成立した場合はバスエラーと判断され , I2C バスインタフェースは停
止状態となります。
- マスタ時にストップ条件を検出した場合。
- 第 1 バイト送受信中にスタートまたはストップ条件を検出した場合。
- データ送受信中 ( スタート , 1 番目のデータおよびストップビットを除く ) にス
タートまたはストップ条件を検出した場合。
この場合 , バスエラー割込み要求許可ビットが許可 (IBCR1n:BEIE = 1) されていると
CPU に割込み要求を出力します。
割込みサービスルーチン内でバスエラー割込み要求
フラグビット (IBCR1n:BER) に "0" を書き込んで , 割込み要求をクリアしてください。
IBCR1n:BEIE ビット値にかかわらず , バスエラーが発生した場合は , IBCR1n:BER ビッ
トが "1" に設定されます。
382
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.5 割込み
Ha rdware
Manual
■ ストップ割込み
表 23.5-2 に , ストップ割込みの制御ビットと I2C バスインタフェース の割込み要因 ( ト
リガイベント ) について示します。
表 23.5-2 ストップ割込みの制御ビットと I2C バスインタフェースの割込み要因
割込み要求フラグビット
IBCR0n:SPF = 1
IBCR0n:ALF = 1
MCU のストップ / 時計
モードに対する
ウェイクアップ機能
IBCR0n:WUF =1
割込み要求許可ビット
IBCR0n:SPE = 1
IBCR0n:ALE = 1
IBCR0n:WUE = 1
割込み要因
ストップ条件検出
アービトレーションロス
トを検出している場合
スタート条件検出
項目
ストップ条件検出
アービトレーション
ロスト検出
• ストップ条件検出時の割込み
以下のすべての条件が成立しているときにストップ条件が検出された場合 , ストッ
プ条件は正常として扱われます。
- バスビジー中 ( スタート条件が検出されている状態 )
- IBCR1n:MSS = 0
- アクノリッジを含む 1 バイトのデータ転送後
この場合 , ストップ条件検出割込み要求許可ビットが許可 (IBCR0n:SPE = 1) されてい
ると CPU に割込み要求を出力します。割込みサービスルーチン内で IBCR0n:SPF ビッ
トに "0" を書き込んで , 割込み要求をクリアしてください。
IBCR0n:SPE ビット値にかかわらず , 有効なストップ条件が発生した場合 , IBCR0n:SPF
ビットが "1" に設定されます。
• アービトレーションロスト検出時の割込み
アービトレーションロストが検出され , アービトレーションロスト検出割込み要求
許可ビットが許可 (IBCR0n:ALE = 1) されていると , CPU に割込み要求を出力しま
す。バ ス が ア イ ド ル 中 に ア ー ビ ト レ ー シ ョ ン ロ ス ト 割 込 み 要 求 フ ラ グ ビ ッ ト
(IBCR0n:ALF) に "0" を書き込むかバスビジー中に割込みサービスルーチン内で
IBCR1n:INT ビットに "0" を書き込んで , 割込み要求をクリアしてください。
IBCR0n:ALE ビット値にかかわらず , アービトレーションロストが発生した場合 ,
IBCR0n:ALF ビットが "1" に設定されます。
• MCU のストップ モード / 時計モードに対するウェイクアップ機能時の割込み
MCU のストップモード / 時計モードに対するウェイクアップ機能が許可 (IBCR0n:
WUE = 1) されており , スタート条件が検出されると , CPU に割込み要求が出力され
ます。
割込みサービスルーチン内で MCU スタンバイモードウェイクアップ割込み要求フ
ラグビット (IBCR0n:WUF) に "0" を書き込んで , 割込み要求をクリアしてください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
383
第 23 章 I2C バスインタフェース
23.6 動作説明と設定手順例
H ard war e
23.6
Ma nu al
動作説明と設定手順例
I2C バスインタフェースの動作について説明します。
■ I2C バスインタフェースの動作
● I2C バスインタフェース
I2C バスインタフェースは , シフトクロックに同期した 8 ビットデータのシリアルイン
タフェースです。
● MCU スタンバイモードに対するウェイクアップ機能
MCU をストップモード / 時計モード の低消費電力モードで動作させておいた場合で
も , スタート条件の検出により , ウェイクアップさせることができるウェイクアップ機
能があります。
■ 設定手順例
I2C バスインタフェース の設定手順例を以下に示します。
● 初期設定
1. ポートの入力を設定してください (DDR)。
2. 割込みレベルを設定してください (ILR*)。
3. スレーブアドレスを設定してください (IAARn)。
4. クロック選択 , I2C バスインタフェース動作を許可してください (ICCRn)。
5. バスエラー割込み要求を許可してください (IBCR0n:BEIE = 1)。
*: 割込みレベル設定レジスタ (ILR) の詳細について , 本ハードウェアマニュアルの「第 5 章 割
込み」とデバイスのデータシートの「■ 割込み要因のテーブル」を参照してください。
● 割込み処理
1. 任意の処理を行ってください。
2. バスエラー割込み要求フラグをクリアしてください (IBCR1n:BER = 0)。
384
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.6 動作説明と設定手順例
Ha rdware
Manual
l2C バスインタフェース
23.6.1
I2C バスインタフェースは , シフトクロックに同期した 8 ビットデータのシリアルイ
ンタフェースです。
■ I2C のシステム
I2C バスシステムはデータ転送にシリアルデータライン (SDAn) とシリアルクロック
ライン (SCLn) を使用します。バスに接続された全装置はオープンドレインまたはオー
プンコレクタ出力である必要があり , プルアップ抵抗を接続して使用します。
バスに接続された各デバイスには固有のアドレスがあり , アドレスは , ソフトウェアで
設定が可能です。そして常に単純なマスタ / スレーブ関係が存在し , マスタはマスタト
ランスミッタまたはマスタレシーバとして機能します。
万一 , 複数のマスタが同時に
データ転送を開始しようとした場合でも , データ破壊を防ぐために衝突検出機能およ
びアービトレーション機能を備えた本格的なマルチマスタバスです。
■ I2C のプロトコル
図 23.6-1 に , データ転送に必要なフォーマットを示します。
図 23.6-1 データ転送例
MSB
LSB
MSB
LSB
SDAn
SCLn
スタート
条件 (S)
7 ビットアドレス
R/W
アクノリッジビット
8 ビットデータ
ストップ
条件 (P)
アクノリッジなし
スタート条件 (S) 発生後 , スレーブアドレスが送信されます。このアドレスは 7 ビット
長で , 8 ビット目にデータ方向ビット (R/W) があります。アドレスの後にデータが送信
されます。データは 8 ビット長で , その後にアクノリッジビットがあります。
データは 8 ビット+アクノリッジの単位で連続させることにより同一スレーブアドレ
スに連続して送信できます。
データ転送は常にマスタストップ条件 (P) で終了します。しかし , 繰返しスタート条件
(S) を行うことによって , ストップ条件を発生せずに別のスレーブを示すアドレスを送
信することも可能です。
■ スタート条件
バスが開放されている状態 (SCLn と SDAn の両方が論理 "H" である ) において , マス
タはスタート条件を発生することによって送信を開始します。図 23.6-1 に示したとお
り , SCLn="H" の場合に SDAn ラインを "H" → "L" にするとスタート条件となります。
この場合 , 新しいデータ転送が始まり , マスタ / スレーブ動作を開始します。
スタート条件を発生させる条件として , 次の 2 とおりがあります。
• I2C バスインタフェースが使用されていない状態 (IBCR1n:MSS = 0, IBSRn:BB = 0,
IBCR1n:INT = 0, IBCR0n:ALF=0) での IBCR1n:MSS ビットの"1"の書込みを行った場
合 ( その後 , IBSRn:BB が "1" に設定され , バスビジーを示します ) 。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
385
第 23 章 I2C バスインタフェース
23.6 動作説明と設定手順例
H ard war e
Ma nu al
• バスマスタ時の割込み状態 (IBCR1n:MSS = 1, IBSRn:BB = 1, IBCR1n:INT = 1,
IBCR0n:ALF = 0) での IBCR1n:SCC ビットへの "1" の書込みを行った場合 ( これによ
り繰返しスタート条件を発生します ) 。
上記の条件以外において , IBCR1n:MSS = 1 または IBCR1n:SCC = 1 の書込みは無視され
ます。ほかのシステムがバス使用中に , IBCR1n:MSS ビットへの "1" の書込みを行うと ,
IBCR0n:ALF ビットが "1" に設定されます。
■ アドレッシング
● マスタモードにおいてスレーブアドレッシングをする場合
マスタモードでは , スタート条件発生後 , IBSRn:BB = 1, IBSRn:TRX = 1 に設定され , ス
レーブアドレスの IDDRn レジスタの内容を上位ビット MSB からバスに出力します。こ
のアドレスデータは , 7 ビットのスレーブアドレスとデータの転送方向を示す R/W
ビット (IDDRn の bit0) の 8 ビットで構成されます。
アドレスデータ送信後 , スレーブからアクノリッジを受信します。
9 番目のクロックサ
イクルで SDAn が "L" レベルになって , 受信デバイスからアクノリッジビットを受信し
ます ( 図 23.6-1 を参照 )。この場合 , R/W ビット (IDDRn:bit0) が論理的に反転し , SDAn
が "L" の場合は "1" として IBSRn:TRX ビットに格納されます。
● スレーブモードにおいてアドレッシングを受ける場合
スレーブモードではスタート条件検出後, IBSRn:BB = 1, IBSRn:TRX = 0 に設定され, マ
スタからの受信データを IDDRn レジスタへ格納します。アドレスデータ受信後 , IDDRn
レジスタと IAARn レジスタとの比較が行われ , 一致している場合 , IBSRn:AAS = 1 に設
定し , マスタに対してアクノリッジを送信します。その後, 受信データの bit0 (IDDRn レ
ジスタの bit0) を IBSRn:TRX ビットへ格納します。
■ データ転送
スレーブとしてアドレス指定されると , マスタが送った R/W ビットによって決定され
る方向で , バイトごとにデータ送受信ができます。
SDAn ラインに出力される各バイトは 8 ビット固定です。図 23.6-1 に示したとおりア
クノリッジクロックパルスが "H" の状態の場合に SDAn ラインを "L" レベルの状態に
安定させることで , 受信装置はアクノリッジを送信側に伝えるようになっています。
MSB を先頭に 1 ビットごとに 1 クロックパルスでデータを転送します。バイト転送ご
とに, アクノリッジの送受信が行われる必要があります。そのため, 1 つの完全なデータ
バイト転送は 9 つのクロックパルスが必要です。
■ アクノリッジ
アクノリッジは , 次に示す条件の元 , 送信側データバイト転送の 9 番目のクロックサイ
クルに対して受信側から送信されます。
アドレスアクノリッジは下記条件で発生します。
• 受信アドレスが IAARn の設定アドレスと一致し, さらにアドレスアクノリッジ自動
出力 (IBCR0n:AACKX = 0) の場合
• ゼネラルコールアドレス (0x00) を受信し , さらにゼネラルコールアドレスアクノ
リッジ出力許可 (IBCR1n:GACKE = 1) の場合
データを受信したときのデータアクノリッジビットは , IBCR1n:DACKE ビットにより
許可 / 禁止できます。マスタモードでは IBCR1n:DACKE = 1 のときにデータアクノ
386
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.6 動作説明と設定手順例
Ha rdware
Manual
リッジが発生し , スレーブモードでは , アドレスアクノリッジが既に発生しており , か
つ IBCR1n:DACKE = 1 の場合に , データアクノリッジが発生します。また , 受信したア
クノリッジは , 9 番目の SCLn サイクルで IBSRn:LRB に保持されます。
• データアクノリッジが受信データの内容に依存する場合 (SM バスで使われるパケッ
トエラーチェッキングなど ), IBCR0n:INTS ビットに "1" を書き込む ( 例えば前の転
送完了割込みにて ) ことで最新の受信データを読み出せるようにした上で , データ
アクノリッジ許可ビット (IBCR1n:DACKE) の設定によりデータアクノリッジを制御
してください。
• 最新のデータアクノリッジ (IBSRn:LRB) の読出しは , アクノリッジ受信後に行えま
す (LRB の読出しは , 9 番目の SCLn サイクルにおける転送終了割込みで行われる必
要があります ) 。そのため , IBCR0n:INTS ビットが "1" のときにアクノリッジを読み
出す場合は , 8 番目の SCLn サイクルによる転送終了割込み中に , このビットに "0"
を書き込んで , 9 番目の SCLn サイクルで , 再度 , 転送終了割込みが発生するように
設定してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
387
第 23 章 I2C バスインタフェース
23.6 動作説明と設定手順例
H ard war e
Ma nu al
■ ゼネラルコールアドレス
ゼネラルコールアドレスは , スタートアドレスバイト (0x00) とそれに続く第 2 アドレ
スバイトから構成されます。ゼネラルコールアドレスを使用するためには , 第 1 バイト
のゼネラルコールアドレスに対するアクノリッジの前に , IBCR1n:GACKE = 1 を設定
しておいてください。また , 第 2 アドレスバイトのアクノリッジは , 図 23.6-2 に示され
るような方法で制御できます。
図 23.6-2 ゼネラルコール動作
スレーブモード
第 1 バイトゼネラルコールアドレス
第 2 バイトゼネラルコールアドレス
ACK
ACK/NACK
9th SCL↓で IBCR1n:INTが設定される
IBSRn:LRB を読み出す
9th SCL↓で IBCR1n:INT が設定される
IBCR0n:INTS=1を設定する
IBCR1n:GACKE=1のとき ACK が与えられ
IBSRn:GCAが設定される
8th SCL↓でIBCR1n:INT が設定される
IDDRnを読み出してIBCR1n:DACKE によりACK/NACKを制御
IBSRn:LRBを読み出す必要がある場合は INTS=0に設定する
(a) スレーブモード時のゼネラルコール動作
マスタモード
GACKE=1
第 1 バイトゼネラルコールアドレス
第 2 バイトゼネラルコールアドレス
ACK
9th SCL↓で IBCR1n:INT が設定される
IBCR0n:INTS=1, GACKE=0 を設定する
ACK が与えられ, IBSRn:GCAが設定される
ACK/NACK
9th SCL↓でIBCR1n:INTが設定される
IBSRn:LRBを読み出す
GCAがクリアされる
8th SCL↓でIBCR1n:INTが設定される
IBSRn:LRBを読み出すためINTS=0に設定する
(b) マスタモード時のゼネラルコール動作 (AL なし, GACKE=1 からスタート)
マスタモード
GACKE=1
第 1 バイトゼネラルコールアドレス
第 2 バイトゼネラルコールアドレス
ACK
ACK/NACK
9th SCL↓でIBCR1n:INTが設定される
IBSRn:LRBを読み出す
9th SCL↓で IBCR1n:INTが設定される
IBCR0n:INTS=1, GACKE=0 を設定する
8th SCL↓で IBCR1n:INTが設定される
IDDRnを読み出してIBCR1n:DACKEによりACK/NACKを制御
IBSRn:LRBを読み出す必要がある場合はINTS=0に設定する
ACK が与えられ, IBSRn:GCA が設定される
第2アドレスでALが発生してスレーブモードへ切り換える
(c) マスタモード時のゼネラルコール動作 (第 2 アドレスで AL あり, GACKE=1 からスタート)
マスタモード
GACKE=0
第1バイトゼネラルコールアドレス
NACK
第2バイトゼネラルコールアドレス
9th SCL↓で IBCR1n:INT が設定される
IBCR0n:INTS=1を設定する
ACK は与えられず, IBSRn:GCAは設定されない
ACK/NACK
9th SCL↓で IBCR1n:INTが設定される
IBSRn:LRBを読み出す
8th SCL↓でIBCR1n:INTが設定される
IBSRn:LRBを読み出すため INTS=0に設定する
(d) マスタモード時のゼネラルコール動作 (ALなし, GACKE=0 からスタート)
マスタモード
GACKE=0
第1バイトゼネラルコールアドレス
NACK
第2バイトゼネラルコールアドレス
9th SCL↓で IBCR1n:INTが設定される
IBCR0n:INTS=1を設定する
ACK は与えられず,IBSRn:GCAは設定されない
ACK/NACK
9th SCL↓で IBCR1n:INTが設定される
IBSRn:LRBを読み出す
8th SCL↓で IBCR1n:INTが設定される
IDDRnを読み出して IBCR1n:DACKEによりACK/NACKを制御
IBSRn:LRBを読み出す必要がある場合は INTS=0に設定する
第2アドレスで AL が発生し, IBSRn:GCAが設定され,
スレーブモードへ切換える
(e) マスタモード時のゼネラルコール動作 (第2アドレスでALあり, GACKE=0からスタート)
ACK
NACK
GCA
AL
: アクノリッジ
: アクノリッジなし
: ゼネラルコールアドレス
: アービトレーションロスト
本モジュールとほかのデバイスがゼネラルコールアドレスを同時に送信した場合, 第 2
アドレスバイト転送時にアービトレーションロストが検出されていないかどうかで ,
バスを獲得したかどうかを確認できます。もし , アービトレーションロストが検出され
た場合 , 本モジュールはスレーブモードとなり , マスタからのデータ受信を継続しま
す。
388
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.6 動作説明と設定手順例
Ha rdware
Manual
■ ストップ条件
ストップ条件を発生させることによって , マスタはバスを開放して通信を終了します。
SCLn が "H" の場合に , SDAn ラインを "L" → "H" にするとストップ条件となります。マ
スタモード時の通信終了 ( 以後バスフリー) をバス上のデバイスに知らせるための信号
です。また , マスタはストップ条件を発生させずに , 連続してスタート条件を発生でき
ます。これを繰返しスタート条件とよびます。
バスマスタ時の割込み状態 (IBCR1n:MSS = 1 , IBSRn:BB = 1, IBCR1n:INT = 1 および
IBCR0n:ALF = 0) で , IBCR1n:MSS ビットに "0" を書き込むとストップ条件が発生して
スレーブモードになります。上記以外において , IBCR1n:MSS ビットへの "0" の書込み
は無視されます。
■ アービトレーション
このインタフェース回路は複数のマスタを接続できる本格的なマルチマスタバスで
す。
マスタ転送で , システム内のほかのマスタが同時にデータ転送をした場合 , アービ
トレーションが発生します。
アービトレーションは , SCLn ラインが "H" レベルの場合に SDAn ラインで発生しま
す。マスタは , 自身の送信データが "1", SDAn ライン上のデータが "L" レベルの場合 ,
アービトレーションロストが発生したとみなし ,
データ出力をオフにして ,
IBCR0n:ALF = 1 に設定します。このとき , アービトレーションロスト割込みが許可
(IBCR0n:ALE = 1) されていると , 割込みが発生します。IBCR0n:ALF = 1 に設定される
と , IBCR1n:MSS = 0, IBSRn:TRX = 0 となり , TRX ビットがクリアされてスレーブ受信
モードとなります。
もし , IBSRn:BB=0 のときに IBCR0n:ALF が "1" に設定された場合 , IBCR0n:ALF は "0"
の書込みでのみクリアされます。また , IBSRn:BB = 1 のときに IBCR0n:ALF が "1" に設
定された場合 , IBCR0n:ALF は IBCR1n:INT を "0" にクリアすることによってのみクリ
アされます。
● IBSRn:BB = 0 でアービトレーションロスト割込みが発生する条件
図 23.6-3 や 図 23.6-4 に示されるようなタイミングにて , プログラムによりスタート条
件を発生させた場合 (IBCR1n:MSS を "1" に設定 ), アービトレーションロスト検出
(IBCR0n:ALF = 1) により割込みの発生 (IBCR1n:INT = 1) が抑止されます。
• アービトレーションロストにより割込みが発生しない条件 1
スタート条件が検出されておらず (IBSRn:BB = 0), SDAn と SCLn ラインの端子状態が
"L" レベルとなっている状態で , プログラムによりスタート条件を発生 (IBCR1n:MSS
を "1" に設定 ) させた場合。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
389
第 23 章 I2C バスインタフェース
23.6 動作説明と設定手順例
H ard war e
Ma nu al
図 23.6-3 IBCR0n:ALF = 1 で割込みが発生しない場合のタイミングダイヤグラム
SCLn端子もしくはSDAn端子が “L” レベル
SCLn端子
SDAn端子
"L"
"L"
1
I2C
動作許可状態 (ICCRn:EN = 1)
マスタモード設定 (IBCR1n:MSS = 1)
アービトレーションロスト検出ビット
(IBCR0n:ALF = 1)
390
バスビジー (IBSRn:BB)
0
割込み (IBCR1n:INT)
0
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.6 動作説明と設定手順例
Ha rdware
Manual
• アービトレーションロストにより割込みが発生しない条件 2
I2C バスがほかのマスタにより使用されているとき , プログラムにより I2C バスインタ
フェース の動作を許可 (ICCRn:ENを"1"に設定) し, スタート条件を発生 (IBCR1n:MSS
を "1" に設定 ) させた場合。
これは , 図 23.6-4 に示すように , 本 I2C バスインタフェースの動作が禁止 (ICCRn:EN =
0) のときに I2C バス上のほかのマスタが通信を開始した場合, 本 I2Cバスインタフェー
ス はスタート条件を検出できないためです (IBSRn:BB = 0)。
図 23.6-4 IBCR0n:ALF = 1 で割込みが発生しない場合のタイミングダイヤグラム
9番目のクロックサイクルで IBCR1n:INTの
割込みは発生しない
スタート条件
ストップ条件
SCLn端子
スレーブアドレス
SDAn端子
ACK
データ
ACK
ICCRn:EN
IBCR1n:MSS
IBCR0n:ALF
IBSRn:BB
0
IBCR1n:INT
0
上記のような現象が発生し得る場合 , 以下のソフトウェアの設定手順に従ってくださ
い。
1. プログラムによりスタート条件を発生させる (IBCR1n:MSS を "1" に設定 ) 。
2. アービトレーションロスト割込みで IBCR0n:ALF と IBSRn:BB を確認。
IBCR0n:ALF = 1かつIBSRn:BB = 0であった場合, IBCR0n:ALFを "0" にクリアします。
IBCR0n:ALF = 1 かつ IBSRn:BB = 1 であった場合 , IBCR0n:ALE を "0" にクリアして
通常制御を行います ( 通常制御の INT 割込みにて , IBCR1n:INT への "0" の書込みで
IBCR0n:ALF を "0" にクリアします )。
それ以外は , 通常制御を行います ( 通常制御の INT 割込みにて , IBCR1n:INT への "0"
の書込みで IBCR0n:ALF をクリアします )。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
391
第 23 章 I2C バスインタフェース
23.6 動作説明と設定手順例
H ard war e
Ma nu al
図 23.6-5 に , サンプルフローを示します。
図 23.6-5 サンプルフロー 1
AL割込みを許可 (IBCR0n:ALE=1)
マスタモードに設定
I2Cバス制御レジスタ1 ch. n (IBCR1n)のMSSビットを“1”に設定
IBCR0n:ALF = 1
NO
YES
IBSRn:BB = 0
NO
YES
IBCR0n:ALFに“0”をライトして
ALフラグと割込みをクリア
IBCR0n:ALEに“0”をライトして
AL割込みをクリア
通常制御
● 「IBCR0n:ALF = 1」
の検出時における割込み (IBCR1n:INT = 1) 発生例
バスビジー(IBSRn:BB = 1) およびアービトレーションロストが検出されたとき , プロ
グラムがスタート条件を発生させた場合 (IBCR1n:MSS を "1" に設定 ),「IBCR0n:ALF =
1」の検出により転送完了割込み (IBCR1n:INT = 1) が発生します。
図 23.6-6 「IBCR0n:ALF = 1」
検出時における割込み発生のタイミングダイヤグラム
スタート条件
9 番目のクロックサイクルにおける割込み
SCLn端子
SDAn端子
スレーブアドレス
ACK
データ
ICCRn:EN
IBCR1n:MSS
IBCR0n:ALF
ソフトウェアにより
IBCR0n:ALFをクリア
IBSRn:BB
IBCR1n:INT
392
ソフトウェアにより IBCR1n:INTを
クリアして SCLnラインをリリース
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.6 動作説明と設定手順例
Ha rdware
Manual
MCU スタンバイモードに対するウェイクアップ機能
23.6.2
ウェイクアップ機能により , MCU のストップモード / 時計モードで I2C バスインタ
フェースへアクセスできます。
■ MCU スタンバイモードに対するウェイクアップ機能
本 I2C バスインタフェースは , MCU スタンバイモードウェイクアップ機能を内蔵して
おり , MCU スタンバイモードウェイクアップ機能許可ビット (IBCR0n:WUE) に "1" を
書き込むと動作を許可できます。
MCU がストップ モード / 時計モードで WUE ビットが "1" のとき , I2C バス上にスター
ト条件を検出すると , MCU スタンバイモードウェイクアップ割込み要求フラグビット
(IBCR0n:WUF) が "1" に設定され , MCU をストップモード / 時計モードからウェイク
アップさせるためのウェイクアップ割込み要求を発生します。
• MCU をストップ モード / 時計モードに入れる直前に , WUE ビットを "1" に設定し
てください。また , MCU がストップモード / 時計モードからウェイクアップした後 ,
I2C の動作を直ちに再開できるように WUE ビット をクリア ("0" 書込み ) してくだ
さい。
• このウェイクアップ機能は MCU のストップ モード / 時計モードでのみ有効です。
図 23.6-7 通常の I2C バスインタフェース動作とウェイクアップ中の動作との比較
SDAn
SCLn
5
IBCR0n:WUF
による IRQ
マシン
クロック
1
2
3
4
➀
ストップモード / 時計モードに入る直前に IBCR0n:WUE を "1" に設定し , IBSRn:BB = 0 を確認する。
➁
MCU をストップモード / 時計モードに設定し , マシンクロックを停止させる。
➂
ストップモード / 時計モード中に , スタート条件を検出。IBCR0n:WUF = 1 となり , ウェイクアップ IRQ が発生。
ス
トップモードの場合 , 発振安定待ち時間後 , MCU はウェイクアップし , ストップモード / 時計モードに入る前の
クロックモードとなる。
➃
I2C が通常動作を再び開始できるよう , WUE ビットを "0" にクリアし , さらに WUF ビットを "0" にしてウェイク
アップ割込みをクリアする。
➄
データバイトを正確に受信するため , I2C 送信開始 (SDAn の立下りエッジ検出 ) から 100 s ( 最小の発振安定待ち
時間が 100s と仮定した場合 ) 後に ,SCLn が最初のサイクルとして開放されなければなりません。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
393
第 23 章 I2C バスインタフェース
23.6 動作説明と設定手順例
H ard war e
Ma nu al
図 23.6-8 に , ウェイクアップ機能のサンプルフローを示します。
図 23.6-8 サンプルフロー 2
ストップモード / 時計
モードへの遷移手順
IBSRn:BB=0
NO
YES
IBCR0n:WUE =1 の設定により
ウェイクアップ機能許可
IBSRn:BB=0
NO
IBCR0n:WUE = 0
YES
ストップ モード / 時計モードへ遷移
394
IBCR0n:ALE に "0" を書き込んで
AL 割込みをクリア
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.7 レジスタ
Ha rdware
23.7
Manual
レジスタ
I2C バスインタフェースのレジスタについて説明します。
表 23.7-1
I2C バスインタフェースのレジスタ一覧
レジスタ略称
レジスタ名
2
参照先
IBCR0n
I C バス制御レジスタ 0 ch.n
23.7.1
IBCR1n
I2C バス制御レジスタ 1 ch. n
23.7.2
IBSRn
I2C バスステータスレジスタ ch. n
23.7.3
2
IDDRn
I C データレジスタ ch. n
23.7.4
IAARn
I2C アドレスレジスタ ch. n
23.7.5
ICCRn
I2C クロック制御レジスタ ch. n
23.7.6
April 4, 2014, MB95F718M_MN702-00014-3v0-J
395
第 23 章 I2C バスインタフェース
23.7 レジスタ
H ard war e
23.7.1
Ma nu al
I2C バス制御レジスタ 0 ch. n (IBCR0n)
I2C バス制御レジスタ 0 ch. n (IBCR0n) は , アドレスアクノリッジ , 転送完了フラグ
(INT) タイミングの選択 , アービトレーションロスト割込みの許可 / 禁止 , ストップ条
件検出割込みの許可 / 禁止および MCU スタンバイウェイクアップ機能の許可 / 禁止
を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
AACKX
INTS
ALF
ALE
SPF
SPE
WUF
WUE
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] AACKX: アドレスアクノリッジ禁止ビット
このビットは第 1 バイト送信時のアドレスアクノリッジを制御します。
このビットに "0" が書き込まれた場合 , アドレスアクノリッジが自動的に出力されます ( スレーブア
ドレスと一致すると , アドレスアクノリッジが自動的に返されます ) 。
このビットに "1" が書き込まれた場合 , アドレスアクノリッジは出力されません。
このビットの書き換えは , 次のどちらかの方法で行ってください。
• マスタモードで , このビットに "1" を書き込んでください。
• バスビジービットが "0" (IBSRn:BB) であることを確認後 , このビットを "0" にクリアしてくださ
い。
( 注意事項 )
• 転送完了割込み発生 (IBCR1n:INT = 1) 時に AACKX = 1 かつ IBSRn:FBT = 0 の場合 , I2C のアド
レスとスレーブアドレスが一致してもアドレスアクノリッジは出力されませんが , アドレッシ
ングされた場合と同様に 1 バイトのアドレス / データ転送終了ごとに割込みを発生するため ,
IBCR1n:INT ビットを "0" にクリアしてください。
• 転送完了割込み発生 (IBCR1n:INT = 1) 時に AACKX = 1 かつ IBSRn:FBT = 1 の場合 , スレーブ
モードとしてアドレッシングされた後に AACKX に "1" を書き込んだことが考えられるため ,
再度 AACKX に "0" を設定した後に通常の通信を続けるか , I2C バスインタフェースの動作を
禁止 (ICCRn:EN=0) した後に通信を再開するかしてください。
bit7
396
説明
"0" を書き込んだ場合
アドレスアクノリッジを許可します。
"1" を書き込んだ場合
アドレスアクノリッジを禁止します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.7 レジスタ
Ha rdware
Manual
[bit6] INTS: データ受信時の転送完了フラグビットタイミング選択ビット
このビットはデータ受信時における転送完了割込み (IBCR1n:INT) のタイミングを選択します。こ
のビットの設定を変更したい場合 , IBSRn:TRX = 0 かつ IBSRn:FBT = 0 のときに変更してください。
このビットに "0" が書き込まれた場合 , 9 番目の SCLn サイクルで転送完了割込み要求フラグビット
(IBCR1n:INT) が "1" に設定されます。
このビットに "1" が書き込まれた場合 , 8 番目の SCLn サイクルで転送完了割込み要求フラグビット
(IBCR1n:INT) が "1" に設定されます。
( 注意事項 )
• データ受信時 (IBSRn:TRX = 1 もしくは IBSRn:FBT = 1) 以外 , 転送完了割込み要求フラグビッ
ト (IBCR1n:INT) は常に 9 番目の SCLn サイクルで "1" に設定されます。
• データアクノリッジが受信データの内容に依存する場合 (SM バスで使われるパケットエラー
チェッキングなど ), このビットに "1" を書き込む ( 例えば前の転送完了割込みにて ) ことで最
新の受信データを読み出せるようにした上で, データアクノリッジ許可ビット(IBCR1n:DACKE)
の設定によりデータアクノリッジを制御してください。
• 最新のデータアクノリッジ(IBSRn:LRB)の読出しは, アクノリッジ受信後に実行できます (LRB
の読出しは , 9 番目の SCLn サイクルにおける転送終了割込みで行われる必要があります ) 。そ
のため , このビットが "1" のときにデータアクノリッジを読み出す場合は , 8 番目の SCLn サイ
クルによる転送終了割込み中に , このビットに "0" を書き込んで , 9 番目の SCLn サイクルで ,
再度 , 転送終了割込みが発生するよう設定してください。
説明
bit6
"0" を書き込んだ場合
9 番目の SCLn サイクルで INT を設定します。
"1" を書き込んだ場合
8 番目の SCLn サイクルで INT を設定します。
[bit5] ALF: アービトレーションロスト割込み要求フラグビット
このビットはアービトレーションロストを検出します。
このビットと IBCR0n:ALE ビットがともに "1" のとき , アービトレーションロスト割込み要求が発
生します。
このビットは以下の条件で "1" になります。
• マスタとしてデータ / アドレス送信中にアービトレーションロストが検出された場合
• ほかのシステムがバスを使用中に IBCR1n:MSS ビットに "1" を書き込んだ場合
ただし , スレーブとして AACK または GACK を返した後 , MSS ビットに "1" を書き込んだ場合は
このビットは "1" に設定されません。
このビットは以下の条件で "0" になります。
• IBSRn:BB=0 のときに IBCR0n:ALF ビットに "0" を書き込んだ場合
• 転送終了フラグのクリアのために IBCR1n:INT ビットに "0" を書き込んだ場合
このビットに "1" を書き込んでも動作に影響はありません。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit5
"0" が読み出された場合
アービトレーションロストが検出されていないことを示します。
"1" が読み出された場合
アービトレーションロストが検出されていることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
397
第 23 章 I2C バスインタフェース
23.7 レジスタ
H ard war e
Ma nu al
[bit4] ALE: アービトレーションロスト割込み許可ビット
このビットはアービトレーションロスト割込みを許可または 禁止します。
このビットと IBCR0n:ALF ビットがともに "1" のとき , アービトレーションロスト割込み要求が発
生します。
説明
bit4
"0" を書き込んだ場合
アービトレーションロスト割込みを禁止します。
"1" を書き込んだ場合
アービトレーションロスト割込みを許可します。
[bit3] SPF: ストップ検出割込み要求フラグビット
このビットはストップ条件を検出します。
このビットと IBCR0n:SPE ビットがともに "1" のとき , ストップ検出割込み要求が発生します。
このビットは , バスビジー中にストップ条件が正当に検出された場合は "1" になります。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit3
"0" が読み出された場合
ストップ条件が検出されていないことを示します。
"1" が読み出された場合
ストップ条件が検出されていることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit2] SPE: ストップ検出割込み許可ビット
このビットはストップ検出割込みを許可 または 禁止します。
このビットと IBCR0n:SPF ビットがともに "1" のとき , ストップ検出割込み要求が発生します。
説明
bit2
"0" を書き込んだ場合
ストップ検出割込みを禁止します。
"1" を書き込んだ場合
ストップ検出割込みを許可します。
[bit1] WUF: MCU スタンバイモードウェイクアップ割込み要求フラグビット
このビットはストップモード / 時計モード中の MCU スタンバイモードウェイクアップを検出しま
す。
このビットと IBCR0n:WUE ビットがともに "1" のとき , ウェイクアップ割込み要求が発生します。
このビットは , ウェイクアップ機能の許可 (IBCR0n:WUE = 1) 時に , スタート条件が検出された場合
は "1" になります。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit1
398
"0" が読み出された場合
スタート条件が検出されていないことを示します。
"1" が読み出された場合
スタート条件が検出されていることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.7 レジスタ
Ha rdware
Manual
[bit0] WUE: MCU スタンバイモードウェイクアップ機能許可ビット
このビットはストップモード / 時計モード中の MCU スタンバイモードウェイクアップ機能を許可
または禁止します。
ストップモード / 時計モードでこのビットが "1" で , かつスタート条件が検出された場合 , I2C の動
作開始のためにウェイクアップ割込み要求が発生します。
説明
bit0
"0" を書き込んだ場合
ストップモード / 時計モードにおける MCU スタンバイモードウェイクアップ機
能を禁止します。
"1" を書き込んだ場合
ストップモード / 時計モードにおける MCU スタンバイモードウェイクアップ機
能を許可します。
( 注意事項 )
• このビットへの "1" の書込みは , MCU がストップモード / 時計モードに入る直前に行ってくだ
さい。また , MCU がストップモード / 時計モードからウェイクアップした後 , I2C の動作をす
ぐに再開できるように , できるだけ早くこのビットをクリア ("0" の 書込み ) してください。
• ウェイクアップ割込み要求が発生した後 , MCU は発振安定待ち時間の経過後にウェイクアッ
プします。したがって , ウェイクアップ直後のデータの取り逃しを避けるため , I2C 送信開始
(SDAn の立下りエッジ検出 ) によるウェイクアップから 100 µs ( 最小の発振安定待ち時間が
100 µs と仮定した場合 ) 以降に , SCLn が最初のサイクルとして立ち上り , 第 1 ビットがデータ
として受信されなければなりません。
• MCU スタンバイモード中 , 本 I2C 機能のステータスフラグ , ステートマシンおよび I2C バス出
力は , スタンバイモードに入る直前の状態を保持します。I2C バスシステム全体のハングアッ
プを避けるため , スタンバイモードに入れる前に , IBSRn:BB = 0 となっていることを確認して
ください。
• ウェイクアップ機能は , IBSRn:BB = 1 における MCU のストップモード / 時計モードへの遷移
をサポートしていません。IBSRn:BB = 1 で MCU がストップモード / 時計モードへ遷移した場
合 , スタート条件が検出された段階でバスエラーが発生します。
• ウェイクアップ機能は MCU のストップモード / 時計モードでのみ有効です 。
<注意事項>
I2C の動作が禁止 (ICCRn:EN = 0) された場合 , IBCR0n レジスタの AACKX ビット , INTS
ビットおよび WUE ビットは , "0" になり , 値の書込みができなくなります。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
399
第 23 章 I2C バスインタフェース
23.7 レジスタ
H ard war e
23.7.2
Ma nu al
I2C バス制御レジスタ 1 ch. n (IBCR1n)
I2C バス制御レジスタ 1 ch. n (IBCR1n) は , バスエラー割込みの許可 / 禁止 , スター
ト条件発生 , マスタ / スレーブモードの選択 , データアクノリッジの許可 / 禁止 , ゼネ
ラルコールアクノリッジの許可 / 禁止および転送完了割込みの許可 / 禁止を制御しま
す。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
BER
BEIE
SCC
MSS
DACKE
GACKE
INTE
INT
属性
R/W
R/W
W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] BER: バスエラー割込み要求フラグビット
このビットはバスエラーを検出します。
このビットと BEIE ビットがともに "1" のとき , バスエラー割込み要求が発生します。
不正なスタート条件または不正なストップ条件が検出された場合 , このビットは "1" になります。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit7
"0" が読み出された場合
バスエラーが検出されていないことを示します。
"1" が読み出された場合
不正なスタート条件または不正なストップ条件が検出されていることを示しま
す。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit6] BEIE: バスエラー割込み要求許可ビット
このビットはバスエラー割込みを許可または禁止します。
このビットと BER ビットがともに "1" のとき , バスエラー割込み要求が発生します。
説明
bit6
400
"0" を書き込んだ場合
バスエラー割込みを禁止します。
"1" を書き込んだ場合
バスエラー割込みを許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.7 レジスタ
Ha rdware
Manual
[bit5] SCC: スタート条件発生ビット
このビットは , マスタモード中に繰返しスタート条件を発生し , 通信を再スタートさせます。
マスタモードでこのビットに "1" が書き込まれた場合 , 繰返しスタート条件が発生します。
このビットに "0" を書き込んでも動作に影響はありません。
説明
bit5
読出し動作
読出し値は常に "0" です。
"0" を書き込んだ場合
動作に影響はありません。
"1" を書き込んだ場合
マスタモードで繰返しスタート条件が発生します。
( 注意事項 )
• IBCR1n:SCC = 1 と IBCR1n:MSS = 0 を同時に設定しないでください。
• IBCR1n:INT = 0 のときに , このビットに "1" を書き込んだ場合 , 書込みは無視されます ( スター
ト条件は発生しません ) 。また , IBCR1n:INT = 1 のときに , このビットへの "1" の書込みと ,
IBCR1n:INT ビットへの "0" の書込みが同時に行われた場合 , このビットが優先されてスタート
条件が発生します。
[bit4] MSS: マスタ / スレーブ選択ビット
このビットはマスタモードとスレーブモードから動作モードを選択します。
I2C バスがアイドル状態 (IBSRn:BB = 0) のときに , このビットに "1" が書き込まれると , マスタモー
ドが選択され , スタート条件の発生後にアドレス転送が開始されます。
I2C バスがビジー状態 (IBSRn:BB = 1) のときに , このビットに "0" が書き込まれると , スレーブモー
ドが選択され , ストップ条件の発生後にデータ転送が終了します。
マスタモードのデータ / アドレス転送中にアービトレーションロストが発生した場合 , このビット
は "0" にクリアされて動作モードがスレーブモードになります。
説明
bit4
"0" を書き込んだ場合
スレーブモード
"1" を書き込んだ場合
マスタモード
( 注意事項 )
• IBCR1n:SCC = 1 と IBCR1n:MSS = 0 を同時に設定しないでください。
• IBCR1n:INT = 0 のときに , このビットに "0" を書き込んだ場合 , 書込みは無視されます。また ,
IBCR1n:INT = 1 のときに , このビットへ の "0" の書込みと , IBCR1n:INT ビットへの "0" の書込
みが同時に行われた場合 , このビットが優先されてストップ条件が発生します。
• スレーブモードで送受信中に MSS ビットに "1" が書き込まれても , IBCR0n:ALF ビットは設定
されません。スレーブモードで送受信中に MSS ビットに "1" を書き込まないでください。
[bit3] DACKE: データアクノリッジ許可ビット
このビットはデータ受信時のデータアクノリッジを制御します。
このビットに "0" が書き込まれた場合 , データアクノリッジ出力は禁止されます。
このビットに "1" が書き込まれた場合 , データアクノリッジ出力は許可されます。このとき , マスタ
モードでは , データアクノリッジがデータ受信の 9 番目の SCLn サイクルで出力されます。また , ス
レーブモードでは , アドレスアクノリッジが既に出力されている場合のみ , データアクノリッジが
データ受信の 9 番目の SCLn サイクルで出力されます。
説明
bit3
"0" を書き込んだ場合
データアクノリッジ出力を禁止します。
"1" を書き込んだ場合
データアクノリッジ出力を許可します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
401
第 23 章 I2C バスインタフェース
23.7 レジスタ
H ard war e
Ma nu al
[bit2] GACKE: ゼネラルコールアドレスアクノリッジ許可ビット
このビットはゼネラルコールアドレスアクノリッジを制御します。
このビットに "0" が書き込まれた場合 , ゼネラルコールアドレスアクノリッジ出力は禁止されます。
このビットに "1" が書き込まれた場合 , マスタモード / スレーブモードで , ゼネラルコールアドレス
(0x00) が受信されると , ゼネラルコールアドレスアクノリッジが出力されます。
説明
bit2
"0" を書き込んだ場合
ゼネラルコールアドレスアクノリッジを禁止します。
"1" を書き込んだ場合
ゼネラルコールアドレスアクノリッジを許可します。
[bit1] INTE: 転送完了割込み許可ビット
このビットは転送完了割込みを許可または禁止します。
このビットと IBCR1n:INT ビットがともに "1" のとき , 転送完了割込み要求が発生します。
説明
bit1
"0" を書き込んだ場合
転送完了割込みを禁止します。
"1" を書き込んだ場合
転送完了割込みを許可します。
[bit0] INT: 転送完了割込み要求フラグビット
このビットは転送完了を検出します。
このビットと INTE ビットがともに "1" のとき , 転送完了割込み要求が発生します。
このビットは , 以下の 4 つのいずれかの条件で , 1 バイトのアドレス / データ転送が完了 ( アクノ
リッジを含むかどうかは INTS ビットの設定に依存する ) した場合に "1" になります。
• バスマスタモードの場合
• スレーブとしてアドレッシングされている場合
• ゼネラルコールアドレスを受信している場合
• アービトレーションロストを検出している場合
このビットは以下の条件で "0" になります。
• このビットに "0" を書き込んだ場合
• マスタモードで , 繰返しスタート条件 (IBCR1n:SCC = 1) もしくはストップ条件 (IBCR1n:MSS = 0)
が発生した場合
このビットに "1" を書き込んでも動作に影響はありません。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
このビットが "1" のとき , SCLn ラインは "L" を保持します。
このビットに "0" を書き込んでクリアすると ( 値が "0" になります ), SCLn ラインは開放されて次の
バイトデータ送信が可能となります。
説明
bit0
"0" が読み出された場合
データ転送がまだ完了していないことを示します。
"1" が読み出された場合
1 バイトデータ ( アクノリッジを含む ) の転送が完了していることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
( 注意事項 )
• このビットが "0" のときに IBCR1n:SCC に "1" が書き込まれた場合 , IBCR1n:SCC ビットが優先
されてスタート条件が発生します。
• このビットが "0" のときに IBCR1n:MSS に "0" が書き込まれた場合 , IBCR1n:MSS ビットが優
先されてストップ条件が発生します。
• データ受信時に IBCR0n:INTS が "1" の場合 , このビットは 1 バイトデータ転送完了後 ( アクノ
リッジを含みません ) に "1" になります。それ以外の場合 , このビットはアクノリッジを含む
1 バイトのデータ / アドレス送受信完了後に "1" になります。
402
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.7 レジスタ
Ha rdware
Manual
I
<注意事項>
• 割込み要求フラグビット (IBCR1n:BER) に "0" を書き込んでクリアするとき , 割込み
要求許可ビット (IBCR1n:BEIE) を同時に書き換えないでください。
• BER ビット と BEIE ビットを除く IBCR1n レジスタ のすべてのビットは , I2C バスイ
ンタフェースの動作禁止 (ICCRn:EN = 0) により , "0" にクリアされます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
403
第 23 章 I2C バスインタフェース
23.7 レジスタ
H ard war e
23.7.3
Ma nu al
I2C バスステータスレジスタ ch. n (IBSRn)
I2C バスステータスレジスタ ch. n (IBSRn) は I2C バスインタフェースのステータス
を示します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
BB
RSC
—
LRB
TRX
AAS
GCA
FBT
属性
R
R
—
R
R
R
R
R
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] BB: バスビジービット
このビットはバスの状態を示します。
bit7
説明
"0" が読み出された場合
ストップ条件が検出され , バスはアイドル状態になったことを示します。
"1" が読み出された場合
スタート条件が検出され , バスはビジー状態になったことを示します。
[bit6] RSC: 繰返しスタート条件検出ビット
このビットは繰返しスタート条件を検出します。
このビットは , 繰返しスタート条件が検出された場合に "1" になります。
このビットは以下の条件で "0" になります。
• IBCR1n:INT ビットに "0" を書き込んだ場合
• スレーブモードでスレーブアドレスが IAARn の設定アドレスと一致しない場合
• スレーブモードでスレーブアドレスが IAARn の設定アドレスと一致するが , IBCR0n:AACKX ビッ
トが "1" である場合
• スレーブモードでデバイスはゼネラルコールアドレスを受信したが , IBCR1n:GACKE ビットが "0" で
ある場合
• ストップ条件が検出された場合
bit6
説明
"0" が読み出された場合
繰返しスタート条件がまだ検出されていないことを示します。
"1" が読み出された場合
バス使用中に繰返しスタート条件が検出されていることを示します。
[bit5] 未定義ビット
読出し値は常に "0" です。このビットに値を書き込んでも動作に影響はありません。
404
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.7 レジスタ
Ha rdware
Manual
[bit4] LRB: アクノリッジ格納ビット
このビットは , データバイト転送時に , 9 番目のシフトクロックで SDAn ラインの値を取り込みま
す。
このビットは , アクノリッジが未検出のとき (SDAn = "H") に "1" になります。
このビットは以下の条件で "0" になります。
• アクノリッジを検出 (SDAn = "L") した場合
• スタート条件またはストップ条件を検出した場合
説明
bit4
"0" が読み出された場合
アクノリッジが 9 番目のシフトクロックで検出されていることを示します。
"1" が読み出された場合
アクノリッジが 9 番目のシフトクロックで検出されていないことを示します。
( 注意事項 ) 上記のことから , このビットの読出しはアクノリッジの後に行う必要があります (9 番
目の SCLn サイクルにおける転送完了割込みで値を読み出してください )。そのため ,
IBCR0n:INTS ビットが "1" のときにアクノリッジを読み出す場合は , 9 番目の SCLn サ
イクルで再度転送完了割込みが発生するように , 8 番目の SCLn サイクルにおける転送
完了割込み中に , IBCR0n:INTS ビットに "0" を書き込んでください。
[bit3] TRX: データ転送状態ビット
このビットはデータ転送モードを示します。
このビットは , 送信モードでデータ転送が行われた場合に "1" になります。
このビットは以下の条件で "0" になります。
• 受信モードでデータ転送が行われた場合
• デバイスはスレーブ送信モードで NACK を受信した場合
説明
bit3
"0" が読み出された場合
データ転送モードが受信モードであることを示します。
"1" が読み出された場合
データ転送モードが送信モードであることを示します。
[bit2] AAS: アドレッシング検出ビット
このビットはスレーブモードで MCU がアドレッシングされているかどうかを示します。
このビットは , スレーブモードで MCU がアドレッシングされた場合に "1" になります。
このビットは , スタート条件またはストップ条件が検出された場合に "0" になります。
説明
bit2
"0" が読み出された場合
スレーブモードで MCU がアドレッシングされていないことを示します。
"1" が読み出された場合
スレーブモードで MCU がアドレッシングされていることを示します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
405
第 23 章 I2C バスインタフェース
23.7 レジスタ
H ard war e
Ma nu al
[bit1] GCA: ゼネラルコールアドレス検出ビット
このビットはゼネラルコールアドレスを検出します。
このビットは以下の条件で "1" になります。
• デバイスはスレーブモードでゼネラルコールアドレス (0x00) を受信した場合
• IBCR1n:GACKE=1 のとき , デバイスはマスタモードでゼネラルコールアドレス (0x00) を受信した
場合
• マスタモードで , 2 バイト目のゼネラルコールアドレス送信中に , アービトレーションロストが検
出された場合
このビットは以下の条件で "0" になります。
• スタート条件またはストップ条件が検出された場合
• マスタモードで , 2 バイト目のゼネラルコールアドレス送信中に , アービトレーションロストが検
出されなかった場合
bit1
説明
"0" が読み出された場合
スレーブモードでゼネラルコールアドレス (0x00) の受信がないことを示します。
"1" が読み出された場合
スレーブモードでゼネラルコールアドレス (0x00) の受信があることを示します。
[bit0] FBT: 第 1 バイト検出ビット
このビットは第 1 バイトを検出します。
このビットは , スタート条件が検出された場合に "1" になります。
このビットは以下の条件で "0" になります。
• IBCR1n:INT ビットに "0" を書き込んだ場合
• スレーブモードでスレーブアドレスが IAARn レジスタの設定アドレスと一致しない場合
• スレーブモードでスレーブアドレスが IAARn レジスタの設定アドレスと一致するが , IBCR0n:
AACKX ビットが "1" である場合
• スレーブモードでデバイスはゼネラルコールアドレスを受信したが , IBCR1n:GACKE ビットが "0" で
ある場合
• スレーブモードでストップ条件が検出された場合
bit0
406
説明
"0" が読み出された場合
データ受信時に受信データが第 1 バイトではないことを示します。
"1" が読み出された場合
データ受信時に受信データが第 1 バイト ( アドレス ) であることを示します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.7 レジスタ
Ha rdware
23.7.4
Manual
I2C データレジスタ ch. n (IDDRn)
I2C データレジスタch. n (IDDRn) レジスタは, 送信データ / アドレスの設定および受
信データ / アドレスの保持を行います。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
D7
D6
D5
D4
D3
D2
D1
D0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
送信モード時 , レジスタに書かれたデータ / アドレスが MSB ビットから SDAn ライン
にビットごとにシフトされます。このレジスタの書込み側はダブルバッファになって
おり , バスが使用中 (IBSRn:BB = 1) の場合 , 書込みデータは , 現在のデータ転送完了割
込みのクリア時 (IBCR1n:INT ビットへの "0" の書込み ) または繰返しスタート条件発
生時 (IBCR1n:SCC ビットへの "1" 書込み ) に , 8 ビットのシフトレジスタにロードされ
ます。シフトレジスタのデータはビットごとに SDAn ラインにシフト出力されます。
なお , このレジスタへの書込みは現在のデータ転送には影響がありません。ただし , ス
レーブモード時は , アドレスの確定後にシフトレジスタへデータが転送されます。
転送終了割込みの間 (IBCR1n:INT = 1), 受信データ / アドレスをこのレジスタから読み
出せます。ただし , 読出し時はシリアル転送用のレジスタを直接読み出すため , 受信
データは IBCR1n:INT = 1 の場合のみ有効です。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
407
第 23 章 I2C バスインタフェース
23.7 レジスタ
H ard war e
23.7.5
Ma nu al
I2C アドレスレジスタ ch. n (IAARn)
I2C アドレスレジスタ ch. n (IAARn) はスレーブアドレスを設定します。
スレーブアドレスの設定に使用されます。スレーブモード時に , マスタからのアドレ
スデータの受信後 , IAARn レジスタの値との比較判定に使用されます。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
A6
A5
A4
A3
A2
A1
A0
属性
—
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] 未定義ビット
読出し値は常に "0" です。このビットに値を書き込んでも動作に影響はありません。
[bit6:0] A[6:0]: アドレスビット
これらのビットはスレーブアドレスを設定します。
408
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.7 レジスタ
Ha rdware
23.7.6
Manual
I2C クロック制御レジスタ ch. n (ICCRn)
I2C クロック制御レジスタ ch. n (ICCRn) は , I2C 動作の許可とシフトクロック周波数
の選択を行います。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
DMBP
予約
EN
CS4
CS3
CS2
CS1
CS0
属性
R/W
W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] DMBP: 分周器 m バイパスビット
このビットはシフトクロック周波数を発生させるための分周器 m のバイパスに使用されます。
このビットに "0" が書き込まれた場合 , CS[4:3] で選択された値が分周器 m の値になります (m =
ICCRn:CS[4:3]) 。
このビットに "1" が書き込まれた場合 , 分周器 m はバイパスされます。
分周器 n = 4 (ICCRn:CS[2:0] = 0b000) のとき , このビットに "1" を書き込まないでください。
説明
bit7
"0" を書き込んだ場合
ICCRn:CS[4:3]( 分周器 m) の設定が有効になります。
"1" を書き込んだ場合
ICCRn:CS[4:3]( 分周器 m) の設定が無効になります。
[bit6] 予約ビット
このビットは常に "0" に設定してください。
[bit5] EN: I2C バスインタフェース動作許可ビット
このビットは I2C バスインタフェースの動作を許可または禁止します。
このビットに "0" が書き込まれた場合 , I2C バスインタフェースの動作が禁止され , 以下のビットが
"0" にクリアされます。
• IBCR0n レジスタの AACKX, INTS および WUE ビット
• IBCR1n レジスタの BER および BEIE ビットを除くすべてのビット
• IBSRn レジスタのすべてのビット
このビットに "1" が書き込まれた場合 , I2C バスインタフェースの動作が許可されます。
説明
bit5
2
"0" を書き込んだ場合
I C バスインタフェースの動作を禁止します。
"1" を書き込んだ場合
I2C バスインタフェースの動作を許可します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
409
第 23 章 I2C バスインタフェース
23.7 レジスタ
H ard war e
Ma nu al
[bit4:3] CS[4:3]: クロック -1 選択ビット ( 分周器 m)
[bit2:0] CS[2:0]: クロック -2 選択ビット ( 分周器 n)
これらのビットは , シフトクロックの周波数を設定します。
シフトクロック周波数 (Fsck) は次式のように設定されます。

Fsck = --------------------------m  n + 2
 はマシンクロックの周波数 (MCLK) です。
説明
bit4:3
"00" を書き込んだ場合
5
"01" を書き込んだ場合
6
"10" を書き込んだ場合
7
"11" を書き込んだ場合
8
説明
bit2:0
"000" を書き込んだ場合
4
"001" を書き込んだ場合
8
"010" を書き込んだ場合
22
"011" を書き込んだ場合
38
"100" を書き込んだ場合
98
"101" を書き込んだ場合
128
"110" を書き込んだ場合
256
"111" を書き込んだ場合
512
<注意事項>
スタンバイモードウェイクアップ機能を使用しない場合 , MCU をストップモード / 時計
モードに遷移させる前に , I2C バスインタフェース の動作を禁止してください。
410
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 23 章 I2C バスインタフェース
23.8 使用上の注意
Ha rdware
23.8
Manual
使用上の注意
I2C バスインタフェース使用上の注意を示します。
■ I2C バスインタフェース使用上の注意
● I2C バスインタフェースのレジスタの設定時の注意
• I2C バス制御レジスタ ch. n (IBCR0n, IBCR1n) を設定する前に , I2C バスインタ
フェースの動作を許可してください (ICCRn:EN)。
• マスタ / スレーブ選択ビット (IBCR1n:MSS) を設定する ("1" を書き込む ) と , 転送が
開始されます。
● シフトクロック周波数を設定する場合の注意
• Fsck 計算式を使用して , 分周器 m, 分周器 n および DMBP ビット の値を決めること
により , シフトクロック周波数を計算できます。
Fsck 計算式について ,「23.7.6 I2C ク
ロック制御レジスタ ch. n (ICCRn)」
を参照してください。
• 分周器 n の値が "4" (ICCRn:CS[2:0] = 0b000) の場合は , DMBP を " 1" に書き込まない
でください。
● 同時書込み時の優先度の注意
• 次バイト転送とストップ条件の競合
IBCR1n:INT をクリアすると同時に IBCR1n:MSS に "0" を書き込むと , MSS ビットが
優先されてストップ条件が発生します。
• 次バイト転送とスタート条件の競合
IBCR1n:INT をクリアすると同時に IBCR1n:SCC に "1" を書き込むと , SCC ビットが
優先されてスタート条件が発生します。
● ソフトウェアによる設定の注意
• 繰返しスタート条件 (IBCR1n:SCC = 1) とスレーブモード (IBCR1n:MSS = 0) を同時
に選択しないでください。
• 割込み要求フラグビット (IBCR1n:BER/INT) が "1" で , 割込み要求 (IBCR1n:BEIE /
INTE = 1) が許可されたとき , 割込み処理から復帰できません。割込み処理から復帰
するには , 必ず先に IBCR1n:BER/INT ビットを "0" にクリアしてください。
• I2C バスインタフェースの動作が禁止された場合 (ICCRn:EN = 0), 以下のビットが
"0" にクリアされます。
- IBCR0n レジスタの AACKX, INTS および WUE ビット
- IBCR1n レジスタの BER および BEIE ビットを除くすべてのビット
- IBSRn レジスタのすべてのビット
● データアクノリッジに対する注意
スレーブモードでは , データアクノリッジは以下の条件で発生します。
- 受信アドレスがアドレスレジスタ (IAARn) の値と一致し , IBCR0n:AACKX = 0 の
場合
- ゼネラルコールアドレス (0x00) が受信され , IBCR1n:GACKE = 1 の場合
April 4, 2014, MB95F718M_MN702-00014-3v0-J
411
第 23 章 I2C バスインタフェース
23.8 使用上の注意
H ard war e
Ma nu al
● 転送完了タイミング選択時の注意
• データ受信時の転送完了フラグ(INT)タイミング選択ビット (IBCR0n:INTS) は, デー
タ受信時 (IBSRn:TRX = 0 かつ IBSRn:FBT = 0) のみ有効です。
• データ受信時以外 (IBSRn:TRX = 1 か IBSRn:FBT = 1) では , 転送完了割込み要求
(IBCR1n: INT = 1) は常に 9 番目の SCLn サイクルで発生します。
• データアクノリッジが受信データの内容に依存する場合 (SM バスで使われるパケッ
トエラーチェッキングなど ), IBCR0n:INTS ビットに "1" を書き込む ( 例えば前の転
送完了割込みにて ) ことで最新の受信データを読み出せるようにした上で , データ
アクノリッジ許可ビット(IBCR1n:DACKE) の設定によりデータアクノリッジを制御
してください。
• 最新のデータアクノリッジ (IBSRn:LRB) の読出しは , アクノリッジ受信後に行えま
す (IBSRn:LRB の読出しは , 9 番目の SCLn サイクルにおける転送終了割込みで行わ
れる必要があります ) 。
そのため , INTS ビットが "1" のときにアクノリッジを読み出
す場合は , 9 番目の SCLn サイクルで , 再度転送終了割込みが発生するように , 8 番
目の SCLn サイクルによる転送終了割込み中に , INTS ビットに "0" を書き込んでく
ださい。
● MCU スタンバイモードウェイクアップ機能使用上の注意
• MCU をストップモード / 時計モードに入れる直前に , IBCR0n:WUE ビット を "1" に
設定してください。また , MCU がストップモード / 時計モードからウェイクアップ
した後 , I2C バスインタフェースの動作を直ちに再開できるように WUE ビット をク
リア ("0" の書込み ) してください。
• ウェイクアップ割込み要求が発生された後 , MCU は発振安定待ち時間の経過後に
ウェイクアップします。
したがって , ウェイクアップ直後のデータの取逃しを避け
2
るため, I C 送信開始 (SDAn の立下りエッジ検出)によるウェイクアップから 100 s
( 最小の発振安定待ち時間が 100 s と仮定した場合 ) 以降に , SCLn が最初のサイク
ルとして立ち上り , 第 1 ビットがデータとして送信されるようにシステムを設計し
てください。
• MCU スタンバイモードで , 本 I2C バスインタフェースのステータスフラグ , ステー
トマシンおよび I2C バス出力は, スタンバイモードに入る直前の状態を保持します。
I2C バスシステム全体のハングアップを避けるため , スタンバイモードに入れる前
に , IBSRn:BB = 0 となっていることを確認してください。
• ウェイクアップ機能は , IBSRn:BB = 1 における MCU のストップ モード / 時計モード
への遷移をサポートしません。
IBSRn:BB = 1 で MCU がストップモード / 時計モード
へ遷移した場合 , スタート条件が検出された段階でバスエラーが発生します。
• I2C バスインタフェースの動作を確実に行うため , I2C のウェイクアップ機能かほか
の周辺機能を使ったウェイクアップ機能 ( 外部割込みなど ) にかかわらず , ストップ
モード / 時計モードから MCU がウェイクアップした後 , WUE ビットを "0" にクリ
アしてください。
412
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 24 章
LCD コントローラ
(MB95710L シリーズ )
LCD コントローラ (LCDC) の機能と動作について
説明します。
24.1 概要
24.2 構成
24.3 端子
24.4 ディスプレイ RAM
24.5 割込み
24.6 動作説明
24.7 レジスタ
24.8 使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
413
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.1 概要
H ard war e
24.1
Ma nu al
概要
LCD コントローラには , 8 COM モードと 4 COM モードがあります。
8 COM モードでは , LCD コントローラは 36 バイトの表示データメモリを使用でき ,
8 本のコモン出力と 36 本のセグメント出力によって LCD 表示を制御します。また ,
LCD パネル ( 液晶表示器 ) を駆動するためのバイアス出力を 2 種類持っています。
4 COM モードでは , LCD コントローラは 20 バイトの表示データメモリを使用でき ,
4 本のコモン出力と 40 本のセグメント出力によって LCD 表示の制御を行います。ま
た , LCD パネルを駆動するためのバイアス出力を 3 種類持っています。
■ LCD コントローラの機能
LCD コントローラは , セグメント出力とコモン出力によって , 表示データメモリ ( ディ
スプレイ RAM) の内容を LCD パネルに直接表示します。
•
ソフトウェアで 8 COM モードまたは 4 COM モードを選択します。
•
LCD 駆動電圧分割抵抗を内蔵しており , 10 k から 100 kの範囲のレジスタ値を
ソフトウェアによって選択できます。代わりに外部分割抵抗も使用できます。
•
8 COM モードでは , 8 本のコモン出力 (COM0 ~ COM7) と 36 本のセグメント出力
(SEG00 ~ SEG35) を使用できます。
•
4 COM モードでは , 4 本のコモン出力 (COM0 ~ COM3) と 40 本のセグメント出力
(SEG00 ~ SEG39) を使用できます。
•
ディスプレイ RAM サイズは , 8 COM モードでは , 36 バイト (36  8 ビット ) で , 4
COM モードでは , 20 バイト (40  4 ビット ) です。
•
動作クロックとして , メインクロックまたはサブクロックを使用できます。
•
ブリンキング ( 点滅 ) 機能があります ( 端子制限あり )。
•
LCD パネルを直接駆動できます。
•
8 COM モードでは , バイアスは , 1/3 または 1/4 から選択できます。
•
4 COM モードでは , デューティは , 1/2, 1/3, または 1/4 から選択できます。( バイア
スの設定によって制限されます ) 。
•
割込みイベントは , LCD モジュールフレーム周波数と同期します。
表 24.1-1 に , 使用できるバイアス・デューティの組合せを示します。
表 24.1-1 バイアス・デューディの組合せ表
デューディ
1/2 バイアス
1/3 バイアス
1/4 バイアス
1/2
○
X
X
1/3
X
○
X
1/4
X
○
X
1/8, BLS8 = 0
X
○
X
1/8, BLS8 = 1
X
X
○
○ : 推奨組合せ
X : 使用禁止の組合せ
414
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.2 構成
Ha rdware
24.2
Manual
構成
LCD コントローラは , 以下のブロックで構成されており , 機能的にはディスプレイ
RAM の内容に従って , セグメント信号とコモン信号を発生するコントローラ部と ,
LCD を駆動するためのドライバ部に分けられます。
コントローラ部
• LCDC 制御レジスタ (LCDCC1 と LCDCC2)
• LCDC 許可レジスタ (LCDCE1 ~ LCDCE7)
• LCDC ブリンキング設定レジスタ (LCDCB1 と LCDCB2)
• ディスプレイ RAM
• クロック選択
• タイミング制御
ドライブ部
• 交流波形発生回路
• コモンドライバ
• セグメントドライバ
• 分割抵抗
■ LCD コントローラのブロックダイヤグラム
図 24.2-1 LCD コントローラのブロックダイヤグラム (8 COM モード )
LCDC制御レジスタ
(LCDCC1, LCDCC2)
LCDC許可レジスタ
(LCDCE1~LCDCE7)
LCDCブリンキング設定レジスタ
(LCDCB1, LCDCB2)
内部分割抵抗
クロック選択
タイミング制御
サブクロック
ディスプレイRAM:
36 × 8ビット
(36バイト)
コントローラ部
April 4, 2014, MB95F718M_MN702-00014-3v0-J
交流波形生成回路
内部バス
メインクロック
コモン
ドライバ
COM0
:
COM7
セグメント
ドライバ
SEG00
:
SEG35
ドライバ部
415
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.2 構成
H ard war e
Ma nu al
図 24.2-2 LCD コントローラのブロックダイヤグラム (4 COM モード )
LCDC制御レジスタ
(LCDCC1, LCDCC2)
LCDC許可レジスタ
(LCDCE1~LCDCE7)
LCDCブリンキング設定レジスタ
(LCDCB1, LCDCB2)
内部分割抵抗
クロック選択
交流波形生成回路
内部バス
メインクロック
タイミング制御
サブクロック
ディスプレイRAM:
40 × 4ビット
(20バイト)
コントローラ部
コモン
ドライバ
COM0
:
COM3
セグメント
ドライバ
SEG00
:
SEG39
ドライバ部
● LCDC 制御レジスタ 1 (LCDCC1)
フレーム周期発生用クロックの選択 , 表示モードの選択 , フレーム周期クロックの選択
および LCD 駆動電源制御を行います。
● LCDC 制御レジスタ 2 (LCDCC2)
割込みを有効または無効にしたり , 割込みの状態を示したりするレジスタです。下記の
パラメータを設定します。
- 内部抵抗値 (10 k または 100 k)
- 8 COM モードで使用するバイアス (1/3 または 1/4)
- 表示データまたはブランク画面
- 反転表示
● LCDC 許可レジスタ 1 ~ 7 (LCDCE1 ~ LCDCE7)
ポート入力制御 , ブリンク間隔選択および端子制御を行います。
● LCDC ブリンキング設定レジスタ 1 (LCDCB1), LCDC ブリンキング設定レジスタ 2
(LCDCB2)
ブリンキングのオン / オフを設定します。
416
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.2 構成
Ha rdware
Manual
● ディスプレイ RAM
8 COM モードでは , セグメント出力信号発生用の 36  8 ビットの RAM です。
4 COM モードでは , セグメント出力信号発生用の 40  4 ビットの RAM です。
RAM の内容は , コモン信号の選択タイミングに同期して自動的に読み出されてセグメ
ント出力端子より出力されます。
VRAM の内容は , ディスプレイ RAM への書換えと同時にセグメント出力端子より出
力されます。
● クロック選択
2 種類のクロックから生成される 8 種類の周波数から選択された設定によって , フレー
ム周波数を発生します。
● タイミング制御
フレーム周波数と各レジスタの設定をもとに , コモン信号とセグメント信号の制御を
行います。
● 交流波形生成回路
タイミング制御の信号から , LCD を駆動するための交流波形を生成します。
● コモンドライバ
LCD のコモン端子 (COM) のドライバです。
● セグメントドライバ
LCD のセグメント端子 (SEG) のドライバです。
● 分割抵抗
LCD 駆動電圧を発生させるための抵抗です。LCDC ドライバ電源端子 (V0 ~ V4) が分
割抵抗接続端子として機能している場合は , 分割抵抗を外付けすることもできます。
■ LCD コントローラの電源電圧
LCD ドライバの電源電圧は , 内蔵の分割抵抗を使用するかまたは V0 ~ V4 端子に分割
抵抗を接続することにより生成されます。
■ 入力クロック
LCD コントローラは , タイムベースタイマの出力クロックまたは時計プリスケーラの
出力クロックを入力クロック ( 動作クロック ) として使用します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
417
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.2 構成
H ard war e
24.2.1
Ma nu al
LCD コントローラの内部分割抵抗
LCD ドライバの電源電圧は , 内部分割抵抗によって生成されます。
■ 内部分割抵抗
本シリーズには , 内部分割抵抗が内蔵されています。また , LCD 駆動用電源端子 (V0 ~
V4) に外部分割抵抗を接続することもできます。
内部分割抵抗と外部分割抵抗の選択は , LCDC 制御レジスタ 1 の駆動電源制御ビット
(LCDCC1:VSEL) で行います。VSEL ビットを "1" にすることにより内部分割抵抗が通
電状態になります。外部分割抵抗を使用せずに内部分割抵抗のみを使用するためには ,
LCDC 許可レジスタ 1 (LCDCE1) 内の VE3 ビットを "1" に設定してください ( 内部分割
抵抗を使用する場合 , V4 端子を汎用 I/O ポートとして使用できません )。
LCD コントローラは , LCD 動作停止 (LCDCC1:MS[2:0] = 0b000) , メインストップモー
ド, および時計モードでの動作を禁止 (LCDCC1:LCDEN = 0) した状態で, メインストッ
プモード , および時計モード (STBC:TMD = 1) に遷移したときに停止します。
図 24.2-3 に , 内部分割抵抗使用時の等価回路を示します。
418
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.2 構成
Ha rdware
Manual
図 24.2-3 内部分割抵抗使用時の等価回路
VCC
V4
V4
90 kΩ
10 kΩ
V3
V3
バイアス選択信号
90 kΩ
10 kΩ
90 kΩ
10 kΩ
90 kΩ
10 kΩ
V2
V2
V1
V1
V0
V0
LCD許可
N-ch
内部抵抗選択信号
10 kΩまたは100 kΩ
選択信号
V0~V4: V0~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
419
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.2 構成
H ard war e
Ma nu al
■ 内部分割抵抗の使用および輝度調整
内部分割抵抗には 10 k 抵抗と 100 k 抵抗があります。図 24.2-4 に , 内部分割抵抗使
用時の回路を示します。
内部分割抵抗を使用して輝度があがらない場合には , 外部 (Vcc ~ V4 端子間 ) に可変抵
抗 (VR) を接続して V4 の電圧を調整してください。図 24.2-5 に VR を V4 端子に接続
することによる輝度調整を示します。
図 24.2-4 内部分割抵抗使用時の回路状態
VCC
VCC
VR
V4
10 kΩ
90 kΩ
90 kΩ
90 kΩ
V3
10 kΩ
10 kΩ
90 kΩ
90 kΩ
V2
V2
10 kΩ
V2
10 kΩ
90 kΩ
10 kΩ
90 kΩ
90 kΩ
V1
V1
10 kΩ
V1
10 kΩ
90 kΩ
10 kΩ
90 kΩ
V0
LCD許可
On
1/4 バイアスを100 kΩ内部抵抗に内部接続した場合
90 kΩ
V0
1/3 バイアスを100 kΩ内部抵抗に内部接続した場合
VCC
10 kΩ
90 kΩ
90 kΩ
90 kΩ
V3
10 kΩ
90 kΩ
90 kΩ
V2
10 kΩ
90 kΩ
90 kΩ
10 kΩ
90 kΩ
1/4 バイアスを10 kΩ内部抵抗に内部接続した場合
V1
V1
10 kΩ
V0
V2
10 kΩ
V1
90 kΩ
V3
10 kΩ
V2
10 kΩ
V4
10 kΩ
V3
90 kΩ
VR
V4
10 kΩ
10 kΩ
VCC
VR
V4
90 kΩ
V0
On
1/2 バイアスを100 kΩ内部抵抗に内部接続した場合
VR
On
LCD許可
On
VCC
420
V3
10 kΩ
90 kΩ
LCD許可
V4
10 kΩ
V3
10 kΩ
VR
V4
10 kΩ
LCD許可
VCC
VR
LCD許可
90 kΩ
V0
On
1/3 バイアスを10 kΩ内部抵抗に内部接続した場合
LCD許可
V0
On
1/2 バイアスを10 kΩ内部抵抗に内部接続した場合
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.2 構成
Ha rdware
Manual
図 24.2-5 VR を V4 端子に接続することによる輝度調節
VCC
VR
V4
V4
R
V3
V3
R
V2
V2
R
V1
V1
R
V0
V0
LCD許可
N-ch
輝度制御
V0~V4: V0~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
421
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.2 構成
H ard war e
24.2.2
Ma nu al
LCD コントローラの外部分割抵抗
本シリーズ は V0 ~ V4 端子に外部分割抵抗を接続できます。
また , Vcc と V4 端子間に可変抵抗を接続することで , 輝度を調整できます。
■ 外部分割抵抗
内部分割抵抗を使用せずに , LCD 駆動用電源端子 (V0 ~ V4) に外部分割抵抗を接続し
て使用できます。図 24.2-6 にバイアス方式に対応した外部分割抵抗の接続を , 表 24.2-1
に LCD 駆動電圧を示します。
図 24.2-6 外部分割抵抗の接続例
VCC
VCC
VCC
VR
VR
V4
VR
V4
V4
R
R
V3
R
V3
V3
R
V2
VLCD
V2
R
VLCD
R
V1
V1
V1
R
R
V0
1/4バイアス
V2
VLCD
R
V0
V0
1/3バイアス
1/2バイアス
表 24.2-1 LCD 駆動電圧の設定
V4
V3
V2
V1
V0
1/2 bias
VLCD
X
1/2 VLCD
X
GND
1/3 bias
VLCD
2/3 VLCD
2/3 VLCD
1/3 VLCD
GND
1/4 bias
VLCD
3/4 VLCD
1/2 VLCD
1/4 VLCD
GND
VLCD : LCD 動作電圧
X
: 外部分割抵抗なし
GND : 接地
422
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.2 構成
Ha rdware
Manual
■ 外部分割抵抗の使用
V0 端子は内部でトランジスタを通して Vss (GND) へ接続されているため , 外部分割抵
抗を使用する場合 , 分割抵抗の Vss 側を V0 端子に接続することにより , LCD コント
ローラ停止時に抵抗へ流れる電流を遮断します。図 24.2-7 に , 外部分割抵抗使用時の
状態を示します。
図 24.2-7 外部分割抵抗の使用
VCC
VR
V4
10 kΩ
RX
90 kΩ
V3
10 kΩ
RX
90 kΩ
V2
10 kΩ
RX
90 kΩ
V1
10 kΩ
RX
90 kΩ
LCD許可(Q1)
V0
On
1. 内部分割抵抗の影響を受けずに外部に分割抵抗を接続するには , LCDC 制御レジス
タ 1 の駆動電圧制御ビット (LCDCC1:VSEL) に "0" を書き込み , 内部分割抵抗全体を
切り離してください。ポートを LCD の駆動用電源端子として設定するためには ,
LCDC 許可レジスタ 1 の V4 ~ V0 選択ビット (LCDCE1:VE[4:0]) に "1" を書き込ん
でください。
2. 内部分割抵抗が切り離された状態で , LCDCC1 レジスタの表示モード選択ビット
(MS[2:0]) に "0b000" 以外の値を書き込むと LCDC 許可トランジスタ (Q1) が "ON" と
なって外部分割抵抗に電流が流れます。
3. MS[2:0] ビットに "0b000" を書き込むと LCDC 許可トランジスタ (Q1) が "OFF" と
なって分割抵抗に電流が流れなくなります。
<注意事項>
外部 RX 抵抗の適切な抵抗値は使用する LCD により異なります。使用する LCD に適する
抵抗値を持つ外部 RX 抵抗を使用してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
423
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.3 端子
H ard war e
24.3
Ma nu al
端子
LCD コントローラの端子について説明します。
■ LCD コントローラの端子
LCD コントローラの端子は , 8 本のコモン出力端子 (COM0 ~ COM7) , 40 本のセグメン
ト出力端子 (SEG00 ~ SEG39) および 5 本の LCD 駆動用電源端子 (V0 ~ V4) です。
LCD 端子として使用する場合は , LCDC 許可レジスタ (LCDCE1 ~ LCDCE7) のその端
子に対応するビットを "1" に設定してください。
汎用入出力ポートと兼用する LCD 端子を汎用入出力ポートとして使用する場合は ,
LCDC 許可レジスタ (LCDCE1 ~ LCDCE7) のその端子に対応するビットを "0" に設定
してから , LCDC 許可レジスタ 1 のポート入力制御ビット (LCDCE1:PICTL) を "1" に設
定してください。
● COM0 ~ COM7 端子
8 COM モードでは , COM0 ~ COM7 端子は , LCD コモン出力端子です。
4 COM モードでは , COM0 ~ COM3 端子は , LCD コモン出力端子です。COM4 ~ COM7
端子は , LCDCE1 ~ LCDCE7 レジスタの設定にかかわらず , 初期設定では汎用入出力
ポートとして機能します。
COM0 ~ COM7 端子は , 汎用入出力ポートと兼用しています。
● SEG00 ~ SEG39 端子
8 COM モードでは , SEG00 ~ SEG35 端子は LCD セグメント出力端子 , SEG36 ~ SEG39
端子は , LCDCE1 ~ LCDCE7 レジスタの設定にかかわらず , 初期設定では汎用入出力
ポートです。
4 COM モードでは , SEG00 ~ SEG39 端子は LCD セグメント出力端子です。
SEG00 ~ SEG39 端子は , 汎用入出力ポートと兼用しています。
● V0 ~ V4 端子
LCD 駆動用電源端子です。
汎用入出力ポートと兼用しています。
424
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.4 ディスプレイ RAM
Ha rdware
Manual
ディスプレイ RAM
24.4
ディスプレイ RAM のサイズは , 8 COM モードと 4 COM モードとでは異なります。
8 COM モードでは , ディスプレイ RAM には , セグメント出力信号発生用の 36  8
ビット (36 バイト ) の表示データメモリがあります。
4 COM モードでは , ディスプレイ RAM には , セグメント出力信号発生用の 40  4
ビット (20 バイト ) の表示データメモリがあります。
■ ディスプレイ RAM と出力端子
ディスプレイ RAM の内容は , コモン信号の選択タイミングで自動的に読み出され同期
して , セグメント出力端子より出力されます。
各ビットの内容が "1" であれば選択電圧に変換 (LCD は表示 ) され , "0" であれば非選
択電圧に変換 (LCD は非表示 ) されて出力されます。
LCD 表示動作は CPU の動作とは非同期で行われるため , ディスプレイ RAM に対して
は任意のタイミングで書込み / 読込みができます。セグメント出力に指定されなかっ
た端子は入出力ポートとして , また , 対応するディスプレイ RAM は通常の RAM とし
て使用できます。表 24.4-1 に , デューティとコモン出力およびディスプレイ RAM の使
用ビットの関係を示します。
図 24.4-1 と図 24.4-2 に , 8 COM モードおよび 4 COM モードにおける , コモン出力およ
びセグメント出力端子へのディスプレイ RAM アドレスの割当てを示します。
表 24.4-1 デューディとコモン出力およびディスプレイ RAM の使用ビットの関係
使用するディスプレイデータビット
デューディ設定値
使用するコモン出力端子
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
1/2
COM0, COM1 (2 本 )
-
-
○
○
-
-
○
○
1/3
COM0 ~ COM2 (3 本 )
-
○
○
○
-
○
○
○
1/4
COM0 ~ COM3 (4 本 )
○
○
○
○
○
○
○
○
1/8
COM0 ~ COM7 (8 本 )
○
○
○
○
○
○
○
○
○ : 使用するビット
-
: 使用しないビット
April 4, 2014, MB95F718M_MN702-00014-3v0-J
425
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.4 ディスプレイ RAM
H ard war e
Ma nu al
図 24.4-1 ディスプレイ RAM およびコモン / セグメント出力端子 (8 COM モード )
RAM アドレス
n
Bit7
n+1 Bit7
n+2 Bit7
n+3 Bit7
n+4 Bit7
Bit6
Bit6
Bit6
Bit6
Bit6
Bit5
Bit5
Bit5
Bit5
Bit5
Bit4
Bit4
Bit4
Bit4
Bit4
Bit3
Bit3
Bit3
Bit3
Bit3
Bit2
Bit2
Bit2
Bit2
Bit2
Bit1
Bit1
Bit1
Bit1
Bit1
Bit0
Bit0
Bit0
Bit0
Bit0
SEG00
SEG01
SEG02
SEG03
SEG04
:
:
:
:
:
:
:
:
:
:
n+30
n+31
n+32
n+33
n+34
n+35
Bit7
Bit7
Bit7
Bit7
Bit7
Bit7
COM7
Bit6
Bit6
Bit6
Bit6
Bit6
Bit6
COM6
Bit5
Bit5
Bit5
Bit5
Bit5
Bit5
COM5
Bit4
Bit4
Bit4
Bit4
Bit4
Bit4
COM4
Bit3
Bit3
Bit3
Bit3
Bit3
Bit3
COM3
Bit2
Bit2
Bit2
Bit2
Bit2
Bit2
COM2
Bit1
Bit1
Bit1
Bit1
Bit1
Bit1
COM1
Bit0
Bit0
Bit0
Bit0
Bit0
Bit0
COM0
SEG30
SEG31
SEG32
SEG33
SEG34
SEG35
1/8 デューティ比で使用される領域と
COM 端子
図 24.4-2 ディスプレイ RAM およびコモン / セグメント出力端子 (4 COM モード )
RAM アドレス
Bit3
n
Bit7
Bit3
n+1
Bit7
Bit3
n+2
Bit7
:
n+17
n+18
n+19
Bit2
Bit6
Bit2
Bit6
Bit2
Bit6
Bit1
Bit5
Bit1
Bit5
Bit1
Bit5
Bit0
Bit4
Bit0
Bit4
Bit0
Bit4
SEG00
SEG01
SEG02
SEG03
SEG04
SEG05
:
:
:
:
:
Bit3
Bit7
Bit3
Bit7
Bit3
Bit7
COM3
Bit2
Bit6
Bit2
Bit6
Bit2
Bit6
COM2
Bit1
Bit5
Bit1
Bit5
Bit1
Bit5
COM1
Bit0
Bit4
Bit0
Bit4
Bit0
Bit4
COM0
SEG34
SEG35
SEG36
SEG37
SEG38
SEG39
1/2 デューティ比で使用される領域と COM 端子
1/3 デューティ比で使用される領域と COM 端子
1/4 デューティ比で使用される領域と COM 端子
<注意事項>
アドレスコラム内の "n" は "0x0FBD" を示します。
426
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.5 割込み
Ha rdware
24.5
Manual
割込み
LCD コントローラは , LCD モジュールフレーム周波数と同期して , 割込みを生成しま
す。
■ LCD コントローラ動作時の割込み
フレーム処理が完了すると , LCD コントローラは , LCDC 割込み要求フラグビット
(LCDCC2:LCDIF) を "1" に設定します。LCDIF ビットが "1" に設定されたとき , すでに
割込み要求が許可されている場合(LCDCC2:LCDIEN = 1), LCDコントローラは, 割込み
コントローラに割込み要求を発行します。割込み要求をクリアするには , 割込みサー
ビスルーチンで , LCDIF ビットに "0" を書き込んでください。
LCD コントローラは , フレーム処理が完了次第 , LCDIEN ビットの値に関係なく , 常に
LCDIF ビットを "1" に設定します。LCDC 割込み要求の発行後 , LCDIF ビットおよび
LCDIEN ビットの両方が "1" に設定されたままの場合 , CPU は , 割込み処理から復帰で
きません。CPU が割込み処理から復帰できるように , LCDC 割込み要求の発行後は , 常
に LCDIF ビットを "0" にクリアしてください。
図 24.5-1 割込みタイミングチャート
第1フレーム
第2フレーム
割込み
COM0
V4
V3
V2
V1
V0
COM1
V4
V3
V2
V1
V0
COM2
.
.
.
COM6
COM7
V4
V3
V2
V1
V0
SEGn
V4
V3
V2
V1
V0
V0~V4: V0~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
427
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
H ard war e
Ma nu al
動作説明
24.6
LCD コントローラの動作を説明します。
図 24.6-1 に , 8 COM モードで LCD 表示を行うために必要な設定を示します。
図 24.6-1 8 COM モードにおける LCD コントローラ設定
LCDCC1
LCDCC2
LCDCE1
LCDCE2
LCDCE3
LCDCE4
LCDCE5
LCDCE6
LCDCE7
LCDCB1
LCDCB2
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
CSS
LCDEN
VSEL
MS2
MS1
MS0
FP1
FP0
○
○
○
1
0/1
0/1
○
○
-
-
RSEL
BLS8
INV
BK
LCDIEN
LCDIF
-
-
○
○
○
○
○
○
PICTL
BLSEL
VE4
VE3
VE2
VE1
VE0
-
○
○
○
○
○
○
○
-
COM7
COM6
COM5
COM4
COM3
COM2
COM1
COM0
○
○
○
○
○
○
○
○
SEG07
SEG06
SEG05
SEG04
SEG03
SEG02
SEG01
SEG00
○
○
○
○
○
○
○
○
SEG15
SEG14
SEG13
SEG12
SEG11
SEG10
SEG09
SEG08
○
○
○
○
○
○
○
○
SEG23
SEG22
SEG21
SEG20
SEG19
SEG18
SEG17
SEG16
○
○
○
○
○
○
○
○
SEG31
SEG30
SEG29
SEG28
SEG27
SEG26
SEG25
SEG24
○
○
○
○
○
○
○
○
SEG39
SEG38
SEG37
SEG36
SEG35
SEG34
SEG33
SEG32
-
-
-
-
○
○
○
○
BLD7
BLD6
BLD5
BLD4
BLD3
BLD2
BLD1
BLD0
○
○
○
○
○
○
○
○
BLD15
BLD14
BLD13
BLD12
BLD11
BLD10
BLD9
BLD8
○
○
○
○
○
○
○
○
ディスプレイ RAM
○
1
0/1
428
:
:
:
:
ディスプレイデータ
使用するビット
使用しないビット
"1" を書き込んでください。
"0" または "1" を書き込んでください。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
Ha rdware
Manual
図 24.6-2 8 COM モードにおける LCD コントローラ設定フロー
レジスタを初期化する。
8 COM モード
動作モードおよび
各端子の機能を選択する。
すべてのコモン/
セグメント出力端子を
使用する?
No
4 COM モード
PICTLを“1”に設定する。
コモン/セグメント出力に使用しない
端子に対応するCOM/SEG
端子選択ビットを“0”に設定する。
Yes
ディスプレイ点滅を行う。
PICTLを“0”に設定する。
No
BKを“0”に設定する。
Yes
BKを“1”に設定する。
BLSELでブリンク間隔を選択する。
BLD[15:0]のブリンキング表示
ビットを設定する。
MS[2:0]を“0b100”, “0b101”, “0b110”または
“0b111”に設定し, LCDを開始する。
•
図 24.6-1 の設定が行われ , 選択したフレーム周期発生用クロックが発振している場
合 , LCD コントローラは , ディスプレイ RAM および LCDC のレジスタの内容に従っ
て , コモン出力端子とセグメント出力端子 (COM0 ~ COM7, SEG00 ~ SEG35) に
LCD パネルの駆動波形を出力します。
•
LCDCE1 ~ LCDCE7 により LCD の出力端子が選択されます。また , コモン / セグメ
ント出力端子として選択されなかった端子は , 汎用入出力ポートと使用されます。
•
LCD 表示動作中であっても , フレーム周期発生用クロックを切り換えられます。た
だし , 切換え時に LCD 表示がちらつくことがあります。LCD 表示のちらつきを防止
するには , ブランキング (LCDCC2:BK = 1) などで表示を一時的に停止させてから ,
フレーム周期発生用クロックを切り換えてください。
•
表示駆動出力は , バイアスおよびデューティの設定によって選択される , 2 フレーム
を交流化した波形です。
•
ブリンク(点滅)機能を使用する場合は, LCDCブリンキング設定レジスタ1(LCDCB1)
と LCDC ブリンキング設定レジスタ 2 (LCDCB2) により対応するビットを "1" (ON)
に設定してください。ブリンキング間隔はLCDC制御レジスタ1 (LCDCE1)のBLSEL
ビットで 2 種類から選択できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
429
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
H ard war e
Ma nu al
図 24.6-3 に , 4 COM モードで LCD 表示を行うために必要な設定を示します。
図 24.6-3 4 COM モードにおける LCD コントローラ設定
LCDCC1
LCDCC2
LCDCE1
LCDCE2
LCDCE3
LCDCE4
LCDCE5
LCDCE6
LCDCE7
LCDCB1
LCDCB2
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
CSS
LCDEN
VSEL
MS2
MS1
MS0
FP1
FP0
○
○
○
0
0/1
0/1
○
○
-
-
RSEL
BLS8
INV
BK
LCDIEN
LCDIF
-
-
○
○
○
○
○
○
PICTL
BLSEL
VE4
VE3
VE2
VE1
VE0
-
○
○
○
○
○
○
○
-
COM7
COM6
COM5
COM4
COM3
COM2
COM1
COM0
-
-
-
-
○
○
○
○
SEG07
SEG06
SEG05
SEG04
SEG03
SEG02
SEG01
SEG00
○
○
○
○
○
○
○
○
SEG15
SEG14
SEG13
SEG12
SEG11
SEG10
SEG09
SEG08
○
○
○
○
○
○
○
○
SEG23
SEG22
SEG21
SEG20
SEG19
SEG18
SEG17
SEG16
○
○
○
○
○
○
○
○
SEG31
SEG30
SEG29
SEG28
SEG27
SEG26
SEG25
SEG24
○
○
○
○
○
○
○
○
SEG39
SEG38
SEG37
SEG36
SEG35
SEG34
SEG33
SEG32
○
○
○
○
○
○
○
○
BLD7
BLD6
BLD5
BLD4
BLD3
BLD2
BLD1
BLD0
○
○
○
○
○
○
○
○
BLD15
BLD14
BLD13
BLD12
BLD11
BLD10
BLD9
BLD8
○
○
○
○
○
○
○
○
ディスプレイ RAM
○
1
0/1
430
:
:
:
:
ディスプレイデータ
使用するビット
使用しないビット
"1" を書き込んでください。
"0" または "1" を書き込んでください。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
Ha rdware
Manual
図 24.6-4 4 COM モードにおける LCD コントローラ設定フロー
レジスタを初期化する。
4 COM モード
動作モードおよび
各端子の機能を選択する。
すべてのコモン/
セグメント出力端子を
使用する?
No
8 COM モード
PICTLを“1”に設定する。
コモン/セグメント出力に使用しない
端子に対応するCOM/SEG
端子選択ビットを“0”に設定する。
Yes
ディスプレイ点滅を行う。
PICTLを“0”に設定する。
No
BKを“0”に設定する。
Yes
BKを“1”に設定する。
BLSELでブリンク間隔を選択する。
BLD[15:0]のブリンキング表示
ビットを設定する。
MS[2:0]を“0b001”, “0b010”または“0b011”
に設定し, LCDを開始する。
•
図 24.6-3 の設定が行われ , 選択したフレーム周期発生用クロックが発振している場
合 , LCD コントローラは , ディスプレイ RAM および LCDC のレジスタの内容に従っ
て , コモン出力端子とセグメント出力端子 (COM0 ~ COM3, SEG00 ~ SEG39) に
LCD パネルの駆動波形を出力します。
•
LCDCE1 ~ LCDCE7 により LCD の出力端子が選択されます。また , コモン / セグメ
ント出力端子として選択されなかった端子は , 汎用入出力ポートと使用されます。
•
LCD 表示動作中であっても , フレーム周期発生用クロックを切り換えられます。た
だし , 切換え時に LCD 表示がちらつくことがあります。LCD 表示のちらつきを防止
するには , ブランキング (LCDCC2:BK = 1) などで表示を一時的に停止させてから ,
フレーム周期発生用クロックを切り換えてください。
•
表示駆動出力は , バイアスおよびデューティの設定によって選択される , 2 フレーム
を交流化した波形です。
•
1/2 デューティの場合の COM2, COM3 端子の出力および 1/3 デューティの場合の
COM3 端子の出力は , 非選択レベルの出力波形または入出力ポートとして使用可能
となります。
•
ブリンク(点滅)機能を使用する場合は, LCDCブリンキング設定レジスタ1(LCDCB1)
と LCDC ブリンキング設定レジスタ 2 (LCDCB2) により対応するビットを "1" (ON)
に設定してください。ブリンキング間隔はLCDC制御レジスタ1 (LCDCE1)のBLSEL
ビットで 2 種類から選択できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
431
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
H ard war e
Ma nu al
<注意事項>
LCD 表示動作中に , 選択したフレーム周期発生用クロックが停止すると , 交流波形生成回
路が停止するため液晶素子に直流電圧が印加されます。この場合あらかじめ LCD 表示動
作を停止しておく必要があります。メインクロック ( タイムベースタイマ ) またはサブク
ロック ( 時計プリスケーラ ) が停止する条件はクロックモードとスタンバイモードとの選
択によります。また , フレーム周期発生用クロック選択ビット (LCDCC1:CSS) の設定に
従い , タイムベースタイマまたは時計プリスケーラがクリアされるとフレーム周期が影響
を受けます。
■ LCD の駆動波形
LCDはその性質上, 直流駆動を行うと液晶表示素子に化学変化が生じ, 液晶表示素子が
劣化してしまいます。このため LCD コントローラ・ドライバは交流波形生成回路を内
蔵し , 2 フレームを交流化した波形で LCD を駆動します。出力波形には以下の 5 種類
があります。
8 COM モード :
•
1/3 バイアス , 1/8 デューティ出力波形
•
1/4 バイアス , 1/8 デューティ出力波形
4 COM モード :
432
•
1/2 バイアス , 1/2 デューティ出力波形
•
1/3 バイアス , 1/3 デューティ出力波形
•
1/3 バイアス , 1/4 デューティ出力波形
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
Ha rdware
24.6.1
Manual
4 COM モードにおける LCD コントローラ動作時の
出力波形 (1/2 バイアス , 1/2 デューティ )
表示駆動出力は , 分割駆動タイプの 2 フレームを交流化した波形です。
4 COM モードでは , 1/2 バイアスおよび 1/2 デューティのときには , COM0 および
COM1 が表示に使用され , COM2 および COM3 は使用されません。
■ 4 COM モード , 1/2 バイアス , 1/2 デューティ出力波形例
表示はコモン出力とセグメント出力の電位差が最大となる液晶素子が "ON" となりま
す。
ディスプレイ RAM の内容が表 24.6-1 のときの出力波形を図 24.6-5 に示されます。
表 24.6-1 ディスプレイ RAM の内容例
セグメント
COM3
ディスプレイ RAM の内容
COM2
COM1
COM0
SEGn
-
-
0
0
SEG(n+1)
-
-
0
1
-: 使用しない
図 24.6-5 4 COM モード , 1/2 バイアス , 1/2 デューティ比出力波形の例
COM0
V4
V3=V2=V1
V0=Vss
COM1
V4
V3=V2=V1
V0=Vss
COM2
V4
V3=V2=V1
V0=Vss
COM3
V4
V3=V2=V1
V0=Vss
SEGn
V4
V3=V2=V1
V0=Vss
SEG(n+1)
V4
V3=V2=V1
V0=Vss
COM0とSEGnとの
電位差
V4(オン)
V3
Vss
-V3
-V4(オン)
COM1とSEGnとの
電位差
V4(オン)
V3
Vss
-V3
-V4(オン)
COM0とSEG(n+1)との
電位差
V4(オン)
V3
Vss
-V3
-V4(オン)
1フレーム
1サイクル
V0~V4: V0~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
433
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
H ard war e
24.6.2
Ma nu al
4 COM モードにおける LCD コントローラ動作時の
出力波形 (1/3 バイアス , 1/3 デューティ )
4 COM モードでは , 1/3 バイアスおよび 1/3 デューティのときには , COM0, COM1,
および COM2 が表示に使用され , COM3 は使用されません。
■ 4 COM モード , 1/3 バイアス , 1/3 デューティ出力波形例
表示はコモン出力とセグメント出力の電位差が最大となる液晶素子が "ON" となりま
す。
ディスプレイ RAM の内容が表 24.6-2 のときの出力波形を図 24.6-6 に示します。
表 24.6-2 ディスプレイ RAM の内容例
セグメント
COM3
ディスプレイ RAM の内容
COM2
COM1
COM0
SEGn
-
1
0
0
SEG(n+1)
-
1
0
1
-: 使用しない
434
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
Ha rdware
Manual
図 24.6-6 4 COM モード , 1/3 バイアス , 1/3 デューティ比出力波形の例
COM0
V4
V3=V2
V1
V0=Vss
COM1
V4
V3=V2
V1
V0=Vss
COM2
V4
V3=V2
V1
V0=Vss
COM3
V4
V3=V2
V1
V0=Vss
SEGn
V4
V3=V2
V1
V0=Vss
SEG(n+1)
V4
V3=V2
V1
V0=Vss
COM0とSEGnとの
電位差 V4(オン)
V3
V1
Vss
-V1
-V3
-V4(オン)
COM1とSEGnとの
電位差
V4(オン)
V3
V1
Vss
-V1
-V3
-V4(オン)
COM2とSEGnとの
電位差
V4(オン)
V3
V1
Vss
-V1
-V3
-V4(オン)
COM0とSEG(n+1)との
電位差
V4(オン)
V3
V1
Vss
-V1
-V3
-V4(オン)
COM1とSEG(n+1)との
電位差
V4(オン)
V3
V1
Vss
-V1
-V3
-V4(オン)
COM2とSEG(n+1)との
電位差
V4(オン)
V3
V1
Vss
-V1
-V3
-V4(オン)
1フレーム
1サイクル
V0~V4: V0~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
435
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
H ard war e
24.6.3
Ma nu al
4 COM モードにおける LCD コントローラ動作時の
出力波形 (1/3 バイアス , 1/4 デューティ )
4 COM モードでは , 1/3 バイアスおよび 1/4 デューティのときには , COM0 ~ COM3
が表示に使用されます。
■ 4 COM モード , 1/3 バイアス , 1/4 デューティ出力波形例
表示はコモン出力とセグメント出力の電位差が最大となる液晶素子が "ON" となりま
す。
ディスプレイ RAM の内容が表 24.6-3 のときの出力波形を図 24.6-7 に示します。
表 24.6-3 ディスプレイ RAM の内容例
セグメント
436
COM3
ディスプレイ RAM の内容
COM2
COM1
COM0
SEGn
0
1
0
0
SEG(n+1)
0
1
0
1
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
Ha rdware
Manual
図 24.6-7 4 COM モード , 1/3 バイアス , 1/4 デューティ比出力波形の例
COM0
V4
V3=V2
V1
V0=Vss
COM1
V4
V3=V2
V1
V0=Vss
COM2
V4
V3=V2
V1
V0=Vss
COM3
V4
V3=V2
V1
V0=Vss
SEGn
V4
V3=V2
V1
V0=Vss
SEG(n+1)
V4
V3=V2
V1
V0=Vss
COM0とSEGnとの
電位差
V4(オン)
V3
V1
Vss
-V3
-V1
-V4(オン)
COM1とSEGnとの
電位差
V4(オン)
V3
V1
Vss
-V3
-V1
-V4(オン)
COM2とSEGnとの
電位差
V4(オン)
V3
V1
Vss
-V3
-V1
-V4(オン)
COM2とSEG(n+1)との
電位差
V4(オン)
V3
V1
Vss
-V3
-V1
-V4(オン)
COM3とSEG(n+1)との
電位差
V4(オン)
V3
V1
Vss
-V3
-V1
-V4(オン)
1フレーム
1サイクル
V0~V4: V0~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
437
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
H ard war e
24.6.4
Ma nu al
8 COM モードにおける LCD コントローラ動作時の
出力波形 (1/3 バイアス , 1/8 デューティ )
8 COM モードでは , 1/3 バイアスおよび 1/8 デューティのときには , COM0 ~ COM7
が表示に使用されます。
■ 8 COM モード , 1/3 バイアス , 1/8 デューティ出力波形例
表示はコモン出力とセグメント出力の電位差が最大となる液晶素子が "ON" となりま
す。
ディスプレイ RAM の内容が表 24.6-4 のときの出力波形を図 24.6-8 に示します。
表 24.6-4 ディスプレイ RAM の内容例
セグメント
SEGn
438
COM7
COM6
0
0
ディスプレイ RAM の内容
COM5
COM4
COM3
COM2
0
0
0
0
COM1
COM0
0
1
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
Ha rdware
Manual
図 24.6-8 8 COM モード , 1/3 バイアス , 1/8 デューティ比出力波形の例
COM0
V4
V3=V2
V1
V0
COM1
V4
V3=V2
V1
V0
COM2
V4
V3=V2
V1
V0
COM3
V4
V3=V2
V1
V0
COM4
V4
V3=V2
V1
V0
COM5
V4
V3=V2
V1
V0
COM6
V4
V3=V2
V1
V0
COM7
V4
V3=V2
V1
V0
SEGn
V4
V3=V2
V1
V0
COM0-SEGn (オン)
V4
V3
V1
V0
-V1
-V3
-V4
COM1-SEGn (オフ)
V4
V3
V1
V0
-V1
-V3
-V4
1フレーム
1サイクル
V0~V4: V0~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
439
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
H ard war e
24.6.5
Ma nu al
8 COM モードにおける LCD コントローラ動作時の
出力波形 (1/4 バイアス , 1/8 デューティ )
8 COM モードでは , 1/4 バイアスおよび 1/8 デューティのときには , COM0 ~ COM7
が表示に使用されます。
■ 8 COM モード , 1/4 バイアス , 1/8 デューティ出力波形例
表示はコモン出力とセグメント出力の電位差が最大となる液晶素子が "ON" となりま
す。
ディスプレイ RAM の内容が表 24.6-5 のときの出力波形を図 24.6-9 に示します。
表 24.6-5 ディスプレイ RAM の内容例
セグメント
SEGn
440
COM7
COM6
0
0
ディスプレイ RAM の内容
COM5
COM4
COM3
COM2
0
0
0
0
COM1
COM0
0
1
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.6 動作説明
Ha rdware
Manual
図 24.6-9 8 COM モード , 1/4 バイアス , 1/8 デューティ比出力波形の例
COM0
V4
V3
V2
V1
V0
COM1
V4
V3
V2
V1
V0
COM2
V4
V3
V2
V1
V0
COM3
V4
V3
V2
V1
V0
COM4
V4
V3
V2
V1
V0
COM5
V4
V3
V2
V1
V0
COM6
V4
V3
V2
V1
V0
COM7
V4
V3
V2
V1
V0
SEGn
V4
V3
V2
V1
V0
V4
V3
V2
V1
V0
-V1
-V2
-V3
-V4
COM0-SEGn (オン)
V4
V3
V2
V1
V0
-V1
-V2
-V3
-V4
COM1-SEGn (オフ)
COM2-SEGn (オフ)
COM3-SEGn (オフ)
COM4-SEGn (オフ)
COM5-SEGn (オフ)
COM6-SEGn (オフ)
COM7-SEGn (オフ)
1フレーム
1サイクル
V0~V4: V0~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
441
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
H ard war e
24.7
Ma nu al
レジスタ
LCD コントローラのレジスタについて説明します。
表 24.7-1 LCD コントローラのレジスタ一覧
レジスタ略称
442
レジスタ名
参照先
LCDCC1
LCDC 制御レジスタ 1
24.7.1
LCDCC2
LCDC 制御レジスタ 2
24.7.2
LCDCE1
LCDC 許可レジスタ 1
24.7.3
LCDCE2
LCDC 許可レジスタ 2
24.7.4
LCDCE3
LCDC 許可レジスタ 3
24.7.5
LCDCE4
LCDC 許可レジスタ 4
24.7.6
LCDCE5
LCDC 許可レジスタ 5
24.7.7
LCDCE6
LCDC 許可レジスタ 6
24.7.8
LCDCE7
LCDC 許可レジスタ 7
24.7.9
LCDCB1
LCDC ブリンキング設定レジスタ 1
24.7.10
LCDCB2
LCDC ブリンキング設定レジスタ 2
24.7.11
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
Ha rdware
24.7.1
Manual
LCDC 制御レジスタ 1 (LCDCC1)
LCDC 制御レジスタ 1 (LCDCC1) はクロックと表示モードを設定し , 電源を制御しま
す。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
CSS
LCDEN
VSEL
MS2
MS1
MS0
FP1
FP0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] CSS: フレーム周期発生用クロック選択ビット
このビットは LCD 表示のフレーム周期を発生するためのクロックを選択します。
LCD コントローラは , このビットが "0" のときメインクロック発振によるタイムベースタイマ出力
で動作し , "1" のときサブクロックにより時計プリスケーラ出力で動作します。
タイムベースタイマ出力で動作中にメインクロックの速度切換え (ギア機能) を行っても , フレーム
周期は影響を受けません。
フレーム周期発生用クロックが切り換わるときに表示がちらつくことがあるため , ブランキング
(LCDCC2:BK=1) などで表示を一時的に停止させてからフレーム周期発生用クロックを切り換えて
ください。
説明
bit7
"0" を書き込んだ場合
LCD 表示のフレーム周期発生用クロックとしてメインクロックを選択します。
"1" を書き込んだ場合
LCD 表示のフレーム周期発生用クロックとしてサブクロックを選択します。
( 注意事項 ) メインストップモードおよびサブクロックモードでは , メインクロックの発振が停止
するため , タイムベースタイマ出力による動作はできません。
[bit6] LCDEN: メインストップ / 時計モード時動作許可ビット
このビットはメインストップモードおよび時計モードの場合に , LCD コントローラに動作を継続さ
せるかどうかを制御します。
説明
bit6
"0" を書き込んだ場合
LCD コントローラを停止します。
"1" を書き込んだ場合
クロックモードがメインストップモードまたは時計モードに遷移した後も LCD
コントローラに動作を継続させます。
( 注意事項 ) メインストップモードまたは時計モード中も LCD コントローラに動作を継続させるに
は , サブクロックを LCD 表示のフレーム周期発生用クロックとして選択してください
(CSS = 1)。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
443
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
H ard war e
Ma nu al
[bit5] VSEL: LCD 駆動電源制御ビット
このビットは内部分割抵抗に通電するかどうかを制御します。
説明
bit5
"0" を書き込んだ場合
内部分割抵抗を遮断します。
"1" を書き込んだ場合
内部分割抵抗を導通します。
( 注意事項 ) 外部分割抵抗を接続する場合 , このビットに "0" を書き込んでください。
[bit4:2] MS[2:0]: 表示モード選択ビット
これらのビットは表示モードを 4 COM モードと 8 COM モードから選択し , 出力波形デューティを
4 種類から選択します。
使用されるコモン端子が選択したデューティ出力モードによって決まります。
これらのビットが "0b000" に設定されたときは , LCD コントローラ・ドライバは表示動作を停止し
ます。
表示モードが切り換わるときに表示がちらつくことがあるため , ブランキング (LCDCC2:BK=1) な
どで表示を一時的に停止させてから表示モードを切り換えてください。
説明
bit4:2
"000" を書き込んだ場合
LCD 表示動作を停止します。
"001" を書き込んだ場合
表示モードとして 4 COM モードを , 出力波形デューティとして 1/2 ( 時間区分番
号 N = 2) をそれぞれ選択します。
"010" を書き込んだ場合
表示モードとして 4 COM モードを , 出力波形デューティとして 1/3 ( 時間区分番
号 N = 3) をそれぞれ選択します。
"011" を書き込んだ場合
表示モードとして 4 COM モードを , 出力波形デューティとして 1/4 ( 時間区分番
号 N = 4) をそれぞれ選択します。
"100" を書き込んだ場合
"101" を書き込んだ場合
"110" を書き込んだ場合
表示モードとして 8 COM モードを , 出力波形デューティとして 1/8 ( 時間区分番
号 N = 8) をそれぞれ選択します。
"111" を書き込んだ場合
( 注意事項 ) クロックモードがストップモードに遷移すると, LCD表示のフレーム周期発生用クロッ
ク ( メインクロックまたはサブクロック ) が停止します。そのため , クロックモードが
ストップモードに遷移する前に , LCD 表示動作を停止 (MS[2:0] = 0b000) してください。
444
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
Ha rdware
Manual
[bit1:0] FP[1:0]: フレーム周期選択ビット
これらのビットは LCD 表示のフレーム周期を選択します。
フレーム周期が切り換わるときに表示がちらつくことがあるため , ブランキング (LCDCC2:BK=1)
などで表示を一時的に停止させてからフレーム周期を切り換えてください。
説明
bit1:0
"00" を書き込んだ場合
メインクロックにより発生されたフ
レーム周期 (LCDCC1:CSS = 0)
(FCH: メインクロック ,
サブクロックにより発生されたフレー
ム周期 (LCDCC1:CSS = 1)
(FCL: サブクロック ,
FCRH: メイン CR クロック )
FCRL: サブ CR クロック )
214  N/FCH*1
26  N/FCL
213  N/FCH*2
26  N/FCRL
213
"01" を書き込んだ場合
 N/FCRH
215  N/FCH*1
27  N/FCL
214  N/FCH*2
27  N/FCRL
214  N/FCRH
"10" を書き込んだ場合
216  N/FCH*1
28  N/FCL
215  N/FCH*2
28  N/FCRL
215  N/FCRH
"11" を書き込んだ場合
217  N/FCH*1
29  N/FCR
216  N/FCH*2
29  N/FCRL
216
 N/FCRH
*1: メインクロックモード
*2: メイン PLL クロックモード
( 注意事項 ) 使用する LCD モジュールに応じて最適フレーム周波数を計算して FP[1:0] ビットを設
定してください。フレーム周期は原発振の周波数の影響を受けます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
445
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
H ard war e
24.7.2
Ma nu al
LCDC 制御レジスタ 2 (LCDCC2)
LCDC 制御レジスタ 2 (LCDCC2) は , 割込みを許可または禁止し , 割込みの状態を示
し , 以下のパラメータを設定します。
• 内部抵抗 (10 k または 100 k)
• 8 COM モードで使用されるバイアス (1/3 または 1/4)
• 表示データまたはブランク画面
• 反転表示
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
RSEL
BLS8
属性
—
—
R/W
R/W
INV
BK
LCDIEN
LCDIF
R/W
R/W
R/W
R/W
初期値
0
0
0
1
0
1
0
0
■ レジスタ機能
[bit7:6] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit5] RSEL: 内部分割抵抗選択ビット
このビットは内部分割抵抗として使用される抵抗を選択します。
説明
bit5
"0" を書き込んだ場合
100 k 抵抗を選択します。
"1" を書き込んだ場合
10 k 抵抗を選択します。
[bit4] BLS8: 8 COM モードバイアス選択ビット
このビットは 8 COM モードでソフトウェアが使用するバイアスの種類を選択します。
説明
bit4
"0" を書き込んだ場合
1/3 バイアスを選択停止します。
"1" を書き込んだ場合
1/4 バイアスを選択停止します。
( 注意事項 ) このビットには , 8 COM モードでも 4 COM モードでもアクセスできますが , 4 COM
モードではこのビットに値を書き込んでも動作に影響はありません。
[bit3] INV: 反転表示制御ビット
このビットは LCD の反転表示を制御します。
説明
bit3
446
"0" を書き込んだ場合
LCD の反転表示を禁止します。
"1" を書き込んだ場合
LCD の反転表示を許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
Ha rdware
Manual
[bit2] BK: 表示ブランキング制御ビット
このビットは表示ブランキングを制御します。
表示ブランキングが選択された場合 (BK = 1) , セグメント出力端子は非選択波形 ( 表示条件となら
ない波形 ) を出力します。
説明
bit2
"0" を書き込んだ場合
LCD に LCD コントローラのディスプレイ RAM を表示させます。
"1" を書き込んだ場合
LCD を非表示にします。
[bit1] LCDIEN: LCDC 割込み要求許可ビット
このビットは LCD フレーム周波数に同期した割込み要求の生成を許可または禁止します。
説明
bit1
"0" を書き込んだ場合
割込み要求の生成を禁止します。
"1" を書き込んだ場合
割込み要求の生成を許可します。
[bit0] LCDIF: LCDC 割込み要求フラグビット
このビットは LCD コントローラがフレーム処理を完了したかどうかを示します。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit0
"0" が読み出された場合
LCD コントローラがフレームを処理中であることを示します。
"1" が読み出された場合
LCD コントローラがフレーム処理を完了したことを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
447
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
H ard war e
24.7.3
Ma nu al
LCDC 許可レジスタ 1 (LCDCE1)
LCDC許可レジスタ1 (LCDCE1)はポート入力を制御し, ブリンク周期を選択し, LCD
コントローラの駆動電源端子を許可します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
PICTL
BLSEL
VE4
VE3
VE2
VE1
VE0
—
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
—
初期値
0
0
1
1
1
1
1
0
■ レジスタ機能
[bit7] PICTL: ポート入力制御ビット
このビットはセグメント / コモン出力端子と兼用する汎用入出力ポートを制御します。
このビットに "0" が書き込まれると , そういう汎用入出力ポートの入出力機能が禁止され , LCD 出
力時の貫通電流が抑えられます。
このビットに "1" が書き込まれると , そういう汎用入出力ポートの入出力機能が許可され , それらの
端子はセグメント / コモン出力端子ではなく , 汎用入出力ポートとして機能します。
説明
bit7
"0" を書き込んだ場合
セグメント / コモン出力端子と兼用する汎用入出力ポートの入出力機能を禁止
します。
"1" を書き込んだ場合
セグメント / コモン出力端子と兼用する汎用入出力ポートの入出力機能を許可
します。
( 注意事項 ) リセットでそういう汎用入出力ポートなどの入力機能は無効になるため , リセット発
生後 , そういう汎用入出力ポートの入力機能を使用する場合は必ずこのビットに "1" を
書き込んでください。そういう汎用入出力ポートは , セグメント / コモン出力端子とし
て使用されるとき , このビットの設定にかかわらず入力機能が禁止されます。
[bit6] BLSEL: ブリンク間隔選択ビット
このビットはブリンク可能時のブリンク間隔を選択します。
ブリンクは , LCDC ブリンキング設定レジスタ 1 (LCDCB1) と LCDC ブリンキング設定レジスタ 2
(LCDCB2) により制御されます。
ブリンク間隔が 1.0 s の場合 , LCD は 0.5 s 点灯 , 0.5 s 消灯を行い , ブリンク間隔が 0.5 s の場合 , LCD
は 0.25 s 点灯 , 0.25 s 消灯を行います。
説明
bit6
"0" を書き込んだ場合
0.5 s ( サブクロック周波数が 32 kHz の場合 ) をブリンク間隔として選択します。
"1" を書き込んだ場合
1.0 s ( サブクロック周波数が 32 kHz の場合 ) をブリンク間隔として選択します。
[bit5] VE4: V4 機能選択ビット
このビットは V4 端子の機能を選択します。
bit5
448
説明
"0" を書き込んだ場合
V4 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
V4 端子を LCD 駆動電源端子として機能させます。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
Ha rdware
Manual
[bit4] VE3: V3 機能選択ビット
このビットは V3 端子の機能を選択します。
説明
bit4
"0" を書き込んだ場合
V3 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
V3 端子を LCD 駆動電源端子として機能させます。
[bit3] VE2: V2 機能選択ビット
このビットは V2 端子の機能を選択します。
説明
bit3
"0" を書き込んだ場合
V2 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
V2 端子を LCD 駆動電源端子として機能させます。
[bit2] VE1: V1 機能選択ビット
このビットは V1 端子の機能を選択します。
説明
bit2
"0" を書き込んだ場合
V1 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
V1 端子を LCD 駆動電源端子として機能させます。
[bit1] VE0: V0 機能選択ビット
このビットは V0 端子の機能を選択します。
説明
bit1
"0" を書き込んだ場合
V0 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
V0 端子を LCD 駆動電源端子として機能させます。
[bit0] 未定義ビット
読出し値は常に "0" です。このビットに値を書き込んでも動作に影響はありません。
<注意事項>
内部分割抵抗を使用する場合 , V4 端子が汎用入出力ポートとして使用できないため , VE4
ビットに "1" を書き込んで , V4 端子を LCD 駆動電源端子として機能させてください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
449
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
H ard war e
24.7.4
Ma nu al
LCDC 許可レジスタ 2 (LCDCE2)
LCDC 許可レジスタ 2 (LCDCE2) は COM0 ~ COM7 端子の機能を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
COM7
COM6
COM5
COM4
COM3
COM2
COM1
COM0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] COM7: COM7 機能選択ビット
このビットは COM7 端子の機能を選択します。
説明
bit7
"0" を書き込んだ場合
COM7 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM7 端子をコモン出力端子として機能させます。
( 注意事項 ) 4 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
[bit6] COM6: COM6 機能選択ビット
このビットは COM6 端子の機能を選択します。
説明
bit6
"0" を書き込んだ場合
COM6 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM6 端子をコモン出力端子として機能させます。
( 注意事項 ) 4 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
[bit5] COM5: COM5 機能選択ビット
このビットは COM5 端子の機能を選択します。
説明
bit5
"0" を書き込んだ場合
COM5 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM5 端子をコモン出力端子として機能させます。
( 注意事項 ) 4 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
[bit4] COM4: COM4 機能選択ビット
このビットは COM4 端子の機能を選択します。
bit4
説明
"0" を書き込んだ場合
COM4 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM4 端子をコモン出力端子として機能させます。
( 注意事項 ) 4 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
450
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
Ha rdware
Manual
[bit3] COM3: COM3 機能選択ビット
このビットは COM3 端子の機能を選択します。
説明
bit3
"0" を書き込んだ場合
COM3 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM3 端子をコモン出力端子として機能させます。
[bit2] COM2: COM2 機能選択ビット
このビットは COM2 端子の機能を選択します。
説明
bit2
"0" を書き込んだ場合
COM2 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM2 端子をコモン出力端子として機能させます。
[bit1] COM1: COM1 機能選択ビット
このビットは COM1 端子の機能を選択します。
説明
bit1
"0" を書き込んだ場合
COM1 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM1 端子をコモン出力端子として機能させます。
[bit0] COM0: COM0 機能選択ビット
このビットは COM0 端子の機能を選択します。
説明
bit0
"0" を書き込んだ場合
COM0 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM0 端子をコモン出力端子として機能させます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
451
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
H ard war e
24.7.5
Ma nu al
LCDC 許可レジスタ 3 (LCDCE3)
LCDC 許可レジスタ 3 (LCDCE3) は SEG00 ~ SEG07 端子の機能を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
SEG07
SEG06
SEG05
SEG04
SEG03
SEG02
SEG01
SEG00
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] SEG07: SEG07 機能選択ビット
このビットは SEG07 端子の機能を選択します。
説明
bit7
"0" を書き込んだ場合
SEG07 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG07 端子をセグメント出力端子として機能させます。
[bit6] SEG06: SEG06 機能選択ビット
このビットは SEG06 端子の機能を選択します。
説明
bit6
"0" を書き込んだ場合
SEG06 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG06 端子をセグメント出力端子として機能させます。
[bit5] SEG05: SEG05 機能選択ビット
このビットは SEG05 端子の機能を選択します。
説明
bit5
"0" を書き込んだ場合
SEG05 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG05 端子をセグメント出力端子として機能させます。
[bit4] SEG04: SEG04 機能選択ビット
このビットは SEG04 端子の機能を選択します。
説明
bit4
"0" を書き込んだ場合
SEG04 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG04 端子をセグメント出力端子として機能させます。
[bit3] SEG03: SEG03 機能選択ビット
このビットは SEG03 端子の機能を選択します。
bit3
452
説明
"0" を書き込んだ場合
SEG03 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG03 端子をセグメント出力端子として機能させます。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
Ha rdware
Manual
[bit2] SEG02: SEG02 機能選択ビット
このビットは SEG02 端子の機能を選択します。
説明
bit2
"0" を書き込んだ場合
SEG02 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG02 端子をセグメント出力端子として機能させます。
[bit1] SEG01: SEG01 機能選択ビット
このビットは SEG01 端子の機能を選択します。
説明
bit1
"0" を書き込んだ場合
SEG01 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG01 端子をセグメント出力端子として機能させます。
[bit0] SEG00: SEG00 機能選択ビット
このビットは SEG00 端子の機能を選択します。
説明
bit0
"0" を書き込んだ場合
SEG00 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG00 端子をセグメント出力端子として機能させます。
<注意事項>
LCDCE1 レジスタの PICTL ビットが "1" に設定されている場合のみ , LCDCE3 レジスタ
はセグメント出力端子 SEG00 ~ SEG07 を制御できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
453
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
H ard war e
24.7.6
Ma nu al
LCDC 許可レジスタ 4 (LCDCE4)
LCDC 許可レジスタ 4 (LCDCE4) は SEG08 ~ SEG15 端子の機能を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
SEG15
SEG14
SEG13
SEG12
SEG11
SEG10
SEG09
SEG08
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] SEG15: SEG15 機能選択ビット
このビットは SEG15 端子の機能を選択します。
説明
bit7
"0" を書き込んだ場合
SEG15 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG15 端子をセグメント出力端子として機能させます。
[bit6] SEG14: SEG14 機能選択ビット
このビットは SEG14 端子の機能を選択します。
説明
bit6
"0" を書き込んだ場合
SEG14 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG14 端子をセグメント出力端子として機能させます。
[bit5] SEG13: SEG13 機能選択ビット
このビットは SEG13 端子の機能を選択します。
説明
bit5
"0" を書き込んだ場合
SEG13 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG13 端子をセグメント出力端子として機能させます。
[bit4] SEG12: SEG12 機能選択ビット
このビットは SEG12 端子の機能を選択します。
説明
bit4
"0" を書き込んだ場合
SEG12 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG12 端子をセグメント出力端子として機能させます。
[bit3] SEG11: SEG11 機能選択ビット
このビットは SEG11 端子の機能を選択します。
bit3
454
説明
"0" を書き込んだ場合
SEG11 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG11 端子をセグメント出力端子として機能させます。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
Ha rdware
Manual
[bit2] SEG10: SEG10 機能選択ビット
このビットは SEG10 端子の機能を選択します。
説明
bit2
"0" を書き込んだ場合
SEG10 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG10 端子をセグメント出力端子として機能させます。
[bit1] SEG09: SEG09 機能選択ビット
このビットは SEG09 端子の機能を選択します。
説明
bit1
"0" を書き込んだ場合
SEG09 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG09 端子をセグメント出力端子として機能させます。
[bit0] SEG08: SEG08 機能選択ビット
このビットは SEG08 端子の機能を選択します。
説明
bit0
"0" を書き込んだ場合
SEG08 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG08 端子をセグメント出力端子として機能させます。
<注意事項>
LCDCE1 レジスタの PICTL ビットが "1" に設定されている場合のみ , LCDCE4 レジスタ
はセグメント出力端子 SEG08 ~ SEG15 を制御できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
455
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
H ard war e
24.7.7
Ma nu al
LCDC 許可レジスタ 5 (LCDCE5)
LCDC 許可レジスタ 5 (LCDCE5) は SEG16 ~ SEG23 端子の機能を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
SEG23
SEG22
SEG21
SEG20
SEG19
SEG18
SEG17
SEG16
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] SEG23: SEG23 機能選択ビット
このビットは SEG23 端子の機能を選択します。
説明
bit7
"0" を書き込んだ場合
SEG23 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG23 端子をセグメント出力端子として機能させます。
[bit6] SEG22: SEG22 機能選択ビット
このビットは SEG22 端子の機能を選択します。
説明
bit6
"0" を書き込んだ場合
SEG22 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG22 端子をセグメント出力端子として機能させます。
[bit5] SEG21: SEG21 機能選択ビット
このビットは SEG21 端子の機能を選択します。
説明
bit5
"0" を書き込んだ場合
SEG21 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG21 端子をセグメント出力端子として機能させます。
[bit4] SEG20: SEG20 機能選択ビット
このビットは SEG20 端子の機能を選択します。
説明
bit4
"0" を書き込んだ場合
SEG20 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG20 端子をセグメント出力端子として機能させます。
[bit3] SEG19: SEG19 機能選択ビット
このビットは SEG19 端子の機能を選択します。
bit3
456
説明
"0" を書き込んだ場合
SEG19 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG19 端子をセグメント出力端子として機能させます。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
Ha rdware
Manual
[bit2] SEG18: SEG18 機能選択ビット
このビットは SEG18 端子の機能を選択します。
説明
bit2
"0" を書き込んだ場合
SEG18 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG18 端子をセグメント出力端子として機能させます。
[bit1] SEG17: SEG17 機能選択ビット
このビットは SEG17 端子の機能を選択します。
説明
bit1
"0" を書き込んだ場合
SEG17 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG17 端子をセグメント出力端子として機能させます。
[bit0] SEG16: SEG16 機能選択ビット
このビットは SEG16 端子の機能を選択します。
説明
bit0
"0" を書き込んだ場合
SEG16 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG16 端子をセグメント出力端子として機能させます。
<注意事項>
LCDCE1 レジスタの PICTL ビットが "1" に設定されている場合のみ , LCDCE5 レジスタ
はセグメント出力端子 SEG16 ~ SEG23 を制御できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
457
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
H ard war e
24.7.8
Ma nu al
LCDC 許可レジスタ 6 (LCDCE6)
LCDC 許可レジスタ 6 (LCDCE6) は SEG24 ~ SEG31 端子の機能を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
SEG31
SEG30
SEG29
SEG28
SEG27
SEG26
SEG25
SEG24
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] SEG31: SEG31 機能選択ビット
このビットは SEG31 端子の機能を選択します。
説明
bit7
"0" を書き込んだ場合
SEG31 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG31 端子をセグメント出力端子として機能させます。
[bit6] SEG30: SEG30 機能選択ビット
このビットは SEG30 端子の機能を選択します。
説明
bit6
"0" を書き込んだ場合
SEG30 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG30 端子をセグメント出力端子として機能させます。
[bit5] SEG29: SEG29 機能選択ビット
このビットは SEG29 端子の機能を選択します。
説明
bit5
"0" を書き込んだ場合
SEG29 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG29 端子をセグメント出力端子として機能させます。
[bit4] SEG28: SEG28 機能選択ビット
このビットは SEG28 端子の機能を選択します。
説明
bit4
"0" を書き込んだ場合
SEG28 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG28 端子をセグメント出力端子として機能させます。
[bit3] SEG27: SEG27 機能選択ビット
このビットは SEG27 端子の機能を選択します。
bit3
458
説明
"0" を書き込んだ場合
SEG27 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG27 端子をセグメント出力端子として機能させます。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
Ha rdware
Manual
[bit2] SEG26: SEG26 機能選択ビット
このビットは SEG26 端子の機能を選択します。
説明
bit2
"0" を書き込んだ場合
SEG26 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG26 端子をセグメント出力端子として機能させます。
[bit1] SEG25: SEG25 機能選択ビット
このビットは SEG25 端子の機能を選択します。
説明
bit1
"0" を書き込んだ場合
SEG25 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG25 端子をセグメント出力端子として機能させます。
[bit0] SEG24: SEG24 機能選択ビット
このビットは SEG24 端子の機能を選択します。
説明
bit0
"0" を書き込んだ場合
SEG24 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG24 端子をセグメント出力端子として機能させます。
<注意事項>
LCDCE1 レジスタの PICTL ビットが "1" に設定されている場合のみ , LCDCE6 レジスタ
はセグメント出力端子 SEG24 ~ SEG31 を制御できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
459
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
H ard war e
24.7.9
Ma nu al
LCDC 許可レジスタ 7 (LCDCE7)
LCDC 許可レジスタ 7 (LCDCE7) は SEG32 ~ SEG39 端子の機能を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
SEG39
SEG38
SEG37
SEG36
SEG35
SEG34
SEG33
SEG32
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] SEG39: SEG39 機能選択ビット
このビットは SEG39 端子の機能を選択します。
説明
bit7
"0" を書き込んだ場合
SEG39 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG39 端子をセグメント出力端子として機能させます。
( 注意事項 ) 8 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
[bit6] SEG38: SEG38 機能選択ビット
このビットは SEG38 端子の機能を選択します。
説明
bit6
"0" を書き込んだ場合
SEG38 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG38 端子をセグメント出力端子として機能させます。
( 注意事項 ) 8 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
[bit5] SEG37: SEG37 機能選択ビット
このビットは SEG37 端子の機能を選択します。
説明
bit5
"0" を書き込んだ場合
SEG37 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG37 端子をセグメント出力端子として機能させます。
( 注意事項 ) 8 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
[bit4] SEG36: SEG36 機能選択ビット
このビットは SEG36 端子の機能を選択します。
bit4
説明
"0" を書き込んだ場合
SEG36 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG36 端子をセグメント出力端子として機能させます。
( 注意事項 ) 8 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
460
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
Ha rdware
Manual
[bit3] SEG35: SEG35 機能選択ビット
このビットは SEG35 端子の機能を選択します。
説明
bit3
"0" を書き込んだ場合
SEG35 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG35 端子をセグメント出力端子として機能させます。
[bit2] SEG34: SEG34 機能選択ビット
このビットは SEG34 端子の機能を選択します。
説明
bit2
"0" を書き込んだ場合
SEG34 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG34 端子をセグメント出力端子として機能させます。
[bit1] SEG33: SEG33 機能選択ビット
このビットは SEG33 端子の機能を選択します。
説明
bit1
"0" を書き込んだ場合
SEG33 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG33 端子をセグメント出力端子として機能させます。
[bit0] SEG32: SEG32 機能選択ビット
このビットは SEG32 端子の機能を選択します。
説明
bit0
"0" を書き込んだ場合
SEG32 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG32 端子をセグメント出力端子として機能させます。
<注意事項>
LCDCE1 レジスタの PICTL ビットが "1" に設定されている場合のみ , LCDCE7 レジスタ
はセグメント出力端子 SEG32 ~ SEG39 を制御できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
461
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
H ard war e
24.7.10
Ma nu al
LCDC ブリンキング設定レジスタ 1 (LCDCB1)
LCDC ブリンキング設定レジスタ 1 (LCDCB1) はブリンキング機能を許可または禁止
します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
BLD7
BLD6
BLD5
BLD4
BLD3
BLD2
BLD1
BLD0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能 (8 COM モード )
[bit7] BLD7: S0C7 ブリンキング設定ビット
このビットは SEG00 と COM7 にあるドットのブリンキングを許可または禁止します。
bit7
説明
"0" を書き込んだ場合
SEG00 と COM7 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM7 にあるドットのブリンキングを許可します。
[bit6] BLD6: S0C6 ブリンキング設定ビット
このビットは SEG00 と COM6 にあるドットのブリンキングを許可または禁止します。
bit6
説明
"0" を書き込んだ場合
SEG00 と COM6 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM6 にあるドットのブリンキングを許可します。
[bit5] BLD5: S0C5 ブリンキング設定ビット
このビットは SEG00 と COM5 にあるドットのブリンキングを許可または禁止します。
bit5
説明
"0" を書き込んだ場合
SEG00 と COM5 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM5 にあるドットのブリンキングを許可します。
[bit4] BLD4: S0C4 ブリンキング設定ビット
このビットは SEG00 と COM4 にあるドットのブリンキングを許可または禁止します。
bit4
説明
"0" を書き込んだ場合
SEG00 と COM4 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM4 にあるドットのブリンキングを許可します。
[bit3] BLD3: S0C3 ブリンキング設定ビット
このビットは SEG00 と COM3 にあるドットのブリンキングを許可または禁止します。
bit3
462
説明
"0" を書き込んだ場合
SEG00 と COM3 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM3 にあるドットのブリンキングを許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
Ha rdware
Manual
[bit2] BLD2: S0C2 ブリンキング設定ビット
このビットは SEG00 と COM2 にあるドットのブリンキングを許可または禁止します。
説明
bit2
"0" を書き込んだ場合
SEG00 と COM2 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM2 にあるドットのブリンキングを許可します。
[bit1] BLD1: S0C1 ブリンキング設定ビット
このビットは SEG00 と COM1 にあるドットのブリンキングを許可または禁止します。
説明
bit1
"0" を書き込んだ場合
SEG00 と COM1 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM1 にあるドットのブリンキングを許可します。
[bit0] BLD0: S0C0 ブリンキング設定ビット
このビットは SEG00 と COM0 にあるドットのブリンキングを許可または禁止します。
説明
bit0
"0" を書き込んだ場合
SEG00 と COM0 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM0 にあるドットのブリンキングを許可します。
■ レジスタ機能 (4 COM モード )
[bit7] BLD7: S1C3 ブリンキング設定ビット
このビットは SEG01 と COM3 にあるドットのブリンキングを許可または禁止します。
説明
bit7
"0" を書き込んだ場合
SEG01 と COM3 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM3 にあるドットのブリンキングを許可します。
[bit6] BLD6: S1C2 ブリンキング設定ビット
このビットは SEG01 と COM2 にあるドットのブリンキングを許可または禁止します。
説明
bit6
"0" を書き込んだ場合
SEG01 と COM2 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM2 にあるドットのブリンキングを許可します。
[bit5] BLD5: S1C1 ブリンキング設定ビット
このビットは SEG01 と COM1 にあるドットのブリンキングを許可または禁止します。
説明
bit5
"0" を書き込んだ場合
SEG01 と COM1 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM1 にあるドットのブリンキングを許可します。
[bit4] BLD4: S1C0 ブリンキング設定ビット
このビットは SEG01 と COM0 にあるドットのブリンキングを許可または禁止します。
説明
bit4
"0" を書き込んだ場合
SEG01 と COM0 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM0 にあるドットのブリンキングを許可します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
463
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
H ard war e
Ma nu al
[bit3] BLD3: S0C3 ブリンキング設定ビット
このビットは SEG00 と COM3 にあるドットのブリンキングを許可または禁止します。
bit3
説明
"0" を書き込んだ場合
SEG00 と COM3 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM3 にあるドットのブリンキングを許可します。
[bit2] BLD2: S0C2 ブリンキング設定ビット
このビットは SEG00 と COM2 にあるドットのブリンキングを許可または禁止します。
bit2
説明
"0" を書き込んだ場合
SEG00 と COM2 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM2 にあるドットのブリンキングを許可します。
[bit1] BLD1: S0C1 ブリンキング設定ビット
このビットは SEG00 と COM1 にあるドットのブリンキングを許可または禁止します。
bit1
説明
"0" を書き込んだ場合
SEG00 と COM1 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM1 にあるドットのブリンキングを許可します。
[bit0] BLD0: S0C0 ブリンキング設定ビット
このビットは SEG00 と COM0 にあるドットのブリンキングを許可または禁止します。
bit0
説明
"0" を書き込んだ場合
SEG00 と COM0 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM0 にあるドットのブリンキングを許可します。
<注意事項>
464
•
LCDCE1 レジスタの BLSEL ビットでブリンキング間隔を選択してください。
•
ブリンキングが許可されたセグメントはすべて同期してブリンキングします。
•
ブリンキング設定ビットに対応するディスプレイ RAM のビットが "1" のときでも , そ
のブリンキング設定ビットの設定が有効のままです。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
Ha rdware
24.7.11
Manual
LCDC ブリンキング設定レジスタ 2 (LCDCB2)
LCDC ブリンキング設定レジスタ 2 (LCDCB2) はブリンキング機能を許可または禁止
します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
BLD15
BLD14
BLD13
BLD12
BLD11
BLD10
BLD9
BLD8
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能 (8 COM モード )
[bit7] BLD15: S1C7 ブリンキング設定ビット
このビットは SEG01 と COM7 にあるドットのブリンキングを許可または禁止します。
説明
bit7
"0" を書き込んだ場合
SEG01 と COM7 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM7 にあるドットのブリンキングを許可します。
[bit6] BLD14: S1C6 ブリンキング設定ビット
このビットは SEG01 と COM6 にあるドットのブリンキングを許可または禁止します。
説明
bit6
"0" を書き込んだ場合
SEG01 と COM6 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM6 にあるドットのブリンキングを許可します。
[bit5] BLD13: S1C5 ブリンキング設定ビット
このビットは SEG01 と COM5 にあるドットのブリンキングを許可または禁止します。
説明
bit5
"0" を書き込んだ場合
SEG01 と COM5 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM5 にあるドットのブリンキングを許可します。
[bit4] BLD12: S1C4 ブリンキング設定ビット
このビットは SEG01 と COM4 にあるドットのブリンキングを許可または禁止します。
説明
bit4
"0" を書き込んだ場合
SEG01 と COM4 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM4 にあるドットのブリンキングを許可します。
[bit3] BLD11: S1C3 ブリンキング設定ビット
このビットは SEG01 と COM3 にあるドットのブリンキングを許可または禁止します。
説明
bit3
"0" を書き込んだ場合
SEG01 と COM3 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM3 にあるドットのブリンキングを許可します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
465
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
H ard war e
Ma nu al
[bit2] BLD10: S1C2 ブリンキング設定ビット
このビットは SEG01 と COM2 にあるドットのブリンキングを許可または禁止します。
説明
bit2
"0" を書き込んだ場合
SEG01 と COM2 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM2 にあるドットのブリンキングを許可します。
[bit1] BLD9: S1C1 ブリンキング設定ビット
このビットは SEG01 と COM1 にあるドットのブリンキングを許可または禁止します。
説明
bit1
"0" を書き込んだ場合
SEG01 と COM1 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM1 にあるドットのブリンキングを許可します。
[bit0] BLD8: S1C0 ブリンキング設定ビット
このビットは SEG01 と COM0 にあるドットのブリンキングを許可または禁止します。
説明
bit0
"0" を書き込んだ場合
SEG01 と COM0 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM0 にあるドットのブリンキングを許可します。
■ レジスタ機能 (4 COM モード )
[bit7] BLD15: S3C3 ブリンキング設定ビット
このビットは SEG03 と COM3 にあるドットのブリンキングを許可または禁止します。
bit7
説明
"0" を書き込んだ場合
SEG03 と COM3 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG03 と COM3 にあるドットのブリンキングを許可します。
[bit6] BLD14: S3C2 ブリンキング設定ビット
このビットは SEG03 と COM2 にあるドットのブリンキングを許可または禁止します。
bit6
説明
"0" を書き込んだ場合
SEG03 と COM2 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG03 と COM2 にあるドットのブリンキングを許可します。
[bit5] BLD13: S3C1 ブリンキング設定ビット
このビットは SEG03 と COM1 にあるドットのブリンキングを許可または禁止します。
bit5
説明
"0" を書き込んだ場合
SEG03 と COM1 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG03 と COM1 にあるドットのブリンキングを許可します。
[bit4] BLD12: S3C0 ブリンキング設定ビット
このビットは SEG03 と COM0 にあるドットのブリンキングを許可または禁止します。
bit4
466
説明
"0" を書き込んだ場合
SEG03 と COM0 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG03 と COM0 にあるドットのブリンキングを許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.7 レジスタ
Ha rdware
Manual
[bit3] BLD11: S2C3 ブリンキング設定ビット
このビットは SEG02 と COM3 にあるドットのブリンキングを許可または禁止します。
説明
bit3
"0" を書き込んだ場合
SEG02 と COM3 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG02 と COM3 にあるドットのブリンキングを許可します。
[bit2] BLD10: S2C2 ブリンキング設定ビット
このビットは SEG02 と COM2 にあるドットのブリンキングを許可または禁止します。
説明
bit2
"0" を書き込んだ場合
SEG02 と COM2 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG02 と COM2 にあるドットのブリンキングを許可します。
[bit1] BLD9: S2C1 ブリンキング設定ビット
このビットは SEG02 と COM1 にあるドットのブリンキングを許可または禁止します。
説明
bit1
"0" を書き込んだ場合
SEG02 と COM1 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG02 と COM1 にあるドットのブリンキングを許可します。
[bit0] BLD8: S2C0 ブリンキング設定ビット
このビットは SEG02 と COM0 にあるドットのブリンキングを許可または禁止します。
説明
bit0
"0" を書き込んだ場合
SEG02 と COM0 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG02 と COM0 にあるドットのブリンキングを許可します。
<注意事項>
•
LCDCE1 レジスタの BLSEL ビットでブリンキング間隔を選択してください。
•
ブリンキングが許可されたセグメントはすべて同期してブリンキングします。
•
ブリンキング設定ビットに対応するディスプレイ RAM のビットが "1" のときでも , そ
のブリンキング設定ビットの設定が有効のままです。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
467
第 24 章 LCD コントローラ (MB95710L シリーズ )
24.8 使用上の注意
H ard war e
24.8
Ma nu al
使用上の注意
LCD コントローラ使用上の注意を示します。
•
LCD 端子を汎用入出力ポートとして使用する場合 , その端子に対応する , LCDC 許
可レジスタ (LCDCE1 ~ LCDCE7) のコモン / セグメント選択ビットを "0" に , LCDC
許可レジスタ1のポート入力制御ビット(LCDCE1:PICTL)を"1"に設定してください。
•
LCD 表示動作中に , 選択したフレーム周期発生用クロックが停止すると , 交流波形
生成回路が停止するため液晶素子に直流電圧が印加されます。この場合あらかじめ
LCD 表示動作を停止しておく必要があります。メインクロック ( タイムベースタイ
マ ) またはサブクロック ( 時計プリスケーラ ) が停止する条件はクロックモードと
スタンバイモードの選択によります。また , フレーム周期発生用クロック選択ビッ
ト (LCDCC1:CSS) の設定に従い , タイムベースタイマまたは時計プリスケーラがク
リアされるとフレーム周期が影響を受けます。
ディスプレイ RAM のデータを LCD に出力する動作は CPU がディスプレイ RAM
にアクセスする動作とは独立したタイミングで行われます。ディスプレイ RAM の
書換え間隔が設定した LCD 周期より短い場合は , フレームの表示パターンが異なる
ため , ちらつきが発生することがあります。
•
468
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 25 章
LCD コントローラ
(MB95770L シリーズ )
LCD コントローラ (LCDC) の機能と動作について
説明します。
25.1 概要
25.2 構成
25.3 端子
25.4 ディスプレイ RAM
25.5 割込み
25.6 動作説明
25.7 レジスタ
25.8 使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
469
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.1 概要
H ard war e
25.1
Ma nu al
概要
LCD コントローラには , 8 COM モードと 4 COM モードがあります。
8 COM モードでは , LCD コントローラは 28 バイトの表示データメモリを使用でき ,
8 本のコモン出力と 28 本のセグメント出力によって LCD 表示を制御します。また ,
LCD パネル ( 液晶表示器 ) を駆動するためのバイアス出力を 2 種類持っています。
4 COM モードでは , LCD コントローラは 16 バイトの表示データメモリを使用でき ,
4 本のコモン出力と 32 本のセグメント出力によって LCD 表示の制御を行います。ま
た , LCD パネルを駆動するためのバイアス出力を 3 種類持っています。
■ LCD コントローラの機能
LCD コントローラは , セグメント出力とコモン出力によって , 表示データメモリ ( ディ
スプレイ RAM) の内容を LCD パネルに直接表示します。
•
ソフトウェアで 8 COM モードまたは 4 COM モードを選択します。
•
LCD 駆動電圧分割抵抗を内蔵しており , 10 k から 100 kの範囲のレジスタ値を
ソフトウェアによって選択できます。代わりに外部分割抵抗も使用できます。
•
8 COM モードでは , 8 本のコモン出力 (COM0 ~ COM7) と 28 本のセグメント出力
(SEG00 ~ SEG27) を使用できます。
•
4 COM モードでは , 4 本のコモン出力 (COM0 ~ COM3) と 32 本のセグメント出力
(SEG00 ~ SEG31) を使用できます。
•
ディスプレイ RAM サイズは , 8 COM モードでは , 28 バイト (28  8 ビット ) で , 4
COM モードでは , 16 バイト (32  4 ビット ) です。
•
動作クロックとして , メインクロックまたはサブクロックを使用できます。
•
ブリンキング ( 点滅 ) 機能があります ( 端子制限あり )。
•
LCD パネルを直接駆動できます。
•
8 COM モードでは , バイアスは , 1/3 または 1/4 から選択できます。
•
4 COM モードでは , デューティは , 1/2, 1/3, または 1/4 から選択できます。( バイア
スの設定によって制限されます ) 。
•
割込みイベントは , LCD モジュールフレーム周波数と同期します。
表 25.1-1 に , 使用できるバイアス・デューティの組合せを示します。
表 25.1-1 バイアス・デューディの組合せ表
デューディ
1/2 バイアス
1/3 バイアス
1/4 バイアス
1/2
○
X
X
1/3
X
○
X
1/4
X
○
X
1/8, BLS8 = 0
X
○
X
1/8, BLS8 = 1
X
X
○
○ : 推奨組合せ
X : 使用禁止の組合せ
470
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.2 構成
Ha rdware
25.2
Manual
構成
LCD コントローラは , 以下のブロックで構成されており , 機能的にはディスプレイ
RAM の内容に従って , セグメント信号とコモン信号を発生するコントローラ部と ,
LCD を駆動するためのドライバ部に分けられます。
コントローラ部
• LCDC 制御レジスタ (LCDCC1 と LCDCC2)
• LCDC 許可レジスタ (LCDCE1 ~ LCDCE6)
• LCDC ブリンキング設定レジスタ (LCDCB1 と LCDCB2)
• ディスプレイ RAM
• クロック選択
• タイミング制御
ドライブ部
• 交流波形発生回路
• コモンドライバ
• セグメントドライバ
• 分割抵抗
■ LCD コントローラのブロックダイヤグラム
図 25.2-1 LCD コントローラのブロックダイヤグラム (8 COM モード )
LCDC制御レジスタ
(LCDCC1, LCDCC2)
LCDC許可レジスタ
(LCDCE1~LCDCE6)
LCDCブリンキング設定レジスタ
(LCDCB1, LCDCB2)
内部分割抵抗
クロック選択
タイミング制御
サブクロック
ディスプレイRAM:
28 × 8ビット
(28バイト)
コントローラ部
April 4, 2014, MB95F718M_MN702-00014-3v0-J
交流波形生成回路
内部バス
メインクロック
コモン
ドライバ
COM0
:
COM7
セグメント
ドライバ
SEG00
:
SEG27
ドライバ部
471
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.2 構成
H ard war e
Ma nu al
図 25.2-2 LCD コントローラのブロックダイヤグラム (4 COM モード )
LCDC制御レジスタ
(LCDCC1, LCDCC2)
LCDC許可レジスタ
(LCDCE1~LCDCE6)
LCDCブリンキング設定レジスタ
(LCDCB1, LCDCB2)
内部分割抵抗
クロック選択
交流波形生成回路
内部バス
メインクロック
タイミング制御
サブクロック
ディスプレイRAM:
32 × 4ビット
(16バイト)
コントローラ部
コモン
ドライバ
COM0
:
COM3
セグメント
ドライバ
SEG00
:
SEG31
ドライバ部
● LCDC 制御レジスタ 1 (LCDCC1)
フレーム周期発生用クロックの選択 , 表示モードの選択 , フレーム周期クロックの選択
および LCD 駆動電源制御を行います。
● LCDC 制御レジスタ 2 (LCDCC2)
割込みを有効または無効にしたり , 割込みの状態を示したりするレジスタです。下記の
パラメータを設定します。
- 内部抵抗値 (10 k または 100 k)
- 8 COM モードで使用するバイアス (1/3 または 1/4)
- 表示データまたはブランク画面
- 反転表示
● LCDC 許可レジスタ 1 ~ 6 (LCDCE1 ~ LCDCE6)
ポート入力制御 , ブリンク間隔選択および端子制御を行います。
● LCDC ブリンキング設定レジスタ 1 (LCDCB1), LCDC ブリンキング設定レジスタ 2
(LCDCB2)
ブリンキングのオン / オフを設定します。
472
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.2 構成
Ha rdware
Manual
● ディスプレイ RAM
8 COM モードでは , セグメント出力信号発生用の 28  8 ビットの RAM です。
4 COM モードでは , セグメント出力信号発生用の 32  4 ビットの RAM です。
RAM の内容は , コモン信号の選択タイミングに同期して自動的に読み出されてセグメ
ント出力端子より出力されます。
VRAM の内容は , ディスプレイ RAM への書換えと同時にセグメント出力端子より出
力されます。
● クロック選択
2 種類のクロックから生成される 8 種類の周波数から選択された設定によって , フレー
ム周波数を発生します。
● タイミング制御
フレーム周波数と各レジスタの設定をもとに , コモン信号とセグメント信号の制御を
行います。
● 交流波形生成回路
タイミング制御の信号から , LCD を駆動するための交流波形を生成します。
● コモンドライバ
LCD のコモン端子 (COM) のドライバです。
● セグメントドライバ
LCD のセグメント端子 (SEG) のドライバです。
● 分割抵抗
LCD 駆動電圧を発生させるための抵抗です。LCDC ドライバ電源端子 (V1 ~ V4) が分
割抵抗接続端子として機能している場合は , 分割抵抗を外付けすることもできます。
■ LCD コントローラの電源電圧
LCD ドライバの電源電圧は , 内蔵の分割抵抗を使用するかまたは V1 ~ V4 端子に分割
抵抗を接続することにより生成されます。
■ 入力クロック
LCD コントローラは , タイムベースタイマの出力クロックまたは時計プリスケーラの
出力クロックを入力クロック ( 動作クロック ) として使用します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
473
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.2 構成
H ard war e
25.2.1
Ma nu al
LCD コントローラの内部分割抵抗
LCD ドライバの電源電圧は , 内部分割抵抗によって生成されます。
■ 内部分割抵抗
本シリーズには , 内部分割抵抗が内蔵されています。また , LCD 駆動用電源端子 (V1 ~
V4) に外部分割抵抗を接続することもできます。
内部分割抵抗と外部分割抵抗の選択は , LCDC 制御レジスタ 1 の駆動電源制御ビット
(LCDCC1:VSEL) で行います。VSEL ビットを "1" にすることにより内部分割抵抗が通
電状態になります。外部分割抵抗を使用せずに内部分割抵抗のみを使用するためには ,
LCDC 許可レジスタ 1 (LCDCE1) 内の VE3 ビットを "1" に設定してください ( 内部分割
抵抗を使用する場合 , V4 端子を汎用 I/O ポートとして使用できません )。
LCD コントローラは , LCD 動作停止 (LCDCC1:MS[2:0] = 0b000) , メインストップモー
ド, および時計モードでの動作を禁止 (LCDCC1:LCDEN = 0) した状態で, メインストッ
プモード , および時計モード (STBC:TMD = 1) に遷移したときに停止します。
図 25.2-3 に , 内部分割抵抗使用時の等価回路を示します。
474
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.2 構成
Ha rdware
Manual
図 25.2-3 内部分割抵抗使用時の等価回路
VCC
V4
V4
90 kΩ
10 kΩ
V3
V3
バイアス選択信号
90 kΩ
10 kΩ
90 kΩ
10 kΩ
90 kΩ
10 kΩ
V2
V2
V1
V1
LCD許可
N-ch
内部抵抗選択信号
10 kΩまたは100 kΩ
選択信号
V1~V4: V1~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
475
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.2 構成
H ard war e
Ma nu al
■ 内部分割抵抗の使用および輝度調整
内部分割抵抗には 10 k 抵抗と 100 k 抵抗があります。図 25.2-4 に , 内部分割抵抗使
用時の回路を示します。
内部分割抵抗を使用して輝度があがらない場合には , 外部 (Vcc ~ V4 端子間 ) に可変抵
抗 (VR) を接続して V4 の電圧を調整してください。図 25.2-5 に VR を V4 端子に接続
することによる輝度調整を示します。
図 25.2-4 内部分割抵抗使用時の回路状態
VCC
VCC
VR
V4
VR
V4
10 kΩ
10 kΩ
90 kΩ
90 kΩ
V4
10 kΩ
90 kΩ
V3
V3
10 kΩ
V3
10 kΩ
90 kΩ
10 kΩ
90 kΩ
90 kΩ
V2
V2
10 kΩ
V2
10 kΩ
90 kΩ
10 kΩ
90 kΩ
90 kΩ
V1
V1
V1
10 kΩ
10 kΩ
10 kΩ
90 kΩ
90 kΩ
90 kΩ
LCD許可
LCD許可
On
1/4 バイアスを100 kΩ内部抵抗に内部接続した場合
LCD許可
On
1/3 バイアスを100 kΩ内部抵抗に内部接続した場合
VCC
VR
10 kΩ
90 kΩ
90 kΩ
90 kΩ
V3
10 kΩ
V3
10 kΩ
90 kΩ
90 kΩ
V2
V2
10 kΩ
90 kΩ
V4
10 kΩ
V3
10 kΩ
VR
V4
10 kΩ
90 kΩ
VCC
VR
V4
10 kΩ
V2
10 kΩ
90 kΩ
90 kΩ
V1
V1
V1
10 kΩ
10 kΩ
10 kΩ
90 kΩ
90 kΩ
90 kΩ
LCD許可
On
1/4 バイアスを10 kΩ内部抵抗に内部接続した場合
On
1/2 バイアスを100 kΩ内部抵抗に内部接続した場合
VCC
476
VCC
VR
LCD許可
On
1/3 バイアスを10 kΩ内部抵抗に内部接続した場合
LCD許可
On
1/2 バイアスを10 kΩ内部抵抗に内部接続した場合
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.2 構成
Ha rdware
Manual
図 25.2-5 VR を V4 端子に接続することによる輝度調節
VCC
VR
V4
V4
R
V3
V3
R
V2
V2
R
V1
V1
R
LCD許可
N-ch
輝度制御
V1~V4: V1~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
477
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.2 構成
H ard war e
25.2.2
Ma nu al
LCD コントローラの外部分割抵抗
本シリーズ は V1 ~ V4 端子に外部分割抵抗を接続できます。
また , Vcc と V4 端子間に可変抵抗を接続することで , 輝度を調整できます。
■ 外部分割抵抗
内部分割抵抗を使用せずに , LCD 駆動用電源端子 (V1 ~ V4) に外部分割抵抗を接続し
て使用できます。図 25.2-6 にバイアス方式に対応した外部分割抵抗の接続を , 表 25.2-1
に LCD 駆動電圧を示します。
図 25.2-6 外部分割抵抗の接続例
VCC
VCC
VCC
VR
VR
V4
VR
V4
V4
R
R
V3
R
V3
V3
R
V2
VLCD
V2
R
VLCD
R
V1
V1
V1
R
1/4バイアス
V2
VLCD
R
1/3バイアス
R
1/2バイアス
表 25.2-1 LCD 駆動電圧の設定
V4
V3
V2
V1
1/2 bias
VLCD
X
1/2 VLCD
X
1/3 bias
VLCD
2/3 VLCD
2/3 VLCD
1/3 VLCD
1/4 bias
VLCD
3/4 VLCD
1/2 VLCD
1/4 VLCD
VLCD : LCD 動作電圧
X
: 外部分割抵抗なし
GND : 接地
478
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.2 構成
Ha rdware
Manual
■ 外部分割抵抗の使用
V0 端子は内部でトランジスタを通して Vss (GND) へ接続されているため , 外部分割抵
抗を使用する場合 , 分割抵抗の Vss 側を V1 端子に接続することにより , LCD コント
ローラ停止時に抵抗へ流れる電流を遮断します。図 25.2-7 に , 外部分割抵抗使用時の
状態を示します。
図 25.2-7 外部分割抵抗の使用
VCC
VR
V4
10 kΩ
RX
90 kΩ
V3
10 kΩ
RX
90 kΩ
V2
10 kΩ
RX
90 kΩ
V1
10 kΩ
90 kΩ
RX
LCD許可
1. 内部分割抵抗の影響を受けずに外部に分割抵抗を接続するには , LCDC 制御レジス
タ 1 の駆動電圧制御ビット (LCDCC1:VSEL) に "0" を書き込み , 内部分割抵抗全体を
切り離してください。ポートを LCD の駆動用電源端子として設定するためには ,
LCDC 許可レジスタ 1 の V4 ~ V1 選択ビット (LCDCE1:VE[4:0]) に "1" を書き込ん
でください。
2. 内部分割抵抗が切り離された状態で , LCDCC1 レジスタの表示モード選択ビット
(MS[2:0]) に "0b000" 以外の値を書き込むと LCDC 許可トランジスタ (Q1) が "ON" と
なって外部分割抵抗に電流が流れます。
<注意事項>
外部 RX 抵抗の適切な抵抗値は使用する LCD により異なります。使用する LCD に適する
抵抗値を持つ外部 RX 抵抗を使用してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
479
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.3 端子
H ard war e
25.3
Ma nu al
端子
LCD コントローラの端子について説明します。
■ LCD コントローラの端子
LCD コントローラの端子は , 8 本のコモン出力端子 (COM0 ~ COM7) , 32 本のセグメン
ト出力端子 (SEG00 ~ SEG31) および 4 本の LCD 駆動用電源端子 (V1 ~ V4) です。
LCD 端子として使用する場合は , LCDC 許可レジスタ (LCDCE1 ~ LCDCE6) のその端
子に対応するビットを "1" に設定してください。
汎用入出力ポートと兼用する LCD 端子を汎用入出力ポートとして使用する場合は ,
LCDC 許可レジスタ (LCDCE1 ~ LCDCE6) のその端子に対応するビットを "0" に設定
してから , LCDC 許可レジスタ 1 のポート入力制御ビット (LCDCE:1PICTL) を "1" に設
定してください。
● COM0 ~ COM7 端子
8 COM モードでは , COM0 ~ COM7 端子は , LCD コモン出力端子です。
4 COM モードでは , COM0 ~ COM3 端子は , LCD コモン出力端子です。COM4 ~ COM7
端子は , LCDCE1 ~ LCDCE6 レジスタの設定にかかわらず , 初期設定では汎用入出力
ポートとして機能します。
COM0 ~ COM7 端子は , 汎用入出力ポートと兼用しています。
● SEG00 ~ SEG31 端子
8 COM モードでは , SEG00 ~ SEG27 端子は LCD セグメント出力端子 , SEG28 ~ SEG31
端子は , LCDCE1 ~ LCDCE6 レジスタの設定にかかわらず , 初期設定では汎用入出力
ポートです。
4 COM モードでは , SEG00 ~ SEG31 端子は LCD セグメント出力端子です。
SEG00 ~ SEG31 端子は , 汎用入出力ポートと兼用しています。
● V1 ~ V4 端子
LCD 駆動用電源端子です。
汎用入出力ポートと兼用しています。
480
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.4 ディスプレイ RAM
Ha rdware
Manual
ディスプレイ RAM
25.4
ディスプレイ RAM のサイズは , 8 COM モードと 4 COM モードとでは異なります。
8 COM モードでは , ディスプレイ RAM には , セグメント出力信号発生用の 28  8
ビット (28 バイト ) の表示データメモリがあります。
4 COM モードでは , ディスプレイ RAM には , セグメント出力信号発生用の 32  4
ビット (16 バイト ) の表示データメモリがあります。
■ ディスプレイ RAM と出力端子
ディスプレイ RAM の内容は , コモン信号の選択タイミングで自動的に読み出され同期
して , セグメント出力端子より出力されます。
各ビットの内容が "1" であれば選択電圧に変換 (LCD は表示 ) され , "0" であれば非選
択電圧に変換 (LCD は非表示 ) されて出力されます。
LCD 表示動作は CPU の動作とは非同期で行われるため , ディスプレイ RAM に対して
は任意のタイミングで書込み / 読込みができます。セグメント出力に指定されなかっ
た端子は入出力ポートとして , また , 対応するディスプレイ RAM は通常の RAM とし
て使用できます。表 25.4-1 に , デューティとコモン出力およびディスプレイ RAM の使
用ビットの関係を示します。
図 25.4-1 と図 25.4-2 に , 8 COM モードおよび 4 COM モードにおける , コモン出力およ
びセグメント出力端子へのディスプレイ RAM アドレスの割当てを示します。
表 25.4-1 デューディとコモン出力およびディスプレイ RAM の使用ビットの関係
使用するディスプレイデータビット
デューディ設定値
使用するコモン出力端子
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
1/2
COM0, COM1 (2 本 )
-
-
○
○
-
-
○
○
1/3
COM0 ~ COM2 (3 本 )
-
○
○
○
-
○
○
○
1/4
COM0 ~ COM3 (4 本 )
○
○
○
○
○
○
○
○
1/8
COM0 ~ COM7 (8 本 )
○
○
○
○
○
○
○
○
○ : 使用するビット
-
: 使用しないビット
April 4, 2014, MB95F718M_MN702-00014-3v0-J
481
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.4 ディスプレイ RAM
H ard war e
Ma nu al
図 25.4-1 ディスプレイ RAM およびコモン / セグメント出力端子 (8 COM モード )
RAM アドレス
n
Bit7
n+1 Bit7
n+2 Bit7
n+3 Bit7
n+4 Bit7
Bit6
Bit6
Bit6
Bit6
Bit6
Bit5
Bit5
Bit5
Bit5
Bit5
Bit4
Bit4
Bit4
Bit4
Bit4
Bit3
Bit3
Bit3
Bit3
Bit3
Bit2
Bit2
Bit2
Bit2
Bit2
Bit1
Bit1
Bit1
Bit1
Bit1
Bit0
Bit0
Bit0
Bit0
Bit0
SEG00
SEG01
SEG02
SEG03
SEG04
:
:
:
:
:
:
:
:
:
:
n+22
n+23
n+24
n+25
n+26
n+27
Bit7
Bit7
Bit7
Bit7
Bit7
Bit7
COM7
Bit6
Bit6
Bit6
Bit6
Bit6
Bit6
COM6
Bit5
Bit5
Bit5
Bit5
Bit5
Bit5
COM5
Bit4
Bit4
Bit4
Bit4
Bit4
Bit4
COM4
Bit3
Bit3
Bit3
Bit3
Bit3
Bit3
COM3
Bit2
Bit2
Bit2
Bit2
Bit2
Bit2
COM2
Bit1
Bit1
Bit1
Bit1
Bit1
Bit1
COM1
Bit0
Bit0
Bit0
Bit0
Bit0
Bit0
COM0
SEG22
SEG23
SEG24
SEG25
SEG26
SEG27
1/8 デューティ比で使用される領域と
COM 端子
図 25.4-2 ディスプレイ RAM およびコモン / セグメント出力端子 (4 COM モード )
RAM アドレス
Bit3
n
Bit7
Bit3
n+1
Bit7
Bit3
n+2
Bit7
:
n+13
n+14
n+15
Bit2
Bit6
Bit2
Bit6
Bit2
Bit6
Bit1
Bit5
Bit1
Bit5
Bit1
Bit5
Bit0
Bit4
Bit0
Bit4
Bit0
Bit4
SEG00
SEG01
SEG02
SEG03
SEG04
SEG05
:
:
:
:
:
Bit3
Bit7
Bit3
Bit7
Bit3
Bit7
COM3
Bit2
Bit6
Bit2
Bit6
Bit2
Bit6
COM2
Bit1
Bit5
Bit1
Bit5
Bit1
Bit5
COM1
Bit0
Bit4
Bit0
Bit4
Bit0
Bit4
COM0
SEG26
SEG27
SEG28
SEG29
SEG30
SEG31
1/2 デューティ比で使用される領域と COM 端子
1/3 デューティ比で使用される領域と COM 端子
1/4 デューティ比で使用される領域と COM 端子
<注意事項>
アドレスコラム内の "n" は "0x0FBD" を示します。
482
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.5 割込み
Ha rdware
25.5
Manual
割込み
LCD コントローラは , LCD モジュールフレーム周波数と同期して , 割込みを生成しま
す。
■ LCD コントローラ動作時の割込み
フレーム処理が完了すると , LCD コントローラは , LCDC 割込み要求フラグビット
(LCDCC2:LCDIF) を "1" に設定します。LCDIF ビットが "1" に設定されたとき , すでに
割込み要求が許可されている場合(LCDCC2:LCDIEN = 1), LCDコントローラは, 割込み
コントローラに割込み要求を発行します。割込み要求をクリアするには , 割込みサー
ビスルーチンで , LCDIF ビットに "0" を書き込んでください。
LCD コントローラは , フレーム処理が完了次第 , LCDIEN ビットの値に関係なく , 常に
LCDIF ビットを "1" に設定します。LCDC 割込み要求の発行後 , LCDIF ビットおよび
LCDIEN ビットの両方が "1" に設定されたままの場合 , CPU は , 割込み処理から復帰で
きません。CPU が割込み処理から復帰できるように , LCDC 割込み要求の発行後は , 常
に LCDIF ビットを "0" にクリアしてください。
図 25.5-1 割込みタイミングチャート
第1フレーム
第2フレーム
割込み
COM0
V4
V3
V2
V1
Vss
COM1
V4
V3
V2
V1
Vss
COM2
.
.
.
COM6
COM7
V4
V3
V2
V1
Vss
SEGn
V4
V3
V2
V1
Vss
V1~V4: V1~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
483
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
H ard war e
Ma nu al
動作説明
25.6
LCD コントローラの動作を説明します。
図 25.6-1 に , 8 COM モードで LCD 表示を行うために必要な設定を示します。
図 25.6-1 8 COM モードにおける LCD コントローラ設定
LCDCC1
LCDCC2
LCDCE1
LCDCE2
LCDCE3
LCDCE4
LCDCE5
LCDCE6
LCDCB1
LCDCB2
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
CSS
LCDEN
VSEL
MS2
MS1
MS0
FP1
FP0
○
○
○
1
0/1
0/1
○
○
-
-
RSEL
BLS8
INV
BK
LCDIEN
LCDIF
-
-
○
○
○
○
○
○
PICTL
BLSEL
VE4
VE3
VE2
VE1
-
-
○
○
○
○
○
○
-
-
COM7
COM6
COM5
COM4
COM3
COM2
COM1
COM0
○
○
○
○
○
○
○
○
SEG07
SEG06
SEG05
SEG04
SEG03
SEG02
SEG01
SEG00
○
○
○
○
○
○
○
○
SEG15
SEG14
SEG13
SEG12
SEG11
SEG10
SEG09
SEG08
○
○
○
○
○
○
○
○
SEG23
SEG22
SEG21
SEG20
SEG19
SEG18
SEG17
SEG16
○
○
○
○
○
○
○
○
SEG31
SEG30
SEG29
SEG28
SEG27
SEG26
SEG25
SEG24
-
-
-
-
○
○
○
○
BLD7
BLD6
BLD5
BLD4
BLD3
BLD2
BLD1
BLD0
○
○
○
○
○
○
○
○
BLD15
BLD14
BLD13
BLD12
BLD11
BLD10
BLD9
BLD8
○
○
○
○
○
○
○
○
ディスプレイ RAM
○
1
0/1
484
:
:
:
:
ディスプレイデータ
使用するビット
使用しないビット
"1" を書き込んでください。
"0" または "1" を書き込んでください。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
Ha rdware
Manual
図 25.6-2 8 COM モードにおける LCD コントローラ設定フロー
レジスタを初期化する。
8 COM モード
動作モードおよび
各端子の機能を選択する。
すべてのコモン/
セグメント出力端子を
使用する?
No
4 COM モード
PICTLを“1”に設定する。
コモン/セグメント出力に使用しない
端子に対応するCOM/SEG
端子選択ビットを“0”に設定する。
Yes
ディスプレイ点滅を行う。
PICTLを“0”に設定する。
No
BKを“0”に設定する。
Yes
BKを“1”に設定する。
BLSELでブリンク間隔を選択する。
BLD[15:0]のブリンキング表示
ビットを設定する。
MS[2:0]を“0b100”, “0b101”, “0b110”または
“0b111”に設定し, LCDを開始する。
•
図 25.6-1 の設定が行われ , 選択したフレーム周期発生用クロックが発振している場
合 , LCD コントローラは , ディスプレイ RAM および LCDC のレジスタの内容に従っ
て , コモン出力端子とセグメント出力端子 (COM0 ~ COM7, SEG00 ~ SEG27) に
LCD パネルの駆動波形を出力します。
•
LCDCE1 ~ LCDCE6 により LCD の出力端子が選択されます。また , コモン / セグメ
ント出力端子として選択されなかった端子は , 汎用入出力ポートと使用されます。
•
LCD 表示動作中であっても , フレーム周期発生用クロックを切り換えられます。た
だし , 切換え時に LCD 表示がちらつくことがあります。LCD 表示のちらつきを防止
するには , ブランキング (LCDCC2:BK = 1) などで表示を一時的に停止させてから ,
フレーム周期発生用クロックを切り換えてください。
•
表示駆動出力は , バイアスおよびデューティの設定によって選択される , 2 フレーム
を交流化した波形です。
•
ブリンク(点滅)機能を使用する場合は, LCDCブリンキング設定レジスタ1(LCDCB1)
と LCDC ブリンキング設定レジスタ 2 (LCDCB2) により対応するビットを "1" (ON)
に設定してください。ブリンキング間隔はLCDC制御レジスタ1 (LCDCE1)のBLSEL
ビットで 2 種類から選択できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
485
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
H ard war e
Ma nu al
図 25.6-3 に , 4 COM モードで LCD 表示を行うために必要な設定を示します。
図 25.6-3 4 COM モードにおける LCD コントローラ設定
LCDCC1
LCDCC2
LCDCE1
LCDCE2
LCDCE3
LCDCE4
LCDCE5
LCDCE6
LCDCB1
LCDCB2
bit7
bit6
bit5
bit4
bit3
bit2
bit1
bit0
CSS
LCDEN
VSEL
MS2
MS1
MS0
FP1
FP0
○
○
○
0
0/1
0/1
○
○
-
-
RSEL
BLS8
INV
BK
LCDIEN
LCDIF
-
-
○
○
○
○
○
○
PICTL
BLSEL
VE4
VE3
VE2
VE1
-
-
○
○
○
○
○
○
-
-
COM7
COM6
COM5
COM4
COM3
COM2
COM1
COM0
-
-
-
-
○
○
○
○
SEG07
SEG06
SEG05
SEG04
SEG03
SEG02
SEG01
SEG00
○
○
○
○
○
○
○
○
SEG15
SEG14
SEG13
SEG12
SEG11
SEG10
SEG09
SEG08
○
○
○
○
○
○
○
○
SEG23
SEG22
SEG21
SEG20
SEG19
SEG18
SEG17
SEG16
○
○
○
○
○
○
○
○
SEG31
SEG30
SEG29
SEG28
SEG27
SEG26
SEG25
SEG24
○
○
○
○
○
○
○
○
BLD7
BLD6
BLD5
BLD4
BLD3
BLD2
BLD1
BLD0
○
○
○
○
○
○
○
○
BLD15
BLD14
BLD13
BLD12
BLD11
BLD10
BLD9
BLD8
○
○
○
○
○
○
○
○
ディスプレイ RAM
○
1
0/1
486
:
:
:
:
ディスプレイデータ
使用するビット
使用しないビット
"1" を書き込んでください。
"0" または "1" を書き込んでください。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
Ha rdware
Manual
図 25.6-4 4 COM モードにおける LCD コントローラ設定フロー
レジスタを初期化する。
4 COM モード
動作モードおよび
各端子の機能を選択する。
すべてのコモン/
セグメント出力端子を
使用する?
No
8 COM モード
PICTLを“1”に設定する。
コモン/セグメント出力に使用しない
端子に対応するCOM/SEG
端子選択ビットを“0”に設定する。
Yes
ディスプレイ点滅を行う。
PICTLを“0”に設定する。
No
BKを“0”に設定する。
Yes
BKを“1”に設定する。
BLSELでブリンク間隔を選択する。
BLD[15:0]のブリンキング表示
ビットを設定する。
MS[2:0]を“0b001”, “0b010”または“0b011”
に設定し, LCDを開始する。
•
図 25.6-3 の設定が行われ , 選択したフレーム周期発生用クロックが発振している場
合 , LCD コントローラは , ディスプレイ RAM および LCDC のレジスタの内容に従っ
て , コモン出力端子とセグメント出力端子 (COM0 ~ COM3, SEG00 ~ SEG31) に
LCD パネルの駆動波形を出力します。
•
LCDCE1 ~ LCDCE6 により LCD の出力端子が選択されます。また , コモン / セグメ
ント出力端子として選択されなかった端子は , 汎用入出力ポートと使用されます。
•
LCD 表示動作中であっても , フレーム周期発生用クロックを切り換えられます。た
だし , 切換え時に LCD 表示がちらつくことがあります。LCD 表示のちらつきを防止
するには , ブランキング (LCDCC2:BK = 1) などで表示を一時的に停止させてから ,
フレーム周期発生用クロックを切り換えてください。
•
表示駆動出力は , バイアスおよびデューティの設定によって選択される , 2 フレーム
を交流化した波形です。
•
1/2 デューティの場合の COM2, COM3 端子の出力および 1/3 デューティの場合の
COM3 端子の出力は , 非選択レベルの出力波形または入出力ポートとして使用可能
となります。
•
ブリンク(点滅)機能を使用する場合は, LCDCブリンキング設定レジスタ1(LCDCB1)
と LCDC ブリンキング設定レジスタ 2 (LCDCB2) により対応するビットを "1" (ON)
に設定してください。ブリンキング間隔はLCDC制御レジスタ1 (LCDCE1)のBLSEL
ビットで 2 種類から選択できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
487
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
H ard war e
Ma nu al
<注意事項>
LCD 表示動作中に , 選択したフレーム周期発生用クロックが停止すると , 交流波形生成回
路が停止するため液晶素子に直流電圧が印加されます。この場合あらかじめ LCD 表示動
作を停止しておく必要があります。メインクロック ( タイムベースタイマ ) またはサブク
ロック ( 時計プリスケーラ ) が停止する条件はクロックモードとスタンバイモードとの選
択によります。また , フレーム周期発生用クロック選択ビット (LCDCC1:CSS) の設定に
従い , タイムベースタイマまたは時計プリスケーラがクリアされるとフレーム周期が影響
を受けます。
■ LCD の駆動波形
LCDはその性質上, 直流駆動を行うと液晶表示素子に化学変化が生じ, 液晶表示素子が
劣化してしまいます。このため LCD コントローラ・ドライバは交流波形生成回路を内
蔵し , 2 フレームを交流化した波形で LCD を駆動します。出力波形には以下の 5 種類
があります。
8 COM モード :
•
1/3 バイアス , 1/8 デューティ出力波形
•
1/4 バイアス , 1/8 デューティ出力波形
4 COM モード :
488
•
1/2 バイアス , 1/2 デューティ出力波形
•
1/3 バイアス , 1/3 デューティ出力波形
•
1/3 バイアス , 1/4 デューティ出力波形
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
Ha rdware
25.6.1
Manual
4 COM モードにおける LCD コントローラ動作時の
出力波形 (1/2 バイアス , 1/2 デューティ )
表示駆動出力は , 分割駆動タイプの 2 フレームを交流化した波形です。
4 COM モードでは , 1/2 バイアスおよび 1/2 デューティのときには , COM0 および
COM1 が表示に使用され , COM2 および COM3 は使用されません。
■ 4 COM モード , 1/2 バイアス , 1/2 デューティ出力波形例
表示はコモン出力とセグメント出力の電位差が最大となる液晶素子が "ON" となりま
す。
ディスプレイ RAM の内容が表 25.6-1 のときの出力波形を図 25.6-5 に示されます。
表 25.6-1 ディスプレイ RAM の内容例
セグメント
COM3
ディスプレイ RAM の内容
COM2
COM1
COM0
SEGn
-
-
0
0
SEG(n+1)
-
-
0
1
-: 使用しない
図 25.6-5 4 COM モード , 1/2 バイアス , 1/2 デューティ比出力波形の例
COM0
V4
V3=V2=V1
Vss
COM1
V4
V3=V2=V1
Vss
COM2
V4
V3=V2=V1
Vss
COM3
V4
V3=V2=V1
Vss
SEGn
V4
V3=V2=V1
Vss
SEG(n+1)
V4
V3=V2=V1
Vss
COM0とSEGnとの
電位差
V4(オン)
V3
Vss
-V3
-V4(オン)
COM1とSEGnとの
電位差
V4(オン)
V3
Vss
-V3
-V4(オン)
COM0とSEG(n+1)との
電位差
V4(オン)
V3
Vss
-V3
-V4(オン)
1フレーム
1サイクル
V1~V4: V1~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
489
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
H ard war e
25.6.2
Ma nu al
4 COM モードにおける LCD コントローラ動作時の
出力波形 (1/3 バイアス , 1/3 デューティ )
4 COM モードでは , 1/3 バイアスおよび 1/3 デューティのときには , COM0, COM1,
および COM2 が表示に使用され , COM3 は使用されません。
■ 4 COM モード , 1/3 バイアス , 1/3 デューティ出力波形例
表示はコモン出力とセグメント出力の電位差が最大となる液晶素子が "ON" となりま
す。
ディスプレイ RAM の内容が表 25.6-2 のときの出力波形を図 25.6-6 に示します。
表 25.6-2 ディスプレイ RAM の内容例
セグメント
COM3
ディスプレイ RAM の内容
COM2
COM1
COM0
SEGn
-
1
0
0
SEG(n+1)
-
1
0
1
-: 使用しない
490
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
Ha rdware
Manual
図 25.6-6 4 COM モード , 1/3 バイアス , 1/3 デューティ比出力波形の例
COM0
V4
V3=V2
V1
Vss
COM1
V4
V3=V2
V1
Vss
COM2
V4
V3=V2
V1
Vss
COM3
V4
V3=V2
V1
Vss
SEGn
V4
V3=V2
V1
Vss
SEG(n+1)
V4
V3=V2
V1
Vss
COM0とSEGnとの
電位差 V4(オン)
V3
V1
Vss
-V1
-V3
-V4(オン)
COM1とSEGnとの
電位差
V4(オン)
V3
V1
Vss
-V1
-V3
-V4(オン)
COM2とSEGnとの
電位差
V4(オン)
V3
V1
Vss
-V1
-V3
-V4(オン)
COM0とSEG(n+1)との
電位差
V4(オン)
V3
V1
Vss
-V1
-V3
-V4(オン)
COM1とSEG(n+1)との
電位差
V4(オン)
V3
V1
Vss
-V1
-V3
-V4(オン)
COM2とSEG(n+1)との
電位差
V4(オン)
V3
V1
Vss
-V1
-V3
-V4(オン)
1フレーム
1サイクル
V1~V4: V1~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
491
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
H ard war e
25.6.3
Ma nu al
4 COM モードにおける LCD コントローラ動作時の
出力波形 (1/3 バイアス , 1/4 デューティ )
4 COM モードでは , 1/3 バイアスおよび 1/4 デューティのときには , COM0 ~ COM3
が表示に使用されます。
■ 4 COM モード , 1/3 バイアス , 1/4 デューティ出力波形例
表示はコモン出力とセグメント出力の電位差が最大となる液晶素子が "ON" となりま
す。
ディスプレイ RAM の内容が表 25.6-3 のときの出力波形を図 25.6-7 に示します。
表 25.6-3 ディスプレイ RAM の内容例
セグメント
492
COM3
ディスプレイ RAM の内容
COM2
COM1
COM0
SEGn
0
1
0
0
SEG(n+1)
0
1
0
1
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
Ha rdware
Manual
図 25.6-7 4 COM モード , 1/3 バイアス , 1/4 デューティ比出力波形の例
COM0
V4
V3=V2
V1
Vss
COM1
V4
V3=V2
V1
Vss
COM2
V4
V3=V2
V1
Vss
COM3
V4
V3=V2
V1
Vss
SEGn
V4
V3=V2
V1
Vss
SEG(n+1)
V4
V3=V2
V1
Vss
COM0とSEGnとの
電位差
V4(オン)
V3
V1
Vss
-V3
-V1
-V4(オン)
COM1とSEGnとの
電位差
V4(オン)
V3
V1
Vss
-V3
-V1
-V4(オン)
COM2とSEGnとの
電位差
V4(オン)
V3
V1
Vss
-V3
-V1
-V4(オン)
COM2とSEG(n+1)との
電位差
V4(オン)
V3
V1
Vss
-V3
-V1
-V4(オン)
COM3とSEG(n+1)との
電位差
V4(オン)
V3
V1
Vss
-V3
-V1
-V4(オン)
1フレーム
1サイクル
V1~V4: V1~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
493
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
H ard war e
25.6.4
Ma nu al
8 COM モードにおける LCD コントローラ動作時の
出力波形 (1/3 バイアス , 1/8 デューティ )
8 COM モードでは , 1/3 バイアスおよび 1/8 デューティのときには , COM0 ~ COM7
が表示に使用されます。
■ 8 COM モード , 1/3 バイアス , 1/8 デューティ出力波形例
表示はコモン出力とセグメント出力の電位差が最大となる液晶素子が "ON" となりま
す。
ディスプレイ RAM の内容が表 25.6-4 のときの出力波形を図 25.6-8 に示します。
表 25.6-4 ディスプレイ RAM の内容例
セグメント
SEGn
494
COM7
COM6
0
0
ディスプレイ RAM の内容
COM5
COM4
COM3
COM2
0
0
0
0
COM1
COM0
0
1
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
Ha rdware
Manual
図 25.6-8 8 COM モード , 1/3 バイアス , 1/8 デューティ比出力波形の例
COM0
V4
V3=V2
V1
Vss
COM1
V4
V3=V2
V1
Vss
COM2
V4
V3=V2
V1
Vss
COM3
V4
V3=V2
V1
Vss
COM4
V4
V3=V2
V1
Vss
COM5
V4
V3=V2
V1
Vss
COM6
V4
V3=V2
V1
Vss
COM7
V4
V3=V2
V1
Vss
SEGn
V4
V3=V2
V1
Vss
COM0-SEGn (オン)
V4
V3
V1
Vss
-V1
-V3
-V4
COM1-SEGn (オフ)
V4
V3
V1
Vss
-V1
-V3
-V4
1フレーム
1サイクル
V1~V4: V1~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
495
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
H ard war e
25.6.5
Ma nu al
8 COM モードにおける LCD コントローラ動作時の
出力波形 (1/4 バイアス , 1/8 デューティ )
8 COM モードでは , 1/4 バイアスおよび 1/8 デューティのときには , COM0 ~ COM7
が表示に使用されます。
■ 8 COM モード , 1/4 バイアス , 1/8 デューティ出力波形例
表示はコモン出力とセグメント出力の電位差が最大となる液晶素子が "ON" となりま
す。
ディスプレイ RAM の内容が表 25.6-5 のときの出力波形を図 25.6-9 に示します。
表 25.6-5 ディスプレイ RAM の内容例
セグメント
SEGn
496
COM7
COM6
0
0
ディスプレイ RAM の内容
COM5
COM4
COM3
COM2
0
0
0
0
COM1
COM0
0
1
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.6 動作説明
Ha rdware
Manual
図 25.6-9 8 COM モード , 1/4 バイアス , 1/8 デューティ比出力波形の例
COM0
V4
V3
V2
V1
Vss
COM1
V4
V3
V2
V1
Vss
COM2
V4
V3
V2
V1
Vss
COM3
V4
V3
V2
V1
Vss
COM4
V4
V3
V2
V1
Vss
COM5
V4
V3
V2
V1
Vss
COM6
V4
V3
V2
V1
Vss
COM7
V4
V3
V2
V1
Vss
SEGn
V4
V3
V2
V1
Vss
COM0-SEGn (オン)
V4
V3
V2
V1
Vss
-V1
-V2
-V3
-V4
V4
V3
V2
V1
Vss
-V1
-V2
-V3
-V4
COM1-SEGn (オフ)
COM2-SEGn (オフ)
COM3-SEGn (オフ)
COM4-SEGn (オフ)
COM5-SEGn (オフ)
COM6-SEGn (オフ)
COM7-SEGn (オフ)
1フレーム
1サイクル
V1~V4: V1~V4端子のそれぞれの電圧
April 4, 2014, MB95F718M_MN702-00014-3v0-J
497
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
H ard war e
25.7
Ma nu al
レジスタ
LCD コントローラのレジスタについて説明します。
表 25.7-1 LCD コントローラのレジスタ一覧
レジスタ略称
498
レジスタ名
参照先
LCDCC1
LCDC 制御レジスタ 1
25.7.1
LCDCC2
LCDC 制御レジスタ 2
25.7.2
LCDCE1
LCDC 許可レジスタ 1
25.7.3
LCDCE2
LCDC 許可レジスタ 2
25.7.4
LCDCE3
LCDC 許可レジスタ 3
25.7.5
LCDCE4
LCDC 許可レジスタ 4
25.7.6
LCDCE5
LCDC 許可レジスタ 5
25.7.7
LCDCE6
LCDC 許可レジスタ 6
25.7.8
LCDCB1
LCDC ブリンキング設定レジスタ 1
25.7.9
LCDCB2
LCDC ブリンキング設定レジスタ 2
25.7.10
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
Ha rdware
25.7.1
Manual
LCDC 制御レジスタ 1 (LCDCC1)
LCDC 制御レジスタ 1 (LCDCC1) はクロックと表示モードを設定し , 電源を制御しま
す。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
CSS
LCDEN
VSEL
MS2
MS1
MS0
FP1
FP0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] CSS: フレーム周期発生用クロック選択ビット
このビットは LCD 表示のフレーム周期を発生するためのクロックを選択します。
LCD コントローラは , このビットが "0" のときメインクロック発振によるタイムベースタイマ出力
で動作し , "1" のときサブクロックにより時計プリスケーラ出力で動作します。
タイムベースタイマ出力で動作中にメインクロックの速度切換え (ギア機能) を行っても , フレーム
周期は影響を受けません。
フレーム周期発生用クロックが切り換わるときに表示がちらつくことがあるため , ブランキング
(LCDCC2:BK=1) などで表示を一時的に停止させてからフレーム周期発生用クロックを切り換えて
ください。
説明
bit7
"0" を書き込んだ場合
LCD 表示のフレーム周期発生用クロックとしてメインクロックを選択します。
"1" を書き込んだ場合
LCD 表示のフレーム周期発生用クロックとしてサブクロックを選択します。
( 注意事項 ) メインストップモードおよびサブクロックモードでは , メインクロックの発振が停止
するため , タイムベースタイマ出力による動作はできません。
[bit6] LCDEN: メインストップ / 時計モード時動作許可ビット
このビットはメインストップモードおよび時計モードの場合に , LCD コントローラに動作を継続さ
せるかどうかを制御します。
説明
bit6
"0" を書き込んだ場合
LCD コントローラを停止します。
"1" を書き込んだ場合
クロックモードがメインストップモードまたは時計モードに遷移した後も LCD
コントローラに動作を継続させます。
( 注意事項 ) メインストップモードまたは時計モード中も LCD コントローラに動作を継続させるに
は , サブクロックを LCD 表示のフレーム周期発生用クロックとして選択してください
(CSS = 1)。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
499
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
H ard war e
Ma nu al
[bit5] VSEL: LCD 駆動電源制御ビット
このビットは内部分割抵抗に通電するかどうかを制御します。
説明
bit5
"0" を書き込んだ場合
内部分割抵抗を遮断します。
"1" を書き込んだ場合
内部分割抵抗を導通します。
( 注意事項 ) 外部分割抵抗を接続する場合 , このビットに "0" を書き込んでください。
[bit4:2] MS[2:0]: 表示モード選択ビット
これらのビットは表示モードを 4 COM モードと 8 COM モードから選択し , 出力波形デューティを
4 種類から選択します。
使用されるコモン端子が選択したデューティ出力モードによって決まります。
これらのビットが "0b000" に設定されたときは , LCD コントローラ・ドライバは表示動作を停止し
ます。
表示モードが切り換わるときに表示がちらつくことがあるため , ブランキング (LCDCC2:BK=1) な
どで表示を一時的に停止させてから表示モードを切り換えてください。
説明
bit4:2
"000" を書き込んだ場合
LCD 表示動作を停止します。
"001" を書き込んだ場合
表示モードとして 4 COM モードを , 出力波形デューティとして 1/2 ( 時間区分番
号 N = 2) をそれぞれ選択します。
"010" を書き込んだ場合
表示モードとして 4 COM モードを , 出力波形デューティとして 1/3 ( 時間区分番
号 N = 3) をそれぞれ選択します。
"011" を書き込んだ場合
表示モードとして 4 COM モードを , 出力波形デューティとして 1/4 ( 時間区分番
号 N = 4) をそれぞれ選択します。
"100" を書き込んだ場合
"101" を書き込んだ場合
"110" を書き込んだ場合
表示モードとして 8 COM モードを , 出力波形デューティとして 1/8 ( 時間区分番
号 N = 8) をそれぞれ選択します。
"111" を書き込んだ場合
( 注意事項 ) クロックモードがストップモードに遷移すると, LCD表示のフレーム周期発生用クロッ
ク ( メインクロックまたはサブクロック ) が停止します。そのため , クロックモードが
ストップモードに遷移する前に , LCD 表示動作を停止 (MS[2:0] = 0b000) してください。
500
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
Ha rdware
Manual
[bit1:0] FP[1:0]: フレーム周期選択ビット
これらのビットは LCD 表示のフレーム周期を選択します。
フレーム周期が切り換わるときに表示がちらつくことがあるため , ブランキング (LCDCC2:BK=1)
などで表示を一時的に停止させてからフレーム周期を切り換えてください。
説明
bit1:0
"00" を書き込んだ場合
メインクロックにより発生されたフ
レーム周期 (LCDCC1:CSS = 0)
(FCH: メインクロック ,
サブクロックにより発生されたフレー
ム周期 (LCDCC1:CSS = 1)
(FCL: サブクロック ,
FCRH: メイン CR クロック )
FCRL: サブ CR クロック )
214  N/FCH*1
26  N/FCL
213  N/FCH*2
26  N/FCRL
213
"01" を書き込んだ場合
 N/FCRH
215  N/FCH*1
27  N/FCL
214  N/FCH*2
27  N/FCRL
214  N/FCRH
"10" を書き込んだ場合
216  N/FCH*1
28  N/FCL
215  N/FCH*2
28  N/FCRL
215  N/FCRH
"11" を書き込んだ場合
217  N/FCH*1
29  N/FCR
216  N/FCH*2
29  N/FCRL
216
 N/FCRH
*1: メインクロックモード
*2: メイン PLL クロックモード
( 注意事項 ) 使用する LCD モジュールに応じて最適フレーム周波数を計算して FP[1:0] ビットを設
定してください。フレーム周期は原発振の周波数の影響を受けます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
501
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
H ard war e
25.7.2
Ma nu al
LCDC 制御レジスタ 2 (LCDCC2)
LCDC 制御レジスタ 2 (LCDCC2) は , 割込みを許可または禁止し , 割込みの状態を示
し , 以下のパラメータを設定します。
• 内部抵抗 (10 k または 100 k)
• 8 COM モードで使用されるバイアス (1/3 または 1/4)
• 表示データまたはブランク画面
• 反転表示
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
RSEL
BLS8
属性
—
—
R/W
R/W
INV
BK
LCDIEN
LCDIF
R/W
R/W
R/W
R/W
初期値
0
0
0
1
0
1
0
0
■ レジスタ機能
[bit7:6] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit5] RSEL: 内部分割抵抗選択ビット
このビットは内部分割抵抗として使用される抵抗を選択します。
説明
bit5
"0" を書き込んだ場合
100 k 抵抗を選択します。
"1" を書き込んだ場合
10 k 抵抗を選択します。
[bit4] BLS8: 8 COM モードバイアス選択ビット
このビットは 8 COM モードでソフトウェアが使用するバイアスの種類を選択します。
説明
bit4
"0" を書き込んだ場合
1/3 バイアスを選択停止します。
"1" を書き込んだ場合
1/4 バイアスを選択停止します。
( 注意事項 ) このビットには , 8 COM モードでも 4 COM モードでもアクセスできますが , 4 COM
モードではこのビットに値を書き込んでも動作に影響はありません。
[bit3] INV: 反転表示制御ビット
このビットは LCD の反転表示を制御します。
説明
bit3
502
"0" を書き込んだ場合
LCD の反転表示を禁止します。
"1" を書き込んだ場合
LCD の反転表示を許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
Ha rdware
Manual
[bit2] BK: 表示ブランキング制御ビット
このビットは表示ブランキングを制御します。
表示ブランキングが選択された場合 (BK = 1) , セグメント出力端子は非選択波形 ( 表示条件となら
ない波形 ) を出力します。
説明
bit2
"0" を書き込んだ場合
LCD に LCD コントローラのディスプレイ RAM を表示させます。
"1" を書き込んだ場合
LCD を非表示にします。
[bit1] LCDIEN: LCDC 割込み要求許可ビット
このビットは LCD フレーム周波数に同期した割込み要求の生成を許可または禁止します。
説明
bit1
"0" を書き込んだ場合
割込み要求の生成を禁止します。
"1" を書き込んだ場合
割込み要求の生成を許可します。
[bit0] LCDIF: LCDC 割込み要求フラグビット
このビットは LCD コントローラがフレーム処理を完了したかどうかを示します。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit0
"0" が読み出された場合
LCD コントローラがフレームを処理中であることを示します。
"1" が読み出された場合
LCD コントローラがフレーム処理を完了したことを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
503
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
H ard war e
25.7.3
Ma nu al
LCDC 許可レジスタ 1 (LCDCE1)
LCDC許可レジスタ1 (LCDCE1)はポート入力を制御し, ブリンク周期を選択し, LCD
コントローラの駆動電源端子を許可します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
PICTL
BLSEL
VE4
VE3
VE2
VE1
—
—
属性
R/W
R/W
R/W
R/W
R/W
R/W
—
—
初期値
0
0
1
1
1
1
0
0
■ レジスタ機能
[bit7] PICTL: ポート入力制御ビット
このビットはセグメント / コモン出力端子と兼用する汎用入出力ポートを制御します。
このビットに "0" が書き込まれると , そういう汎用入出力ポートの入出力機能が禁止され , LCD 出
力時の貫通電流が抑えられます。
このビットに "1" が書き込まれると , そういう汎用入出力ポートの入出力機能が許可され , それらの
端子はセグメント / コモン出力端子ではなく , 汎用入出力ポートとして機能します。
説明
bit7
"0" を書き込んだ場合
セグメント / コモン出力端子と兼用する汎用入出力ポートの入出力機能を禁止
します。
"1" を書き込んだ場合
セグメント / コモン出力端子と兼用する汎用入出力ポートの入出力機能を許可
します。
( 注意事項 ) リセットでそういう汎用入出力ポートなどの入力機能は無効になるため , リセット発
生後 , そういう汎用入出力ポートの入力機能を使用する場合は必ずこのビットに "1" を
書き込んでください。そういう汎用入出力ポートは , セグメント / コモン出力端子とし
て使用されるとき , このビットの設定にかかわらず入力機能が禁止されます。
[bit6] BLSEL: ブリンク間隔選択ビット
このビットはブリンク可能時のブリンク間隔を選択します。
ブリンクは , LCDC ブリンキング設定レジスタ 1 (LCDCB1) と LCDC ブリンキング設定レジスタ 2
(LCDCB2) により制御されます。
ブリンク間隔が 1.0 s の場合 , LCD は 0.5 s 点灯 , 0.5 s 消灯を行い , ブリンク間隔が 0.5 s の場合 , LCD
は 0.25 s 点灯 , 0.25 s 消灯を行います。
説明
bit6
"0" を書き込んだ場合
0.5 s ( サブクロック周波数が 32 kHz の場合 ) をブリンク間隔として選択します。
"1" を書き込んだ場合
1.0 s ( サブクロック周波数が 32 kHz の場合 ) をブリンク間隔として選択します。
[bit5] VE4: V4 機能選択ビット
このビットは V4 端子の機能を選択します。
bit5
504
説明
"0" を書き込んだ場合
V4 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
V4 端子を LCD 駆動電源端子として機能させます。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
Ha rdware
Manual
[bit4] VE3: V3 機能選択ビット
このビットは V3 端子の機能を選択します。
説明
bit4
"0" を書き込んだ場合
V3 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
V3 端子を LCD 駆動電源端子として機能させます。
[bit3] VE2: V2 機能選択ビット
このビットは V2 端子の機能を選択します。
説明
bit3
"0" を書き込んだ場合
V2 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
V2 端子を LCD 駆動電源端子として機能させます。
[bit2] VE1: V1 機能選択ビット
このビットは V1 端子の機能を選択します。
説明
bit2
"0" を書き込んだ場合
V1 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
V1 端子を LCD 駆動電源端子として機能させます。
[bit1:0] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
<注意事項>
内部分割抵抗を使用する場合 , V4 端子が汎用入出力ポートとして使用できないため , VE4
ビットに "1" を書き込んで , V4 端子を LCD 駆動電源端子として機能させてください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
505
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
H ard war e
25.7.4
Ma nu al
LCDC 許可レジスタ 2 (LCDCE2)
LCDC 許可レジスタ 2 (LCDCE2) は COM0 ~ COM7 端子の機能を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
COM7
COM6
COM5
COM4
COM3
COM2
COM1
COM0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] COM7: COM7 機能選択ビット
このビットは COM7 端子の機能を選択します。
説明
bit7
"0" を書き込んだ場合
COM7 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM7 端子をコモン出力端子として機能させます。
( 注意事項 ) 4 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
[bit6] COM6: COM6 機能選択ビット
このビットは COM6 端子の機能を選択します。
説明
bit6
"0" を書き込んだ場合
COM6 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM6 端子をコモン出力端子として機能させます。
( 注意事項 ) 4 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
[bit5] COM5: COM5 機能選択ビット
このビットは COM5 端子の機能を選択します。
説明
bit5
"0" を書き込んだ場合
COM5 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM5 端子をコモン出力端子として機能させます。
( 注意事項 ) 4 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
[bit4] COM4: COM4 機能選択ビット
このビットは COM4 端子の機能を選択します。
bit4
説明
"0" を書き込んだ場合
COM4 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM4 端子をコモン出力端子として機能させます。
( 注意事項 ) 4 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
506
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
Ha rdware
Manual
[bit3] COM3: COM3 機能選択ビット
このビットは COM3 端子の機能を選択します。
説明
bit3
"0" を書き込んだ場合
COM3 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM3 端子をコモン出力端子として機能させます。
[bit2] COM2: COM2 機能選択ビット
このビットは COM2 端子の機能を選択します。
説明
bit2
"0" を書き込んだ場合
COM2 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM2 端子をコモン出力端子として機能させます。
[bit1] COM1: COM1 機能選択ビット
このビットは COM1 端子の機能を選択します。
説明
bit1
"0" を書き込んだ場合
COM1 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM1 端子をコモン出力端子として機能させます。
[bit0] COM0: COM0 機能選択ビット
このビットは COM0 端子の機能を選択します。
説明
bit0
"0" を書き込んだ場合
COM0 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
COM0 端子をコモン出力端子として機能させます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
507
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
H ard war e
25.7.5
Ma nu al
LCDC 許可レジスタ 3 (LCDCE3)
LCDC 許可レジスタ 3 (LCDCE3) は SEG00 ~ SEG07 端子の機能を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
SEG07
SEG06
SEG05
SEG04
SEG03
SEG02
SEG01
SEG00
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] SEG07: SEG07 機能選択ビット
このビットは SEG07 端子の機能を選択します。
説明
bit7
"0" を書き込んだ場合
SEG07 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG07 端子をセグメント出力端子として機能させます。
[bit6] SEG06: SEG06 機能選択ビット
このビットは SEG06 端子の機能を選択します。
説明
bit6
"0" を書き込んだ場合
SEG06 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG06 端子をセグメント出力端子として機能させます。
[bit5] SEG05: SEG05 機能選択ビット
このビットは SEG05 端子の機能を選択します。
説明
bit5
"0" を書き込んだ場合
SEG05 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG05 端子をセグメント出力端子として機能させます。
[bit4] SEG04: SEG04 機能選択ビット
このビットは SEG04 端子の機能を選択します。
説明
bit4
"0" を書き込んだ場合
SEG04 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG04 端子をセグメント出力端子として機能させます。
[bit3] SEG03: SEG03 機能選択ビット
このビットは SEG03 端子の機能を選択します。
bit3
508
説明
"0" を書き込んだ場合
SEG03 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG03 端子をセグメント出力端子として機能させます。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
Ha rdware
Manual
[bit2] SEG02: SEG02 機能選択ビット
このビットは SEG02 端子の機能を選択します。
説明
bit2
"0" を書き込んだ場合
SEG02 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG02 端子をセグメント出力端子として機能させます。
[bit1] SEG01: SEG01 機能選択ビット
このビットは SEG01 端子の機能を選択します。
説明
bit1
"0" を書き込んだ場合
SEG01 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG01 端子をセグメント出力端子として機能させます。
[bit0] SEG00: SEG00 機能選択ビット
このビットは SEG00 端子の機能を選択します。
説明
bit0
"0" を書き込んだ場合
SEG00 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG00 端子をセグメント出力端子として機能させます。
<注意事項>
LCDCE1 レジスタの PICTL ビットが "1" に設定されている場合のみ , LCDCE3 レジスタ
はセグメント出力端子 SEG00 ~ SEG07 を制御できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
509
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
H ard war e
25.7.6
Ma nu al
LCDC 許可レジスタ 4 (LCDCE4)
LCDC 許可レジスタ 4 (LCDCE4) は SEG08 ~ SEG15 端子の機能を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
SEG15
SEG14
SEG13
SEG12
SEG11
SEG10
SEG09
SEG08
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] SEG15: SEG15 機能選択ビット
このビットは SEG15 端子の機能を選択します。
説明
bit7
"0" を書き込んだ場合
SEG15 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG15 端子をセグメント出力端子として機能させます。
[bit6] SEG14: SEG14 機能選択ビット
このビットは SEG14 端子の機能を選択します。
説明
bit6
"0" を書き込んだ場合
SEG14 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG14 端子をセグメント出力端子として機能させます。
[bit5] SEG13: SEG13 機能選択ビット
このビットは SEG13 端子の機能を選択します。
説明
bit5
"0" を書き込んだ場合
SEG13 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG13 端子をセグメント出力端子として機能させます。
[bit4] SEG12: SEG12 機能選択ビット
このビットは SEG12 端子の機能を選択します。
説明
bit4
"0" を書き込んだ場合
SEG12 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG12 端子をセグメント出力端子として機能させます。
[bit3] SEG11: SEG11 機能選択ビット
このビットは SEG11 端子の機能を選択します。
bit3
510
説明
"0" を書き込んだ場合
SEG11 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG11 端子をセグメント出力端子として機能させます。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
Ha rdware
Manual
[bit2] SEG10: SEG10 機能選択ビット
このビットは SEG10 端子の機能を選択します。
説明
bit2
"0" を書き込んだ場合
SEG10 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG10 端子をセグメント出力端子として機能させます。
[bit1] SEG09: SEG09 機能選択ビット
このビットは SEG09 端子の機能を選択します。
説明
bit1
"0" を書き込んだ場合
SEG09 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG09 端子をセグメント出力端子として機能させます。
[bit0] SEG08: SEG08 機能選択ビット
このビットは SEG08 端子の機能を選択します。
説明
bit0
"0" を書き込んだ場合
SEG08 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG08 端子をセグメント出力端子として機能させます。
<注意事項>
LCDCE1 レジスタの PICTL ビットが "1" に設定されている場合のみ , LCDCE4 レジスタ
はセグメント出力端子 SEG08 ~ SEG15 を制御できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
511
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
H ard war e
25.7.7
Ma nu al
LCDC 許可レジスタ 5 (LCDCE5)
LCDC 許可レジスタ 5 (LCDCE5) は SEG16 ~ SEG23 端子の機能を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
SEG23
SEG22
SEG21
SEG20
SEG19
SEG18
SEG17
SEG16
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] SEG23: SEG23 機能選択ビット
このビットは SEG23 端子の機能を選択します。
説明
bit7
"0" を書き込んだ場合
SEG23 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG23 端子をセグメント出力端子として機能させます。
[bit6] SEG22: SEG22 機能選択ビット
このビットは SEG22 端子の機能を選択します。
説明
bit6
"0" を書き込んだ場合
SEG22 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG22 端子をセグメント出力端子として機能させます。
[bit5] SEG21: SEG21 機能選択ビット
このビットは SEG21 端子の機能を選択します。
説明
bit5
"0" を書き込んだ場合
SEG21 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG21 端子をセグメント出力端子として機能させます。
[bit4] SEG20: SEG20 機能選択ビット
このビットは SEG20 端子の機能を選択します。
説明
bit4
"0" を書き込んだ場合
SEG20 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG20 端子をセグメント出力端子として機能させます。
[bit3] SEG19: SEG19 機能選択ビット
このビットは SEG19 端子の機能を選択します。
bit3
512
説明
"0" を書き込んだ場合
SEG19 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG19 端子をセグメント出力端子として機能させます。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
Ha rdware
Manual
[bit2] SEG18: SEG18 機能選択ビット
このビットは SEG18 端子の機能を選択します。
説明
bit2
"0" を書き込んだ場合
SEG18 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG18 端子をセグメント出力端子として機能させます。
[bit1] SEG17: SEG17 機能選択ビット
このビットは SEG17 端子の機能を選択します。
説明
bit1
"0" を書き込んだ場合
SEG17 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG17 端子をセグメント出力端子として機能させます。
[bit0] SEG16: SEG16 機能選択ビット
このビットは SEG16 端子の機能を選択します。
説明
bit0
"0" を書き込んだ場合
SEG16 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG16 端子をセグメント出力端子として機能させます。
<注意事項>
LCDCE1 レジスタの PICTL ビットが "1" に設定されている場合のみ , LCDCE5 レジスタ
はセグメント出力端子 SEG16 ~ SEG23 を制御できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
513
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
H ard war e
25.7.8
Ma nu al
LCDC 許可レジスタ 6 (LCDCE6)
LCDC 許可レジスタ 6 (LCDCE6) は SEG24 ~ SEG31 端子の機能を制御します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
SEG31
SEG30
SEG29
SEG28
SEG27
SEG26
SEG25
SEG24
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] SEG31: SEG31 機能選択ビット
このビットは SEG31 端子の機能を選択します。
説明
bit7
"0" を書き込んだ場合
SEG31 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG31 端子をセグメント出力端子として機能させます。
( 注意事項 ) 8 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
[bit6] SEG30: SEG30 機能選択ビット
このビットは SEG30 端子の機能を選択します。
説明
bit6
"0" を書き込んだ場合
SEG30 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG30 端子をセグメント出力端子として機能させます。
( 注意事項 ) 8 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
[bit5] SEG29: SEG29 機能選択ビット
このビットは SEG29 端子の機能を選択します。
説明
bit5
"0" を書き込んだ場合
SEG29 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG29 端子をセグメント出力端子として機能させます。
( 注意事項 ) 8 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
[bit4] SEG28: SEG28 機能選択ビット
このビットは SEG28 端子の機能を選択します。
bit4
説明
"0" を書き込んだ場合
SEG28 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG28 端子をセグメント出力端子として機能させます。
( 注意事項 ) 8 COM モードでは , このビットに値を書き込んでも動作に影響はありません。
514
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
Ha rdware
Manual
[bit3] SEG27: SEG27 機能選択ビット
このビットは SEG27 端子の機能を選択します。
説明
bit3
"0" を書き込んだ場合
SEG27 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG27 端子をセグメント出力端子として機能させます。
[bit2] SEG26: SEG26 機能選択ビット
このビットは SEG26 端子の機能を選択します。
説明
bit2
"0" を書き込んだ場合
SEG26 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG26 端子をセグメント出力端子として機能させます。
[bit1] SEG25: SEG25 機能選択ビット
このビットは SEG25 端子の機能を選択します。
説明
bit1
"0" を書き込んだ場合
SEG25 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG25 端子をセグメント出力端子として機能させます。
[bit0] SEG24: SEG24 機能選択ビット
このビットは SEG24 端子の機能を選択します。
説明
bit0
"0" を書き込んだ場合
SEG24 端子を汎用入出力ポートとして機能させます。
"1" を書き込んだ場合
SEG24 端子をセグメント出力端子として機能させます。
<注意事項>
LCDCE1 レジスタの PICTL ビットが "1" に設定されている場合のみ , LCDCE6 レジスタ
はセグメント出力端子 SEG24 ~ SEG31 を制御できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
515
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
H ard war e
25.7.9
Ma nu al
LCDC ブリンキング設定レジスタ 1 (LCDCB1)
LCDC ブリンキング設定レジスタ 1 (LCDCB1) はブリンキング機能を許可または禁止
します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
BLD7
BLD6
BLD5
BLD4
BLD3
BLD2
BLD1
BLD0
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能 (8 COM モード )
[bit7] BLD7: S0C7 ブリンキング設定ビット
このビットは SEG00 と COM7 にあるドットのブリンキングを許可または禁止します。
bit7
説明
"0" を書き込んだ場合
SEG00 と COM7 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM7 にあるドットのブリンキングを許可します。
[bit6] BLD6: S0C6 ブリンキング設定ビット
このビットは SEG00 と COM6 にあるドットのブリンキングを許可または禁止します。
bit6
説明
"0" を書き込んだ場合
SEG00 と COM6 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM6 にあるドットのブリンキングを許可します。
[bit5] BLD5: S0C5 ブリンキング設定ビット
このビットは SEG00 と COM5 にあるドットのブリンキングを許可または禁止します。
bit5
説明
"0" を書き込んだ場合
SEG00 と COM5 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM5 にあるドットのブリンキングを許可します。
[bit4] BLD4: S0C4 ブリンキング設定ビット
このビットは SEG00 と COM4 にあるドットのブリンキングを許可または禁止します。
bit4
説明
"0" を書き込んだ場合
SEG00 と COM4 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM4 にあるドットのブリンキングを許可します。
[bit3] BLD3: S0C3 ブリンキング設定ビット
このビットは SEG00 と COM3 にあるドットのブリンキングを許可または禁止します。
bit3
516
説明
"0" を書き込んだ場合
SEG00 と COM3 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM3 にあるドットのブリンキングを許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
Ha rdware
Manual
[bit2] BLD2: S0C2 ブリンキング設定ビット
このビットは SEG00 と COM2 にあるドットのブリンキングを許可または禁止します。
説明
bit2
"0" を書き込んだ場合
SEG00 と COM2 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM2 にあるドットのブリンキングを許可します。
[bit1] BLD1: S0C1 ブリンキング設定ビット
このビットは SEG00 と COM1 にあるドットのブリンキングを許可または禁止します。
説明
bit1
"0" を書き込んだ場合
SEG00 と COM1 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM1 にあるドットのブリンキングを許可します。
[bit0] BLD0: S0C0 ブリンキング設定ビット
このビットは SEG00 と COM0 にあるドットのブリンキングを許可または禁止します。
説明
bit0
"0" を書き込んだ場合
SEG00 と COM0 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM0 にあるドットのブリンキングを許可します。
■ レジスタ機能 (4 COM モード )
[bit7] BLD7: S1C3 ブリンキング設定ビット
このビットは SEG01 と COM3 にあるドットのブリンキングを許可または禁止します。
説明
bit7
"0" を書き込んだ場合
SEG01 と COM3 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM3 にあるドットのブリンキングを許可します。
[bit6] BLD6: S1C2 ブリンキング設定ビット
このビットは SEG01 と COM2 にあるドットのブリンキングを許可または禁止します。
説明
bit6
"0" を書き込んだ場合
SEG01 と COM2 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM2 にあるドットのブリンキングを許可します。
[bit5] BLD5: S1C1 ブリンキング設定ビット
このビットは SEG01 と COM1 にあるドットのブリンキングを許可または禁止します。
説明
bit5
"0" を書き込んだ場合
SEG01 と COM1 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM1 にあるドットのブリンキングを許可します。
[bit4] BLD4: S1C0 ブリンキング設定ビット
このビットは SEG01 と COM0 にあるドットのブリンキングを許可または禁止します。
説明
bit4
"0" を書き込んだ場合
SEG01 と COM0 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM0 にあるドットのブリンキングを許可します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
517
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
H ard war e
Ma nu al
[bit3] BLD3: S0C3 ブリンキング設定ビット
このビットは SEG00 と COM3 にあるドットのブリンキングを許可または禁止します。
bit3
説明
"0" を書き込んだ場合
SEG00 と COM3 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM3 にあるドットのブリンキングを許可します。
[bit2] BLD2: S0C2 ブリンキング設定ビット
このビットは SEG00 と COM2 にあるドットのブリンキングを許可または禁止します。
bit2
説明
"0" を書き込んだ場合
SEG00 と COM2 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM2 にあるドットのブリンキングを許可します。
[bit1] BLD1: S0C1 ブリンキング設定ビット
このビットは SEG00 と COM1 にあるドットのブリンキングを許可または禁止します。
bit1
説明
"0" を書き込んだ場合
SEG00 と COM1 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM1 にあるドットのブリンキングを許可します。
[bit0] BLD0: S0C0 ブリンキング設定ビット
このビットは SEG00 と COM0 にあるドットのブリンキングを許可または禁止します。
bit0
説明
"0" を書き込んだ場合
SEG00 と COM0 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG00 と COM0 にあるドットのブリンキングを許可します。
<注意事項>
518
•
LCDCE1 レジスタの BLSEL ビットでブリンキング間隔を選択してください。
•
ブリンキングが許可されたセグメントはすべて同期してブリンキングします。
•
ブリンキング設定ビットに対応するディスプレイ RAM のビットが "1" のときでも , そ
のブリンキング設定ビットの設定が有効のままです。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
Ha rdware
25.7.10
Manual
LCDC ブリンキング設定レジスタ 2 (LCDCB2)
LCDC ブリンキング設定レジスタ 2 (LCDCB2) はブリンキング機能を許可または禁止
します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
BLD15
BLD14
BLD13
BLD12
BLD11
BLD10
BLD9
BLD8
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能 (8 COM モード )
[bit7] BLD15: S1C7 ブリンキング設定ビット
このビットは SEG01 と COM7 にあるドットのブリンキングを許可または禁止します。
説明
bit7
"0" を書き込んだ場合
SEG01 と COM7 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM7 にあるドットのブリンキングを許可します。
[bit6] BLD14: S1C6 ブリンキング設定ビット
このビットは SEG01 と COM6 にあるドットのブリンキングを許可または禁止します。
説明
bit6
"0" を書き込んだ場合
SEG01 と COM6 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM6 にあるドットのブリンキングを許可します。
[bit5] BLD13: S1C5 ブリンキング設定ビット
このビットは SEG01 と COM5 にあるドットのブリンキングを許可または禁止します。
説明
bit5
"0" を書き込んだ場合
SEG01 と COM5 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM5 にあるドットのブリンキングを許可します。
[bit4] BLD12: S1C4 ブリンキング設定ビット
このビットは SEG01 と COM4 にあるドットのブリンキングを許可または禁止します。
説明
bit4
"0" を書き込んだ場合
SEG01 と COM4 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM4 にあるドットのブリンキングを許可します。
[bit3] BLD11: S1C3 ブリンキング設定ビット
このビットは SEG01 と COM3 にあるドットのブリンキングを許可または禁止します。
説明
bit3
"0" を書き込んだ場合
SEG01 と COM3 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM3 にあるドットのブリンキングを許可します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
519
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
H ard war e
Ma nu al
[bit2] BLD10: S1C2 ブリンキング設定ビット
このビットは SEG01 と COM2 にあるドットのブリンキングを許可または禁止します。
説明
bit2
"0" を書き込んだ場合
SEG01 と COM2 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM2 にあるドットのブリンキングを許可します。
[bit1] BLD9: S1C1 ブリンキング設定ビット
このビットは SEG01 と COM1 にあるドットのブリンキングを許可または禁止します。
説明
bit1
"0" を書き込んだ場合
SEG01 と COM1 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM1 にあるドットのブリンキングを許可します。
[bit0] BLD8: S1C0 ブリンキング設定ビット
このビットは SEG01 と COM0 にあるドットのブリンキングを許可または禁止します。
説明
bit0
"0" を書き込んだ場合
SEG01 と COM0 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG01 と COM0 にあるドットのブリンキングを許可します。
■ レジスタ機能 (4 COM モード )
[bit7] BLD15: S3C3 ブリンキング設定ビット
このビットは SEG03 と COM3 にあるドットのブリンキングを許可または禁止します。
bit7
説明
"0" を書き込んだ場合
SEG03 と COM3 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG03 と COM3 にあるドットのブリンキングを許可します。
[bit6] BLD14: S3C2 ブリンキング設定ビット
このビットは SEG03 と COM2 にあるドットのブリンキングを許可または禁止します。
bit6
説明
"0" を書き込んだ場合
SEG03 と COM2 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG03 と COM2 にあるドットのブリンキングを許可します。
[bit5] BLD13: S3C1 ブリンキング設定ビット
このビットは SEG03 と COM1 にあるドットのブリンキングを許可または禁止します。
bit5
説明
"0" を書き込んだ場合
SEG03 と COM1 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG03 と COM1 にあるドットのブリンキングを許可します。
[bit4] BLD12: S3C0 ブリンキング設定ビット
このビットは SEG03 と COM0 にあるドットのブリンキングを許可または禁止します。
bit4
520
説明
"0" を書き込んだ場合
SEG03 と COM0 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG03 と COM0 にあるドットのブリンキングを許可します。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.7 レジスタ
Ha rdware
Manual
[bit3] BLD11: S2C3 ブリンキング設定ビット
このビットは SEG02 と COM3 にあるドットのブリンキングを許可または禁止します。
説明
bit3
"0" を書き込んだ場合
SEG02 と COM3 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG02 と COM3 にあるドットのブリンキングを許可します。
[bit2] BLD10: S2C2 ブリンキング設定ビット
このビットは SEG02 と COM2 にあるドットのブリンキングを許可または禁止します。
説明
bit2
"0" を書き込んだ場合
SEG02 と COM2 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG02 と COM2 にあるドットのブリンキングを許可します。
[bit1] BLD9: S2C1 ブリンキング設定ビット
このビットは SEG02 と COM1 にあるドットのブリンキングを許可または禁止します。
説明
bit1
"0" を書き込んだ場合
SEG02 と COM1 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG02 と COM1 にあるドットのブリンキングを許可します。
[bit0] BLD8: S2C0 ブリンキング設定ビット
このビットは SEG02 と COM0 にあるドットのブリンキングを許可または禁止します。
説明
bit0
"0" を書き込んだ場合
SEG02 と COM0 にあるドットのブリンキングを禁止します。
"1" を書き込んだ場合
SEG02 と COM0 にあるドットのブリンキングを許可します。
<注意事項>
•
LCDCE1 レジスタの BLSEL ビットでブリンキング間隔を選択してください。
•
ブリンキングが許可されたセグメントはすべて同期してブリンキングします。
•
ブリンキング設定ビットに対応するディスプレイ RAM のビットが "1" のときでも , そ
のブリンキング設定ビットの設定が有効のままです。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
521
第 25 章 LCD コントローラ (MB95770L シリーズ )
25.8 使用上の注意
H ard war e
25.8
Ma nu al
使用上の注意
LCD コントローラ使用上の注意を示します。
•
LCD 端子を汎用入出力ポートとして使用する場合 , その端子に対応する , LCDC 許
可レジスタ (LCDCE1 ~ LCDCE6) のコモン / セグメント選択ビットを "0" に , LCDC
許可レジスタ1のポート入力制御ビット(LCDCE1:PICTL)を"1"に設定してください。
•
LCD 表示動作中に , 選択したフレーム周期発生用クロックが停止すると , 交流波形
生成回路が停止するため液晶素子に直流電圧が印加されます。この場合あらかじめ
LCD 表示動作を停止しておく必要があります。メインクロック ( タイムベースタイ
マ ) またはサブクロック ( 時計プリスケーラ ) が停止する条件はクロックモードと
スタンバイモードの選択によります。また , フレーム周期発生用クロック選択ビッ
ト (LCDCC1:CSS) の設定に従い , タイムベースタイマまたは時計プリスケーラがク
リアされるとフレーム周期が影響を受けます。
ディスプレイ RAM のデータを LCD に出力する動作は CPU がディスプレイ RAM
にアクセスする動作とは独立したタイミングで行われます。ディスプレイ RAM の
書換え間隔が設定した LCD 周期より短い場合は , フレームの表示パターンが異なる
ため , ちらつきが発生することがあります。
•
522
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 26 章
シリアル書込み接続例
シリアル書込み接続例を示します。
26.1 シリアル書込み接続の基本構成
26.2 シリアル書込み接続例
April 4, 2014, MB95F718M_MN702-00014-3v0-J
523
第 26 章 シリアル書込み接続例
26.1 シリアル書込み接続の基本構成
H ard war e
26.1
Ma nu al
シリアル書込み接続の基本構成
MB95710L/770L シリーズは , フラッシュメモリのシリアルオンボード書込みをサ
ポートしています。本節では , 構成について説明します。
■ シリアル書込み接続の基本構成
シリアルオンボード書込みには , Spansion Inc. 製の BGM アダプタ MB2146-07-E または
MB2146-08-E が使用されます。
図 26.1-1 に , シリアル書込み接続の基本構成を示します。
図 26.1-1 シリアル書込み接続の基本構成
ホストインタフェースケーブル
USB
BGMアダプタ
(MB2146-07-E/
MB2146-08-E)
1線式UART
フラッシュメモリ品
ユーザシステム
表 26.1-1 標準シリアルオンボード書込みに使用する端子
端子
機能
説明
VCC
電源電圧供給端子
書込み電圧 (1.8 V ~ 5.5 V) は , ユーザシステムから供給されます。
VSS
GND 端子
フラッシュマイコンプログラマの GND と兼用となっています。
C
バイパスコンデンサ接続端子
バイパスコンデンサに接続してから , グランドに接続してください。
RST
リセット
RST 端子は , VCC に設定 ( プルアップ ) されます。
DBG
1 線式 UART
設定シリアル書込みモード
DBG 端子は , プログラマとの 1 線式 UART 通信を提供します。
特定のタイミングで DBG 端子と VCC 端子に電圧が供給されると , シ
リアル書込みモードが設定されます。
( そのタイミングについては , 図 26.2-1 を参照してください。)
● UART クロック
UART クロックは , 内部 CR クロックにより供給されます。
524
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 26 章 シリアル書込み接続例
26.2 シリアル書込み接続例
Ha rdware
Manual
シリアル書込み接続例
26.2
MCU は , 次のタイミングで PGM モードに遷移します。
■ MCU の PGM モードへの遷移
MCU は , 次のタイミングで PGM モードに遷移します。
シリアルプログラマは , VCC 入力に従って , DBG 端子を制御します。
図 26.2-1 タイミングダイヤグラム
Vcc
H
L
PGM モードに遷移
↓
DBG
H
L
→
April 4, 2014, MB95F718M_MN702-00014-3v0-J
≧1s
←
525
第 26 章 シリアル書込み接続例
26.2 シリアル書込み接続例
H ard war e
Ma nu al
■ シリアル書込み接続例
図 26.2-2 に , シリアル書込みのための接続例を示します。
図 26.2-2 シリアル書込み接続例
IDC10 (オス・コネクタ)
インデックス・マーク
MCU
端子 9
端子 1
1
Vcc
アダプタによる電源
(MB2146-07-Eのみ)
端子10
6
端子 2
Vcc
(TOP VIEW)
MB2146-07-E
MB2146-08-E
名称
No.
DBG
8
Vcc
名称
No.
1
UVCC
1
UVCC
2
VSS
2
VSS
4
RSTOUT
4
RSTOUT
6
POUT3V
8
DBG
8
DBG
IDC10
RST
IC
4
2
Vss
アダプタによる電源のための
MB2146-07-Eのジャンパ接続
2
6
10
ターゲットボード
1
9
プルアップ抵抗値は , 使用するツールや配線長に依存するため , ツールのドキュメント
に従ってプルアップ抵抗を選択してください。
Spansion Inc. 製の BGM アダプタ MB2146-07-E を使用する場合 , 約 2 k ~ 10 k のプ
ルアップ抵抗を使用することを推奨します。
526
MB95F718M_MN702-00014-3v0-J, April 4, 2014
Ha rdware
Manual
第 27 章
デュアルオペレーション
フラッシュメモリ
160/288/480 K ビットデュアルオペレーションフ
ラッシュメモリの機能と動作について説明します。
27.1 概要
27.2 セクタ / バンク構成
27.3 フラッシュメモリ自動アルゴリズムの起動方法
27.4 自動アルゴリズム実行状態の確認
27.5 フラッシュメモリの書込み / 消去
27.6 動作説明
27.7 フラッシュセキュリティ
27.8 レジスタ
27.9 使用上の注意
April 4, 2014, MB95F718M_MN702-00014-3v0-J
527
第 27 章 デュアルオペレーション フラッシュメモリ
27.1 概要
H ard war e
27.1
Ma nu al
概要
デュアルオペレーションフラッシュメモリは , 160 K ビットフラッシュメモリでは
CPU メモリマップの 0x1000 ~ 0x1FFF および 0xC000 ~ 0xFFFF に , 288 K ビット
フラッシュメモリでは CPU メモリマップの 0x1000 ~ 0x1FFF および 0x8000 ~
0xFFFF に , 480 K ビットフラッシュメモリでは CPU メモリマップの 0x1000 ~
0xFFFF に配置されています。
デュアルオペレーションフラッシュは , 上位バンクと下位バンク * で構成されており ,
従来のフラッシュ品では行えなかったバンクごとの消去 / 書込みと読出しの同時実行
が可能です。
*: MB95F718E/F718L/F778E/F778L
上位バンク : 32 K バイト × 1 + 24 K バイト × 1, 下位バンク : 2 K バイト × 2
MB95F716E/F716L/F776E/F776L
上位バンク : 32 K バイト × 1, 下位バンク : 2 K バイト × 2
MB95F714E/F714L/F774E/F774L
上位バンク : 16 K バイト × 1, 下位バンク : 2 K バイト × 2
■ デュアルオペレーションフラッシュメモリの概要
フラッシュメモリへのデータの書込み / 消去の方法には , 以下の方法があります。
•
専用シリアルプログラマによる書込み / 消去
•
プログラム実行による書込み / 消去
プログラム実行によるフラッシュメモリへのデータの書込み / 消去は , フラッシュメモ
リインタフェース回路を介して CPU からの命令により実行できるため , デバイスが回
路基板に実装された状態でプログラムコードやデータを効率的に書き換えられます。
また , セクタ構成も最小 2K バイトと小セクタで , プログラム / データ領域として扱い
やすい構成になっています。
データの書換え方法は , RAM 上におけるプログラム実行またはデュアルオペレーショ
ンにおけるフラッシュメモリ上におけるプログラム実行があります。また , 異なるバン
ク ( 上位バンク / 下位バンク ) における消去 / 書込みと読出しの同時実行が可能です。
デュアルオペレーションフラッシュでは , 次の組合せが可能です。
上位バンク
下位バンク
読出し
書込み / セクタ消去
読出し
書込み / セクタ消去
読出し
チップ消去
528
セクタ消去 ( 消去一時中断 )
書込み
書込み
セクタ消去 ( 消去一時中断 )
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.1 概要
Ha rdware
Manual
■ デュアルオペレーションフラッシュメモリの特長
•
セクタ構成
- 20 K バイト (16 K バイト + 2 K バイト × 2)
- 36 K バイト (32 K バイト + 2 K バイト × 2)
- 60 K バイト (32 K バイト + 24 K バイト + 2 K バイト × 2)
•
2 バンク構成 , 書込み / 消去動作と読込み動作を同時に行える
•
自動アルゴリズム (Embedded Algorithm)
•
消去一時停止 / 消去再開機能を搭載
•
データポーリングフラグまたはトグルビットによる書込み / 消去完了の検出
•
CPU 割込みによる書込み / 消去完了の検出
•
セクタごとの消去が可能 ( セクタ組合せ自由 )
•
JEDEC 標準規格コマンドとの互換性
•
書込み / 消去回数 ( 最小 ):100000 回
•
フラッシュ読込みサイクルタイム ( 最小 ) :1 マシンサイクル
■ フラッシュメモリの書込み / 消去
•
フラッシュメモリは,同一バンクの書込みと読出しを同時に行うことはできません。
•
フラッシュメモリバンクのデータを書込み/消去するには,ほかのバンクまたはRAM
に書込み / 読込みプログラムをコピーしてから , そのプログラムを実行してくださ
い。
•
デュアルオペレーションフラッシュメモリにより , フラッシュメモリ上におけるプ
ログラム実行および割込みを用いた書込み制御が可能です。また , 書込みの際にプ
ログラムを RAM 上へダウンロードして実行する必要もなく , ダウンロードの時間
削減および RAM データの電源瞬断のケアも不要です。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
529
第 27 章 デュアルオペレーション フラッシュメモリ
27.2 セクタ / バンク構成
H ard war e
27.2
Ma nu al
セクタ / バンク構成
デュアルオペレーションフラッシュメモリのセクタ / バンク構成を示します。
■ セクタ / バンク構成
図 27.2-1 に , デュアルオペレーションフラッシュメモリのセクタ / バンク構成を示しま
す。図中アドレスは , 各セクタの上位アドレスと下位アドレスを示します。
● バンク構成
フラッシュメモリの下位バンクは SA0 と SA1 で , 上位バンクは SA2 と SA3 です。
図 27.2-1 デュアルオペレーションフラッシュメモリのセクタ / バンク構成
フラッシュメモリ
(20 K バイト )
SA0: 2 K バイト
SA1: 2 K バイト
フラッシュメモリ
(36 K バイト )
下位
バンク
SA0: 2 K バイト
SA1: 2 K バイト
フラッシュメモリ
(60 K バイト )
下位
バンク
SA0: 2 K バイト
SA1: 2 K バイト
CPU
アドレス
0x1000
下位
バンク
0x17FF
0x1800
0x1FFF
0x2000
SA2: 24 K バイト
-
0x7FFF
0x8000
上位
バンク
SA3: 32 K バイト
SA3: 16 K バイト
上位
バンク
上位
バンク
SA3: 32 K バイト
0xBFFF
0xC000
0xDFFF
0xE000
0xEFFF
0xF000
0xFFFF
530
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.3 フラッシュメモリ自動アルゴリズムの起動方法
Ha rdware
27.3
Manual
フラッシュメモリ自動アルゴリズムの起動方法
フラッシュメモリ自動アルゴリズムを起動するコマンドには , 読出し / リセット , 書
込み , チップ消去 , セクタ消去の 4 種類があります。セクタ消去コマンドで , セクタ
消去の停止 / 再開ができます。
■ コマンドシーケンス表
表 27.3-1 に , フラッシュメモリの書込み / 消去時に使用するコマンドの一覧を示します。
表 27.3-1
コマンドシーケンス
バス書
コマンド
込みサ
シーケンス
イクル
読出し /
リセット
書込み
チップ消去
セクタ消去
アンロック
バイパス
エントリ
アンロック
バイパス
書込み
アンロック
バイパス
リセット
最初の
バス書込み
サイクル
2 回目の
バス書込み
サイクル
3 回目の
バス書込み
サイクル
アドレス データ
アドレス データ
アドレス データ
PA
SA
PD
U
X
any
-
アドレス データ アドレス データ
6 回目の
バス書込み
サイクル
アドレス データ
0xUXXX 0xF0
-
4
0xUAAA 0xAA
0xU554
0x55 0xUAAA 0xA0
6
0xUAAA 0xAA
0xU554
0x55 0xUAAA 0x80 0xUAAA 0xAA 0xU554 0x55 0xUAAA 0x10
6
0xUAAA 0xAA
0xU554
0x55 0xUAAA 0x80 0xUAAA 0xAA 0xU554 0x55
3
0xUAAA 0xAA
0xU554
0x55 0xUAAA 0x20
2
0xUXXX 0xA0
PA
2
0xUXXX 0x90 0xUXXX
セクタ消去再開
-
5 回目の
バス書込み
サイクル
1
セクタ消去一時停止
-
4 回目の
バス書込み
サイクル
-
-
-
-
-
-
PA
PD
-
-
-
-
SA
0x30
-
-
-
-
-
-
PD
-
-
-
-
-
-
-
-
any
-
-
-
-
-
-
-
-
アドレス "0xUXXX" にデータ "0xB0" を入力することによって , セクタ消去を一時停
止します。
アドレス "0xUXXX" にデータ "0x30" を入力することによって , セクタ消去一時停止
後 , 消去を再開します。
SA にデータ "0x30" を入力することによって , 新しい消去セクタを追加します。
消去セクタ追加
: 書込みアドレス
: セクタアドレス ( セクタ内の任意のアドレスを指定する。)
: 書込みデータ
: 上位 4 ビットは , 書込みが許可されているセクタ内の任意のアドレスです。
: 任意の値
: 任意の書込みデータ
April 4, 2014, MB95F718M_MN702-00014-3v0-J
531
第 27 章 デュアルオペレーション フラッシュメモリ
27.3 フラッシュメモリ自動アルゴリズムの起動方法
H ard war e
Ma nu al
<注意事項>
•
表 27.3-1 にあるアドレスは , CPU メモリマップ上の値です。アドレスおよびデータは
すべて 16 進数で表記しています。ただし , "X" は任意の値です。
•
表 27.3-1 のアドレスにおける "U" は任意の値ではなく , アドレスの上位 4 ビット
(bit15 ~ bit12) を表します。
•
すべてのセクタへのデータ書込みが許可されている場合のみ , チップ消去コマンドが
受け入れられます。フラッシュメモリセクタ書込み制御レジスタ 0(SWRE0) のどのセ
クタのビットであっても , "0" に設定されている ( セクタへのデータ書込みが禁止され
ている ) 場合は , チップ消去コマンドは無視されます。
■ コマンドの発行に関する注意事項
コマンドシーケンス表の第一コマンドを発行する前に , 必要なセクタへのデータ書込
みを許可してください。
532
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.4 自動アルゴリズム実行状態の確認
Ha rdware
Manual
自動アルゴリズム実行状態の確認
27.4
フラッシュメモリは , 自動アルゴリズムを用いて書込み / 消去のフローを実行するた
め , フラッシュメモリ内部の動作状態をハードウェアシーケンスフラグによって確認
できます。
■ ハードウェアシーケンスフラグ
● ハードウェアシーケンスフラグの概要
ハードウェアシーケンスフラグは , 以下の 5 ビットの出力で構成されます。
- データポーリングフラグ (DQ7)
- トグルビットフラグ (DQ6)
- タイミングリミットフラグ (DQ5)
- セクタ消去タイマフラグ (DQ3)
- トグルビット 2 フラグ (DQ2)
ハードウェアシーケンスフラグは , 書込みコマンド , チップ消去コマンド , あるいはセ
クタ消去コマンドが終了したかどうか , 消去コードが書き込まれたかおよび読出され
ているセクタが消去セクタであるか否かを示します。
ハードウェアシーケンスフラグの値は , コマンドシーケンス設定後にフラッシュメモ
リ内の対象セクタのアドレスにリードアクセスすることにより確認できます。ハード
ウェアシーケンスフラグは , コマンドが発行されたバンクにのみ出力されることに注
意してください。
表 27.4-1 に , ハードウェアシーケンスフラグのビット割当てを示します。
表 27.4-1
ハードウェアシーケンスフラグのビット割当て
ビット No.
7
6
5
4
3
2
1
0
ハードウェアシーケンスフラグ
DQ7
DQ6
DQ5
-
DQ3
DQ2
-
-
•
書込み / チップ消去 , あるいはセクタ消去コマンドが実行中であるかまたは完了し
ているかを判断するためには , 対応するハードウェアシーケンスフラグまたはフ
ラッシュメモリステータスレジスタのフラッシュメモリ書込み / 消去ステータス
ビット (FSR:RDY) を確認します。書込みまたはチップ消去の完了後 , フラッシュメ
モリは読出し / リセット状態に戻ります。
•
書込み / チップ消去プログラムを作成する際には , DQ2, DQ3, DQ5, DQ6 および DQ7
フラグにより書込み / チップ消去が完了していることを確認してから , データを読
み出すように , プログラムを作成してください。
•
ハードウェアシーケンスフラグは , 2 回目セクタ消去コード書込みおよびその後に
実行されるこれらが有効であるか否かを確認するために使用できます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
533
第 27 章 デュアルオペレーション フラッシュメモリ
27.4 自動アルゴリズム実行状態の確認
H ard war e
Ma nu al
● ハードウェアシーケンスフラグの説明
表 27.4-2 に , ハードウェアシーケンスフラグの機能を示します。
表 27.4-2
ハードウェアシーケンスフラグの機能一覧
状態
通常動作時
の状態遷移
DQ7
DQ6
DQ5
DQ3
DQ2
書込み 
書込み完了
( 書込みアドレス指定時 )
DQ7 
DATA: 7
Toggle 
DATA: 6
0
DATA: 5
0
DATA: 3
0
DATA: 2
チップ / セクタ消去 
消去完了
0 1
Toggle 1
0 1
1
Toggle 1
セクタ消去待ち 
消去開始
0
Toggle
0
0 1
Toggle
消去 
セクタ消去一時停止
( セクタ消去実行中 )
0
Toggle  0
0
1
Toggle
セクタ消去一時停止 
消去再開
( セクタ消去実行中 )
0
0  Toggle
0
1
Toggle
セクタ消去一時停止中
( セクタ消去停止 )
DATA: 7
DATA: 6
DATA: 5
DATA: 3
DATA: 2
DQ7
Toggle
1
0
0
0
Toggle
1
1
Toggle
書込み
異常動作
534
チップ / セクタ消去
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.4 自動アルゴリズム実行状態の確認
Ha rdware
Manual
データポーリングフラグ (DQ7)
27.4.1
データポーリングフラグ (DQ7) は , 自動アルゴリズム実行が進行中もしくは終了状
態であることをデータポーリング機能によって知らせるハードウェアシーケンスフ
ラグです。
■ データポーリングフラグ (DQ7)
表 27.4-3 と表 27.4-4 に , 正常動作時と異常動作時のそれぞれのデータポーリングフラ
グの状態遷移を示します。
表 27.4-3
データポーリングフラグの状態遷移 ( 正常動作時の状態変化 )
動作状態
書込み 
書込み完了
チップ /
セクタ
消去 
消去完了
セクタ消去
待ち 
消去開始
消去 
セクタ消去一時
停止
( セクタ消去実
行中 )
セクタ消去一時
停止 
消去再開
( セクタ消去実
行中 )
セクタ消去
一時停止中
( セクタ消去
停止 )
DQ7
DQ7  
DATA: 7
01
0
0
0
DATA: 7
表 27.4-4
データポーリングフラグの状態遷移 ( 異常動作時の状態変化 )
動作状態
書込み
チップ / セクタ消去
DQ7
DQ7
0
● 書込みの場合
自動書込みアルゴリズム実行中にリードアクセスを行った場合 , フラッシュメモリは
最後に書き込まれたデータの bit7 を反転させた値を DQ7 に出力します。
自動書込みアルゴリズム終了時にリードアクセスを行った場合 , フラッシュメモリは
リードアクセスを行ったアドレスの読出し値の bit7 を DQ7 に出力します。
● チップ / セクタ消去の場合
チップ / セクタ消去の自動アルゴリズム実行中に現在消去しているセクタをリードア
クセスすると , フラッシュメモリの bit7 は "0" を出力します。チップ / セクタ消去が終
了すると , フラッシュメモリの bit7 は "1" を出力します。
● セクタ消去一時停止の場合
•
セクタ消去一時停止時にリードアクセスすると , フラッシュメモリはアドレスの指
し示す番地が消去中のセクタであれば "0" を DQ7 に出力し , 消去中のセクタでなけ
ればアドレスの指し示す番地の読出し値の bit7 (DATA: 7) を出力します。
•
トグルビットフラグ (DQ6) とともにデータポーリングフラグ (DQ7) を参照すること
によって , 現在セクタ一時停止状態であるか , どのセクタが消去中であるかの判定
が可能です。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
535
第 27 章 デュアルオペレーション フラッシュメモリ
27.4 自動アルゴリズム実行状態の確認
H ard war e
Ma nu al
<注意事項>
自動アルゴリズムを起動した場合は , 指定したアドレスへのリードアクセスは無視されま
す。データの読出しは , データポーリングフラグ (DQ7) が "1" に設定された後 , 可能にな
ります。自動アルゴリズム終了後のデータの読出しは , データポーリング終了を確認した
リードアクセスの後に行ってください。
536
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.4 自動アルゴリズム実行状態の確認
Ha rdware
Manual
トグルビットフラグ (DQ6)
27.4.2
トグルビットフラグ (DQ6) は , 自動アルゴリズム実行が進行中 , もしくは終了状態で
あることをトグルビット機能によって知らせるハードウェアシーケンスフラグです。
■ トグルビットフラグ (DQ6)
表 27.4-5 と表 27.4-6 に , 正常動作時と異常動作時のそれぞれのトグルビットフラグの
状態遷移を示します。
表 27.4-5
トグルビットフラグの状態遷移 ( 正常動作時の状態変化 )
動作状態
書込み 
書込み完了
チップ /
セクタ
消去 
消去完了
セクタ消去
待ち 
消去開始
消去 
セクタ消去一時
停止
( セクタ消去実
行中 )
セクタ消去一時
停止 
消去再開
( セクタ消去実
行中 )
セクタ消去
一時停止中
( セクタ消去
停止 )
DQ6
Toggle 
DATA: 6
Toggle  1
Toggle
Toggle  0
0  Toggle
DATA: 6
表 27.4-6
トグルビットフラグの状態遷移 ( 異常動作時の状態変化 )
動作状態
書込み
チップ / セクタ消去
DQ6
Toggle
Toggle
● 書込みとチップ / セクタ消去の場合
•
自動書込みアルゴリズムまたはチップ / セクタ消去の自動アルゴリズムを実行中に
リードアクセスを連続して行った場合 , フラッシュメモリは , 読出しを行うごとに
"1" と "0" を交互にトグル出力します。
•
自動書込みアルゴリズムまたはチップ / セクタ消去の自動アルゴリズムが終了した
後にリードアクセスを連続して行った場合 , フラッシュメモリは読出しを行うごと
にリードアドレスの読出し値の bit6 (DATA: 6) を出力します。
● セクタ消去一時停止時
セクタ消去一時停止時にリードアクセスすると,フラッシュメモリはアドレスの指し示
す番地が消去中のセクタに属する場合には , "0" を出力します。消去中のセクタに属さ
ない場合には , アドレスの指し示す番地の読出し値の bit6 (DATA: 6) を出力します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
537
第 27 章 デュアルオペレーション フラッシュメモリ
27.4 自動アルゴリズム実行状態の確認
H ard war e
Ma nu al
<注意事項>
デュアルオペレーションフラッシュメモリ ( フラッシュメモリ書込み制御プログラムをフ
ラッシュメモリ上で実行する ) を用いる場合 , トグルビットフラグ (DQ6) を使用して書込
み / 消去中の状態を確認することができません。
「27.9 使用上の注意」記載の注意事項を
参照の上 , プログラムを作成してください。
なお , フラッシュメモリ書込み制御プログラムを RAM 上で実行する場合は , 本注意事項
は該当しません。
538
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.4 自動アルゴリズム実行状態の確認
Ha rdware
Manual
タイミングリミット超過フラグ (DQ5)
27.4.3
タイミングリミット超過フラグ (DQ5) は , 自動アルゴリズムの実行時間がフラッシュ
メモリ内の規定時間 ( 書込み / 消去に要する時間 ) を超えてしまったことを示すハー
ドウェアシーケンスフラグです。
■ タイミングリミット超過フラグ (DQ5)
表 27.4-7 と表 27.4-8 に , 正常動作時と異常動作時のフラグそれぞれのタイミングリ
ミット超過フラグの状態遷移を示します。
表 27.4-7
タイミングリミット超過フラグの状態遷移 ( 正常動作時 )
動作状態
書込み 
書込み完了
チップ /
セクタ
消去 
消去完了
セクタ消去
待ち 
消去開始
消去 
セクタ消去一時
停止
( セクタ消去実
行中 )
セクタ消去一時
停止 
消去再開
( セクタ消去実
行中 )
セクタ消去
一時停止中
( セクタ消去
停止 )
DQ5
0  DATA: 5
01
0
0
0
DATA: 5
表 27.4-8
タイミングリミット超過フラグの状態遷移 ( 異常動作時 )
動作状態
書込み
チップ / セクタ消去
DQ5
1
1
● 書込みとチップ / セクタ消去時について
書込みまたはチップ / セクタ消去の自動アルゴリズム起動後にこのフラグにリードア
クセスを行うと , 自動アルゴリズム実行時間が , 規定の時間 ( 書込み / 消去に要する時
間 ) 以内であれば "0" が , また超えている場合は "1" が出力されます。
タイミングリミット超過フラグ (DQ5) は , 自動アルゴリズムが実行中か終了している
かにかかわらず , 書込み / 消去の成功または失敗を確認するために使用できます。タイ
ミングリミット超過フラグ(DQ5)が"1"で, フラッシュメモリステータスレジスタ(FSR)
のフラッシュメモリ書込み / 消去ステータスビット (RDY) が "0" ならば , 書込みは失敗
したと判断できます。
例えば , "0" が書き込まれているフラッシュメモリアドレスに "1" を書き込もうとする
と , フラッシュメモリはロックされます。この場合 , 自動アルゴリズムは終了すること
ができず , その実行時間がフラッシュメモリ内で設定された規定時間を超えてしまう
ため , タイミングリミット超過フラグ (DQ5) は "1" を出力します。DQ5 が "1" であるこ
とは , フラッシュメモリの不良ではなく , それが正しく使用されなかったことを示しま
す。DQ5 が "1" を出力する場合は , リセットコマンドを実行してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
539
第 27 章 デュアルオペレーション フラッシュメモリ
27.4 自動アルゴリズム実行状態の確認
H ard war e
Ma nu al
セクタ消去タイマフラグ (DQ3)
27.4.4
セクタ消去タイマフラグ (DQ3) は , セクタ消去コマンド起動後にセクタ消去待ち時間
中であるか否かを知らせるフラグです。
■ セクタ消去タイマフラグ (DQ3)
表 27.4-9 と表 27.4-10 に , 正常動作時と異常動作時のフラグそれぞれのセクタ消去タイ
マフラグの状態遷移を示します。
表 27.4-9
セクタ消去タイマフラグの状態遷移 ( 正常動作時 )
動作状態
書込み 
書込み完了
チップ /
セクタ
消去 
消去完了
セクタ消去
待ち 
消去開始
消去 
セクタ消去一時
停止
( セクタ消去実
行中 )
セクタ消去一時
停止 
消去再開
( セクタ消去実
行中 )
セクタ消去
一時停止中
( セクタ消去
停止 )
DQ3
0  DATA: 3
1
01
1
1
DATA: 3
表 27.4-10
セクタ消去タイマフラグの状態遷移 ( 異常動作時 )
動作状態
書込み
チップ / セクタ消去
DQ3
0
1
● セクタ消去動作時
•
セクタ消去コマンド起動後にリードアクセスが行われると , セクタ消去タイマフラ
グ (DQ3) はセクタ消去待ち時間中の場合には "0" を , セクタ消去待ち時間を超えて
しまっている場合には "1" を出力します。
•
データポーリング機能やトグルビット機能によって消去アルゴリズムが実行中を
示している場合に (DQ7 = 0, DQ6 はトグル出力を示す ), フラッシュメモリはセクタ
消去を行います。続けて設定されるコマンドがセクタ消去一時停止コマンドでなけ
れば , 消去が終了されるまでそのコマンドは無視されます。
•
このフラグが "0" の場合には , フラッシュメモリはセクタ消去コマンドを受付け可
能です。フラッシュメモリへのセクタ消去コマンドの書込みに先立って , セクタ消
去タイマフラグ (DQ3) が "0" であることを確かめてください。フラグが "1" であっ
た場合には , フラッシュメモリはセクタ消去コマンドの一時停止を受け付けないこ
とがあります。
● セクタ消去一時停止時
セクタ消去一時停止中にリードアクセスが行われると,フラッシュメモリはアドレスの
示す番地が消去中のセクタに属する場合には "1" を出力します。消去中のセクタに属
さない場合にはアドレスの示す番地の読出し値の bit3 (DATA: 3) を出力します。
540
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.4 自動アルゴリズム実行状態の確認
Ha rdware
Manual
トグルビット 2 フラグ (DQ2)
27.4.5
トグルビット 2 フラグ (DQ2) は , セクタ消去一時停止状態で読出しアドレスが消去対
象セクタであるか否かおよび出力データがトグルされたかどうかをトグルビット機
能によって知らせるハードウェアシーケンスフラグです
■ トグルビット 2 フラグ (DQ2)
表 27.4-11 と表 27.4-12 に , 正常動作時と異常動作時のそれぞれのトグルビット 2 フラ
グの状態遷移を示します。
表 27.4-11
トグルビット 2 フラグの状態遷移 ( 正常動作時の状態変化 )
動作状態
書込み 
書込み完了
チップ /
セクタ
消去 
消去完了
セクタ消去
待ち 
消去開始
消去 
セクタ消去一時
停止
( セクタ消去実
行中 )
セクタ消去一時
停止 
消去再開
( セクタ消去実
行中 )
セクタ消去
一時停止中
( セクタ消去
停止 )
DQ2
0  DATA: 2
Toggle  1
Toggle
Toggle
Toggle
DATA: 2
表 27.4-12
トグルビット 2 フラグの状態遷移 ( 異常動作時の状態変化 )
動作状態
書込み
チップ / セクタ消去
DQ2
0
Toggle
● チップ / セクタ消去の場合
•
チップ / セクタ消去の自動アルゴリズムを実行中に消去対象セクタにリードアクセ
スを連続して行った場合 , フラッシュメモリはリードアクセスを行うごとに "1" と
"0" を交互にトグル出力します。
•
チップ / セクタ消去の自動アルゴリズムを実行中に消去対象ではないセクタにリー
ドアクセスを連続して行った場合 , フラッシュメモリはリードアクセスを行うごと
にリードアドレスの読出し値の bit2 (DATA: 2) を出力します。
● セクタ消去一時停止時
•
•
セクタ消去一時停止時に消去対象セクタにリードアクセスを連続して行った場合 ,
フラッシュメモリはリードアクセスを行うごとに "1" と "0" を交互にトグル出力し
ます。
セクタ消去一時停止時に消去対象ではないセクタにリードアクセスを連続して
行った場合 , フラッシュメモリはリードアクセスを行うごとにリードアドレスの読
出し値の bit2 (DATA: 2) を出力します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
541
第 27 章 デュアルオペレーション フラッシュメモリ
27.5 フラッシュメモリの書込み / 消去
H ard war e
27.5
Ma nu al
フラッシュメモリの書込み / 消去
自動アルゴリズムを起動する各コマンドを入力し , フラッシュメモリに読出し / リ
セット , 書込み , チップ消去 , セクタ消去 , セクタ消去一時停止 , セクタ消去再開のそ
れぞれの動作を行う手順を説明します。
■ フラッシュメモリの書込み / 消去の詳細説明
自動アルゴリズムは , 読出し / リセット , 書込み , チップ消去 , セクタ消去 , セクタ消去
一時停止 , セクタ消去再開のコマンドシーケンスを CPU からフラッシュメモリに書き
込むことにより起動できます。CPU からフラッシュメモリへのコマンドシーケンスの
コマンドの書込みは , 必ず連続して行ってください。自動アルゴリズムの終了は , デー
タポーリング機能により確認できます。自動アルゴリズムの正常終了後は , フラッシュ
メモリは読出し / リセット状態に戻ります。
動作について , 以下の順序で説明します。
542
•
読出し / リセット状態への遷移
•
データの書込み
•
全データの消去 ( チップ消去 )
•
任意のデータの消去 ( セクタ消去 )
•
•
セクタ消去の一時停止
セクタ消去の再開
•
アンロックバイパス書込み
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.5 フラッシュメモリの書込み / 消去
Ha rdware
27.5.1
Manual
フラッシュメモリの読出し / リセット状態への遷移
読出し / リセットコマンドを入力して , フラッシュメモリを読出し / リセット状態に
する手順について説明します。
■ フラッシュメモリの読出し / リセット状態への遷移
•
フラッシュメモリを読出し / リセット状態にするには , コマンドシーケンス表の読
出し / リセットコマンドを CPU からフラッシュメモリに送信してください。
•
読出し / リセット状態はフラッシュメモリの初期状態であるため , フラッシュメモ
リは電源投入後またはコマンドの正常終了後は , 必ず読出し / リセット状態となり
ます。読出し / リセット状態は , コマンドの入力待ち状態でもあります。
•
読出し / リセット状態では , フラッシュメモリへのリードアクセスによって , その
データを読み出せます。
•
フラッシュメモリにリードアクセスする場合は , 読出し / リセットコマンドは必要
ありません。コマンドが正常に終了しなかった場合は , 自動アルゴリズムを初期化
するために , 読出し / リセットコマンドを使用してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
543
第 27 章 デュアルオペレーション フラッシュメモリ
27.5 フラッシュメモリの書込み / 消去
H ard war e
27.5.2
Ma nu al
フラッシュメモリへのデータ書込み
書込みコマンドを入力して , フラッシュメモリにデータを書き込む手順について説明
します。
■ フラッシュメモリへのデータ書込み
•
フラッシュメモリにデータを書き込むための自動アルゴリズムを起動するには , コ
マンドシーケンス表の書込みコマンドを連続的に CPU からフラッシュメモリに送
信してください。
•
4 サイクル目に対象のアドレスへデータを書き込むと , 自動アルゴリズムが起動さ
れ自動書込みを開始します。
● アドレッシング方式
書込みは , どのようなアドレスの順番でも , セクタの境界を越えても行えます。1 回の
書込みコマンドによって書き込むことのできるデータは 1 バイトのみです。
● データ書込みに関する注意事項
•
書込みによって , ビットデータを "0" から "1" に戻すことはできません。"0" であっ
たビットデータに "1" が書き込まれると , データポーリング機能 (DQ7), あるいはト
グル動作 (DQ6) が終了せず , フラッシュメモリ素子が不良であると判断され , 自動
アルゴリズムの実行時間が規定の書込み時間を超えてしまうため , タイミングリ
ミット超過フラグ (DQ5) がエラーの発生を示すことになります。読出し / リセット
状態でデータを読み出すと , ビットデータは "0" のままです。ビットデータを "0" か
ら "1" に戻すには , フラッシュメモリの消去を行ってください。
•
書込みの実行中は , すべてのコマンドが無視されます。
•
書込み中にハードウェアリセットが生じた場合は , その時点のアドレスに書込み中
であったデータの整合性は保証されません。チップ消去コマンドまたはセクタ消去
コマンドからデータの書込みをやり直してください。
■ フラッシュメモリ書込み手順
544
•
図 27.5-1 に , フラッシュメモリへのデータ書込み手順の例を示します。ハードウェ
アシーケンスフラグにより , フラッシュメモリ内の自動アルゴリズムの動作状態を
確認できます。この例では , データポーリングフラグ (DQ7) を使用して , フラッシュ
メモリへのデータ書込みの終了を確認しています。
•
フラグチェックのために読み出すデータは , 最後に書込みを行ったアドレスからの
読出しとなります
•
データポーリングフラグ (DQ7) およびタイミングリミット超過フラグ (DQ5) は , 同
時に変更されるため, タイミングリミット超過フラグ(DQ5)が, "1"であっても, デー
タポーリングフラグ (DQ7) を確認してください。
•
同様に , トグルビットフラグ (DQ6) は , タイミングリミット超過フラグ (DQ5) が ,
"1" に変化すると同時にトグルを停止するため , DQ5 が "1" に変化した後に , DQ6 を
確認してください。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.5 フラッシュメモリの書込み / 消去
Ha rdware
Manual
図 27.5-1 フラッシュメモリへの書込み手順の例
書込み開始
FSR:WRE
フラッシュメモリ書込み許可
SWRE0
セクタへのデータ書込みの禁止/許可
("0"を書き込んでセクタへのデータ書込みを禁止,あるいは
"1"を書き込んでセクタへのデータ書込みを許可)
書込みコマンドシーケンス
(1) 0xUAAA ← 0xAA
(2) 0xU554 ← 0x55
(3) 0xUAAA ← 0xA0
(4) 書込みアドレス←書込みデータ
次のアドレス
内部アドレスの読出し
データポーリング
(DQ7)
Data
Data
0
タイミングリミット
(DQ5)
1
内部アドレスの読出し
Data
データポーリング
(DQ7)
Data
書込みエラー
最終アドレス?
NO
YES
FSR:WRE
フラッシュメモリ書込み禁止
書込み完了
April 4, 2014, MB95F718M_MN702-00014-3v0-J
545
第 27 章 デュアルオペレーション フラッシュメモリ
27.5 フラッシュメモリの書込み / 消去
H ard war e
27.5.3
Ma nu al
フラッシュメモリの全データ消去 ( チップ消去 )
チップ消去コマンドを発行して , フラッシュメモリの全データを消去する手順につい
て説明します。
■ フラッシュメモリからのデータ消去 ( チップ消去 )
•
フラッシュメモリから全データを消去するには , コマンドシーケンス表のチップ消
去コマンドを連続的に CPU からフラッシュメモリに送信してください。
•
チップ消去コマンドは , 6 回のバス動作で実行されます。チップ消去は , 書込みコマ
ンドの 6 サイクル目が完了した時点で開始します。
•
チップ消去では , データ消去を開始する前にユーザがフラッシュメモリにデータを
書き込む必要はありません。自動消去アルゴリズム実行中には , フラッシュメモリ
はデータを消去する前にフラッシュメモリのすべてのセルに "0" を自動的に書き込
んでから消去します。
■ チップ消去に関する注意事項
546
•
すべてのセクタへのデータ書込みが許可されている場合のみチップ消去コマンド
が受け付けられます。フラッシュメモリ書込み制御レジスタ 0 (SWRE0) 内の 1 セク
タでもビットが "0" に設定 ( 当該セクタへのデータ書込みが禁止 ) されている場合
は , チップ消去コマンドは無視されます。
•
チップ消去中にハードウェアリセットが生じた場合は , フラッシュメモリ内のデー
タの整合性は保証されません。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.5 フラッシュメモリの書込み / 消去
Ha rdware
27.5.4
Manual
フラッシュメモリの特定データ消去 ( セクタ消去 )
フラッシュメモリの特定セクタの消去のため , セクタ消去コマンドを入力する手順を
説明します。セクタ別消去が可能で , かつ同時に複数のセクタも指定できます。
■ フラッシュメモリの特定データ消去 ( セクタ消去 )
フラッシュメモリの特定セクタからデータを消去するには , コマンドシーケンス表の
セクタ消去コマンドを連続的に CPU からフラッシュメモリに送信してください。
● セクタの指定
•
セクタ消去コマンドは 6 回のバス動作で行われます。6 サイクル目のアドレスに消
去対象のセクタ内のアドレスを指定し , データとしてセクタ消去コード (0x30) を書
き込むことにより最小 35 µs のセクタ消去待ち時間が開始します。
•
複数のセクタを消去する場合は , 上記に続き消去する消去対象のセクタ内のアドレ
スに消去コード (0x30) を書き込んでください。
● 複数セクタ指定する場合の注意事項
•
最後のセクタ消去コードの書込みから最小 35 µs のセクタ消去待ち時間終了後 , 消
去が開始します。
•
複数のセクタを同時に消去する場合は , 消去セクタのアドレスと消去コード ( コマ
ンドシーケンス 6 サイクル目 ) を 35 µs 以内に入力してください。35 µs が経過した
後に消去コードを入力した場合は , セクタ消去待ち時間終了により消去コードは受
け付けられません。
•
セクタ消去コードの連続書込みが有効であるかどうかは , セクタ消去タイマフラグ
(DQ3) で確認できます。
•
セクタ消去タイマフラグ (DQ3) を読み出す場合のアドレスには , 消去しようとして
いるセクタを指定してください。
■ フラッシュメモリセクタ消去手順
•
•
•
フラッシュメモリの自動アルゴリズムの状態をチェックするためにハードウェア
シーケンスフラグを使用できます。図 27.5-2 に , フラッシュメモリセクタ消去手順
の例を示します。この例では , トグルビットフラグ (DQ6) を , セクタ消去の終わり
を確認するために使用します。
トグルビットフラグ (DQ6) は , タイミングリミット超過フラグ (DQ5) が "1" に変更
されると同時に , 出力のトグルを停止します。タイミングリミット超過フラグ
(DQ5) が "1" であっても , トグルビットフラグ (DQ6) を確認してください。
データポーリングフラグ (DQ7) とタイミングリミット超過フラグ (DQ5) は同時に変
化するため , データポーリングフラグ (DQ7) を確認してください。
■ セクタデータ消去の注意事項
データ消去中に , ハードウェアリセットが起こると , フラッシュメモリ内のデータの整
合性は保証されません。ハードウェアリセットが発生した後に , 再度セクタ消去手順を
実行してください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
547
第 27 章 デュアルオペレーション フラッシュメモリ
27.5 フラッシュメモリの書込み / 消去
H ard war e
Ma nu al
図 27.5-2 フラッシュメモリのセクタからのデータ消去手順例
消去開始
FSR:WRE
フラッシュメモリ消去許可
SWRE0
セクタへのデータ書込みの禁止/許可
("0"を書き込んでセクタへのデータ書込みを禁止,あるいは
"1"を書き込んでセクタへのデータ書込みを許可)
消去コマンドシーケンス
(1) 0xUAAA ← 0xAA
(2) 0xU554 ← 0x55
(3) 0xUAAA ← 0x80
(4) 0xUAAA ← 0xAA
(5) 0xU554 ← 0x55
(6) 消去セクタへコード
入力 (0x30)
YES
消去セクタがほかに
あるか
NO
内部アドレスリード
0
内部アドレスリード1
DQ3
内部アドレスリード2
1
消去指定の追加が35 μs以内
にされなかった。残りをや
り直すフラグを立て, いった
ん消去を終える。
トグルビット(DQ6)
データ1=データ2
YES
NO
0
タイミングリミット
(DQ5)
1
内部アドレスリード
内部アドレスリード
NO
トグルビット(DQ6)
データ1=データ2
YES
消去エラー
YES
残りやり直し
フラグ?
NO
FSR:WRE
フラッシュメモリ消去禁止
消去完了
548
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.5 フラッシュメモリの書込み / 消去
Ha rdware
Manual
フラッシュメモリセクタ消去の一時停止
27.5.5
フラッシュメモリのセクタ消去を一時停止するためにセクタ消去一時停止コマンド
を入力する手順を説明します。消去実行中でないセクタからはデータの読出しが可能
です。
■ フラッシュメモリのセクタ消去の一時停止
•
フラッシュメモリセクタ消去を一時停止させるには , コマンドシーケンス表のフ
ラッシュメモリセクタ消去一時停止コマンドを CPU からフラッシュメモリに送信
します。
•
セクタ消去一時停止コマンドは , セクタ消去中に消去を一時停止し , 消去中でない
セクタからデータを読み出せます。
•
セクタ消去一時停止コマンドは , 消去待ち時間を含むセクタ消去時間においてのみ
許可されます。チップ消去時 , あるいは書込み時には , 本コマンドは無視されます。
•
セクタ消去一時停止コマンドは, 消去一時停止コード (0xB0) を書き込むことで実行
されます。このときのアドレスは , 消去指定したセクタ内の任意のアドレスを設定
してください。消去一時停止中に再度 , セクタ消去一時停止コマンドを実行した場
合 , 再度入力したコマンドは無視されます。
•
セクタ消去待ち時間中に , セクタ消去一時停止コマンドを入力した場合 , 直ちにセ
クタ消去待ち時間を終了し , 消去動作を中断して消去停止状態になります。
•
セクタ消去待ち時間後のセクタ消去中に , セクタ消去一時停止コマンドが入力され
ると , 最大 35 µs 後に消去一時停止状態となります。
<注意事項>
セクタ消去一時停止コマンドを発行する場合,セクタ消去コマンド発行後35 µs  2 MCLK
( マシンクロック ) 以上経過してから発行してください。
また , セクタ消去再開コマンドによりセクタ消去再開後 , 再びセクタ消去一時停止コマン
ドを発行する場合 , セクタ消去再開コマンド発行後 2 ms 以上経過してから発行してくだ
さい。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
549
第 27 章 デュアルオペレーション フラッシュメモリ
27.5 フラッシュメモリの書込み / 消去
H ard war e
27.5.6
Ma nu al
フラッシュメモリセクタ消去の再開
フラッシュメモリのセクタ消去の一時停止を再開するためのセクタ消去再開コマン
ドを入力する手順を説明します。
■ フラッシュメモリのセクタ消去の再開
550
•
一時停止しているセクタ消去を再開するには , コマンドシーケンス表のセクタ消去
再開コマンドを CPU からフラッシュメモリに送信してください。
•
セクタ消去再開コマンドは , セクタ消去一時停止コマンドで中断したセクタ消去動
作を再開します。セクタ消去再開コマンドは , 消去再開コード (0x30) を書き込むこ
とによって実行されますが , アドレスは消去を指定したセクタ内の任意のアドレス
を指定してください。
•
セクタ消去中は , セクタ消去再開コマンド入力は無視さます。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.5 フラッシュメモリの書込み / 消去
Ha rdware
27.5.7
Manual
アンロックバイパス書込み
アンロックバイパス状態を説明します。
■ ノーマルコマンド状態からアンロックバイパス状態への遷移
ノーマルコマンド状態でアンロックバイパス書込みコマンドが入力されると , フラッ
シュメモリはアンロックバイパス状態に遷移します。アンロックバイパス状態では , 書
込みコマンドが表 27.3-1 のように 2 サイクルで書込みコマンドを実行できます。
■ アンロックバイパス状態からノーマルコマンド状態への復帰
アンロックバイパス状態でアンロックバイパスリセットコマンドが入力されると , フ
ラッシュメモリはアンロックバイパス状態からノーマルコマンド状態に復帰します。
また , アンロックバイパス状態で , ハードウェアリセットを実行することによっても ,
フラッシュメモリはノーマルコマンド状態に復帰します。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
551
第 27 章 デュアルオペレーション フラッシュメモリ
27.6 動作説明
H ard war e
27.6
Ma nu al
動作説明
デュアルオペレーションフラッシュを使用する際には , 以下について注意してくださ
い。
• 上位バンクの書換え時における割込み発生
• フラッシュメモリステータスレジスタのセクタ変換許可ビット (FSR:SSEN) の設
定手順
■ 上位バンクの書換え時における割込み発生
デュアルオペレーションフラッシュは , 2 つのバンクで構成されていますが , 従来のフ
ラッシュ同様 , 同一バンクにおける消去 / 書込みと読出しの実行は行えません。
SA3 には割込みベクタがあるため , 上位バンク書込み時に割込みが発生した場合には
CPU からの割込みベクタを正常に読み出せません。上位バンクの書換えを行う際には
セクタ変換許可ビットを "1" に設定 (FSR:SSEN = 1) してください。そのため , 割込み発
生時は , SA1 に割込みベクタのデータを読み出すため , FSR:SSEN ビットを "1" に設定す
る前に SA1 と SA3 に同じデータをコピーしておいてください。
■ セクタ変換許可ビット (FSR:SSEN) の設定手順
図 27.6-1 に , セクタ変換許可ビット (FSR:SSEN) の設定手順例を示します。
上位バンクのデータを書き換える際には , FSR:SSEN ビットを "1" に設定してください。
また , フラッシュメモリへの書込み中に FSR:SSEN ビットの設定変更は禁止です。
FSR:SSEN ビットの設定は必ずフラッシュメモリへの書込み開始前または終了後に
行ってください。また , FSR:SSEN ビットを設定する前に , フラッシュメモリの割込み
を禁止とし , FSR:SSEN ビットを設定した後に , フラッシュメモリの割込みを許可して
ください。
図 27.6-1 セクタ変換許可ビット (FSR:SSEN) の設定手順例
フラッシュデータ書換え開始
下位バンクのデータ書換え
書込み作業開始
上位バンクのデータ書換え
SA3のデータを
SA1にコピー
FSR:SSENを“1”に設定
書込み作業開始
フラッシュデータ書換え終了
フラッシュデータ書換え終了
FSR:SSENを“0”に設定
552
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.6 動作説明
Ha rdware
Manual
■ 書込み / 消去中の動作について
フラッシュメモリへの書込み / 消去中に割込みが発生した場合 , 割込みルーチン内でフ
ラッシュメモリへの書込みは禁止されています。
書込み / 消去ルーチンが複数存在する場合 , その書込み / 消去ルーチンが完了してから
ほかの書込み / 消去ルーチンを実行するようにしてください。
フラッシュメモリへの書込み / 消去中に , 書込み / 消去中のモード ( クロックモードお
よびスタンバイモード ) から状態遷移することは禁止されています。書込み / 消去終了
後に状態遷移するようにしてください。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
553
第 27 章 デュアルオペレーション フラッシュメモリ
27.7 フラッシュセキュリティ
H ard war e
27.7
Ma nu al
フラッシュセキュリティ
フラッシュセキュリティコントローラ機能により , フラッシュメモリの内容が外部端
子から読み出されることを防ぎます。
■ フラッシュセキュリティ
フラッシュメモリアドレス (0xFFFC) に保護コード "0x01" を書き込むと , フラッシュメ
モリへのアクセスが制限され , どの外部端子からもフラッシュメモリへの読出し / 書込
みアクセスができなくなります。フラッシュメモリが一度保護されると , チップ消去コ
マンドを実行するまでこの機能のロックを解除することはできません。
保護コードは, フラッシュプログラミングの最後にコーディングしてください。これは,
プログラミング中の不要な保護を回避するためです。
フラッシュメモリを一度保護すると , 再度フラッシュメモリにデータを書き込めるよ
うにするにはチップ消去が必要になります。
554
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.8 レジスタ
Ha rdware
27.8
Manual
レジスタ
デュアルオペレーションフラッシュメモリのレジスタについて説明します。
表 27.8-1
デュアルオペレーションフラッシュメモリのレジスタ一覧
レジスタ略称
レジスタ名
参照先
FSR2
フラッシュメモリステータスレジスタ 2
27.8.1
FSR
フラッシュメモリステータスレジスタ
27.8.2
SWRE0
フラッシュメモリセクタ書込み制御レジスタ 0
27.8.3
FSR3
フラッシュメモリステータスレジスタ 3
27.8.4
FSR4
フラッシュメモリステータスレジスタ 4
27.8.5
April 4, 2014, MB95F718M_MN702-00014-3v0-J
555
第 27 章 デュアルオペレーション フラッシュメモリ
27.8 レジスタ
H ard war e
27.8.1
Ma nu al
フラッシュメモリステータスレジスタ 2 (FSR2)
フラッシュメモリステータスレジスタ 2 (FSR2) について説明します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
PEIEN
PGMEND
PTIEN
PGMTO
EEIEN
ERSEND
ETIEN
ERSTO
属性
R/W
R/W
R/W
R/W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7] PEIEN: PGMEND 割込み許可ビット
このビットは , フラッシュメモリ書込みの完了による割込み要求の発生を許可または禁止します。
説明
bit7
"0" を書き込んだ場合
フラッシュメモリ書込みの完了 (FSR2:PGMEND = 1) による割込みを禁止しま
す。
"1" を書き込んだ場合
フラッシュメモリ書込みの完了 (FSR2:PGMEND = 1) による割込みを許可しま
す。
[bit6] PGMEND: PGMEND 割込み要求フラグビット
このビットはフラッシュメモリ書込みの完了を示します。
PGMEND ビットはフラッシュメモリ自動アルゴリズムの完了直後に "1" に設定されます。
フラッシュメモリ書込み完了による割込み要求の発生が許可されている場合は (FSR2:PEIEN = 1),
PGMEND ビットが "1" に設定されると , 割込み要求が発生します。
フラッシュメモリ書込みが完了した後 , PGMEND ビットが "0" に設定されていた場合 , これ以降フ
ラッシュメモリ書込み / 消去はできません。リセットコマンドを書き込むことによりノーマルコマ
ンド状態に復帰できます。
フラッシュメモリ書込みが失敗した場合 (FSR3:HANG = 1), PGMEND ビットが "0" にクリアされま
す。
このビットへの "0" の書込みはこのビットをクリアします。
このビットに "1" を書き込んでも動作に影響はありません。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit6
556
"0" が読み出された場合
デバイスがコマンド入力待ち状態にあることまたはフラッシュメモリ書込み中
であることを示します。
"1" が読み出された場合
フラッシュメモリ書込みが完了していることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.8 レジスタ
Ha rdware
Manual
[bit5] PTIEN: PGMTO 割込み許可ビット
このビットはフラッシュメモリ書込みの失敗による割込み要求の発生を許可または禁止します。
説明
bit5
"0" を書き込んだ場合
フラッシュメモリ書込みの失敗 (FSR2:PGMTO = 1) による割込みを禁止します。
"1" を書き込んだ場合
フラッシュメモリ書込みの失敗 (FSR2:PGMTO = 1) による割込みを許可します。
[bit4] PGMTO: PGMTO 割込み要求フラグビット
このビットはフラッシュメモリ書込みの失敗を示します。
フラッシュメモリ書込みが失敗すると , PGMTO ビットはフラッシュメモリ自動アルゴリズムの完
了直後に "1" に設定されます。これ以降フラッシュメモリ書込み / 消去はできませんが , リセットコ
マンドを書き込むことによりノーマルコマンド状態に復帰できます。
フラッシュメモリ書込み失敗による割込み要求の発生が許可されている場合は (FSR2:PTIEN = 1),
PGMTO ビットが "1" に設定されると , 割込み要求が発生します。
このビットへの "0" の書込みはこのビットをクリアします。
このビットに "1" を書き込んでも動作に影響はありません。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit4
"0" が読み出された場合
デバイスがコマンド入力待ち状態にあることまたはフラッシュメモリ書込み中
であることを示します。
"1" が読み出された場合
フラッシュメモリ書込みが失敗していることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit3] EEIEN: ERSEND 割込み許可ビット
このビットはフラッシュメモリセクタ消去の完了による割込み要求の発生を許可または禁止しま
す。
説明
bit3
"0" を書き込んだ場合
フラッシュメモリセクタ消去の完了 (FSR2:ERSEND = 1) による割込みを禁止し
ます。
"1" を書き込んだ場合
フラッシュメモリセクタ消去の完了 (FSR2:ERSEND = 1) による割込みを許可し
ます。
April 4, 2014, MB95F718M_MN702-00014-3v0-J
557
第 27 章 デュアルオペレーション フラッシュメモリ
27.8 レジスタ
H ard war e
Ma nu al
[bit2] ERSEND: ERSEND 割込み要求フラグビット
このビットはフラッシュメモリセクタ消去の完了を示します。
ERSEND ビットはフラッシュメモリ自動アルゴリズムの完了直後に "1" に設定されます。
フラッシュメモリセクタ消去完了による割込み要求の発生が許可されている場合(FSR2:EEIEN = 1),
ERSEND ビットが "1" に設定されると , 割込み要求が発生します。
フラッシュメモリセクタ消去が完了した後 , ERSEND ビットが "0" に設定されていた場合 , これ以
降フラッシュメモリ書込み / 消去はできません。リセットコマンドを書き込むことによりノーマル
コマンド状態に復帰できます。
フラッシュメモリセクタ消去が失敗した場合 (FSR3:HANG = 1), ERSEND ビットは "0" にクリアされ
ます。
このビットへの "0" の書込みはこのビットをクリアします。
このビットに "1" を書き込んでも動作に影響はありません。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit2
"0" が読み出された場合
デバイスがコマンド入力待ち状態にあることまたはフラッシュメモリセクタ消
去中であることを示します。
"1" が読み出された場合
フラッシュメモリセクタ消去が完了していることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit1] ETIEN: ERSTO 割込み許可ビット
このビットはフラッシュメモリセクタ消去の失敗による割込み要求の発生を許可または禁止しま
す。
説明
bit1
"0" を書き込んだ場合
フラッシュメモリセクタ消去の失敗 (FSR2:ERSTO = 1) による割込みを禁止しま
す。
"1" を書き込んだ場合
フラッシュメモリセクタ消去の失敗 (FSR2:ERSTO = 1) による割込みを許可しま
す。
[bit0] ERSTO: ERSTO 割込み要求フラグビット
このビットはフラッシュメモリセクタ消去の失敗を示します。
フラッシュメモリセクタ消去に失敗すると , ERSTO ビットはフラッシュメモリ自動アルゴリズムの
完了直後に "1" に設定されます。これ以降フラッシュメモリ書込み / 消去はできませんが , リセット
コマンドを書き込むことによりノーマルコマンド状態に復帰できます。
フラッシュメモリセクタ消去失敗による割込み要求の発生が許可されている場合(FSR2:ETIEN = 1),
ERSTO ビットが "1" に設定されると , 割込み要求が発生します。
このビットへの "0" の書込みはこのビットをクリアします。
このビットに "1" を書き込んでも動作に影響はありません。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit0
558
"0" が読み出された場合
デバイスがコマンド入力待ち状態にあることまたはフラッシュメモリセクタ消
去中であることを示します。
"1" が読み出された場合
フラッシュメモリセクタ消去が失敗したことを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.8 レジスタ
Ha rdware
27.8.2
Manual
フラッシュメモリステータスレジスタ (FSR)
フラッシュメモリステータスレジスタ (FSR) について説明します。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
—
—
RDYIRQ
RDY
予約
IRQEN
WRE
SSEN
属性
—
—
R/W
R
W
R/W
R/W
R/W
初期値
0
0
0
X
0
0
0
0
■ レジスタ機能
[bit7:6] 未定義ビット
読出し値は常に "0" です。これらのビットに値を書き込んでも動作に影響はありません。
[bit5] RDYIRQ: フラッシュメモリ動作フラグビット
このビットはフラッシュメモリの動作状態を示します。
フラッシュメモリ書込み / 消去が完了すると , フラッシュメモリの自動アルゴリズムが終了した時
点で RDYIRQ ビットに "1" が設定されます。
フラッシュメモリ書込み / 消去の完了による割込みが許可されている場合は (FSR:IRQEN=1),
RDYIRQ ビットに "1" が設定されると , 割込み要求が発生します。
フラッシュメモリ書込み / 消去の完了後 , RDYIRQ ビットが "0" に設定されていた場合 , これ以降フ
ラッシュメモリ書込み / 消去はできません。リセットコマンドを書き込むことによりノーマルコマ
ンド状態に復帰できます。
このビットへの "0" の書込みはこのビットをクリアします。
このビットに "1" を書き込んでも動作に影響はありません。
リードモディファイライト (RMW) 系命令でこのビットを読み出すと , 常に "1" が読み出されます。
説明
bit5
"0" が読み出された場合
フラッシュメモリ書込み / 消去が実行中であることを示します。
"1" が読み出された場合
フラッシュメモリ書込み / 消去が完了していることを示します。
"0" を書き込んだ場合
このビットをクリアします。
"1" を書き込んだ場合
動作に影響はありません。
[bit4] RDY: フラッシュメモリ書込み / 消去ステータスビット
このビットはフラッシュメモリの書込み / 消去状態を示します。
RDY ビットが "0" の場合は , フラッシュメモリへのデータの書込み / 消去は禁止されます。
RDY ビットが "0" の場合でも , 読出し / リセットコマンド / セクタ消去一時停止コマンドを受け付
けることができます。書込みまたは消去が終了すると , RDY ビットに "1" が設定されます。
書込み / 消去コマンドの発行後 , RDY ビットが "0" となるまでに 2 マシンクロック (MCLK) サイク
ルの遅延があります。書込み / 消去コマンドの発行後は , この 2 マシンクロックサイクルが経過す
るのを待ってから (NOP 命令を 2 個挿入するなど ) , このビットを読み出してください。
説明
bit4
"0" が読み出された場合
フラッシュメモリ書込み / 消去が実行中であることを示します。( 次のデータの
書込み / 消去は禁止されます。)
"1" が読み出された場合
フラッシュメモリ書込み / 消去が完了していることを示します。( 次のデータの
書込み / 消去は許可されます。)
April 4, 2014, MB95F718M_MN702-00014-3v0-J
559
第 27 章 デュアルオペレーション フラッシュメモリ
27.8 レジスタ
H ard war e
Ma nu al
[bit3] 予約ビット
このビットは常に "0" に設定してください。
[bit2] IRQEN: フラッシュメモリ書込み / 消去割込み許可ビット
このビットはフラッシュメモリの書込み / 消去の完了による割込み要求の発生を許可または禁止し
ます。
bit2
説明
"0" を書き込んだ場合
フラッシュメモリ書込み / 消去による割込みを禁止します。
"1" を書き込んだ場合
フラッシュメモリ書込み / 消去による割込みを許可します。
[bit1] WRE: フラッシュメモリ書込み / 消去許可ビット
このビットはフラッシュメモリ領域の書込み / 消去を許可または禁止します。
WRE ビットはフラッシュメモリの書込み / 消去コマンドの起動前に設定してください。
このビットに "0" が書き込まれた場合 , 書込み / 消去コマンドが入力されても , 書込み / 消去信号は
生成されません。
このビットに "1" が書き込まれた場合 , 書込み / 消去コマンドが入力された後 , フラッシュメモリへ
のデータ書込み / 消去が許可されます。
フラッシュメモリへのデータの書込み / 消去を行わない時には , データが誤ってフラッシュメモリ
に書き込まれたり , フラッシュメモリから消去されたりすることを防ぐために , WRE ビットを "0"
に設定してください。
フラッシュメモリにデータを書き込むには, FSR:WREを"1"に設定して, フラッシュメモリへのデー
タ書込みを許可し , さらにデータが書き込まれるフラッシュメモリのセクタに対応するフラッシュ
メモリセクタ書込み制御レジスタ 0 (SWRE0) を設定してください。フラッシュメモリ書込みが禁止
されている場合 (FSR:WRE = 0) は , セクタに対応するフラッシュセクタ書込み制御レジスタ 0
(SWRE0) のビットが "1" に設定されて書込みが許可されていても , そのフラッシュメモリセクタへ
の書込みアクセスは実行できません。
bit1
説明
"0" を書き込んだ場合
フラッシュメモリ領域の書込み / 消去を禁止します。
"1" を書き込んだ場合
フラッシュメモリ領域の書込み / 消去を許可します。
[bit0] SSEN: セクタスワップ許可ビット
このビットは割込みベクタが存在する領域である上位バンクに位置する SA3 の一部を , 下位バンク
に位置する SA1 と入れ替えるために使用します。
bit0
560
説明
"0" を書き込んだ場合
SA1 を 0x1800 ~ 0x1FFF に , SA3 の 2K バイトを 0xF800 ~ 0xFFFF にマッピン
グします。
"1" を書き込んだ場合
SA3 の 2K バイトを 0x1800 ~ 0x1FFF に , SA1 を 0xF800 ~ 0xFFFF にマッピン
グします。
MB95F718M_MN702-00014-3v0-J, April 4, 2014
第 27 章 デュアルオペレーション フラッシュメモリ
27.8 レジスタ
Ha rdware
Manual
図 27.8-1 FSR:SSEN 設定値におけるアクセスセクタマップ
MB95F716E/F716L/F776E/F776L
CPUアドレス
0x1000
SA0: 2 Kバイト
0x17FF
0x1800
SA1: 2 Kバイト
0x1FFF
0x2000
SA0: 2 Kバイト
SA3: 2 Kバイト
下位バンク
下位バンク
CPUアドレス
0x1000
SA0: 2 Kバイト
0x17FF
0x1800
SA1: 2 Kバイト
0x1FFF
0x2000
-
-
MB95F718E/F718L/F778E/F778L
CPUアドレス
SA0: 2 Kバイト
SA3: 2 Kバイト
下位バンク
MB95F714E/F714L/F774E/F774L
0x1000
SA0: 2 Kバイト
0x17FF
0x1800
SA1: 2 Kバイト
0x1FFF
0x2000
SA2: 24 Kバイト
-
SA0: 2 Kバイト
SA3: 2 Kバイト
SA2: 24 Kバイト
-
0x7FFF
0x8000
上位バンク
上位バンク
0x7FFF
0x8000
上位バンク
0xBFFF
0xC000
SA3: 30 Kバイト
SA3: 30 Kバイト
SA3: 32 Kバイト
SA3: 32 Kバイト
SA3: 14 Kバイト
SA3: 16 Kバイト
0xF7FF
割込み 0xF800
ベクタ
0xFFFF
SA1: 2 Kバイト
FSR:SSEN=0
FSR:SSEN=1
April 4, 2014, MB95F718M_MN702-00014-3v0-J
0xF7FF
0xF800
0xFFFF
SA1: 2 Kバイト
FSR:SSEN=0
FSR:SSEN=1
0xF7FF
0xF800
0xFFFF
SA1: 2 Kバイト
FSR:SSEN=0
FSR:SSEN=1
561
第 27 章 デュアルオペレーション フラッシュメモリ
27.8 レジスタ
H ard war e
27.8.3
Ma nu al
フラッシュメモリセクタ書込み制御レジスタ 0
(SWRE0)
フラッシュメモリセクタ書込み制御レジスタ 0 (SWRE0) は , フラッシュメモリイン
タフェースにあるレジスタで , フラッシュメモリの誤書込み防止機能の設定を行う際
に使用します。
フラッシュメモリセクタ書込み制御レジスタ 0 (SWRE0) には , 個々のセクタ (SA3 ~
SA0) へのデータ書込みを許可 / 禁止するためのビットがあります。各ビットの初期値
は "0" で , 書込み禁止の状態です。SWRE0 のビットに "1" を書き込むと , そのビットに
対応するセクタへのデータ書込みが許可されます。SWRE0 のビットに "0" を書き込む
と , そのビットに対応するセクタへの誤ったデータ書込みが防止されます。SWRE0 の
ビットに "0" を書き込むと , その後そのビットに "1" を書き込んでも , そのビットに対
応するセクタへのデータを書き込むことはできません。再度書き込む場合はリセット
してください。
SWRE0 への書込みは , 必ずバイト書込みで行ってください。ビット操作命令による設
定は禁止されます。
■ レジスタ構成
bit
7
6
5
4
3
2
1
0
Field
予約
予約
予約
予約
SA3E
SA2E
SA1E
SA0E
属性
W
W
W
W
R/W
R/W
R/W
R/W
初期値
0
0
0
0
0
0
0
0
■ レジスタ機能
[bit7:4] 予約ビット
これらのビットは常に "0" に設定してください。
[bit3:0] SA3E, SA2E, SA1E, SA0E: 書込み機能セットアップビット
これらのビットは , データが誤ってフラ