

# RX ファミリ、RL78 ファミリ、78K0R/Kx3-L

R01AN1439JJ0104 Rev.1.04

Micron Technology 社製 P5Q Serial Phase Change Memory 制御ソフトウェア 2016.03.31

#### 要旨

本アプリケーションノートでは、ルネサス エレクトロニクス製 RX ファミリ、RL78 ファミリ、78K0R/Kx3-L を使用した Micron Technology, Inc.社製 P5Q Serial Phase Change Memory 制御方法とサンプルコードの使用方法を説明します。

なお、本サンプルコードは、スレーブデバイスとしての Serial Phase Change Memory を制御するための上位層に位置するソフトウェアです。

別途、マスタデバイスとしての各 MCU 個別の SPI モードを制御するための下位層に位置するソフトウェア (クロック同期式シングルマスタ制御ソフトウェア) を用意していますので、以下から入手してください。なお、クロック同期式シングルマスタ制御ソフトウェアにおいて、新規 MCU が対応可能になった場合でも、本アプリケーションノートの更新が間に合わないことがあります。最新のサポート MCU とその制御ソフトウェアの情報は、以下の URL のページに記載されている「クロック同期式シングルマスタドライバ(下位層ソフトウェア)」を参照してください。

 SPI/QSPI シリアルフラッシュメモリ制御、QSPI シリアル相変化メモリ制御 http://japan.renesas.com/driver/spi\_serial\_flash

#### 動作確認デバイス

Serial Phase Change Memory Micron Technology, Inc.社製 P5Q Serial Phase Change Memory

なお、P5Q Serial Phase Change Memory の製品入手につきましては、Micron Technology, Inc.社にご確認ください。

動作確認に使用した MCU

RX600 シリーズ : RX63N (RSPI を使用) RX100 シリーズ : RX111 (SCI を使用)

: RX111 (RSPI を使用)

RL78/G1x : RL78/G14, RL78/G1C (SAU を使用)

RL78/L1x : RL78/L12, RL78/L13, RL78/L1C (SAU を使用)

上記以外の対象マイコンについては、「3.関連アプリケーションノート」を参照ください。

本アプリケーションノートを他のマイコンへ適用する場合、そのマイコンの仕様にあわせて変更し、十分評価してください。

なお、本アプリケーションノートでは、以下の略称を使用します。

Single-SPI (Single SPI mode による通信)

Dual-SPI (Dual SPI mode による通信)

Quad-SPI (Quad SPI mode による通信)

# 目次

| 1. 仕   | 策                                     | 4        |
|--------|---------------------------------------|----------|
| 2. 動作  | 作確認条件                                 | <b>-</b> |
|        | F唯応未件<br> RX ファミリ                     |          |
|        |                                       |          |
| 2.2 F  | RL78 ファミリ、78K0R/Kx3-L                 | /        |
| 3. 関   | 連アプリケーションノート                          | 13       |
| 3.1 F  | RX ファミリ 関連アプリケーションノートー覧               | 13       |
| 3.2 F  | RL78 ファミリ、78K0R ファミリ 関連アプリケーションノートー覧  | 13       |
| 4. /\- | ードウェア説明                               | 14       |
|        | ハードウェア構成例                             |          |
| 4.1.1  |                                       |          |
| 4.1.2  |                                       |          |
| 4.1.3  |                                       |          |
| 4.1.4  |                                       |          |
| 4.1.5  |                                       |          |
| 4.1.6  |                                       |          |
| 7.1.0  |                                       |          |
| 5. ソ   | フトウェア説明                               | 17       |
| 5.1    | 動作概要                                  | 17       |
| 5.1.1  | Ⅰ データバッファと送信/受信データの関係                 | 17       |
| 5.1.2  | 2 クロック同期式モードで発生させるタイミング               | 18       |
| 5.1.3  | 3 Serial Phase Change Memory の S#端子制御 | 20       |
| 5.1.4  | 4 Serial Phase Change Memory の命令コード   | 21       |
| 5.2    | ソフトウェア構成                              | 22       |
|        | 込要メモリサイズ                              |          |
| 5.3.1  | I RX ファミリ                             | 23       |
| 5.3.2  | 2 RL78 ファミリ、78K0R/Kx3-L               | 25       |
| 5.4    | ファイル構成                                | 28       |
|        | 定数一覧                                  |          |
| 5.5.1  | I 戻り値                                 | 29       |
| 5.5.2  | 2 コマンド定義                              | 29       |
| 5.5.3  | 3 各種定義                                | 30       |
|        | 構造体/共用体一覧                             |          |
|        | 変数一覧                                  |          |
| 5.8    | <b>對数一</b> 覧                          | 34       |
| 5.9    | 男数仕様                                  | 35       |
|        | ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・  |          |
|        | 2 ステータスレジスタ読み出し処理                     |          |
|        | - ・ ・ ・ ・ ・ ・ ・ ・ ・ ・ ・ ・ ・ ・ ・ ・ ・   |          |
|        | 4 WRDIコマンド発行処理                        |          |
|        | 5 データ読み出し処理                           |          |
|        | -                                     |          |

# RX ファミリ、RL78 ファミリ、78K0R/Kx3-L

# Micron Technology 社製 P5Q Serial Phase Change Memory 制御ソフトウェア

|    | 5.9.7  | データ書き込み処理(1Page 書き込み用)                | 44 |
|----|--------|---------------------------------------|----|
|    | 5.9.8  | 消去処理                                  | 47 |
|    | 5.9.9  | ID 読み出し処理                             |    |
|    | 5.9.10 | )ビジーウェイト処理                            | 51 |
| 6. | 応用     | ]例                                    | 53 |
| 6  |        | erial Phase Change Memory 制御ソフトウェアの設定 |    |
|    | 6.1.1  | r_qspi_pcm_p5q.h                      |    |
|    | 6.1.2  | r_qspi_pcm_p5q_sfr.h                  | 56 |
|    | 6.1.3  | r_qspi_pcm_p5q_sub.h                  | 59 |
|    | 6.1.4  | r_qspi_pcm_p5q_sub.c                  | 60 |
|    | 6.1.5  | r_qspi_pcm_p5q_drvif.c                | 62 |
|    | 6.1.6  | r_qspi_pcm_p5q_sfr_rl78.c             | 65 |
| 7. | 使用     | 上の注意事項                                | 66 |
| 7  | '.1 組  | み込み時の注意事項                             | 66 |
| 7  | '.2 +  | ·ャッシュ搭載の MCU を使用する場合                  | 66 |
| 7  |        | 容量に対応する場合                             |    |
| 7  | '.4 他  | スレーブデバイスを使用する場合                       | 66 |
| 7  |        | 源投入後の電圧安定待ち時間について                     |    |
| 7  | '.6 Se | erial Phase Change Memory の使用制限について   | 67 |

#### 1. 仕様

ルネサス エレクトロニクス製 MCU を使用し、Micron Technology, Inc.社製 P5Q Serial Phase Change Memory を制御します。

別途、MCU 個別のクロック同期式シングルマスタ制御ソフトウェアが必要です。

表 1-1 に使用する周辺機能と用途を、図 1-1 に使用例を示します。

以下に、機能概略を示します。

- マスタデバイスをルネサス エレクトロニクス製 MCU、スレーブデバイスを Micron Technology, Inc.社製 P5Q Serial Phase Change Memory としたデバイスドライバです。
- MCU 内蔵のシリアル通信機能(クロック同期式モード)を使用し、Single-SPI、Dual-SPI、Quad-SPI により制御します。
- ユーザ設定したシリアル通信機能1チャネルの使用が可能です。複数チャネルの使用はできません。
- 同一型名、かつ最大 2 個の Serial Phase Change Memory の制御が可能です。
- 通信速度レートは、ユーザ設定可能です。
- ビッグエンディアン/リトルエンディアンでの動作が可能です。(使用 MCU 依存)

| 周辺機能            | 用途                      |
|-----------------|-------------------------|
| MCU 内蔵のシリアル通信機能 | シリアル通信機能(クロック同期式モード)による |
| (クロック同期式モード)    | SPI スレーブデバイスとの通信        |
|                 | 1ch(必須)                 |
| Port            | SPI スレーブデバイスセレクト制御信号用   |
|                 | 使用デバイス数分のポートが必要(必須)     |

表 1-1 使用する周辺機能と用途



図 1-1 使用例

### 2. 動作確認条件

本アプリケーションノートのサンプルコードは、下記の条件で動作を確認しています。

### 2.1 RX ファミリ

#### (1) RX63N RSPI の場合

表 2-1 動作確認条件

| 項目            | 内容                                                       |
|---------------|----------------------------------------------------------|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory |
| 評価に使用したマイコン   | RX63N グループ(プログラム ROM 1MB/RAM 128KB)                      |
| 動作周波数         | ICLK: 96MHz、PCLK: 48MHz                                  |
| 動作電圧          | 3.3V                                                     |
| 統合開発環境        | ルネサス エレクトロニクス製                                           |
|               | High-performance embedded Workshop Version 4.09.01.007   |
| Cコンパイラ        | ルネサス エレクトロニクス製                                           |
|               | RX ファミリ用 C/C++コンパイラパッケージ (ツールチェーン 1.2.1.0)               |
|               | コンパイルオプション                                               |
|               | 統合開発環境のデフォルト設定を使用しています。                                  |
| エンディアン        | ビッグエンディアン/リトルエンディアン                                      |
| サンプルコードのバージョン | Ver.2.20                                                 |
| 評価に使用したソフトウェア | RX63N 用 RSPI を使ったクロック同期式シングルマスタ制御ソフトウェア                  |
|               | Ver.2.04                                                 |
| 評価に使用した使用ボード  | Renesas Starter Kit for RX63N                            |

#### (2) RX111 RSPI の場合

表 2-2 動作確認条件

| 項目            | 内容                                                       |
|---------------|----------------------------------------------------------|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory |
| 評価に使用したマイコン   | RX111 グループ(プログラム ROM 128KB RAM 16KB)                     |
| 動作周波数         | ICLK: 32MHz、PCLK: 32MHz                                  |
| 動作電圧          | 3.3V                                                     |
| 統合開発環境        | ルネサス エレクトロニクス製                                           |
|               | CubeSuite+ V2.01.00                                      |
| Cコンパイラ        | ルネサス エレクトロニクス製                                           |
|               | RX ファミリ用 C/C++コンパイラケッケージ (ツールチェーン 2.01.00)               |
|               | コンパイルオプション                                               |
|               | 総合開発環境のデフォルト設定(※1)を使用しています。                              |
|               | ※1:最適化レベル"2"、最適化方法"サイズ優先"                                |
| エンディアン        | ビッグエンディアン/リトルエンディアン                                      |
| サンプルコードのバージョン | Ver.2.21 R01                                             |
| 評価に使用したソフトウェア | RX210, RX21A, RX220, RX63N, RX63T, RX111 グループ RSPI を使った  |
|               | クロック同期式シングルマスタ制御ソフトウェア(R01AN1196JJ) Ver.2.04             |
|               | R04                                                      |
| 評価に使用した使用ボード  | Renesas Starter Kit for RX111                            |

#### (3) RX111 SCI の場合

表 2-3 動作確認条件

| 項目            | 内容                                                       |
|---------------|----------------------------------------------------------|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory |
| 評価に使用したマイコン   | RX111 グループ(プログラム ROM 128KB RAM 16KB)                     |
| 動作周波数         | ICLK: 32MHz、PCLK: 32MHz                                  |
| 動作電圧          | 3.3V                                                     |
| 統合開発環境        | ルネサス エレクトロニクス製                                           |
|               | CubeSuite+ V2.01.00                                      |
| Cコンパイラ        | ルネサス エレクトロニクス製                                           |
|               | RX ファミリ用 C/C++コンパイラケッケージ (ツールチェーン 2.01.00)               |
|               | コンパイルオプション                                               |
|               | 総合開発環境のデフォルト設定(※1)を使用しています。                              |
|               | ※1:最適化レベル"2"、最適化方法"サイズ優先"                                |
| エンディアン        | ビッグエンディアン/リトルエンディアン                                      |
| サンプルコードのバージョン | Ver.2.21 R01                                             |
| 評価に使用したソフトウェア | RX210, RX21A, RX220, RX63N, RX63T, RX111 グループ SCI を使った   |
|               | クロック同期式シングルマスタ制御ソフトウェア(R01AN1229JJ) Ver.2.01             |
|               | R05                                                      |
| 評価に使用した使用ボード  | Renesas Starter Kit for RX111                            |

## 2.2 RL78 ファミリ、78K0R/Kx3-L

(1) RL78/G14 SAU 統合開発環境 CS+ for CA,CX の場合(コンパイラ:CA78K0R)

表 2-4 動作確認条件

| 項目            | 内容                                                       |
|---------------|----------------------------------------------------------|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory |
| 評価に使用したマイコン   | RL78/G14(プログラム ROM 256KB/RAM 24KB)                       |
| 動作周波数         | メイン・システム・クロック: 24MHz                                     |
|               | CPU/周辺ハードウェア・クロック: 24MHz                                 |
|               | シリアル・クロック:6MHz                                           |
| 動作電圧          | 3.3V                                                     |
| 統合開発環境        | ルネサス エレクトロニクス製 CS+ for CA,CX V3.01.00                    |
| Cコンパイラ        | ルネサス エレクトロニクス製                                           |
|               | RL78,78K0R コンパイラ CA78K0R V1.71                           |
|               | コンパイルオプション                                               |
|               | 統合開発環境のデフォルト設定("-qx2")を使用しています。                          |
| サンプルコードのバージョン | Ver.2.22                                                 |
| 評価に使用したソフトウェア | RL78/G14、RL78/G1C、RL78/L12、RL78/L13、RL78/L1C グループ シリ     |
|               | アル・アレイ・ユニットの CSI モードを使ったクロック同期式シングルマ                     |
|               | スタ制御ソフトウェア(R01AN1195JJ) Ver.2.05                         |
| 評価に使用した使用ボード  | Renesas Starter Kit for RL78/G14                         |

#### (2) RL78/G14 SAU 統合開発環境 CS+ for CC の場合 (コンパイラ: CC-RL)

表 2-5 動作確認条件

| 項目            | 内容                                                       |
|---------------|----------------------------------------------------------|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory |
| 評価に使用したマイコン   | RL78/G14(プログラム ROM 256KB/RAM 24KB)                       |
| 動作周波数         | メイン・システム・クロック: 24MHz                                     |
|               | CPU/周辺ハードウェア・クロック: 24MHz                                 |
|               | シリアル・クロック:6MHz                                           |
| 動作電圧          | 3.3V                                                     |
| 統合開発環境        | ルネサス エレクトロニクス製 CS+ for CC V3.03.00                       |
| Cコンパイラ        | ルネサス エレクトロニクス製 RL78 コンパイラ CC-RL V1.02.00                 |
|               | コンパイルオプション                                               |
|               | 統合開発環境のデフォルト設定 (既定の最適化を行う(なし)) を使用してい                    |
|               | ます。                                                      |
| サンプルコードのバージョン | Ver.2.22                                                 |
| 評価に使用したソフトウェア | RL78/G14、RL78/G1C、RL78/L12、RL78/L13、RL78/L1C グループ シリ     |
|               | アル・アレイ・ユニットの CSI モードを使ったクロック同期式シングルマ                     |
|               | スタ制御ソフトウェア(R01AN1195JJ) Ver.2.05                         |
| 評価に使用した使用ボード  | Renesas Starter Kit for RL78/G14                         |

#### (3) RL78/G14 SAU 統合開発環境 IAR Embedded Workbench の場合

表 2-6 動作確認条件

| 項目            | 内容                                                       |
|---------------|----------------------------------------------------------|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory |
| 評価に使用したマイコン   | RL78/G14(プログラム ROM 256KB/RAM 24KB)                       |
| 動作周波数         | メイン・システム・クロック: 24MHz                                     |
|               | CPU/周辺ハードウェア・クロック: 24MHz                                 |
|               | シリアル・クロック:6MHz                                           |
| 動作電圧          | 3.3V                                                     |
| 統合開発環境        | IAR Systems 製                                            |
|               | IAR Embedded Workbench for Renesas RL78 (Ver.1.30.2)     |
| Cコンパイラ        | IAR Systems 製                                            |
|               | IAR Assembler for Renesas RL78 (Ver.1.30.2.50666)        |
|               | IAR C/C++ Compiler for Renesas RL78 (Ver.1.30.2.50666)   |
|               | コンパイルオプション                                               |
|               | 統合開発環境のデフォルト設定("レベル 低")を使用しています。                         |
| サンプルコードのバージョン | Ver.2.21                                                 |
| 評価に使用したソフトウェア | シリアル・アレイ・ユニットの CSI モードを使ったクロック同期式シング                     |
|               | ルマスタ制御ソフトウェア Ver.2.03                                    |
| 評価に使用した使用ボード  | Renesas Starter Kit for RL78/G14                         |

#### (4) RL78/G1C SAU 統合開発環境 CubeSuite+の場合

表 2-7 動作確認条件

| 項目            | 内容                                                        |
|---------------|-----------------------------------------------------------|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory  |
| 評価に使用したマイコン   | RL78/G1C(プログラム ROM 32KB/RAM 5.5KB)                        |
| 動作周波数         | メイン・システム・クロック: 24MHz                                      |
|               | CPU/周辺ハードウェア・クロック: 24MHz                                  |
|               | シリアル・クロック: 12MHz                                          |
| 動作電圧          | 3.3V                                                      |
| 統合開発環境        | ルネサス エレクトロニクス製 CubeSuite+ V2.01.00                        |
| Cコンパイラ        | ルネサス エレクトロニクス製                                            |
|               | CubeSuite+ RL78,78K0R コンパイラ CA78K0R V1.70                 |
|               | コンパイルオプション                                                |
|               | 統合開発環境のデフォルト設定("-qx2")を使用しています。                           |
| サンプルコードのバージョン | Ver.2.21 R01                                              |
| 評価に使用したソフトウェア | RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C グループ シリア |
|               | ル・アレイ・ユニットの CSI モードを使ったクロック同期式シングルマス                      |
|               | タ制御ソフトウェア(R01AN1195JJ0103) Ver.2.03                       |
| 評価に使用した使用ボード  | Renesas RL78/G1C ターゲット・ボード QB-R5F10JGC-TB                 |

### (5) RL78/G1C SAU 統合開発環境 IAR Embedded Workbench の場合

表 2-8 動作確認条件

| 項目            | 内容                                                        |
|---------------|-----------------------------------------------------------|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory  |
| 評価に使用したマイコン   | RL78/G1C(プログラム ROM 32KB/RAM 5.5KB)                        |
| 動作周波数         | メイン・システム・クロック: 24MHz                                      |
|               | CPU/周辺ハードウェア・クロック: 24MHz                                  |
|               | シリアル・クロック:12MHz                                           |
| 動作電圧          | 3.3V                                                      |
| 統合開発環境        | IAR Systems 製                                             |
|               | IAR Embedded Workbench for Renesas RL78 (Ver.1.30.5)      |
| Cコンパイラ        | IAR Systems 製                                             |
|               | IAR Assembler for Renesas RL78 (Ver.1.30.4.50715)         |
|               | IAR C/C++ Compiler for Renesas RL78 (Ver.1.30.5.50715)    |
|               | コンパイルオプション                                                |
|               | 統合開発環境のデフォルト設定("レベル 低")を使用しています。                          |
| サンプルコードのバージョン | Ver.2.21 R01                                              |
| 評価に使用したソフトウェア | RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C グループ シリア |
|               | ル・アレイ・ユニットの CSI モードを使ったクロック同期式シングルマス                      |
|               | タ制御ソフトウェア(R01AN1195JJ0103) Ver.2.03                       |
| 評価に使用した使用ボード  | Renesas RL78/G1C ターゲット・ボード QB-R5F10JGC-TB                 |

#### (6) RL78/L12 SAU 統合開発環境 CubeSuite+の場合

表 2-9 動作確認条件

| 項目            | 内容                                                        |
|---------------|-----------------------------------------------------------|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory  |
| 評価に使用したマイコン   | RL78/L12(プログラム ROM 32KB / RAM 1.5KB)                      |
| 動作周波数         | メイン・システム・クロック: 24MHz                                      |
|               | CPU/周辺ハードウェア・クロック: 24MHz                                  |
|               | シリアル・クロック:6MHz                                            |
| 動作電圧          | 3.3V                                                      |
| 統合開発環境        | ルネサス エレクトロニクス製 CubeSuite+ V2.01.00                        |
| Cコンパイラ        | ルネサス エレクトロニクス製                                            |
|               | CubeSuite+ RL78,78K0R コンパイラ CA78K0R V1.70                 |
|               | コンパイルオプション                                                |
|               | 統合開発環境のデフォルト設定("-qx2")を使用しています。                           |
| サンプルコードのバージョン | Ver.2.21 R01                                              |
| 評価に使用したソフトウェア | RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C グループ シリア |
|               | ル・アレイ・ユニットの CSI モードを使ったクロック同期式シングルマス                      |
|               | タ制御ソフトウェア(R01AN1195JJ0103) Ver.2.03                       |
| 評価に使用した使用ボード  | Renesas Starter Kit for RL78/L12                          |

### (7) RL78/L12 SAU 統合開発環境 IAR Embedded Workbench の場合

表 2-10 動作確認条件

| 項目            | 内容                                                        |  |  |
|---------------|-----------------------------------------------------------|--|--|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory  |  |  |
| 評価に使用したマイコン   | RL78/L12(プログラム ROM 32KB / RAM 1.5KB)                      |  |  |
| 動作周波数         | メイン・システム・クロック: 24MHz                                      |  |  |
|               | CPU/周辺ハードウェア・クロック: 24MHz                                  |  |  |
|               | シリアル・クロック:6MHz                                            |  |  |
| 動作電圧          | 3.3V                                                      |  |  |
| 統合開発環境        | IAR Systems 製                                             |  |  |
|               | IAR Embedded Workbench for Renesas RL78 (Ver.1.30.5)      |  |  |
| Cコンパイラ        | IAR Systems 製                                             |  |  |
|               | IAR Assembler for Renesas RL78 (Ver.1.30.4.50715)         |  |  |
|               | IAR C/C++ Compiler for Renesas RL78 (Ver.1.30.5.50715)    |  |  |
|               | コンパイルオプション                                                |  |  |
|               | 統合開発環境のデフォルト設定("レベル 低")を使用しています。                          |  |  |
| サンプルコードのバージョン | Ver.2.21 R01                                              |  |  |
| 評価に使用したソフトウェア | RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C グループ シリア |  |  |
|               | ル・アレイ・ユニットの CSI モードを使ったクロック同期式シングルマス                      |  |  |
|               | タ制御ソフトウェア(R01AN1195JJ0103) Ver.2.03                       |  |  |
| 評価に使用した使用ボード  | Renesas Starter Kit for RL78/L12                          |  |  |

#### (8) RL78/L13 SAU 統合開発環境 CubeSuite+の場合

表 2-11 動作確認条件

| 項目            | 内容                                                        |  |  |
|---------------|-----------------------------------------------------------|--|--|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory  |  |  |
| 評価に使用したマイコン   | RL78/L13(プログラム ROM 128KB / RAM 8KB)                       |  |  |
| 動作周波数         | メイン・システム・クロック: 24MHz                                      |  |  |
|               | CPU/周辺ハードウェア・クロック: 24MHz                                  |  |  |
|               | シリアル・クロック:6MHz                                            |  |  |
| 動作電圧          | 3.3V                                                      |  |  |
| 統合開発環境        | ルネサス エレクトロニクス製 CubeSuite+ V2.01.00                        |  |  |
| Cコンパイラ        | ルネサス エレクトロニクス製                                            |  |  |
|               | CubeSuite+ RL78,78K0R コンパイラ CA78K0R V1.70                 |  |  |
|               | コンパイルオプション                                                |  |  |
|               | 統合開発環境のデフォルト設定("-qx2")を使用しています。                           |  |  |
| サンプルコードのバージョン | Ver.2.21 R01                                              |  |  |
| 評価に使用したソフトウェア | RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C グループ シリア |  |  |
|               | ル・アレイ・ユニットの CSI モードを使ったクロック同期式シングルマス                      |  |  |
|               | タ制御ソフトウェア(R01AN1195JJ0103) Ver.2.03                       |  |  |
| 評価に使用した使用ボード  | Renesas Starter Kit for RL78/L13                          |  |  |

### (9) RL78/L13 SAU 統合開発環境 IAR Embedded Workbench の場合

表 2-12 動作確認条件

| 項目            | 内容                                                        |  |  |
|---------------|-----------------------------------------------------------|--|--|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory  |  |  |
| 評価に使用したマイコン   | RL78/L13(プログラム ROM 128KB / RAM 8KB)                       |  |  |
| 動作周波数         | メイン・システム・クロック: 24MHz                                      |  |  |
|               | CPU/周辺ハードウェア・クロック: 24MHz                                  |  |  |
|               | シリアル・クロック:6MHz                                            |  |  |
| 動作電圧          | 3.3V                                                      |  |  |
| 統合開発環境        | IAR Systems 製                                             |  |  |
|               | IAR Embedded Workbench for Renesas RL78 (Ver.1.30.5)      |  |  |
| Cコンパイラ        | IAR Systems 製                                             |  |  |
|               | IAR Assembler for Renesas RL78 (Ver.1.30.4.50715)         |  |  |
|               | IAR C/C++ Compiler for Renesas RL78 (Ver.1.30.5.50715)    |  |  |
|               | コンパイルオプション                                                |  |  |
|               | 統合開発環境のデフォルト設定("レベル 低")を使用しています。                          |  |  |
| サンプルコードのバージョン | Ver.2.21 R01                                              |  |  |
| 評価に使用したソフトウェア | RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C グループ シリア |  |  |
|               | ル・アレイ・ユニットの CSI モードを使ったクロック同期式シングルマス                      |  |  |
|               | タ制御ソフトウェア(R01AN1195JJ0103) Ver.2.03                       |  |  |
| 評価に使用した使用ボード  | Renesas Starter Kit for RL78/L13                          |  |  |

#### (10) RL78/L1C SAU 統合開発環境 CubeSuite+の場合

表 2-13 動作確認条件

| 項目            | 内容                                                        |  |  |
|---------------|-----------------------------------------------------------|--|--|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory  |  |  |
| 評価に使用したマイコン   | RL78/L1C(プログラム ROM 256KB / RAM 16KB)                      |  |  |
| 動作周波数         | メイン・システム・クロック: 24MHz                                      |  |  |
|               | CPU/周辺ハードウェア・クロック: 24MHz                                  |  |  |
|               | シリアル・クロック:6MHz                                            |  |  |
| 動作電圧          | 3.3V                                                      |  |  |
| 統合開発環境        | ルネサス エレクトロニクス製 CubeSuite+ V2.01.00                        |  |  |
| Cコンパイラ        | ルネサス エレクトロニクス製                                            |  |  |
|               | CubeSuite+ RL78,78K0R コンパイラ CA78K0R V1.70                 |  |  |
|               | コンパイルオプション                                                |  |  |
|               | 統合開発環境のデフォルト設定("-qx2")を使用しています。                           |  |  |
| サンプルコードのバージョン | Ver.2.21 R01                                              |  |  |
| 評価に使用したソフトウェア | RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C グループ シリア |  |  |
|               | ル・アレイ・ユニットの CSI モードを使ったクロック同期式シングルマス                      |  |  |
|               | タ制御ソフトウェア(R01AN1195JJ0103) Ver.2.03                       |  |  |
| 評価に使用した使用ボード  | Renesas Starter Kit for RL78/L1C                          |  |  |

### (11) RL78/L1C SAU 統合開発環境 IAR Embedded Workbench の場合

表 2-14 動作確認条件

| 項目            | 内容                                                        |  |  |  |
|---------------|-----------------------------------------------------------|--|--|--|
| 評価に使用したメモリ    | Micron Technology, Inc.社製 P5Q Serial Phase Change Memory  |  |  |  |
| 評価に使用したマイコン   | RL78/L1C(プログラム ROM 256KB / RAM 16KB)                      |  |  |  |
| 動作周波数         | メイン・システム・クロック: 24MHz                                      |  |  |  |
|               | CPU/周辺ハードウェア・クロック: 24MHz                                  |  |  |  |
|               | シリアル・クロック:6MHz                                            |  |  |  |
| 動作電圧          | 3.3V                                                      |  |  |  |
| 統合開発環境        | IAR Systems 製                                             |  |  |  |
|               | IAR Embedded Workbench for Renesas RL78 (Ver.1.30.5)      |  |  |  |
| Cコンパイラ        | IAR Systems 製                                             |  |  |  |
|               | IAR Assembler for Renesas RL78 (Ver.1.30.4.50715)         |  |  |  |
|               | IAR C/C++ Compiler for Renesas RL78 (Ver.1.30.5.50715)    |  |  |  |
|               | コンパイルオプション                                                |  |  |  |
|               | 統合開発環境のデフォルト設定("レベル 低")を使用しています。                          |  |  |  |
| サンプルコードのバージョン | Ver.2.21 R01                                              |  |  |  |
| 評価に使用したソフトウェア | RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C グループ シリア |  |  |  |
|               | ル・アレイ・ユニットの CSI モードを使ったクロック同期式シングルマス                      |  |  |  |
|               | タ制御ソフトウェア(R01AN1195JJ0103) Ver.2.03                       |  |  |  |
| 評価に使用した使用ボード  | Renesas Starter Kit for RL78/L1C                          |  |  |  |

#### 3. 関連アプリケーションノート

本アプリケーションノートに関連するアプリケーションノートを以下に示します。併せて参照してください。

なお、以下の関連アプリケーションノートのうち、動作確認済の MCU については、表紙の"対象デバイス" をご参照ください。

#### 3.1 RX ファミリ 関連アプリケーションノート一覧

- RX610 グループ SCI を使ったクロック同期式シングルマスタ制御ソフトウェア (R01AN0534JJ)
- RX62N グループ RSPI を使ったクロック同期式シングルマスタ制御ソフトウェア (R01AN0323JJ)
- RX62N グループ SCI を使ったクロック同期式シングルマスタ制御ソフトウェア (R01AN1088JJ)
- RX210,RX21A,RX220,RX63N,RX63T,RX111 グループ RSPI を使ったクロック同期式シングルマスタ制御 ソフトウェア (R01AN1196JJ)
- RX210,RX21A,RX220,RX63N,RX63T,RX111 グループ SCI を使ったクロック同期式シングルマスタ制御 ソフトウェア (R01AN1229JJ)

#### 3.2 RL78 ファミリ、78K0R ファミリ 関連アプリケーションノート一覧

- 78K0R/Kx3-L シリアル・アレイ・ユニットの CSI モードを使ったクロック同期式シングルマスタ制御 ソフトウェア (R01AN0708JJ)
- RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C グループ シリアル・アレイ・ユニットの CSI モードを使ったクロック同期式シングルマスタ制御ソフトウェア (R01AN1195JJ)

#### 4. ハードウェア説明

### 4.1 ハードウェア構成例

以下にハードウェア構成例を示します。

#### 4.1.1 Single-SPI 使用時の端子一覧

表 4-1 に MCU 側の Single-SPI 使用端子と機能を示します。

表 4-1 Single-SPI 使用端子と機能

| MCU 端子名   | 入出力 | 内容             |
|-----------|-----|----------------|
| CLK       | 出力  | クロック出力         |
| DataOut   | 出力  | マスタデータ出力       |
| DataIn    | 入力  | マスタデータ入力       |
| Port(CS#) | 出力  | スレーブデバイスセレクト出力 |

#### 4.1.2 Single-SPI 使用時の接続例

以下に Single-SPI 使用時の接続例を示します。



図 4-1 Single-SPI 使用時の MCU と SPI スレーブデバイスの接続例

#### 4.1.3 Dual-SPI 使用時の端子一覧

表 4-2 に MCU 側の Dual-SPI 使用端子と機能を示します。

なお、Dual-SPI を使用するためには、対象 MCU にクワッドシリアルペリフェラルインターフェース機能が搭載されている必要があります。

| MCU 端子名     | 入出力 | 内容             |
|-------------|-----|----------------|
| CLK         | 出力  | クロック出力         |
| DataIn/Out0 | 入出力 | マスタデータ入出力 0    |
| DataIn/Out1 | 入出力 | マスタデータ入出力1     |
| Port(CS#)   | 出力  | スレーブデバイスセレクト出力 |

表 4-2 Dual-SPI 使用端子と機能

#### 4.1.4 Dual-SPI 使用時の接続例

以下に Dual-SPI 使用時の接続例を示します。



図 4-2 Dual-SPI 使用時の MCU と SPI スレーブデバイスの接続例

#### 4.1.5 Quad-SPI 使用時の端子一覧

表 4-3 に MCU 側の Quad-SPI 使用端子と機能を示します。

なお、Quad-SPI を使用するためには、対象 MCU にクワッドシリアルペリフェラルインターフェース機能が搭載されている必要があります。

| MCU 端子名     | 入出力 | 内容             |
|-------------|-----|----------------|
| CLK         | 出力  | クロック出力         |
| DataIn/Out0 | 入出力 | マスタデータ入出力0     |
| DataIn/Out1 | 入出力 | マスタデータ入出力1     |
| DataIn/Out2 | 入出力 | マスタデータ入出力2     |
| DataIn/Out3 | 入出力 | マスタデータ入出力3     |
| Port(CS#)   | 出力  | スレーブデバイスセレクト出力 |

表 4-3 Quad-SPI 使用端子と機能

#### 4.1.6 Quad-SPI 使用時の接続例

以下に Quad-SPI 使用時の接続例を示します。



図 4-3 Quad-SPI 使用時の MCU と SPI スレーブデバイスの接続例

#### 5. ソフトウェア説明

#### 5.1 動作概要

MCU のクロック同期式シリアル通信機能を使って、Serial Phase Change Memory 制御を実現します。 本サンプルコードでは、以下の制御を行っています。

- SPI スレーブデバイスの S#端子を MCU の Port に接続し、MCU 汎用ポート出力で、制御する。(本サンプルコードで制御する。)
- データの入出力を、クロック同期式モード(内部クロック使用)で、制御する。(本サンプルコードが、MCU 個別のクロック同期式シングルマスタ制御ソフトウェアを使用する。)

#### 5.1.1 データバッファと送信/受信データの関係

本サンプルコードは、ブロック型デバイスドライバであり、送信/受信データポインタを引数として設定します。RAM上のデータバッファのデータ並びと送信/受信順番の関係は、以下のとおりで、エンディアンや使用するシリアル通信機能に関係なく、送信データバッファの並びの順に送信し、また、受信の順に受信データバッファに書き込みます。

図 5-1 に転送データの格納を示します。



図 5-1 転送データの格納

#### 5.1.2 クロック同期式モードで発生させるタイミング

以下にクロック同期式モードで発生させるタイミングについて示します。

なお、使用可能なシリアルクロック周波数は、MCUと SPI デバイスの各データシートを参照し、設定してください。

#### (1) Single-SPI 使用時

Serial Phase Change Memory 制御のため、図 5-2 に示す SPI モード 3(CPOL=1、CPHA=1)のタイミングを発生させます。



- ・MCU->Serial Phase Change Memory の送信時: 転送クロックの立ち下がりで送信データ出力開始
- Serial Phase Change Memory->MCU の受信時:転送クロックの立ち上がりで受信データの入力取り込み
- ・MSB ファーストでの転送

転送を行っていないときのCLK 端子のレベルは、"H"です。

図 5-2 Single-SPI 時のクロック同期式モード タイミング設定

#### (2) Dual-SPI 使用時

Serial Phase Change Memory 制御のため、図 5-3 に示す SPI モード 3(CPOL=1、CPHA=1)のタイミングを発生させます。



- MCU->Serial Phase Change Memory の送信時:転送クロックの立ち下がりで送信データ出力開始
- Serial Phase Change Memory->MCU の受信時:転送クロックの立ち上がりで受信データの入力取り込み
- ・MSB ファーストでの転送

転送を行っていないときのCLK 端子のレベルは、"H"です。

図 5-3 Dual-SPI 時のクロック同期式モード タイミング設定

#### (3) Quad-SPI 使用時

Serial Phase Change Memory 制御のため、図 5-4 に示す SPI モード 3(CPOL=1、CPHA=1)のタイミングを発生させます。



- ・MCU->Serial Phase Change Memory の送信時:転送クロックの立ち下がりで送信データ出力開始
- Serial Phase Change Memory->MCU の受信時:転送クロックの立ち上がりで受信データの入力取り込み
- ・MSB ファーストでの転送

転送を行っていないときの CLK 端子のレベルは、"H"です。

#### 図 5-4 Quad-SPI 時のクロック同期式モード タイミング設定

#### 5.1.3 Serial Phase Change Memory の S#端子制御

Serial Phase Change Memory の S#端子を MCU の Port に接続し、MCU 汎用ポート出力で、制御します。

Serial Phase Change Memory の S# (MCU の Port(CS#)) 信号の立ち下がりから、Serial Phase Change Memory の C (MCU の CLK) 信号の立ち下がりまでの時間は、Serial Phase Change Memory の S#セットアップ時間待ちのために、ソフトウェア・ウェイトで制御しています。

Serial Phase Change Memory の C (MCU の CLK) 信号の立ち上がりから、Serial Phase Change Memory の S# (MCU の Port(CS#)) 信号の立ち上がりまでの時間は、Serial Phase Change Memory の S#ホールド時間待ちのために、ソフトウェア・ウェイトで制御しています。

Serial Phase Change Memory のデータシートを確認して、システムに応じたソフトウェア・ウェイト時間を 設定してください。

# 5.1.4 Serial Phase Change Memory の命令コード

Serial Phase Change Memory 制御のための以下の命令(Instruction)コードがあり、このコードを使って、コマンド制御を行います。

表 5-1 Instruction Set

| Instruction | Description                                   | Instruction format |
|-------------|-----------------------------------------------|--------------------|
| WREN        | Write Enable                                  | 0000 0110 (06 h)   |
| WRDI        | Write Disable                                 | 0000 0100 (04 h)   |
| RDSR        | Read Status-Register                          | 0000 0101 (05 h)   |
| WRSR        | Write Status-Register                         | 0000 0001 (01 h)   |
| FAST READ   | Read Data Bytes at Higher Speed               | 0000 1011 (0b h)   |
| READ        | Read Data Bytes                               | 0000 0011 (03 h)   |
| DOFR        | Dual output fast read                         | 0011 1011 (3b h)   |
| QOFR        | Quad output fast read                         | 0110 1011 (6b h)   |
| PP          | Page Program (legacy program)                 | 0000 0010 (02 h)   |
|             | Page Program (bit-alterable write)            | 0010 0010 (22 h)   |
|             | Page Program (on all 1s)                      | 1101 0001 (d1 h)   |
| DIFP        | Dual Input fast program (legacy program)      | 1010 0010 (a2 h)   |
|             | Dual Input fast program (bit-alterable write) | 1011 0011 (d3 h)   |
|             | Dual Input fast program (on all 1s)           | 1101 0101 (d5 h)   |
| QIFP        | Quad Input fast program (legacy program)      | 0011 0010 (32 h)   |
|             | Quad Input fast program (bit-alterable write) | 1101 0111 (d7 h)   |
|             | Quad Input fast program (on all 1s)           | 1101 1001 (d9 h)   |
| SE          | Sector Erase                                  | 1101 1000 (d8 h)   |
| BE          | Bulk Erase                                    | 1100 0111 (c7 h)   |
| RDID        | Read Identification                           | 1001 1111 (9f h)   |

#### 5.2 ソフトウェア構成

本サンプルコードは、Serial Phase Change Memory 制御のための上位層に位置する制御ソフトウェア (図 5-5 の Serial Phase Change Memory 制御ソフトウェア) です。



図 5-5 ソフトウェア構成

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

- ①Port(CS#)信号の立ち下げ
- ②ソフトウェア・ウェイト
- ③クロック同期式シングルマスタソフトウェアを使ったコマンド/データ送受信
- ④ソフトウェア・ウェイト
- ⑤Port(CS#)信号の立ち上げ

#### 5.3 必要メモリサイズ

以下に必要メモリサイズを示します。

#### 5.3.1 RX ファミリ

環境は、「2.動作確認条件」を参照してください。

#### (1) RX63N RSPI の場合

表 5-2 必要メモリサイズ

| 使用メモリ        | サイズ         | 備考                     |
|--------------|-------------|------------------------|
| ROM          | 2,901 バイト   | r_qspi_pcm_p5q_usr.c   |
|              | (リトルエンディアン) | r_qspi_pcm_p5q_sub.c   |
|              |             | r_qspi_pcm_p5q_drvif.c |
| RAM          | 5バイト        | r_qspi_pcm_p5q_usr.c   |
|              | (リトルエンディアン) | r_qspi_pcm_p5q_sub.c   |
|              |             | r_qspi_pcm_p5q_drvif.c |
| 最大使用ユーザスタック  | 136 バイト     |                        |
| 最大使用割り込みスタック | _           | 割り込み未使用                |

【注】 必要メモリサイズは C コンパイラのバージョンやコンパイルオプションにより異なります。

ROM/RAM サイズは下位層のクロック同期式シングルマスタソフトウェアに使用されるメモリサイズを含みません。

使用する MCU により、上記メモリサイズは異なります。

#### (2) RX111 RSPI の場合

表 5-3 必要メモリサイズ

| 使用メモリ        | サイズ         | 備考                     |
|--------------|-------------|------------------------|
| ROM          | 2,850 バイト   | r_qspi_pcm_p5q_usr.c   |
|              | (リトルエンディアン) | r_qspi_pcm_p5q_sub.c   |
|              |             | r_qspi_pcm_p5q_drvif.c |
| RAM          | 5バイト        | r_qspi_pcm_p5q_usr.c   |
|              | (リトルエンディアン) | r_qspi_pcm_p5q_sub.c   |
|              |             | r_qspi_pcm_p5q_drvif.c |
| 最大使用ユーザスタック  | 152 バイト     |                        |
| 最大使用割り込みスタック | _           | 割り込み未使用                |

【注】 必要メモリサイズは C コンパイラのバージョンやコンパイルオプションにより異なります。

ROM/RAM サイズは下位層のクロック同期式シングルマスタソフトウェアに使用されるメモリサイズを含みません。

使用する MCU により、上記メモリサイズは異なります。

最大使用ユーザスタックサイズは、下位層のクロック同期式シングルマスタソフトウェアのスタックサイズも含みます。

#### (3) RX111 SCI の場合

表 5-4 必要メモリサイズ

| 使用メモリ        | サイズ         | 備考                     |
|--------------|-------------|------------------------|
| ROM          | 2,850 バイト   | r_qspi_pcm_p5q_usr.c   |
|              | (リトルエンディアン) | r_qspi_pcm_p5q_sub.c   |
|              |             | r_qspi_pcm_p5q_drvif.c |
| RAM          | 5バイト        | r_qspi_pcm_p5q_usr.c   |
|              | (リトルエンディアン) | r_qspi_pcm_p5q_sub.c   |
|              |             | r_qspi_pcm_p5q_drvif.c |
| 最大使用ユーザスタック  | 148 バイト     |                        |
| 最大使用割り込みスタック | _           | 割り込み未使用                |

【注】 必要メモリサイズは C コンパイラのバージョンやコンパイルオプションにより異なります。

ROM/RAM サイズは下位層のクロック同期式シングルマスタソフトウェアに使用されるメモリサイズを含みません。

使用する MCU により、上記メモリサイズは異なります。

#### 5.3.2 RL78 ファミリ、78K0R/Kx3-L

命令の異なる MCU 毎にメモリサイズを示します。使用 MCU の命令を調査し参考にしてください。 環境は、「2.動作確認条件」を参照してください。

(1) RL78/G14 SAU 統合開発環境 CS+ for CA,CX の場合 (コンパイラ: CA78K0R)

表 5-5 必要メモリサイズ

| 使用メモリ        | サイズ       | 備考                        |
|--------------|-----------|---------------------------|
| ROM          | 5,291 バイト | r_qspi_pcm_p5q_usr.c      |
|              |           | r_qspi_pcm_p5q_sub.c      |
|              |           | r_qspi_pcm_p5q_drvif.c    |
|              |           | r_qspi_pcm_p5q_sfr_rl78.c |
| RAM          | 6バイト      | r_qspi_pcm_p5q_usr.c      |
|              |           | r_qspi_pcm_p5q_sub.c      |
|              |           | r_qspi_pcm_p5q_drvif.c    |
|              |           | r_qspi_pcm_p5q_sfr_rl78.c |
| 最大使用ユーザスタック  | 110 バイト   |                           |
| 最大使用割り込みスタック | _         | 割り込み未使用                   |

【注】 必要メモリサイズは C コンパイラのバージョンやコンパイルオプションにより異なります。

ROM/RAM サイズは下位層のクロック同期式シングルマスタソフトウェアに使用されるメモリサイズを含みません。

使用する MCU により、上記メモリサイズは異なります。

最大使用ユーザスタックサイズは、下位層のクロック同期式シングルマスタソフトウェアのスタックサイズも含みます。

(2) RL78/G14 SAU 統合開発環境 CS+ for CC の場合 (コンパイラ: CC-RL)

表 5-6 必要メモリサイズ

| 使用メモリ        | サイズ       | 備考                        |
|--------------|-----------|---------------------------|
| ROM          | 3,867 バイト | r_qspi_pcm_p5q_usr.c      |
|              |           | r_qspi_pcm_p5q_sub.c      |
|              |           | r_qspi_pcm_p5q_drvif.c    |
|              |           | r_qspi_pcm_p5q_sfr_rl78.c |
| RAM          | 6バイト      | r_qspi_pcm_p5q_usr.c      |
|              |           | r_qspi_pcm_p5q_sub.c      |
|              |           | r_qspi_pcm_p5q_drvif.c    |
|              |           | r_qspi_pcm_p5q_sfr_rl78.c |
| 最大使用ユーザスタック  | 80 バイト    |                           |
| 最大使用割り込みスタック | _         | 割り込み未使用                   |

【注】 必要メモリサイズは C コンパイラのバージョンやコンパイルオプションにより異なります。

ROM/RAM サイズは下位層のクロック同期式シングルマスタソフトウェアに使用されるメモリサイズを含みません。

使用する MCU により、上記メモリサイズは異なります。

#### (3) RL78/G14 SAU 統合開発環境 IAR Embedded Workbench の場合

表 5-7 必要メモリサイズ

| 使用メモリ        | サイズ       | 備考                        |
|--------------|-----------|---------------------------|
| ROM          | 5,534 バイト | r_qspi_pcm_p5q_usr.c      |
|              |           | r_qspi_pcm_p5q_sub.c      |
|              |           | r_qspi_pcm_p5q_drvif.c    |
|              |           | r_qspi_pcm_p5q_sfr_rl78.c |
| RAM          | 6バイト      | r_qspi_pcm_p5q_usr.c      |
|              |           | r_qspi_pcm_p5q_sub.c      |
|              |           | r_qspi_pcm_p5q_drvif.c    |
|              |           | r_qspi_pcm_p5q_sfr_rl78.c |
| 最大使用ユーザスタック  | 154 バイト   |                           |
| 最大使用割り込みスタック | _         | 割り込み未使用                   |

【注】 必要メモリサイズは C コンパイラのバージョンやコンパイルオプションにより異なります。

ROM/RAM サイズは下位層のクロック同期式シングルマスタソフトウェアに使用されるメモリサイズを含みません。

使用する MCU により、上記メモリサイズは異なります。

最大使用ユーザスタックサイズは、プロジェクト全体のスタックサイズです。下位層のクロック同期 式シングルマスタソフトウェアのスタックサイズも含みます。

#### (4) RL78/L13 SAU 統合開発環境 CubeSuite+の場合

表 5-8 必要メモリサイズ

| 使用メモリ        | サイズ       | 備考                        |
|--------------|-----------|---------------------------|
| ROM          | 4,801 バイト | r_qspi_pcm_p5q_usr.c      |
|              |           | r_qspi_pcm_p5q_sub.c      |
|              |           | r_qspi_pcm_p5q_drvif.c    |
|              |           | r_qspi_pcm_p5q_sfr_rl78.c |
| RAM          | 6バイト      | r_qspi_pcm_p5q_usr.c      |
|              |           | r_qspi_pcm_p5q_sub.c      |
|              |           | r_qspi_pcm_p5q_drvif.c    |
|              |           | r_qspi_pcm_p5q_sfr_rl78.c |
| 最大使用ユーザスタック  | 102 バイト   |                           |
| 最大使用割り込みスタック | _         | 割り込み未使用                   |

【注】 必要メモリサイズは C コンパイラのバージョンやコンパイルオプションにより異なります。

ROM/RAM サイズは下位層のクロック同期式シングルマスタソフトウェアに使用されるメモリサイズを含みません。

使用する MCU により、上記メモリサイズは異なります。

#### (5) RL78/L13 SAU 統合開発環境 IAR Embedded Workbench の場合

表 5-9 必要メモリサイズ

| 使用メモリ        | サイズ       | 備考                        |
|--------------|-----------|---------------------------|
| ROM          | 4,058 バイト | r_qspi_pcm_p5q_usr.c      |
|              |           | r_qspi_pcm_p5q_sub.c      |
|              |           | r_qspi_pcm_p5q_drvif.c    |
|              |           | r_qspi_pcm_p5q_sfr_rl78.c |
| RAM          | 6バイト      | r_qspi_pcm_p5q_usr.c      |
|              |           | r_qspi_pcm_p5q_sub.c      |
|              |           | r_qspi_pcm_p5q_drvif.c    |
|              |           | r_qspi_pcm_p5q_sfr_rl78.c |
| 最大使用ユーザスタック  | 120 バイト   |                           |
| 最大使用割り込みスタック | _         | 割り込み未使用                   |

【注】 必要メモリサイズは C コンパイラのバージョンやコンパイルオプションにより異なります。

ROM/RAM サイズは下位層のクロック同期式シングルマスタソフトウェアに使用されるメモリサイズを含みません。

使用する MCU により、上記メモリサイズは異なります。

最大使用ユーザスタックサイズは、プロジェクト全体のスタックサイズです。下位層のクロック同期 式シングルマスタソフトウェアのスタックサイズも含みます。

## 5.4 ファイル構成

表 5-10 に、サンプルコードで使用するファイルを示します。なお、統合開発環境で自動生成するファイルを除きます。

表 5-10 ファイル構成

| r01an1439jj0104_mcu_serial <dir></dir> |                                          |
|----------------------------------------|------------------------------------------|
| r01an1439jj0104_mcu.pdf                | アプリケーションノート                              |
| ¥source <dir></dir>                    | プログラム格納用フォルダ                             |
| ¥r_qspi_pcm_p5q <dir></dir>            | Serial Phase Change Memory 制御ソフトウェア用フォルダ |
| r_qspi_pcm_p5q.h                       | ヘッダファイル                                  |
| r_qspi_pcm_p5q_drvif.c                 | ドライバ I/F ソースファイル                         |
| r_qspi_pcm_p5q_drvif.h                 | ドライバ I/F ヘッダファイル                         |
| r_qspi_pcm_p5q_sfr.h.rl78g14           | レジスタ用共通定義(RL78/G14 用)                    |
| r_qspi_pcm_p5q_sfr.h.rl78g1c           | レジスタ用共通定義(RL78/G1C 用)                    |
| r_qspi_pcm_p5q_sfr.h.rl78l1c           | レジスタ用共通定義(RL78/L1C 用)                    |
| r_qspi_pcm_p5q_sfr.h.rl78l12           | レジスタ用共通定義(RL78/L12 用)                    |
| r_qspi_pcm_p5q_sfr.h.rl78l13           | レジスタ用共通定義(RL78/L13 用)                    |
| r_qspi_pcm_p5q_sfr.h.rx63n             | レジスタ用共通定義(RX63N 用)                       |
| r_qspi_pcm_p5q_sfr.h.rx111             | レジスタ用共通定義(RX111 用)                       |
| r_qspi_pcm_p5q_sfr_rl78g14.c           | レジスタ用共通定義ソースファイル(RL78/G14 用)             |
| r_qspi_pcm_p5q_sfr_rl78g1c.c           | レジスタ用共通定義ソースファイル(RL78/G1C 用)             |
| r_qspi_pcm_p5q_sfr_rl78l1c.c           | レジスタ用共通定義ソースファイル(RL78/G1C 用)             |
| r_qspi_pcm_p5q_sfr_rl78l12.c           | レジスタ用共通定義ソースファイル(RL78/G12 用)             |
| r_qspi_pcm_p5q_sfr_rl78l13.c           | レジスタ用共通定義ソースファイル(RL78/G13 用)             |
| r_qspi_pcm_p5q_sub.c                   | 内部関数ソースファイル                              |
| r_qspi_pcm_p5q_sub.h                   | 内部関数ヘッダファイル                              |
| r_qspi_pcm_p5q_usr.c                   | ユーザ I/F ソースファイル                          |
| ¥sample <dir></dir>                    | 動作確認プログラム格納用フォルダ                         |
| testmain.c                             | 動作確認用のサンプルソースファイル                        |

【注】 別途、MCU 個別のクロック同期式シングルマスタ制御ソフトウェアが必要です。

## 5.5 定数一覧

### 5.5.1 戻り値

表 5-11 にサンプルコードで使用する戻り値を示します。

表 5-11 戻り値

| 定数名             | 設定値           | 内容                   |
|-----------------|---------------|----------------------|
| PCM_OK          | (error_t)( 0) | Successful operation |
| PCM_ERR_PARAM   | (error_t)(-1) | Parameter error      |
| PCM_ERR_HARD    | (error_t)(-2) | Hardware error       |
| PCM_ERR_TIMEOUT | (error_t)(-6) | Time out error       |
| PCM_ERR_OTHER   | (error_t)(-7) | Other error          |

### 5.5.2 コマンド定義

表 5-12 にサンプルコードで使用するコマンド定義を示します。

表 5-12 コマンド定義(r\_qspi\_pcm\_p5q\_sub.c 参照)

| 定数名             | 設定値             | 内容                                            |
|-----------------|-----------------|-----------------------------------------------|
| PCM_CMD_WREN    | (uint8_t)(0x06) | Write Enable                                  |
| PCM_CMD_WRDI    | (uint8_t)(0x04) | Write Disable                                 |
| PCM_CMD_RDSR    | (uint8_t)(0x05) | Read Status Register                          |
| PCM_CMD_WRSR    | (uint8_t)(0x01) | Write Status Register                         |
| PCM_CMD_FREAD   | (uint8_t)(0x0b) | Read for Memory Array at Higher Speed         |
| PCM_CMD_READ    | (uint8_t)(0x03) | Read for Memory Array                         |
| PCM_CMD_DOFR    | (uint8_t)(0x3b) | Dual Output Fast Read                         |
| PCM_CMD_QOFR    | (uint8_t)(0x6b) | Quad Output Fast Read                         |
| PCM_CMD_PP_L    | (uint8_t)(0x02) | Page Program (Legacy Program)                 |
| PCM_CMD_PP_BA   | (uint8_t)(0x22) | Page Program (Bit-alterable Write)            |
| PCM_CMD_PP_OA   | (uint8_t)(0xd1) | Page Program (on all 1s)                      |
| PCM_CMD_DIFP_L  | (uint8_t)(0xa2) | Dual Input Fast Program (Legacy Program)      |
| PCM_CMD_DIFP_BA | (uint8_t)(0xd3) | Dual Input Fast Program (Bit-alterable Write) |
| PCM_CMD_DIFP_OA | (uint8_t)(0xd5) | Dual Input Fast Program (on all 1s)           |
| PCM_CMD_QIFP_L  | (uint8_t)(0x32) | Quad Input Fast Program (Legacy Program)      |
| PCM_CMD_QIFP_BA | (uint8_t)(0xd7) | Quad Input Fast Program (Bit-alterable Write) |
| PCM_CMD_QIFP_OA | (uint8_t)(0xd9) | Quad Input Fast Program (on all 1s)           |
| PCM_CMD_SE      | (uint8_t)(0xd8) | Sector Erase for Memory Array                 |
| PCM_CMD_BE      | (uint8_t)(0xc7) | Bulk Erase for Memory Array                   |
| PCM_CMD_RDID    | (uint8_t)(0x9f) | Read Identification                           |

### 5.5.3 各種定義

以下にサンプルコードで使用する各種定義した値を示します。

表 5-13 r\_qspi\_pcm\_p5q.h の各種定義値

| 定数名                           | 設定値                    | 内容                                            |
|-------------------------------|------------------------|-----------------------------------------------|
| PCM_DEV_NUM                   | (1)                    | 接続するデバイスの数                                    |
| PCM_DEV0                      | (0)                    | デバイス番号 0                                      |
| PCM_DEV1                      | (1)                    | デバイス番号 1                                      |
| PCM_DELAY_TASK                | (uint8_t)(1)           | ディレイタスクのウェイト時間[単位:ms](※1)                     |
| PCM_LOG_ERR                   | (1)                    | Log Type : Error                              |
| PCM_TRUE                      | (uint8_t)(0x01)        | Flag "ON"                                     |
| PCM_FALSE                     | (uint8_t)(0x00)        | Flag "OFF"                                    |
| PCM_MODE_PP_LEGACY            | (uint8_t)(1)           | Page Program Type : Legacy                    |
| PCM_MODE_PP_BIT_ALTE<br>RABLE | (uint8_t)(2)           | Page Program Type : Bit-alterable             |
| PCM_MODE_ON_ALL_1S            | (uint8_t)(3)           | Page Program Type : on all 1s (preset writes) |
| PCM_B_ERASE                   | (uint8_t)(1)           | Erasure Type : Bulk Erase                     |
| PCM_S_ERASE                   | (uint8_t)(2)           | Erasure Type : Sector Erase                   |
| PCM_MEM_SIZE                  | (uint32_t)(16777216)   | メモリサイズ(バイト単位)                                 |
|                               |                        | 左記は 128Mbit の場合の値です。                          |
| PCM_SECT_ADDR                 | (uint32_t)(0xfffe0000) | セクタ消去時のセクタアドレスマスク値                            |
|                               |                        | 左記は 128Mbit の場合の値です。                          |
| PCM_PAGE_SIZE                 | (uint32_t)(64)         | ページサイズ(バイト単位)                                 |
|                               |                        | 左記は、128Mbit の場合の値です。                          |
| PCM_ADDR_SIZE                 | (uint8_t)(3)           | アドレスサイズ(バイト単位)                                |
|                               |                        | 左記は 128Mbit の場合の値です。                          |
| PCM_WP_WHOLE_MEM              | (uint8_t)(0x1f)        | チップ全体のライトプロテクト                                |

※1: OS 制御時のディレイタスクです。本サンプルコードの OS 制御は、μITRON4.0 を想定しています。

| ā | 表 5-14 | r_qspi_pcm_p5q_sfr.h.rx63n の各種定義値 |    |
|---|--------|-----------------------------------|----|
|   |        | 設定値                               | 内容 |

| 定数名               | 設定値               | 内容                           |
|-------------------|-------------------|------------------------------|
| PCM_DR_CS0        | PORTA.PODR.BIT.B0 | デバイス番号 0 ポート出力データレジスタ SFR 定義 |
| PCM_DDR_CS        | PORTA.PDR.BIT.B0  | デバイス番号 0 ポート方向レジスタ SFR 定義    |
| PCM_DR_CS1        | -                 | デバイス番号 1 ポート出力データレジスタ SFR 定義 |
|                   |                   | (2 デバイス制御する場合は設定してください。)     |
| PCM_DDR_CS1       | -                 | デバイス番号 1 ポート方向レジスタ SFR 定義    |
|                   |                   | (2 デバイス制御する場合は設定してください。)     |
| PCM_HI            | (uint8_t)(0x01)   | Port "H"                     |
| PCM_LOW           | (uint8_t)(0x00)   | Port "L"                     |
| PCM_OUT           | (uint8_t)(0x01)   | Port Output Setting          |
| PCM_IN            | (uint8_t)(0x00)   | Port Input Setting           |
| PCM_BR            | (uint8_t)(0x01)   | コマンド送信時の転送レート ※1             |
| PCM_BR_WRITE_DATA | (uint8_t)(0x01)   | データ送信時の転送レート ※1              |
| PCM_BR_READ_DATA  | (uint8_t)(0x01)   | データ受信時の転送レート ※1              |

※ 1: RSPI を使ったクロック同期式シングルマスタ制御ソフトウェアを使用した場合、RSPI ビットレート レジスタ SPBR に設定される値です。周辺モジュールクロックを 48[MHz]とし、転送レートを 12[MHz] に設定する場合の値です。

SCI を使ったクロック同期式シングルマスタ制御ソフトウェアを使用した場合、ビットレートレジスタ BRR に設定される値です。周辺モジュールクロックを 48[MHz]とし、転送レートを 6[MHz]に設定する場合の値です。

| 定数名               | 設定値             | 内容                           |
|-------------------|-----------------|------------------------------|
| PCM_DR_CS0        | P8.0            | デバイス番号 0 ポート・レジスタ SFR 定義     |
| PCM_DDR_CS        | PM8.0           | デバイス番号 0 ポート・モード・レジスタ SFR 定義 |
| PCM_DR_CS1        | -               | デバイス番号 1 ポート・レジスタ SFR 定義     |
|                   |                 | (2 デバイス制御する場合は設定してください。)     |
| PCM_DDR_CS1       | -               | デバイス番号 1 ポート・モード・レジスタ SFR 定義 |
|                   |                 | (2 デバイス制御する場合は設定してください。)     |
| PCM_HI            | (uint8_t)(0x01) | Port "H"                     |
| PCM_LOW           | (uint8_t)(0x00) | Port "L"                     |
| PCM_OUT           | (uint8_t)(0x00) | Port Output Setting          |
| PCM_IN            | (uint8_t)(0x01) | Port Input Setting           |
| PCM_BR            | (uint8_t)(0x01) | コマンド送信時の転送レート ※1             |
| PCM_BR_WRITE_DATA | (uint8_t)(0x01) | データ送信時の転送レート ※1              |
| PCM_BR_READ_DATA  | (uint8_t)(0x01) | データ受信時の転送レート ※1              |

表 5-15 r\_qspi\_pcm\_p5q\_sfr.h.rl78 の各種定義値

※1:シリアル・アレイ・ユニットの CSI モードを使ったクロック同期式シングルマスタ制御ソフトウェア を使用した場合、シリアル・データ・レジスタ SDR のビット 15-9 に設定される値です。本サンプル コードでは、動作クロックを 24[MHz]とし、転送レートを 6[MHz]に設定する場合の値です。

## 表 5-16 r\_qspi\_pcm\_p5q\_sub.c の各種定義値

| 定数名            | 設定値                    | 内容                                |
|----------------|------------------------|-----------------------------------|
| PCM_SHORT_SIZE | (uint32_t)(0x00008000) | 下位関数での最大転送サイズの設定<br>(最大:32KBytes) |

#### 表 5-17 r\_qspi\_pcm\_p5q\_sub.h の各種定義値

| 定数名              | 設定値                 | 内容                            |
|------------------|---------------------|-------------------------------|
| PCM_BE_BUSY_WAIT | (uint32_t)(100000)  | Bulk Erase Busy Timeout       |
|                  |                     | 100000 × 1ms = 100s           |
| PCM_SE_BUSY_WAIT | (uint32_t)(800)     | Sector Erase Busy Timeout     |
|                  |                     | 800 × 1ms = 800ms             |
| PCM_WBUSY_WAIT   | (uint32_t)(400)     | Write Ready Timeout           |
|                  |                     | 400 × 1us = 400us             |
| PCM_T_WBUSY_WAIT | (uint16_t)MTL_T_1US | Write Busy Polling Time       |
| PCM_T_EBUSY_WAIT | (uint16_t)MTL_T_1MS | Erase Busy Polling Time       |
| PCM_T_CS_HOLD    | (uint16_t)MTL_T_1US | CS Stability Waiting Time     |
| PCM_T_R_ACCESS   | (uint16_t)MTL_T_1US | Reading Start Waiting Time    |
| PCM_REG_SRWD     | (uint8_t)(0x80)     | Status Register Write Disable |
| PCM_REG_BP3      | (uint8_t)(0x40)     | Block Protection Bit3         |
| PCM_REG_TB       | (uint8_t)(0x20)     | Top/Bottom Bit                |
| PCM_REG_BP2      | (uint8_t)(0x10)     | Block Protection Bit2         |
| PCM_REG_BP1      | (uint8_t)(0x08)     | Block Protection Bit1         |
| PCM_REG_BP0      | (uint8_t)(0x04)     | Block Protection Bit0         |
| PCM_REG_WEL      | (uint8_t)(0x02)     | Write Enable Latch Bit        |
| PCM_REG_WIP      | (uint8_t)(0x01)     | Write In Progress Bit         |
| PCM_REG          | (uint8_t)(0xfc)     | Write status fixed data       |

#### 5.6 構造体/共用体一覧

図 5-6、図 5-7 にサンプルコードで使用する構造体/共用体を示します。

```
typedef union {
    uint32_t ul;
    uint8_t uc[4];
} PCM_EXCHG_LONG;
/* total 4bytes
*/
```

図 5-6 サンプルコードで使用する共用体 (r\_qspi\_pcm\_p5q\_sub.c 参照)

```
typedef struct
                     Addr;
                                                           /* Address to issue a command
    uint32 t
                                                           /* Number of bytes to be read/written
    uint32_t
                     Cnt;
                                                                                                      */
                     DataCnt;
                                  /* Temporary counter or Number of bytes to be written in a page
                                                                                                      */
    uint16_t
                                                            /* Reserved
                                                                                                       */
    uint8_t
                     rsv[2];
                                                                                                       */
    uint8_t FAR*
                     pData;
                                                           /* Data storage buffer pointer
} r_qspi_pcm_info_t;
```

図 5-7 サンプルコードで使用する構造体(r\_qspi\_pcm\_p5q.h 参照)

| 表   | 5-18 | 構造体 | "r | aspi   | ncm  | info  | t" | の説明    |
|-----|------|-----|----|--------|------|-------|----|--------|
| 200 | 0 10 |     | '- | _4301_ | POIL | 11110 | ٠. | マノロルワ」 |

| 構造体     | 設定可能範囲                    | 説明                                                                                                               |
|---------|---------------------------|------------------------------------------------------------------------------------------------------------------|
| メンバ     |                           |                                                                                                                  |
| Addr    | 0000 0000h~<br>FFFF FFFFh | 書き込み/読み出しを開始するアドレス                                                                                               |
| Cnt     | 0000 0000h~<br>FFFF FFFFh | 書き込み/読み出しのデータカウンタ(バイト単位)                                                                                         |
| DataCnt | (設定禁止)                    | 書き込み時:書き込みデータカウンタ Temp.(最大 1Page)<br>読み出し時:読み出しデータカウンタ Temp.(最大 32KBytes)                                        |
| rsv[2]  | (設定無効)                    | アライメント調整用                                                                                                        |
| pData   | _                         | データ格納バッファポインタ<br>書き込み時:Serial Phase Change Memory へ書き込むデータの格納元<br>読み出し時:Serial Phase Change Memory から読み出すデータの格納先 |

#### 5.7 変数一覧

表 5-19 に static 型変数を示します。

表 5-19 static 型変数 (r\_qspi\_flash\_p5q\_sub.c 参照)

| 型              | 変数名             | 内容        | 使用関数                                      |
|----------------|-----------------|-----------|-------------------------------------------|
| STATIC uint8_t | g_pcm_cmdbuf[5] | コマンド用バッファ | r_qspi_pcm_send_cmd<br>r_qspi_pcm_set_cmd |

#### 5.8 関数一覧

表 5-20 に関数を示します。

表 5-20 関数

| 関数名                            | 概要                     |
|--------------------------------|------------------------|
| R_QSPI_PCM_Init_Driver()       | ドライバ初期化処理              |
| R_QSPI_PCM_Read_Status()       | ステータスレジスタ読み出し処理        |
| R_QSPI_PCM_Set_Write_Protect() | ライトプロテクト設定処理           |
| R_QSPI_PCM_Write_Di()          | WRDI コマンド発行処理          |
| R_QSPI_PCM_Read_Data()         | データ読み出し処理              |
| R_QSPI_PCM_Write_Data()        | データ書き込み処理              |
| R_QSPI_PCM_Write_Data_Page()   | データ書き込み処理(1Page 書き込み用) |
| R_QSPI_PCM_Erase()             | 消去処理                   |
| R_QSPI_PCM_Read_ID()           | ID 読み出し処理              |
| R_QSPI_PCM_Wait()              | ビジーウェイト処理              |

キャッシュ搭載の MCU を使用する場合、読み出し/書き込み用データ格納バッファは、非キャッシュ領域を指定してください。

読み出し/書き込み用データ格納バッファアドレスは、下位層の MCU 個別のクロック同期式シングルマスタ制御ソフトウェアに依存し、4 バイト境界アドレスを指定する必要がある場合があります。 MCU 個別のクロック同期式シングルマスタ制御ソフトウェアのアプリケーションノートを参照してください。

### 5.9 関数仕様

サンプルコードの関数仕様を示します。

#### 5.9.1 ドライバ初期化処理

# R\_QSPI\_PCM\_Init\_Driver

概 要 ドライバ初期化処理

ィッダ r\_qspi\_pcm\_p5q.h, r\_qspi\_pcm\_p5q\_sub.h, r\_qspi\_pcm\_sfr.h, r\_qspi\_pcm\_drvif.h

宣言 error\_t R\_QSPI\_PCM\_Init\_Driver(void)

説 明 ・R\_QSPI\_PCM\_Init\_Port()関数をコールし、CS#端子の初期化を行います。

・クロック同期式シングルマスタ制御ソフトウェアの初期化関数をコールし、I/O ポートの初期化を行います。

・システム起動時に一度だけ呼び出してください。

引数 な

リターン値・初期化結果を返します。

PCM OK ; Successful operation

PCM\_ERR\_OTHER ; Other error



図 5-8 ドライバ初期化処理概要

PCM\_ERR\_OTHER

# Micron Technology 社製 P5Q Serial Phase Change Memory 制御ソフトウェア

# 5.9.2 ステータスレジスタ読み出し処理

| R_QSPI_PCM_Rea | d_Status                                                                     |  |  |  |
|----------------|------------------------------------------------------------------------------|--|--|--|
| 概 要            | ステータスレジスタ読み出し処理                                                              |  |  |  |
| ヘッダ            | r_qspi_pcm_p5q.h, r_qspi_pcm_p5q_sub.h, r_qspi_pcm_sfr.h, r_qspi_pcm_drvif.h |  |  |  |
| 宣言             | error_t R_QSPI_PCM_Read_Status(uint8_t DevNo, uint8_t FAR* pStatus)          |  |  |  |
| 説明             | ・ステータスレジスタを読み出し、pStatus に格納します。                                              |  |  |  |
|                | 読み出しバッファとして、1 バイトを設定してください。                                                  |  |  |  |
|                | ・読み出しステータス格納バッファ(pStatus)には下記情報が格納されます。                                      |  |  |  |
|                | Bit 7:SRWD                                                                   |  |  |  |
|                | 1: TB, BP3, BP2, BP1, BP0 are read-only bits                                 |  |  |  |
|                | 0: TB, BP3, BP2, BP1, BP0 are read/writable                                  |  |  |  |
|                | Bits 6 to 2: BP3, TB, BP2, BP1, BP0                                          |  |  |  |
|                | Bit 1:WEL                                                                    |  |  |  |
|                | 1: Internal Write Enable Latch is set                                        |  |  |  |
|                | 0: Internal Write Enable Latch is reset                                      |  |  |  |
|                | Bit 0:WIP                                                                    |  |  |  |
|                | 1: Program or Erase cycle is in progress                                     |  |  |  |
|                | 0: No Program or Erase cycle is in progress                                  |  |  |  |
|                | ・プロテクト領域とプロテクトビットの関係は、使用する Serial Phase Change Me                            |  |  |  |
|                | mory のデータシートを参照してください。BP ビットが割り当てられていない可能<br>性があります。                         |  |  |  |
| 引数             | uint8_t DevNo ; デバイス番号                                                       |  |  |  |
|                | uint8_t FAR* pStatus ; 読み出しステータス格納バッファポインタ                                   |  |  |  |
| リターン値          | ・ステータスレジスタ取得結果を返します。                                                         |  |  |  |
|                | PCM_OK ; Successful operation                                                |  |  |  |
|                | PCM_ERR_PARAM ; Parameter error                                              |  |  |  |
|                | PCM_ERR_HARD ; Hardware error                                                |  |  |  |

; Other error



図 5-9 ステータスレジスタ読み出し処理概要

# 5.9.3 ライトプロテクト設定処理

#### R\_QSPI\_PCM\_Set\_Write\_Protect

概要

ライトプロテクト設定処理

ヘッダ

宣言説明

r\_qspi\_pcm\_p5q.h, r\_qspi\_pcm\_p5q\_sub.h, r\_qspi\_pcm\_sfr.h, r\_qspi\_pcm\_drvif.h error\_t R\_QSPI\_PCM\_Set\_Write\_Protect(uint8\_t DevNo, uint8\_t WpSts)

- ・32Mb/64Mb/128Mb Serial Phase Change Memory の使用制限(※ 1)により、 ライトプロテクトビットに 1 をセットすることができません。本ユーザ API をご使 用される際は、最新の Serial Phase Change Memory のデータシートから製品情 報をご確認ください。
  - (※1:以下の使用制限情報を参照。32Mb/64Mb P5Q Serial Phase Change Me mory Errata Rev.A、128Mb P5Q Serial Phase Change Memory Errata Rev.D)
- ・ライトプロテクトの設定を行います。
- ・ライトプロテクト設定データ(WpSts)は下記のように設定してください。

| WpSts       | BP3 | TB1 | BP2 | BP1 | BP0 | Protected Area                |
|-------------|-----|-----|-----|-----|-----|-------------------------------|
| 0x00        | 0   | 0   | 0   | 0   | 0   | None                          |
| 0x01        | 0   | 0   | 0   | 0   | 1   | Upper 32nd (sector 31)        |
| 0x02        | 0   | 0   | 0   | 1   | 0   | Upper 16th (sectors 30 to 31) |
| 0x03        | 0   | 0   | 0   | 1   | 1   | Upper 8th (sectors 28 to 31)  |
| 0x04        | 0   | 0   | 1   | 0   | 0   | Upper 4th (sectors 24 to 31)  |
| 0x05        | 0   | 0   | 1   | 0   | 1   | Upper half (sectors 16 to 31) |
| 0x06        | 0   | 0   | 1   | 1   | 0   | All sectors (sectors 0 to 31) |
| 0x07        | 0   | 0   | 1   | 1   | 1   | All sectors (sectors 0 to 31) |
| 0x10 - 0x16 | 1   | 0   | 0/1 | 0/1 | 0/1 | 本ユーザ API では設定禁止               |
| 0x17        | 1   | 0   | 1   | 1   | 1   | All sectors (sectors 0 to 31) |
| 0x08        | 0   | 1   | 0   | 0   | 0   | None                          |
| 0x09        | 0   | 1   | 0   | 0   | 1   | Lower 32nd (sector 0)         |
| 0x0a        | 0   | 1   | 0   | 1   | 0   | Lower 16th (sectors 0 to 1)   |
| 0x0b        | 0   | 1   | 0   | 1   | 1   | Lower 8th (sectors 0 to 3)    |
| 0x0c        | 0   | 1   | 1   | 0   | 0   | Lower 4th (sectors 0 to 7)    |
| 0x0d        | 0   | 1   | 1   | 0   | 1   | Lower half (sectors 0 to 15)  |
| 0x0e        | 0   | 1   | 1   | 1   | 0   | All sectors (sectors 0 to 31) |
| 0x0f        | 0   | 1   | 1   | 1   | 1   | All sectors (sectors 0 to 31) |
| 0x18-0x1e   | 1   | 1   | 0/1 | 0/1 | 0/1 | 本ユーザ API では設定禁止               |
| 0x1f        | 1   | 1   | 1   | 1   | 1   | All sectors (sectors 0 to 31) |

- SRWD は、0 に設定されます。
- ・プロテクト領域とプロテクトビットの関係は、使用する Serial Phase Change Me mory のデータシートを参照してください。BP ビットが割り当てられていない可能性があります。
- ・書き込み完了待ちの方法は二種類あります。以降にその方法を示します。なお、次の処理(書き込み/読み出し/消去等)は、書き込み完了を確認した後、実行してください。
- ・本ユーザ API で完了待ちを行う場合、r\_qspi\_pcm\_p5q.h の「PCM\_WAIT\_READY」を有効にしてください。
- ・本ユーザ API で完了待ちを行わない場合、r\_qspi\_pcm\_p5q.h の「PCM\_WAIT\_RE ADY」を無効にし、本ユーザ API の処理が完了した後、R\_QSPI\_PCM\_Wait()をコールしてください。この処理方法では、ユーザの任意のタイミングで書き込み完了待

ちを確認することができます。使用方法は図 5-11 を参照してください。

引数 uint8\_t DevNo ; デバイス番号

uint8\_t WpSts : ライトプロテクト設定データ

リターン値・ライトプロテクト設定結果を返します。

PCM\_OK ; Successful operation PCM\_ERR\_PARAM ; Parameter error PCM\_ERR\_HARD ; Hardware error

PCM\_ERR\_TIMEOUT ; Time out error (「PCM\_WAIT\_READY」有効時)

PCM\_ERR\_OTHER ; Other error



図 5-10 ライトプロテクト設定処理概要



図 5-11 R\_QSPI\_PCM\_Wait()を使用したライトプロテクト設定完了待ち方法

## 5.9.4 WRDI コマンド発行処理

#### R\_QSPI\_PCM\_Write\_Di 概要 WRDI コマンド発行処理 ヘッダ $r\_qspi\_pcm\_p5q.h, r\_qspi\_pcm\_p5q\_sub.h, r\_qspi\_pcm\_p5q\_sfr.h,$ r\_qspi\_pcm\_p5q\_drvif.h 宣 言 error t R QSPI PCM Write Di(uint8 t DevNo) 説明 ・ステータスレジスタの WEL ビットをクリアします。 ・プログラムエラー、消去エラーと判断される場合は、本関数をコールして WEL ビッ トをクリアする必要があります。 引 数 uint8 t DevNo ; デバイス番号 リターン値 クリア結果を返します。 ; Successful operation PCM\_OK PCM \_ERR\_PARAM ; Parameter error ; Hardware error PCM ERR HARD ; Other error PCM \_ERR\_OTHER



図 5-12 WRDIコマンド発行処理概要

#### 5.9.5 データ読み出し処理

#### R\_QSPI\_PCM\_Read\_Data \_\_\_\_ データ読み出し処理 概要 ヘッダ r\_qspi\_pcm\_p5q.h, r\_qspi\_pcm\_p5q\_sub.h, r\_qspi\_pcm\_sfr.h, r\_qspi\_pcm\_drvif.h error tR QSPI PCM Read Data(uint8 t DevNo, r qspi pcm info t FAR\* 宣 言

pPcm\_Info)

説明 · Serial Phase Change Memory 上の指定アドレスから指定バイト数分、データを読 み出し、pData に格納します。

・最終読み出しアドレスは、Serial Phase Change Memory 容量-1 です。

・ロールオーバーによる読み出しはできません。最終アドレスの読み出し後、一度処 理を完了させて、再度アドレスを設定し直してから、本ユーザ API をコールしてく ださい。なお、32Mb/64Mb Serial Phase Change Memory の使用制限(※1)によ り、最終アドレスを読み出した後、次の読み出しではアドレスがロールオーバーし ないため、続けて先頭アドレスの読み出しを行うことはできません。

(※1:以下の使用制限情報を参照。32Mb/64Mb P5Q Serial Phase Change Memory Errata Rev.A)

; デバイス番号 引 数 uint8 t DevNo

> r\_qspi\_pcm\_info\_t FAR\* pPcm\_Info ; PCM 通信情報構造体 Addr uint32\_t : 読み出し開始アドレス uint32 t Cnt ; 読み出しバイト数

uint16 t DataCnt ; 読み出しバイト Temp. (設定禁止) uint8\_t FAR\* pData ; 読み出しデータ格納バッファポインタ

リターン値 読み出し結果を返します。

> PCM OK ; Successful operation PCM\_ERR\_PARAM ; Parameter error PCM\_ERR\_HARD Hardware error PCM ERR OTHER ; Other error



図 5-13 データ読み出し処理概要

# 5.9.6 データ書き込み処理

| e_Data                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                         |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| データ書き込み処理                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                         |
| error_t R_QSPI_PCM_Write_Data(uint                                                                                                                                                                                                                                         | ub.h, r_qspi_pcm_sfr.h, r_qspi_pcm_drvif.h<br>8_t DevNo, r_qspi_pcm_info_t FAR*                                                                                                                                                                                         |
| <ul> <li>・pData のデータを Serial Phase Chan 数分書き込みます。</li> <li>・ Mode の設定により、legacy program みを実行します。</li> <li>・ Serial Phase Change Memory への書能です。プロテクトされた領域への記せん。WEL ビットは、セット状態で・プログラムエラーが発生した場合、式態です。</li> <li>・ 最終書き込みアドレスは、Serial Pha・書き込みバイト数(Cnt)に設定でき容量の値です。</li> </ul> | エラーを返しません。WEL ビットは、セット<br>ase Change Memory 容量-1 です。<br>る最大値は、Serial Phase Change Memory<br>J.h の「PCM_WAIT_READY」の設定有無に関                                                                                                                                                |
| uint8_t DevNo r_qspi_pcm_info_t FAR* pPcm_Info uint32_t Addr uint32_t Cnt uint16_t DataCnt uint8_t FAR* pData uint8_t Mode                                                                                                                                                 | <ul> <li>デバイス番号</li> <li>PCM 通信情報構造体</li> <li>書き込み開始アドレス</li> <li>書き込みバイト数</li> <li>書き込みバイト Temp. (設定禁止)</li> <li>書き込みデータ格納バッファポインタ</li> <li>書き込みモード(以下より1つ選択)</li> <li>PCM_MODE_PP_LEGACY</li> <li>PCM_MODE_PP_BIT_ALTERABLE</li> <li>PCM_MODE_PP_ON_ALL_1S</li> </ul> |
|                                                                                                                                                                                                                                                                            | データ書き込み処理 r_qspi_pcm_p5q.h, r_qspi_pcm_p5q_s error_t R_QSPI_PCM_Write_Data(uinta pPcm_Info, uint8_t Mode)                                                                                                                                                               |

リターン値

読み出し結果を返します。

PCM\_OK ; Successful operation
PCM\_ERR\_PARAM ; Parameter error
PCM\_ERR\_HARD ; Hardware error
PCM\_ERR\_TIMEOUT ; Time out error
PCM\_ERR\_OTHER ; Other error



図 5-14 データ書き込み処理概要

#### 5.9.7 データ書き込み処理(1Page 書き込み用)

#### R\_QSPI\_PCM\_Write\_Data\_Page

概要デー

データ書き込み処理(1Page 書き込み用)

ヘッダ

宣言

r\_qspi\_pcm\_p5q.h, r\_qspi\_pcm\_p5q\_sub.h, r\_qspi\_pcm\_sfr.h, r\_qspi\_pcm\_drvif.h error\_t R\_QSPI\_PCM\_Write\_Data\_Page(uint8\_t DevNo, r\_qspi\_pcm\_info\_t FAR\* pPcm\_Info, uint8\_t Mode)

説明

- pData のデータを Serial Phase Change Memory 上の指定アドレスから指定バイト 数分(最大: 1Page) 書き込みます。
- Mode の設定により、legacy program、bit-alterable write、on all 1s による書き込みを実行します。
- ・大容量のデータ書き込みの際、Page 単位に通信を分割するため、通信中に他の処理ができなくなることを防ぐことができます。
- ・Serial Phase Change Memory への書き込みは、ライトプロテクト解除領域のみ可能です。プロテクトされた領域への書き込みはできません。また、エラーを返しません。WEL ビットは、セット状態です。
- ・プログラムエラーが発生した場合、エラーを返しません。WEL ビットは、セット 状態です。
- ・最終書き込みアドレスは、Serial Phase Change Memory 容量-1 です。
- ・書き込みバイト数(Cnt)に設定できる最大値は、Serial Phase Change Memory 容量の値です。
- ・1Page を超えるバイト数が設定されている場合でも、1Page 書き込み処理完了後、 残バイト数と次アドレス情報が PCM 通信情報構造体(pPcm\_Info)に残ります。 未変更のまま再びその pPcm\_Info をセットすることで残バイト数の書き込みが可 能です。
- ・書き込み完了待ちの方法は二種類あります。以降にその方法を示します。なお、次の処理(書き込み/読み出し/消去等)は、書き込み完了を確認した後、実行してください
- ・本ユーザ API で完了待ちを行う場合、r\_qspi\_pcm\_p5q.h の「PCM\_WAIT\_READY」を有効にしてください。
- ・本ユーザ API で完了待ちを行わない場合、r\_qspi\_pcm\_p5q.h の「PCM\_WAIT\_READY」を無効にし、本ユーザ API の処理が完了した後、R\_QSPI\_PCM\_Wait()をコールしてください。この処理方法では、ユーザの任意のタイミングで書き込み完了待ちを確認することができます。使用方法は図 5-16 を参照してください。

引 数

uint8\_t DevNo ; デバイス番号

r\_qspi\_pcm\_info\_t FAR\* pPcm\_Info ; PCM 通信情報構造体 uint32\_t Addr ; 書き込み開始アドレス uint32\_t Cnt ; 書き込みバイト数

uint16\_tDataCnt;書き込みバイト Temp. (設定禁止)uint8\_t FAR\*pData;書き込みデータ格納バッファポインタuint8\_tMode:書き込みモード(以下より1つ選択)

PCM\_MODE\_PP\_LEGACY

; PCM\_MODE\_PP\_BIT\_ALTERABLE ; PCM\_MODE\_PP\_ON\_ALL\_1S

リターン値

読み出し結果を返します。

PCM\_OK ; Successful operation
PCM\_ERR\_PARAM ; Parameter error
PCM\_ERR\_HARD ; Hardware error

PCM\_ERR\_TIMEOUT ; Time out error (「PCM\_WAIT\_READY」有効時)

PCM\_ERR\_OTHER ; Other error



図 5-15 データ書き込み処理 (1Page 書き込み用) 概要



図 5-16 R\_QSPI\_PCM\_Wait()を使用したデータ書き込み処理(1Page 書き込み用)の完了待ち方法

#### 5.9.8 消去処理

## R\_QSPI\_PCM\_Erase

概要

消去処理

ヘッダ

r\_qspi\_pcm\_p5q.h, r\_qspi\_pcm\_p5q\_sub.h, r\_qspi\_pcm\_sfr.h, r\_qspi\_pcm\_drvif.h error\_t R\_QSPI\_PCM\_Erase(uint8\_t DevNo, uint32\_t Addr, uint8\_t Mode)

宣言説明

- ・メモリの全データ消去 (Bulk Erase)、または指定されたセクタの全データ消去 (Sector Erase) を行います。
- ・Mode の設定により、Bulk Erase または Sector Erase を実行します。
- ・Bulk Erase の場合、Addr には 0x00000000 を設定してください。
- Serial Phase Change Memory の消去は、ライトプロテクト解除領域のみ可能です。 プロテクトされている領域は、消去はできません。また、エラーは返りません。 WEL ビットは、セット状態です。
- ・消去エラーが発生した場合、エラーを返しません。WEL ビットは、セット状態です。
- ・消去完了待ちの方法は二種類あります。以降にその方法を示します。なお、次の処理(書き込み/読み出し/消去等)は、消去完了を確認した後、実行してください。
- ・本ユーザ API で完了待ちを行う場合、r\_qspi\_pcm\_p5q.h の「PCM\_WAIT\_READY」を有効にしてください。
- ・本ユーザ API で完了待ちを行わない場合、r\_qspi\_pcm\_p5q.h の「PCM\_WAIT\_READY」を無効にし、本ユーザ API の処理が完了した後、R\_QSPI\_PCM\_Wait()をコールしてください。この処理方法では、ユーザの任意のタイミングで書き込み完了待ちを確認することができます。使用方法は図 5-18 を参照してください。
- Bulk Erase と Sector Erase では、R\_QSPI\_PCM\_Wait()をコールする際の引数 BusyCnt の設定が異なります。

Bulk Erase 時 : BusyCnt = PCM\_BE\_BUSY\_WAIT Sector Erase 時 : BusyCnt = PCM\_SE\_BUSY\_WAIT

引 数

uint8\_t

DevNo ; デバイス番号

uint32\_t

Addr ; 消去アドレス

uint8\_t

Mode ; 消去モード (下記より1つ選択)

; PCM\_MODE\_B\_ERASE

; PCM MODE S ERASE

リターン値

・消去結果を返します。

PCM\_OK ; Successful operation PCM\_ERR\_PARAM ; Parameter error

PCM\_ERR\_HARD ; Hardware error

PCM\_ERR\_TIMEOUT ; Time out error (「PCM\_WAIT\_READY」有効時)

PCM\_ERR\_OTHER ; Other error



図 5-17 消去処理概要



図 5-18 R\_QSPI\_PCM\_Wait()を使用した消去処理の完了待ち方法

## 5.9.9 ID 読み出し処理

| R_QSPI_PCM_Read | _ID                                                                                                                                                                                                                                                   |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 概 要             | ID 読み出し処理                                                                                                                                                                                                                                             |
| ヘッダ             | r_qspi_pcm_p5q.h, r_qspi_pcm_p5q_sub.h, r_qspi_pcm_sfr.h, r_qspi_pcm_drvif.h                                                                                                                                                                          |
| 宣言              | error_t R_QSPI_PCM_Read_ID(uint8_t DevNo, uint8_t FAR* pData )                                                                                                                                                                                        |
| 説明              | ・Manufacture ID 及び Device ID を読み出し、pData に格納します。読み出しバッファとして、3 バイトを設定してください。                                                                                                                                                                           |
|                 | ・32Mb/64Mb Serial Phase Change Memory の使用制限(※1)により、Device ID<br>の Memory Capacity(Lower Byte)を読み出すと 18h になります。正常品では、<br>32Mb 時に 16h、64Mb 時に 17h、128Mb 時に 18h が読み出されます。<br>(※1: 以下の使用制限情報を参照。32Mb/64Mb P5Q Serial Phase Change Memory<br>Errata Rev.A) |
| 引数              | uint8_t DevNo ; デバイス番号                                                                                                                                                                                                                                |
| リターン値           | uint8_t FAR* pData ; 読み出しデータ格納バッファポインタ ・読み出し結果を返します。 PCM_OK ; Successful operation PCM_ERR_PARAM ; Parameter error PCM_ERR_HARD ; Hardware error PCM_ERR_OTHER ; Other error                                                                          |



図 5-19 ID 読み出し処理概要

# 5.9.10 ビジーウェイト処理

## R\_QSPI\_PCM\_Wait

概要

ビジーウェイト処理

ヘッダ 宣 言

説明

r\_qspi\_pcm\_p5q.h, r\_qspi\_pcm\_p5q\_sub.h, r\_qspi\_pcm\_sfr.h, r\_qspi\_pcm\_drvif.h error\_t R\_QSPI\_PCM\_Wait(uint8\_t DevNo, uint16\_t BusyTime, uint32\_t BusyCnt)

- ・「PCM\_WAIT\_READY」を無効にし、書き込み/消去の完了を確認する場合に使用してください。
- ・BusyCnt=0 の場合、BusyTime 時間間隔で、ビジーの期間をウェイトします。
- ・BusyCnt≠0 の場合、BusyTime 時間間隔で、BusyCnt 回数分、ビジーの期間をウェイトします。BusyCnt 回数を超えてもビジーの場合、「FLASH\_ERR\_TIMEOUT」を返します。
- ・書き込み/消去により BusyCnt と BusyTime に設定する値が異なります。意図しない設定でビジーウェイトを行うと、Time out error が発生する可能性があります。 下表にしたがって設定してください。

| 状態                | BusyTime         | BusyCnt          |
|-------------------|------------------|------------------|
| ステータスレジスタ書き込      | PCM_T_WBUSY_WAIT | PCM_WBUSY_WAIT   |
| み中(ライトプロテクト       |                  |                  |
| ビットセット)           |                  |                  |
| データ書き込み中          | PCM_T_WBUSY_WAIT | PCM_WBUSY_WAIT   |
| 消去中(Bulk Erase)   | PCM_T_EBUSY_WAIT | PCM_BE_BUSY_WAIT |
| 消去中(Sector Erase) | PCM_T_EBUSY_WAIT | PCM_SE_BUSY_WAIT |

引 数

uint8\_t DevNo ; デバイス番号

uint16\_t BusyTime ; ウェイト時間(以下より1つ選択)

PCM\_T\_WBUSY\_WAIT:書き込み時

PCM\_T\_EBUSY\_WAIT : 消去時

uint32\_t BusyCnt ; カウンタ(以下より1つ選択)

PCM\_WBUSY\_WAIT : 書き込み時

PCM\_BE\_BUSY\_WAIT:消去時(Bulk Erase) PCM\_SE\_BUSY\_WAIT:消去時(Sector Erase)

リターン値

読み出し結果を返します。

PCM\_OK ; Successful operation
PCM\_ERR\_PARAM ; Parameter error
PCM\_ERR\_HARD ; Hardware error

PCM\_ERR\_TIMEOUT ; Time out error (BusyCnt≠0 の場合)

PCM\_ERR\_OTHER ; Other error



図 5-20 ビジーウェイト処理概要

# RX ファミリ、RL78 ファミリ、78K0R/Kx3-L

# Micron Technology 社製 P5Q Serial Phase Change Memory 制御ソフトウェア

## 6. 応用例

Serial Phase Change Memory 制御部分(クロック同期式シングルマスタ制御ソフトウェア部分は、対象外)の設定例を示します。

クロック同期式シングルマスタ制御ソフトウェア部分は、MCU 個別のアプリケーションノートを参照してください。

なお、通信速度は、スレーブデバイス個別の設定が必要なため、本サンプルコードにて設定します。 設定箇所は、各ファイル中の「/\*\* SET \*\*/」というコメントの部分です。

また、共通で使用される関数 (mtl\_wait\_lp()等) は、MCU 個別のクロック同期式シングルマスタ制御ソフトウェアに含まれているものを使用してください。

# 6.1 Serial Phase Change Memory 制御ソフトウェアの設定

設定箇所は、各ファイル中の「/\*\* SET \*\*/」というコメントの部分です。

#### 6.1.1 r\_qspi\_pcm\_p5q.h

本 Serial Phase Change Memory 用の定義ファイルです。

設定箇所は、各ファイル中の「/\*\* SET \*\*/」というコメントの部分です。

#### (1) 使用するデバイスの個数とデバイス番号の定義

使用するデバイスの個数を指定し、各デバイスに番号を割り当ててください。 下記は、デバイスを1個使用し、デバイス番号を0に割り当てる場合の例です。 最大2個までの制御が可能です。

#### (2) 使用するデバイスの容量の定義

使用するデバイスの容量を指定してください。

下記は、64Mbit デバイスを使用する場合の例です。

#### (3) Delay task のウェイト時間設定(OS 制御設定時、有効)

OS 制御(※)の Delay task のウェイト時間を設定します。単位は ms です。

下記は、1msを設定する場合の例です。

```
/*----*/ \#define PCM DELAY TASK (uint8 t)1 /* OS delay task wait time (Uint:ms) */
```

※: 本サンプルコードの OS 制御は、 $\mu$  ITRON4.0 を想定しています。

# (4) 書き込み待ち/消去完了待ち処理の組み込み設定

以下の関数内でコマンド実行後の完了を待つ設定が可能です。完了を待つ設定にする場合、設定を有効に してください。

#### 対象関数:

```
ライトプロテクト設定処理(R_QSPI_PCM_Set_Write_Protect())、
データ書き込み処理(1Page 書き込み用)(R_QSPI_PCM_Write_Data_Page())
```

消去処理 (R\_QSPI\_PCM\_Erase())

下記は、完了待ち設定をする場合の例です。

## 6.1.2 r\_qspi\_pcm\_p5q\_sfr.h

r\_qspi\_pcm\_p5q\_sfr.h.XXX は、MCU 毎に作成したものです。どれか一つを r\_qspi\_pcm\_p5q\_sfr.h にリネームして使用してください。対象 MCU のものが無い場合には、参照して、r\_qspi\_pcm\_p5q\_sfr.h を作成してください。

設定箇所は、各ファイル中の「/\*\* SET \*\*/」というコメントの部分です。

#### (1) チップセレクト信号設定

使用するチップセレクト信号のポートの SFR を定義してください。

2つ目のデバイスを接続する場合、2つ目のポートも定義してください。

以下は、RX63NでポートA0を使用する場合での記述例を示しています。

以下は、RL78/G14でポート80を使用する場合での記述例を示しています。 /\*-----\*/ /\* Define the CS port. /\*-----/ #ifdef \_\_CA78KOR\_\_ /\* Renesas RL78 Compiler \*/
#define PCM\_DR\_CS0 P8.0 /\* PCM CS0 (Negative-true logic) \*/
#define PCM\_DDR\_CS0 PM8.0 /\* PCM CS0 (Negative-true logic) \*/ #if (PCM DEV NUM > 1) #define PCM\_DR\_CS1 /\* PCM CS1 (Negative-true logic) \*/
#define PCM\_DDR\_CS1 /\* PCM CS1 (Negative-true logic) \*/ #endif /\* #if (PCM\_DEV\_NUM > 1) \*/ #endif /\* \_\_CA78KOR\_\_ \*/ def \_\_CCRL\_\_ /\* Renesas CC-RL Compiler #define PCM\_DR\_CSO P8\_bit.no0 /\* PCM CSO (Negative-true logic) #define PCM\_DDR\_CSO PM8\_bit.no0 /\* PCM CSO (Negative-true logic) \*/ #ifdef \* / \*/ #if (PCM DEV NUM > 1) #define PCM\_DR\_CS1 /\* PCM CS1 (Negative-true logic)
#define PCM\_DDR\_CS1 /\* PCM CS1 (Negative-true logic) \* / #endif /\* #if (PCM\_DEV\_NUM > 1) \*/ #endif /\* \_\_CCRL\_\_ \*/
#ifdef ICCRL78 /\* IAR RL78 Compiler \*/ #define PCM\_DR\_CS0 P8\_bit.no0 /\* PCM CS0 (Negative-true logic) \*/ #define PCM DDR CS0 PM8 bit.no0 /\* PCM CS0 (Negative-true logic) #if (PCM DEV NUM > 1) #endif /\* #if (PCM\_DEV\_NUM > 1) \*/ #endif /\* \_\_ICCRL78\_\_ \*/

#### (2) 通信速度の設定

通信速度を設定してください。単位は、bit/secです。

設定値は、使用する MCU とシリアル I/O に依存します。通信する用途により設定を分けています。詳しくは表 6-1 を参照ください。

#### 表 6-1 通信速度設定

| #define 定義        | 用途                   |
|-------------------|----------------------|
| PCM_BR            | 下記2項以外の通信処理(コマンド送信等) |
| PCM_BR_WRITE_DATA | データ書き込み処理            |
| PCM_BR_READ_DATA  | データ読み出し処理            |

以下は、RX63NのRSPIを使用する場合の例です。

```
/* PCLK = 48MHz, n=0 for RX63N RSPI */
                   (uint8 t) (0x01) /* SPBR initial setting
#define PCM BR
                  ++---- 12.00MHz
  /* PCLK = 48MHz, n=0 for RX63N RSPI Write Data */
#define PCM BR WRITE DATA (uint8 t)(0x01) /* SPBR initial setting
            /* ++---- 12.00MHz
  /* PCLK = 48MHz, n=0 for RX63N RSPI Read Data */
#define PCM_BR_READ_DATA (uint8_t)(0x01) /* SPBR initial setting
            /* ++---- 12.00MHz
以下は、RL78/G14のCSIを使用する場合の例です。
  /* fMCK = 24MHz for RL78 CSI */
/* fMCK = 24MHz for RL78 CSI Write Data */
#define PCM_BR_WRITE_DATA (uint8_t)(0x01) /* SDR[15:9] initial setting
                ++---- 6.00MHz
                                                            */
  /* fMCK = 24MHz for RL78 CSI Read Data */
#define PCM BR READ DATA (uint8 t)(0x01) /* SDR[15:9]initial setting
            /* ++----- 6.00MHz
```

設定値は、MCU のハードウェアマニュアルを参考に設定してください。

#### 6.1.3 r gspi pcm p5g sub.h

設定箇所は、各ファイル中の「/\*\* SET \*\*/」というコメントの部分です。

#### (1) 消去タイムアウト時間設定

メモリの全データ消去(Bulk Erase)と指定されたセクタの全データ消去(Sector Erase)のタイムアウト時間を設定します。

デバイスにより、消去時間が異なる場合、以下の設定を見直してください。

以下は、Bulk Erase のタイムアウト時間を 100s、Sector Erase のタイムアウト時間を 800ms に設定する場合での記述例を示します。

#### (2) 書き込みタイムアウト時間設定

デバイスにより、書き込み時間が異なる場合、以下の設定を見直してください。

以下は、書き込みタイムアウト時間を 400us に設定する場合での記述例を示しています。

#define PCM WBUSY WAIT (uint32 t)(400) /\* Write busy timeout 400\*1us = 400us \*/

# RX ファミリ、RL78 ファミリ、78K0R/Kx3-L

# Micron Technology 社製 P5Q Serial Phase Change Memory 制御ソフトウェア

## 6.1.4 r\_qspi\_pcm\_p5q\_sub.c

本 Serial Phase Change Memory 用の内部関数ソースファイルです。

設定箇所は、各ファイル中の「/\*\* SET \*\*/」というコメントの部分です。

#### (1) マクロ関数 R\_QSPI\_PCM\_CMD\_READ()の定義

読み出し処理の動作コマンドを設定します。下表より1つ定義してください。

表 6-2 マクロ関数 R\_QSPI\_PCM\_CMD\_READ()定義

| No. | #define 定義値                                                                                       | データシート上<br>の命令コード | 処理内容                    |
|-----|---------------------------------------------------------------------------------------------------|-------------------|-------------------------|
| 1   | r_qspi_pcm_send_cmd( <b>PCM_CMD_READ</b> , (uint32_t)A ddr, PCM_CMD_SIZE + PCM_ADDR_SIZE)         | READ              | Single-SPI 読み出し<br>(通常) |
| 2   | r_qspi_pcm_send_cmd( <b>PCM_CMD_FREAD</b> , (uint32_t)<br>Addr, PCM_CMD_SIZE + PCM_ADDR_SIZE + 1) | FAST_READ         | Single-SPI 読み出し<br>(高速) |
| 3   | r_qspi_pcm_send_cmd( <b>PCM_CMD_DOFR</b> , (uint32_t)A ddr, PCM_CMD_SIZE + PCM_ADDR_SIZE + 1)     | DOFR              | Dual-SPI 読み出し<br>(高速)   |
| 4   | r_qspi_pcm_send_cmd(PCM_CMD_QOFR, (uint32_t)A ddr, PCM_CMD_SIZE + PCM_ADDR_SIZE + 1)              | QOFR              | Quad-SPI 読み出し<br>(高速)   |

## (2) マクロ関数 R\_QSPI\_PCM\_CMD\_PP\_LEGACY()の設定

legacy program による書き込み処理の動作コマンドを設定します。下表より1つ定義してください。

表 6-3 マクロ関数 R\_QSPI\_PCM\_CMD\_PP\_LEGACY()定義

| No. | #define 定義値                                           | データシート上 | 処理内容             |
|-----|-------------------------------------------------------|---------|------------------|
|     |                                                       | の命令コード  |                  |
| 1   | r_qspi_pcm_send_cmd( <b>PCM_CMD_PP_L</b> , (uint32_t) | PP      | Single-SPI 書き込み  |
|     | Addr,PCM_CMD_SIZE + PCM_ADDR_SIZE)                    |         | (legacy program) |
| 2   | r_qspi_pcm_send_cmd(PCM_CMD_DIPP_L, (uint32           | DIFP    | Dual-SPI 書き込み    |
|     | _t)Addr,PCM_CMD_SIZE + PCM_ADDR_SIZE)                 |         | (legacy program) |
| 3   | r_qspi_pcm_send_cmd(PCM_CMD_QIPP_L, (uint32           | QIFP    | Quad-SPI 書き込み    |
|     | _t)Addr,PCM_CMD_SIZE + PCM_ADDR_SIZE)                 |         | (legacy program) |

## (3) マクロ関数 R\_QSPI\_PCM\_CMD\_PP\_BIT\_ALTERABLE()の設定

bit-alterable write による書き込み処理の動作コマンドを設定します。下表より1つ定義してください。

表 6-4 マクロ関数 R\_QSPI\_PCM\_CMD\_PP\_BIT\_ALTERABLE ()定義

| No. | #define 定義値                                 | データシート上 | 処理内容                  |
|-----|---------------------------------------------|---------|-----------------------|
|     |                                             | の命令コード  |                       |
| 1   | r_qspi_pcm_send_cmd(PCM_CMD_PP_BA, (uint32_ | PP      | Single-SPI 書き込み       |
|     | t)Addr,PCM_CMD_SIZE + PCM_ADDR_SIZE)        |         | (bit-alterable write) |
| 2   | r_qspi_pcm_send_cmd(PCM_CMD_DIPP_BA, (uint3 | DIFP    | Dual-SPI 書き込み         |
|     | 2_t)Addr,PCM_CMD_SIZE + PCM_ADDR_SIZE)      |         | (bit-alterable write) |
| 3   | r_qspi_pcm_send_cmd(PCM_CMD_QIPP_BA, (uint3 | QIFP    | Quad-SPI 書き込み         |
|     | 2_t)Addr,PCM_CMD_SIZE + PCM_ADDR_SIZE)      |         | (bit-alterable write) |

## (4) マクロ関数 R\_QSPI\_PCM\_CMD\_PP\_ON\_ALL\_1S()の設定

on all 1sによる書き込み処理の動作コマンドを設定します。下表より1つ定義してください。

表 6-5 マクロ関数 R\_QSPI\_PCM\_CMD\_PP\_ON\_ALL\_1S()定義

| No. | #define 定義値                                 | データシート上 | 処理内容            |
|-----|---------------------------------------------|---------|-----------------|
|     |                                             | の命令コード  |                 |
| 1   | r_qspi_pcm_send_cmd(PCM_CMD_PP_OA, (uint32_ | PP      | Single-SPI 書き込み |
|     | t)Addr,PCM_CMD_SIZE + PCM_ADDR_SIZE)        |         | (on all 1s)     |
| 2   | r_qspi_pcm_send_cmd(PCM_CMD_DIPP_OA, (uint3 | DIFP    | Dual-SPI 書き込み   |
|     | 2_t)Addr,PCM_CMD_SIZE + PCM_ADDR_SIZE)      |         | (on all 1s)     |
| 3   | r_qspi_pcm_send_cmd(PCM_CMD_QIPP_OA, (uint3 | QIFP    | Quad-SPI 書き込み   |
|     | 2_t)Addr,PCM_CMD_SIZE + PCM_ADDR_SIZE)      |         | (on all 1s)     |

## 6.1.5 r\_qspi\_pcm\_p5q\_drvif.c

本 Serial Phase Change Memory 用のクロック同期式シングル制御ソフトウェア I/F ソースファイルです。 設定箇所は、各ファイル中の「/\*\* SET \*\*/」というコメントの部分です。

#### (1) r\_qspi\_pcm\_drvif\_init\_driver()の設定

使用するクロック同期式シングルマスタ制御ソフトウェアのドライバ初期化処理を設定します。 対応のものが無い場合、追加してください。

```
error_t r_qspi_pcm_drvif_init_driver(void)
{
    return R_SIO_Init_Driver();
}
```

# (2) r\_qspi\_pcm\_drvif\_disable()の設定

使用するクロック同期式シングルマスタ制御ソフトウェアの通信禁止設定処理を設定します。 対応のものが無い場合、追加してください。

```
error_t r_qspi_pcm_drvif_disable(void)
{
    return R_SIO_Disable();
}
```

#### (3) r\_qspi\_pcm\_drvif\_enable()の設定

使用するクロック同期式シングルマスタ制御ソフトウェアの通信許可設定処理を設定します。 対応のものが無い場合、追加してください。

```
error_t r_qspi_pcm_drvif_enable(uint8_t BrgData)
{
    return R_SIO_Enable(BrgData);
}
```

#### (4) r\_qspi\_pcm\_drvif\_enable\_tx\_data()の設定

使用するクロック同期式シングルマスタ制御ソフトウェアのデータ書き込み専用の通信許可設定処理を設定します。

対応のものが無い場合、追加してください。

```
error_t r_qspi_pcm_drvif_enable_tx_data(uint8_t BrgData)
{
    return R_SIO_Enable(BrgData);
}
```

#### (5) r\_qspi\_pcm\_drvif\_enable\_rx\_data()の設定

使用するクロック同期式シングルマスタ制御ソフトウェアのデータ読み出し専用の通信許可設定処理を設定します。

対応のものが無い場合、追加してください。

```
error_t r_qspi_pcm_drvif_enable_rx_data(uint8_t BrgData)
{
   return R_SIO_Enable(BrgData);
}
```

#### (6) r\_qspi\_pcm\_drvif\_open()の設定

使用するクロック同期式シングルマスタ制御ソフトウェアの通信開放設定処理を設定します。 対応のものが無い場合、追加してください。

```
error_t r_qspi_pcm_drvif_open(void)
{
    return R_SIO_Open_Port();
}
```

#### (7) r\_qspi\_pcm\_drvif\_tx()の設定

使用するクロック同期式シングルマスタ制御ソフトウェアのデータ送信処理を設定します。主にコマンド送信やステータスレジスタへの書き込みに使用します。

対応のものが無い場合、追加してください。

```
error_t r_qspi_pcm_drvif_tx(uint16_t TxCnt, uint8_t FAR * pData)
{
    return R_SIO_Tx_Data(TxCnt, pData);
}
```

#### (8) r\_qspi\_pcm\_drvif\_tx\_data()の設定

使用するクロック同期式シングルマスタ制御ソフトウェアの書き込み専用のデータ送信処理を設定します。 対応のものが無い場合、追加してください。

```
error_t r_qspi_pcm_drvif_tx_data(uint16_t TxCnt, uint8_t FAR * pData)
{
    return R_SIO_Tx_Data(TxCnt, pData);
}
```

#### (9) r\_qspi\_pcm\_drvif\_rx()の設定

使用するクロック同期式シングルマスタ制御ソフトウェアのデータ受信処理を設定します。主にステータスレジスタの読み出しに使用します。

対応のものが無い場合、追加してください。

```
error_t r_qspi_pcm_drvif_rx(uint16_t RxCnt, uint8_t FAR * pData)
{
    return R_SIO_Rx_Data(RxCnt, pData);
}
```

#### (10) r\_qspi\_pcm\_drvif\_rx\_data()の設定

使用するクロック同期式シングルマスタ制御ソフトウェアの読み出し専用のデータ受信処理を設定します。 対応のものが無い場合、追加してください。

```
error_t r_qspi_pcm_drvif_rx_data(uint16_t RxCnt, uint8_t FAR * pData)
{
    return R_SIO_Rx_Data(RxCnt, pData);
}
```

## RX ファミリ、RL78 ファミリ、78K0R/Kx3-L

## Micron Technology 社製 P5Q Serial Phase Change Memory 制御ソフトウェア

# 6.1.6 r\_qspi\_pcm\_p5q\_sfr\_rl78.c

本プログラムは RL78 用の SFR モジュールファイルです。

設定箇所は、各ファイル中の「/\*\* SET \*\*/」というコメントの部分です。

#### (1) SFR 領域用デファインの設定

RL78 ファミリ、もしくは 78K0R を使用する場合、使用する C コンパイラには、定義済プリプロセッサシンボルがあります。この定義済プリプロセッサシンボルを使用し、プログラムを記述済です。

また、使用する MCU が RL78 ファミリ、もしくは 78K0R であり、かつ、IAR Systems 製の統合開発環境を使用する場合には、使用する MCU の SFR が定義されているヘッダファイルを設定する必要があります。

MCU 個別のクロック同期式シングルマスタ制御ソフトウェアも参照してください。

本設定は、SPIスレーブデバイスセレクト制御信号用に使用します。

#### 表 6-6 MCU と SFR 領域用デファインの設定

| 統合開発環境                       | MCU   | SFR 設定の要・不要         | 設定方法                                                                                                                                                   |
|------------------------------|-------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| CubeSuite+                   | RL78  | 不要                  | 不要                                                                                                                                                     |
| CS+                          | 78K0R | 不要                  | 不要                                                                                                                                                     |
|                              | RX    | 不要                  | 不要                                                                                                                                                     |
| IAR<br>Embedded<br>Workbench | RL78  | 要                   | #ifdefICCRL78<br>#include <ior5f104pj.h> ←MCU に合わせて変更<br/>#include <ior5f104pj_ext.h> ←MCU に合わせて変更<br/>#endif</ior5f104pj_ext.h></ior5f104pj.h>        |
|                              | 78K0R | 要                   | #ifdefICC78K<br>#include <io78f1009_64.h> ←MCU に合わせて変更<br/>#include <io78f1009_64_ext.h> ←MCU に合わせて変更<br/>#endif</io78f1009_64_ext.h></io78f1009_64.h> |
|                              | RX    | (本ソフトウェアは<br>未サポート) | (本ソフトウェアは未サポート)                                                                                                                                        |

以下は、RL78/G14 100pin を使用する場合の例です。

# 7. 使用上の注意事項

#### 7.1 組み込み時の注意事項

本サンプルコードを組み込む場合は、以下のヘッダファイルをインクルードしてください。

- r\_qspi\_pcm\_p5q.h
- r\_qspi\_pcm\_p5q\_sub.h
- r\_qspi\_pcm\_p5q \_sfr.h
- r\_qspi\_pcm\_p5q \_drvif.h

#### 7.2 キャッシュ搭載の MCU を使用する場合

読み出し/書き込み用データ格納バッファは、非キャッシュ領域を指定してください。

#### 7.3 他容量に対応する場合

他容量に対応する場合、以下の定義の見直しが必要です。

PCM\_MEM\_SIZE

PCM\_SECT\_ADDR

PCM PAGE SIZE

PCM\_ADDR\_SIZE

PCM\_WP\_WHOLE\_MEM

上記以外の定義の見直しが必要になる可能性がありますので、メモリのデータシートを入手し、定義を見直してください。

#### 7.4 他スレーブデバイスを使用する場合

同一SPIバス上で、他スレーブデバイスを制御することが可能です。 スレーブデバイス制御ソフトウェアを作成する場合は、本サンプルコードを参考にしてください。 また、スレーブデバイス制御ソフトウェア毎に、通信速度設定が可能です。

#### 7.5 電源投入後の電圧安定待ち時間について

電源投入後、電圧が安定するまでの間、十分に時間を待ってから初期化関数をコールしてください。 電源投入後の電圧安定待ち時間については、スレーブデバイスのデータシートをご確認ください。

# 7.6 Serial Phase Change Memory の使用制限について

本アプリケーションノート作成時点では、Micron Technology 社より以下の使用制限が報告されています。 当該の機能をご使用される際は、最新のデータシートをご確認の上、十分に評価してからご使用ください。

#### (1) 128Mb P5Q Serial Phase Change Memory Errata

| No. | Errata | 使用制限内容                   | 本サンプルコードへの影響                   |
|-----|--------|--------------------------|--------------------------------|
|     | Rev.   |                          |                                |
| 1   | D      | ライトプロテクトビット(BP3, BP2,    | ユーザ API                        |
|     |        | BP1, BP0) に 1 をセットすることがで | R_QSPI_PCM_Set_Write_Protect() |
|     |        | きない。                     | により、ライトプロテクトビットに1をセットす         |
|     |        |                          | ることができない。                      |

#### (2) 64Mb P5Q Serial Phase Change Memory Errata

| No. | Errata<br>Rev. | 使用制限内容                                                                                                                          | 本サンプルコードへの影響                                                                              |
|-----|----------------|---------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| 1   | A              | ライトプロテクトビット(BP3, BP2,<br>BP1, BP0) に 1 をセットすることがで<br>きない。                                                                       | ユーザ API<br>R_QSPI_PCM_Set_Write_Protect()<br>により、ライトプロテクトビットに 1 をセットす<br>ることができない。        |
| 2   | A              | Device ID の Memory Capacity(Lower<br>Byte)を読み出すと、18h になる。正<br>常品では 17h になる。                                                     | ユーザ API<br>R_QSPI_PCM_RDID()<br>により読み出しを行うと、pData の3バイト目の<br>値が 18h になる。                  |
| 3   | A              | データ読み出し(READ, READ_FAST,<br>DUAL OUTPUT FAST READ, and<br>QUAD OUTPUT FAST READ)では、<br>7FFFFFh を読み出した後、000000h に<br>ロールオーバーしない。 | 影響なし。<br>本サンプルコードの読み出し処理である<br>R_QSPI_PCM_Read_Data()<br>では、ロールオーバーによる読み出しを許可して<br>いないため。 |

# (3) 32Mb P5Q Serial Phase Change Memory Errata

| No. | Errata<br>Rev. | 使用制限内容                                                                                                                          | 本サンプルコードへの影響                                                                              |
|-----|----------------|---------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| 1   | A              | ライトプロテクトビット(BP3, BP2,<br>BP1, BP0) に 1 をセットすることがで<br>きない。                                                                       | ユーザ API<br>R_QSPI_PCM_Set_Write_Protect()<br>により、ライトプロテクトビットに 1 をセットす<br>ることができない。        |
| 2   | A              | Device ID の Memory Capacity(Lower<br>Byte)を読み出すと、18h になる。正<br>常品では 16h になる。                                                     | ユーザ API<br>R_QSPI_PCM_RDID()<br>により読み出しを行うと、pData の3バイト目の<br>値が 18h になる。                  |
| 3   | A              | データ読み出し(READ, READ_FAST,<br>DUAL OUTPUT FAST READ, and<br>QUAD OUTPUT FAST READ)では、<br>3FFFFFh を読み出した後、000000h に<br>ロールオーバーしない。 | 影響なし。<br>本サンプルコードの読み出し処理である<br>R_QSPI_PCM_Read_Data()<br>では、ロールオーバーによる読み出しを許可して<br>いないため。 |

# RX ファミリ、RL78 ファミリ、78K0R/Kx3-L

# Micron Technology 社製 P5Q Serial Phase Change Memory 制御ソフトウェア

# ホームページとサポート窓口

ルネサス エレクトロニクスホームページ

http://japan.renesas.com/

お問合せ先

http://japan.renesas.com/contact/

すべての商標および登録商標は、それぞれの所有者に帰属します。

# 改訂記録

|      |                 |      | 改訂内容                                                                                    |
|------|-----------------|------|-----------------------------------------------------------------------------------------|
| Б.   | <i>5</i> % /− □ | ページ  |                                                                                         |
| Rev. | 発行日             | ヘージ  | ポイント                                                                                    |
| 1.00 | 2013.05.31      | _    | 初版発行                                                                                    |
| 1.02 | 2013.11.29      | 6    | 2. 動作確認条件 に、以下を追加<br>(3) RL78/G14 SAU 統合開発環境 IAR Embedded Workbench                     |
|      |                 |      | の場合                                                                                     |
|      |                 | 18   | 5.3 必要メモリサイズ に、以下を追加                                                                    |
|      |                 |      | (3) RL78/G14 SAU 統合開発環境 IAR Embedded Workbench                                          |
|      |                 | 19   | の場合<br>5.4 ファイル構成 アプリケーションノート番号を変更                                                      |
|      |                 | 47   | 5.4 ファイル構成 アフリケーションノード番号を変更<br>6.1.2 r_qspi_pcm_p5q_sfr.h 内容を修正した。                      |
|      |                 | 55   | 6.1.6 r_qspi_pcm_p5q_sfr_rl78.c を新規追加した。                                                |
| 1.03 | 2014.04.20      | 1    |                                                                                         |
| 1.03 | 2014.04.30      | '    | 要旨 にクロック同期式シングルマスタ制御ソフトウェア情報の URL を追加した。                                                |
|      |                 | 1    | 対象デバイス に、RX111、RL78/G1C、RL78/L1C、RL78/L12、RL78/L13 を追加                                  |
|      |                 | 5,7  | 2. 動作確認条件                                                                               |
|      |                 | 0,1  | 2.1 RX ファミリと 2.2 RL78 ファミリ、78K0R/Kx3-L を追加                                              |
|      |                 |      | した。                                                                                     |
|      |                 | 6    | 2.1 RX ファミリに、以下を追加                                                                      |
|      |                 |      | (2) RX111 RSPI の場合                                                                      |
|      |                 |      | (3) RX111 SCI の場合                                                                       |
|      |                 | 8-11 | 2.2 RL78 ファミリ、78K0R/Kx3-L に、以下を追加                                                       |
|      |                 |      | (3) RL78/G1C SAU 統合開発環境 CubeSuite+の場合                                                   |
|      |                 |      | (4) RL78/G1C SAU 統合開発環境 IAR Embedded Workbench の場合                                      |
|      |                 |      | (5) RL78/L12 SAU 統合開発環境 CubeSuite+の場合                                                   |
|      |                 |      | (6) RL78/L12 SAU 統合開発環境 IAR Embedded Workbench の場合                                      |
|      |                 |      |                                                                                         |
|      |                 |      | (7) RL78/L13 SAU 統合開発環境 CubeSuite+の場合<br>(8) RL78/L13 SAU 統合開発環境 IAR Embedded Workbench |
|      |                 |      | (6) KL76/LT3 SAO 祝日開光環境 IAK Embedded Workbench                                          |
|      |                 |      | (9) RL78/L1C SAU 統合開発環境 CubeSuite+の場合                                                   |
|      |                 |      | (10) RL78/L1C SAU 統合開発環境 IAR Embedded                                                   |
|      |                 |      | Workbench の場合                                                                           |
|      |                 | 12   | 3.関連アプリケーションノート 以下を更新した。                                                                |
|      |                 |      | RX210, RX21A, RX220, RX63N, RX63T, RX111 グループ                                           |
|      |                 |      | RSPIを使ったクロック同期式シングルマスタ制御ソフトウェ                                                           |
|      |                 |      | ア(R01AN1196JJ) 元は、RX210, RX21A, RX220, RX63N,                                           |
|      |                 |      | RX63T グループ RSPI を使ったクロック同期式シングルマ                                                        |
|      |                 |      | スタ制御ソフトウェア(R01AN1196JJ)であった。                                                            |
|      |                 |      | RX210, RX21A, RX220, RX63N, RX63T, RX111 グループ<br>SCI を使ったクロック同期式シングルマスタ制御ソフトウェ          |
|      |                 |      | SCI を使ったクロック同期式シングルマスタ制御グフトリエ<br>  ア(R01AN1229JJ) 元は、RX210, RX21A, RX220, RX63N,        |
|      |                 |      | RX63T グループ SCI を使ったクロック同期式シングルマス                                                        |
|      |                 |      | タ制御ソフトウェア(R01AN1229JJ)であった。                                                             |
|      |                 |      | RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C グ                                      |
|      |                 |      | ループ シリアル・アレイ・ユニットの CSI モードを使った                                                          |
|      |                 |      | クロック同期式シングルマスタ制御ソフトウェア                                                                  |
|      |                 |      | (R01AN1195JJ) 元は、RL78/G14 シリアル・アレイ・ユニッ                                                  |
|      |                 |      | トの CSI モードを使ったクロック同期式シングルマスタ制御                                                          |

| _    |            |       |                                                |
|------|------------|-------|------------------------------------------------|
|      |            |       | ソフトウェア(R01AN1195JJ)であった。                       |
|      |            | 22,24 | 5.3 必要メモリサイズ                                   |
|      |            |       | 5.3.1 RX ファミリと 5.3.2 RL78 ファミリ、78K0R/Kx3-L の   |
|      |            |       | 章を追加し、ファミリ別に分けた。                               |
|      |            | 23    | 5.3.1 RX ファミリに、以下を追加                           |
|      |            |       | (2) RX111 RSPI の場合                             |
|      |            |       | (3) RX111 SCI の場合                              |
|      |            | 25    | 5.3.2 RL78 ファミリ、78K0R/Kx3-L に、以下を追加            |
|      |            |       | (3) RL78/L13 SAU 統合開発環境 CubeSuite+の場合          |
|      |            |       | (4) RL78/L13 SAU 統合開発環境 IAR Embedded Workbench |
|      |            |       | の場合                                            |
|      |            | 26    | 5.4 ファイル構成                                     |
|      |            |       | アプリケーションノート番号を変更                               |
|      |            |       | ソースのフォルダ名を変更                                   |
|      |            |       | 新規デバイスのレジスタ用共通定義を追加                            |
| 1.04 | 2016.03.31 | 7     | 2.動作確認条件                                       |
|      |            |       | 2.2 RL78 ファミリ、78K0R/Kx3-L                      |
|      |            |       | (1) RL78/G14 SAU 統合開発環境 CS+ for CA,CX の場合      |
|      |            |       | (コンパイラ:CA78K0R)を更新した。                          |
|      |            |       | (2) RL78/G14 SAU 統合開発環境 CS+ for CC の場合 (コン     |
|      |            |       | パイラ:CC-RL)を追加した。                               |
|      |            | 25    | 5.3 必要メモリサイズ                                   |
|      |            |       | 5.3.2 RL78 ファミリ、78K0R/Kx3-L                    |
|      |            |       | (1) RL78/G14 SAU 統合開発環境 CS+ for CA,CX の場合      |
|      |            |       | (コンパイラ:CA78K0R)を更新した。                          |
|      |            |       | (2) RL78/G14 SAU 統合開発環境 CS+ for CC の場合 (コン     |
|      |            |       | パイラ: CC-RL) を追加した。                             |
|      |            | 28    | 5.4 ファイル構成のアプリケーションノート番号を変更した。                 |
|      |            | 56-57 | 6.1.2 r_qspi_pcm_p5q_sfr.h                     |
|      |            |       | 記述例を更新した。                                      |

## 製品ご使用上の注意事項

ここでは、マイコン製品全体に適用する「使用上の注意事項」について説明します。個別の使用上の注意 事項については、本ドキュメントおよびテクニカルアップデートを参照してください。

#### 1. 未使用端子の処理

【注意】未使用端子は、本文の「未使用端子の処理」に従って処理してください。

CMOS製品の入力端子のインピーダンスは、一般に、ハイインピーダンスとなっています。未使用端子を開放状態で動作させると、誘導現象により、LSI周辺のノイズが印加され、LSI内部で貫通電流が流れたり、入力信号と認識されて誤動作を起こす恐れがあります。未使用端子は、本文「未使用端子の処理」で説明する指示に従い処理してください。

#### 2. 電源投入時の処置

【注意】電源投入時は、製品の状態は不定です。

電源投入時には、LSIの内部回路の状態は不確定であり、レジスタの設定や各端子の状態は不定です。

外部リセット端子でリセットする製品の場合、電源投入からリセットが有効になるまでの期間、端子の状態は保証できません。

同様に、内蔵パワーオンリセット機能を使用してリセットする製品の場合、電源投入からリセットの かかる一定電圧に達するまでの期間、端子の状態は保証できません。

3. リザーブアドレス(予約領域)のアクセス禁止

【注意】リザーブアドレス(予約領域)のアクセスを禁止します。

アドレス領域には、将来の機能拡張用に割り付けられているリザーブアドレス(予約領域)があります。これらのアドレスをアクセスしたときの動作については、保証できませんので、アクセスしないようにしてください。

4. クロックについて

【注意】リセット時は、クロックが安定した後、リセットを解除してください。

プログラム実行中のクロック切り替え時は、切り替え先クロックが安定した後に切り替えてください。

リセット時、外部発振子(または外部発振回路)を用いたクロックで動作を開始するシステムでは、クロックが十分安定した後、リセットを解除してください。また、プログラムの途中で外部発振子(または外部発振回路)を用いたクロックに切り替える場合は、切り替え先のクロックが十分安定してから切り替えてください。

#### 5. 製品間の相違について

【注意】型名の異なる製品に変更する場合は、製品型名ごとにシステム評価試験を実施してください。

同じグループのマイコンでも型名が違うと、内部ROM、レイアウトパターンの相違などにより、電気的特性の範囲で、特性値、動作マージン、ノイズ耐量、ノイズ輻射量などが異なる場合があります。型名が違う製品に変更する場合は、個々の製品ごとにシステム評価試験を実施してください。

# ご注意書き

- 1. 本資料に記載された回路、ソフトウェアおよびこれらに関連する情報は、半導体製品の動作例、応用例を説明するものです。お客様の機器・システムの設計において、回路、ソフトウェアおよびこれらに関連する情報を使用する場合には、お客様の責任において行ってください。これらの使用に起因して、お客様または第三者に生じた損害に関し、当社は、一切その責任を負いません。
- 2. 本資料に記載されている情報は、正確を期すため慎重に作成したものですが、誤りがないことを保証するものではありません。万一、本資料に記載されている情報の誤りに起因する損害がお客様に生じた場合においても、当社は、一切その責任を負いません。
- 3. 本資料に記載された製品デ-タ、図、表、プログラム、アルゴリズム、応用回路例等の情報の使用に起因して発生した第三者の特許権、著作権その他の知的財産権 に対する侵害に関し、当社は、何らの責任を負うものではありません。当社は、本資料に基づき当社または第三者の特許権、著作権その他の知的財産権を何ら許 諾するものではありません。
- 4. 当社製品を改造、改変、複製等しないでください。かかる改造、改変、複製等により生じた損害に関し、当社は、一切その責任を負いません。
- 5. 当社は、当社製品の品質水準を「標準水準」および「高品質水準」に分類しており、

各品質水準は、以下に示す用途に製品が使用されることを意図しております。

標準水準: コンピュータ、OA機器、通信機器、計測機器、AV機器、

家電、工作機械、パーソナル機器、産業用ロボット等

高品質水準:輸送機器(自動車、電車、船舶等)、交通用信号機器、

防災・防犯装置、各種安全装置等

当社製品は、直接生命・身体に危害を及ぼす可能性のある機器・システム(生命維持装置、人体に埋め込み使用するもの等)、もしくは多大な物的損害を発生させるおそれのある機器・システム(原子力制御システム、軍事機器等)に使用されることを意図しておらず、使用することはできません。 たとえ、意図しない用途に当社製品を使用したことによりお客様または第三者に損害が生じても、当社は一切その責任を負いません。 なお、ご不明点がある場合は、当社営業にお問い合わせください。

- 6. 当社製品をご使用の際は、当社が指定する最大定格、動作電源電圧範囲、放熱特性、実装条件その他の保証範囲内でご使用ください。当社保証範囲を超えて当社製品をご使用された場合の故障および事故につきましては、当社は、一切その責任を負いません。
- 7. 当社は、当社製品の品質および信頼性の向上に努めていますが、半導体製品はある確率で故障が発生したり、使用条件によっては誤動作したりする場合があります。また、当社製品は耐放射線設計については行っておりません。当社製品の故障または誤動作が生じた場合も、人身事故、火災事故、社会的損害等を生じさせないよう、お客様の責任において、冗長設計、延焼対策設計、誤動作防止設計等の安全設計およびエージング処理等、お客様の機器・システムとしての出荷保証を行ってください。特に、マイコンソフトウェアは、単独での検証は困難なため、お客様の機器・システムとしての安全検証をお客様の責任で行ってください。
- 8. 当社製品の環境適合性等の詳細につきましては、製品個別に必ず当社営業窓口までお問合せください。ご使用に際しては、特定の物質の含有・使用を規制する RoHS指令等、適用される環境関連法令を十分調査のうえ、かかる法令に適合するようご使用ください。お客様がかかる法令を遵守しないことにより生じた損害に 関して、当社は、一切その責任を負いません。
- 9. 本資料に記載されている当社製品および技術を国内外の法令および規則により製造・使用・販売を禁止されている機器・システムに使用することはできません。また、当社製品および技術を大量破壊兵器の開発等の目的、軍事利用の目的その他軍事用途に使用しないでください。当社製品または技術を輸出する場合は、「外国為替及び外国貿易法」その他輸出関連法令を遵守し、かかる法令の定めるところにより必要な手続を行ってください。
- 10. お客様の転売等により、本ご注意書き記載の諸条件に抵触して当社製品が使用され、その使用から損害が生じた場合、当社は何らの責任も負わず、お客様にてご負担して頂きますのでご了承ください。
- 11. 本資料の全部または一部を当社の文書による事前の承諾を得ることなく転載または複製することを禁じます。
- 注1. 本資料において使用されている「当社」とは、ルネサスエレクトロニクス株式会社およびルネサスエレクトロニクス株式会社がその総株主の議決権の過半数を直接または間接に保有する会社をいいます。
- 注2. 本資料において使用されている「当社製品」とは、注1において定義された当社の開発、製造製品をいいます。



営業お問合せ窓口

http://www.renesas.com

営業お問合せ窓口の住所は変更になることがあります。最新情報につきましては、弊社ホームページをご覧ください。

ルネサス エレクトロニクス株式会社 〒135-0061 東京都江東区豊洲3-2-24 (豊洲フォレシア)

技術的なお問合せおよび資料のご請求は下記へどうぞ。 総合お問合せ窓口:http://japan.renesas.com/contact/