

# RX Family, RL78 Family, 78K0R/Kx3-L

R01AN1529EJ0104 Rev.1.04

Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory Control Software Mar 31, 2016

#### Introduction

This application note describes how to control S25FLxxxS MirrorBit® flash non-volatile memory, manufactured by Spansion, Inc., using an MCU manufactured by Renesas Electronics, and it explains the usage of the sample code provided for that purpose.

Note that the sample code is upper-layer software for controlling the S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory as a slave device.

Lower-layer software (clock synchronous single master control software) for controlling the SPI modes specific to individual MCU models is available separately, and should be obtained by the user, so please obtain this from the following URL as well. In addition, when a new microcontroller is added to the clock synchronous single-master control software, update of this application note may not be in time. Refer to 'Clock Synchronous Single Master Control Software (Lower-level layer of the software)' information in the following URL for the combination information on the latest supported microcontroller and its single-master control software.

SPI/QSPI Serial Flash Memory, QSPI Serial Phase Change Memory Driver http://www.renesas.com/driver/spi serial flash

#### **Target Device**

RL78/G1x

128 Mbit S25FL128S MirrorBit<sup>®</sup> flash non-volatile memory manufactured by Spansion Serial flash memory:

256 Mbit S25FL256S MirrorBit® flash non-volatile memory manufactured by Spansion

MCUs on which operation has been confirmed:

RX600 series : RX63N (using the RSPI) RX100 series : RX111 (using the SCI) : RX111 (using the RSPI)

: RL78/G14, RL78/G1C group (using the SAU)

RL78/L1x : RL78/L12, RL78/L12, RL78/L1C group (using the SAU)

See 3, Reference Application Notes, regarding MCU models other than those listed above.

When using this application note with other Renesas MCUs, careful evaluation is recommended after making modifications to comply with the alternate MCU.

Note that the following abbreviations are used in this application note:

- Single-SPI (communication in single-SPI mode)
- Dual-SPI (communication in dual-SPI mode)
- Quad-SPI (communication in quad-SPI mode)

# **Contents**

| 1.         | Spec           | cifications                                                   | 4   |
|------------|----------------|---------------------------------------------------------------|-----|
|            | •              |                                                               |     |
| 2.<br>2.1  |                | ration Confirmation Conditions                                |     |
|            |                | .78 Family, 78K0R/Kx3-L                                       |     |
| 2.2        | . KL           | .10 Faililly, 10NUR/NX3-L                                     |     |
| 3.         | Refe           | rence Application Notes                                       | 14  |
| 3.1        | RX             | Family: List of Related Application Notes                     | 14  |
| 3.2        | RL             | .78 Family, 78K0R Family: List of Related Application Notes   | 14  |
| 4.         | Hard           | lware                                                         | 15  |
| 4.1        |                | rdware Configuration                                          |     |
| 4          | .1.1           | Pin Assignments for Single-SPI Configuration                  |     |
| 4          | .1.2           | Single-SPI Connection Example                                 |     |
| 4          | .1.3           | Pin Assignments for Dual-SPI Configuration                    |     |
| 4          | .1.4           | Dual-SPI Connection Example                                   |     |
| 4          | .1.5           | Pin Assignments for Quad-SPI Configuration                    | 17  |
| 4          | .1.6           | Quad-SPI Connection Example                                   |     |
| E          | 6-41-          | Mara.                                                         | 4.0 |
|            |                | wareoeration Overview                                         |     |
| 5.1<br>5   | •              |                                                               |     |
|            | 5.1.1          | Relationship Between Data Buffers and Transmit/Receive Data   |     |
|            | 5.1.2<br>5.1.3 | Timing Generation in Clock Synchronous Mode                   |     |
|            | 5.1.3<br>5.1.4 | S25FLxxxS MirrorBit® Flash Non-Volatile Memory 5# Pin Control |     |
| 5.2        |                | ftware Configurationftware Configuration Codes                |     |
| 5.2<br>5.3 |                | equired Memory Size                                           |     |
|            | . ке<br>5.3.1  | RX Family                                                     |     |
|            | 5.3.1<br>5.3.2 | •                                                             |     |
| 5.4        |                | e Structure                                                   |     |
| 5.5        |                | e structure                                                   |     |
|            | i.5.1          | Return Value                                                  |     |
| •          | 5.5.2          | Command Definitions                                           |     |
| _          | 5.5.3          | Other Definitions                                             |     |
| 5.6        |                | ructure/Union List                                            |     |
| 5.7        |                | riable                                                        |     |
| 5.8        |                | nctions                                                       |     |
| 5.9        |                | nction Specifications                                         |     |
|            | , ги<br>5.9.1  | Driver Initialization Processing                              |     |
| _          | _              | Device Initialization Processing                              |     |
| •          |                |                                                               |     |

# Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory Control Software

|    | 5.9.3  | Status Register 1 Read Processing                                                  | 38   |
|----|--------|------------------------------------------------------------------------------------|------|
|    | 5.9.4  | Status Register 2 Read Processing                                                  | 40   |
|    | 5.9.5  | Write Protect Setting Processing                                                   | 41   |
|    | 5.9.6  | Configuration Register Read Processing                                             | 45   |
|    | 5.9.7  | Configuration Register Write Processing                                            | 47   |
|    | 5.9.8  | Status Clear Processing                                                            | 50   |
|    | 5.9.9  | WRDI Command Issue Processing                                                      | 51   |
|    | 5.9.10 | Data Read Processing                                                               | 52   |
|    | 5.9.11 | Data Write Processing                                                              | 53   |
|    | 5.9.12 | Data Write Processing (for Single-Page Write)                                      | . 55 |
|    | 5.9.13 | Erase Processing                                                                   | 58   |
|    | 5.9.14 | ID Read Processing                                                                 | 61   |
|    | 5.9.15 | Busy Wait Processing                                                               | . 62 |
| 6. | Appl   | ication Example                                                                    | .64  |
|    |        | 5FLxxxS MirrorBit <sup>®</sup> Flash Non-Volatile Memory Control Software Settings |      |
| ·  | 6.1.1  | r_qspi_flash_s25fl.h                                                               |      |
|    | 6.1.2  | r_qspi_flash_s25fl_sfr.h                                                           |      |
|    | 6.1.3  | r_qspi_flash_s25fl_sub.h                                                           |      |
|    | 6.1.4  | r_qspi_flash_s25fl_sub.c                                                           |      |
|    | 6.1.5  | r_qspi_flash_s25fl_drvif.c                                                         |      |
|    | 6.1.6  | r qspi flash s25fl sfr rl78.c                                                      |      |
|    |        |                                                                                    |      |
| 7. | •      | ge Notes                                                                           |      |
|    |        | tes on Integrating Sample Code                                                     |      |
|    |        | ing an MCU with On-Chip Cache                                                      |      |
|    |        | pport for Other Capacities                                                         |      |
|    |        | ing Other Slave Devices                                                            |      |
|    | -      | propriate Use of Control Commands                                                  |      |
|    |        | : 3 (BPNV) in the Configuration Register and Write Protect                         |      |
|    |        | tes on Write Protect Area Selection                                                |      |
|    |        | Notes on the RESET Command                                                         |      |
| 7  | a Va   | Itago Stabilization Time After Power-On                                            | 76   |

#### 1. Specifications

A Renesas Electronics MCU is used to control S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory, manufactured by Spansion, Inc.

Separate MCU-specific clock synchronous single master control software is required.

Figure 1.1 lists the peripheral functions used and their applications, and Figure 1.1 shows a usage example.

Summaries of the functions are provided below:

- The software functions as a device driver, with a Renesas Electronics MCU operating as the master device and the Spansion, Inc., S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory operating as the slave device.
- The MCU's on-chip serial communication function (clock synchronous mode) is used in SPI mode to control operation. One serial I/O channel can be specified by the user for use. It is not possible to use multiple channels.
- It is possible to control up to two S25FLxxxS MirrorBit® flash non-volatile memory devices of the same type name.
- The communication speed can be specified by the user.
- Both big-endian and little-endian operation are supported. (The choice depends on the MCU used.)

Table 1-1 Peripheral Functions and Their Applications

| Peripheral Function                              | Application                                                                                            |
|--------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| MCU's on-chip serial communication functionality | Communication with SPI slave device by means of serial communication function (clock synchronous mode) |
| (clock synchronous mode)                         | 1 channel (required)                                                                                   |
| Port                                             | For SPI slave device select control signal                                                             |
|                                                  | Number of ports equal to number of devices (required)                                                  |



Figure 1.1 Usage Example

# 2. Operation Confirmation Conditions

The sample code accompanying this application note has been run and confirmed under the conditions below.

# 2.1 RX Family

## (1) **RX63N RSPI**

**Table 2-1 Operation Confirmation Conditions** 

| Item                       | Description                                                          |
|----------------------------|----------------------------------------------------------------------|
| Memory                     | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory              |
| Microcontroller used       | RX63N Group (Program ROM: 1 MB/RAM: 128 KB)                          |
| Operating frequency        | ICLK: 96 MHz, PCLK: 48 MHz                                           |
| Operating voltage          | 3.3 V                                                                |
| Integrated development     | Renesas Electronics Corporation                                      |
| environment                | High-performance embedded Workshop Version 4.09.01.007               |
| C compiler                 | Renesas Electronics Corporation                                      |
|                            | RX Family C/C++ Compiler Package (Toolchain 1.2.1.0)                 |
|                            | Compiler options                                                     |
|                            | The integrated development environment default settings are used.    |
| Endian order               | Big endian / Little endian                                           |
| Sample code version number | Ver. 2.20                                                            |
| Software                   | Clock synchronous single master control software using the RSPI, for |
|                            | RX63N, version 2.04                                                  |
| Board                      | Renesas Starter Kit for RX63N                                        |

## (2) **RX111 RSPI**

**Table 2-2 Operation Confirmation Conditions** 

| Item                               | Description                                                                                                                                       |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Memory                             | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory                                                                                           |
| Microcontroller used               | RX111 Group (Program ROM: 128 KB, RAM: 16 KB)                                                                                                     |
| Operating frequency                | ICLK: 32 MHz, PCLK: 32 MHz                                                                                                                        |
| Operating voltage                  | 3.3 V                                                                                                                                             |
| Integrated development environment | Renesas Electronics<br>CubeSuite+ V2.01.00                                                                                                        |
| C compiler                         | Renesas Electronics RX family C/C++ compiler package (Toolchain 2.01.00)                                                                          |
|                                    | Compiler options: The default settings (Optimize Level: 2, Optimize for size) for the integrated development environment are used.                |
| Endian order                       | Big endian / Little endian                                                                                                                        |
| Sample code version number         | Ver. 2.21.R01                                                                                                                                     |
| Software                           | RX210, RX21A, RX220, RX63N, RX63T, RX111 Group Clock<br>Synchronous Single Master Control Software Using the RSPI<br>(R01AN1196EJ), Ver. 2.04.R04 |
| Board                              | Renesas Starter Kit for RX111                                                                                                                     |

#### (3) **RX111 SCI**

**Table 2-3 Operation Confirmation Conditions** 

| Item                               | Description                                                                                                                               |
|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Memory                             | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory                                                                                   |
| Microcontroller used               | RX111 Group (Program ROM: 128 KB, RAM: 16 KB)                                                                                             |
| Operating frequency                | ICLK: 32 MHz, PCLK: 32 MHz                                                                                                                |
| Operating voltage                  | 3.3 V                                                                                                                                     |
| Integrated development environment | Renesas Electronics<br>CubeSuite+ V2.01.00                                                                                                |
| C compiler                         | Renesas Electronics RX family C/C++ compiler package (Toolchain 2.01.00)                                                                  |
|                                    | Compiler options: The default settings (Optimize Level: 2, Optimize for size) for the integrated development environment are used.        |
| Endian order                       | Big endian / Little endian                                                                                                                |
| Sample code version number         | Ver. 2.21.R01                                                                                                                             |
| Software                           | RX210, RX21A, RX220, RX63N, RX63T,RX111 Group Clock Synchronous Single Master Control Software Using the SCI (R01AN1229EJ), Ver. 2.01.R05 |
| Board                              | Renesas Starter Kit for RX111                                                                                                             |

# 2.2 RL78 Family, 78K0R/Kx3-L

## (1) RL78/G14 Integrated Development Environment CS+ for CA,CX (Compiler: CA78K0R)

**Table 2-4 Operation Confirmation Conditions** 

| Item                       | Description                                                                |
|----------------------------|----------------------------------------------------------------------------|
| Memory                     | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory                    |
| Microcontroller used       | RL78/G14 Group (Program ROM: 256 MB/RAM: 24 KB)                            |
| Operating frequency        | Main system clock: 24 MHz                                                  |
|                            | CPU/peripheral hardware clock: 24 MHz                                      |
|                            | Serial clock: 6 MHz                                                        |
| Operating voltage          | 3.3 V                                                                      |
| Integrated development     | Renesas Electronics                                                        |
| environment                | CS+ for CA, CX V3.01.00                                                    |
| C compiler                 | Renesas Electronics                                                        |
|                            | RL78,78K0R compiler CA78K0R V1.71                                          |
|                            | Compiler options:                                                          |
|                            | The default settings (-qx2) for the integrated development environment are |
|                            | used.                                                                      |
| Endian order               | Little endian                                                              |
| Sample code version number | Ver. 2.22                                                                  |
| Software                   | RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C Group                     |
|                            | Clock Synchronous Single Master Control Software Using CSI Mode of         |
|                            | Serial Array Unit (R01AN1195EJ), Ver. 2.05                                 |
| Board                      | Renesas Starter Kit for RL78/G14                                           |

#### (2) RL78/G14 Integrated Development Environment CS+ for CC (Compiler: CC-RL)

**Table 2-5 Operation Confirmation Conditions** 

| Item                       | Description                                                           |
|----------------------------|-----------------------------------------------------------------------|
| Memory                     | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory               |
| Microcontroller used       | RL78/G14 Group (Program ROM: 256 MB/RAM: 24 KB)                       |
| Operating frequency        | Main system clock: 24 MHz                                             |
|                            | CPU/peripheral hardware clock: 24 MHz                                 |
|                            | Serial clock: 6 MHz                                                   |
| Operating voltage          | 3.3 V                                                                 |
| Integrated development     | Renesas Electronics                                                   |
| environment                | CS+ for CC V3.03.00                                                   |
| C compiler                 | Renesas Electronics                                                   |
|                            | RL78 compiler CC-RL V1.02.00                                          |
|                            | Compiler options:                                                     |
|                            | The default settings (Perform the default optimization(None)) for the |
|                            | integrated development environment are used.                          |
| Endian order               | Little endian                                                         |
| Sample code version number | Ver. 2.22                                                             |
| Software                   | RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C Group                |
|                            | Clock Synchronous Single Master Control Software Using CSI Mode of    |
|                            | Serial Array Unit (R01AN1195EJ), Ver. 2.05                            |
| Board                      | Renesas Starter Kit for RL78/G14                                      |

# (3) RL78/G14 Integrated Development Environment IAR Embedded Workbench

**Table 2-6 Operation Confirmation Conditions** 

| Item                       | Description                                                               |
|----------------------------|---------------------------------------------------------------------------|
| Memory                     | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory                   |
| Microcontroller used       | RL78/G14 Group (Program ROM: 256 KB/RAM: 24 KB)                           |
| Operating frequency        | Main system clock: 24 MHz                                                 |
|                            | CPU/peripheral hardware clock: 24 MHz                                     |
|                            | Serial clock: 6 MHz                                                       |
| Operating voltage          | 3.3 V                                                                     |
| Integrated development     | IAR Systems                                                               |
| environment                | IAR Embedded Workbench for Renesas RL78 (Ver.1.30.2)                      |
| C compiler                 | IAR Systems                                                               |
|                            | IAR Assembler for Renesas RL78 (Ver.1.30.2.50666)                         |
|                            | IAR C/C++ Compiler for Renesas RL78 (Ver.1.30.2.50666)                    |
|                            | Compiler options: The default settings (Low) for the integrated           |
|                            | development environment are used.                                         |
| Endian order               | Little endian                                                             |
| Sample code version number | Ver. 2.21                                                                 |
| Software                   | Clock synchronous single master control software using CSI mode of serial |
|                            | array unit, version 2.03                                                  |
| Board                      | Renesas Starter Kit for RL78/G14                                          |

## $(4) \quad RL78/G1C\ Integrated\ Development\ Environment\ Cube Suite+$

## **Table 2-7 Operation Confirmation Conditions**

| Item                       | Description                                                                |
|----------------------------|----------------------------------------------------------------------------|
| Memory                     | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory                    |
| Microcontroller used       | RL78/G1C Group (Program ROM: 32 KB/RAM: 5.5 KB)                            |
| Operating frequency        | Main system clock: 24 MHz                                                  |
|                            | CPU/peripheral hardware clock: 24 MHz                                      |
|                            | Serial clock: 12 MHz                                                       |
| Operating voltage          | 3.3 V                                                                      |
| Integrated development     | Renesas Electronics Corporation                                            |
| environment                | CubeSuite+ V2.01.00                                                        |
| C compiler                 | Renesas Electronics Corporation                                            |
|                            | CubeSuite+ RL78,78K0R Compiler CA78K0R V1.70                               |
|                            | Compiler options                                                           |
|                            | The integrated development environment default settings ("-qx2") are used. |
| Endian order               | Little endian                                                              |
| Sample code version number | Ver. 2.21.R01                                                              |
| Software                   | RL78/G14,RL78/G1C, RL78/L12, RL78/L13, RL78/L1C Group Clock                |
|                            | Synchronous Single Master Control Software Using CSI Mode of Serial        |
|                            | Array Unit (R01AN1195EJ0103), Ver. 2.03                                    |
| Board                      | Renesas RL78/G1C Target Board QB-R5F10JGC-TB                               |

# (5) RL78/G1C Integrated Development Environment IAR Embedded Workbench

**Table 2-8 Operation Confirmation Conditions** 

| Item                       | Description                                                         |
|----------------------------|---------------------------------------------------------------------|
| Memory                     | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory             |
| Microcontroller used       | RL78/G1C Group (Program ROM: 256 KB/RAM: 24 KB)                     |
| Operating frequency        | Main system clock: 24 MHz                                           |
|                            | CPU/peripheral hardware clock: 24 MHz                               |
|                            | Serial clock: 12 MHz                                                |
| Operating voltage          | 3.3 V                                                               |
| Integrated development     | IAR Systems                                                         |
| environment                | IAR Embedded Workbench for Renesas RL78 (Ver.1.30.5)                |
| C compiler                 | IAR Systems                                                         |
|                            | IAR Assembler for Renesas RL78 (Ver.1.30.4.50715)                   |
|                            | IAR C/C++ Compiler for Renesas RL78 (Ver.1.30.5.50715)              |
|                            | Compiler options: The default settings (Low) for the integrated     |
|                            | development environment are used.                                   |
| Endian order               | Little endian                                                       |
| Sample code version number | Ver. 2.21.R01                                                       |
| Software                   | RL78/G14,RL78/G1C, RL78/L12, RL78/L13, RL78/L1C Group Clock         |
|                            | Synchronous Single Master Control Software Using CSI Mode of Serial |
|                            | Array Unit (R01AN1195EJ0103), Ver. 2.03                             |
| Board                      | Renesas RL78/G1C Target Board QB-R5F10JGC-TB                        |

## (6) RL78/L12 Integrated Development Environment CubeSuite+

**Table 2-9 Operation Confirmation Conditions** 

| Item                       | Description                                                                |
|----------------------------|----------------------------------------------------------------------------|
| Memory                     | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory                    |
| Microcontroller used       | RL78/L12 Group (Program ROM: 32 KB, RAM:1.5 KB)                            |
| Operating frequency        | Main system clock: 24 MHz                                                  |
|                            | CPU/peripheral hardware clock: 24 MHz                                      |
|                            | Serial clock: 6 MHz                                                        |
| Operating voltage          | 3.3 V                                                                      |
| Integrated development     | Renesas Electronics Corporation                                            |
| environment                | CubeSuite+ V2.01.00                                                        |
| C compiler                 | Renesas Electronics Corporation                                            |
|                            | CubeSuite+ RL78,78K0R Compiler CA78K0R V1.70                               |
|                            | Compiler options                                                           |
|                            | The integrated development environment default settings ("-qx2") are used. |
| Endian order               | Little endian                                                              |
| Sample code version number | Ver. 2.21.R01                                                              |
| Software                   | RL78/G14,RL78/G1C, RL78/L12, RL78/L13, RL78/L1C Group Clock                |
|                            | Synchronous Single Master Control Software Using CSI Mode of Serial        |
|                            | Array Unit (R01AN1195EJ0103), Ver. 2.03                                    |
| Board                      | Renesas Starter Kit for RL78/L12                                           |

# (7) RL78/L12 Integrated Development Environment IAR Embedded Workbench

**Table 2-10 Operation Confirmation Conditions** 

| Item                       | Description                                                         |  |  |
|----------------------------|---------------------------------------------------------------------|--|--|
| Memory                     | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory             |  |  |
| Microcontroller used       | RL78/L12 Group (Program ROM: 32 KB, RAM:1.5 KB)                     |  |  |
| Operating frequency        | Main system clock: 24 MHz                                           |  |  |
|                            | CPU/peripheral hardware clock: 24 MHz                               |  |  |
|                            | Serial clock: 6 MHz                                                 |  |  |
| Operating voltage          | 3.3 V                                                               |  |  |
| Integrated development     | IAR Systems                                                         |  |  |
| environment                | IAR Embedded Workbench for Renesas RL78 (Ver.1.30.5)                |  |  |
| C compiler                 | IAR Systems                                                         |  |  |
|                            | IAR Assembler for Renesas RL78 (Ver.1.30.4.50715)                   |  |  |
|                            | IAR C/C++ Compiler for Renesas RL78 (Ver.1.30.5.50715)              |  |  |
|                            | Compiler options: The default settings (Low) for the integrated     |  |  |
|                            | development environment are used.                                   |  |  |
| Endian order               | Little endian                                                       |  |  |
| Sample code version number | Ver. 2.21.R01                                                       |  |  |
| Software                   | RL78/G14,RL78/G1C, RL78/L12, RL78/L13, RL78/L1C Group Clock         |  |  |
|                            | Synchronous Single Master Control Software Using CSI Mode of Serial |  |  |
|                            | Array Unit (R01AN1195EJ0103), Ver. 2.03                             |  |  |
| Board                      | Renesas Starter Kit for RL78/L12                                    |  |  |

## (8) RL78/L13 Integrated Development Environment CubeSuite+

**Table 2-11 Operation Confirmation Conditions** 

| Item                       | Description                                                                |  |
|----------------------------|----------------------------------------------------------------------------|--|
| Memory                     | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory                    |  |
| Microcontroller used       | RL78/L13 Group (Program ROM: 128 KB/RAM: 8 KB)                             |  |
| Operating frequency        | Main system clock: 24 MHz                                                  |  |
|                            | CPU/peripheral hardware clock: 24 MHz                                      |  |
|                            | Serial clock: 6 MHz                                                        |  |
| Operating voltage          | 3.3 V                                                                      |  |
| Integrated development     | Renesas Electronics Corporation                                            |  |
| environment                | CubeSuite+ V2.01.00                                                        |  |
| C compiler                 | Renesas Electronics Corporation                                            |  |
|                            | CubeSuite+ RL78,78K0R Compiler CA78K0R V1.70                               |  |
|                            | Compiler options                                                           |  |
|                            | The integrated development environment default settings ("-qx2") are used. |  |
| Endian order               | Little endian                                                              |  |
| Sample code version number | Ver. 2.21.R01                                                              |  |
| Software                   | RL78/G14,RL78/G1C, RL78/L12, RL78/L13, RL78/L1C Group Clock                |  |
|                            | Synchronous Single Master Control Software Using CSI Mode of Serial        |  |
|                            | Array Unit (R01AN1195EJ0103), Ver. 2.03                                    |  |
| Board                      | Renesas Starter Kit for RL78/L13                                           |  |

# (9) RL78/L13 Integrated Development Environment IAR Embedded Workbench

**Table 2-12 Operation Confirmation Conditions** 

| Item                       | Description                                                         |  |  |
|----------------------------|---------------------------------------------------------------------|--|--|
| Memory                     | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory             |  |  |
| Microcontroller used       | RL78/L13 Group (Program ROM: 128 KB/RAM: 8 KB)                      |  |  |
| Operating frequency        | Main system clock: 24 MHz                                           |  |  |
|                            | CPU/peripheral hardware clock: 24 MHz                               |  |  |
|                            | Serial clock: 6 MHz                                                 |  |  |
| Operating voltage          | 3.3 V                                                               |  |  |
| Integrated development     | IAR Systems                                                         |  |  |
| environment                | IAR Embedded Workbench for Renesas RL78 (Ver.1.30.5)                |  |  |
| C compiler                 | IAR Systems                                                         |  |  |
|                            | IAR Assembler for Renesas RL78 (Ver.1.30.4.50715)                   |  |  |
|                            | IAR C/C++ Compiler for Renesas RL78 (Ver.1.30.5.50715)              |  |  |
|                            | Compiler options: The default settings (Low) for the integrated     |  |  |
|                            | development environment are used.                                   |  |  |
| Endian order               | Little endian                                                       |  |  |
| Sample code version number | Ver. 2.21.R01                                                       |  |  |
| Software                   | RL78/G14,RL78/G1C, RL78/L12, RL78/L13, RL78/L1C Group Clock         |  |  |
|                            | Synchronous Single Master Control Software Using CSI Mode of Serial |  |  |
|                            | Array Unit (R01AN1195EJ0103), Ver. 2.03                             |  |  |
| Board                      | Renesas Starter Kit for RL78/L13                                    |  |  |

## (10) RL78/L1C Integrated Development Environment CubeSuite+

**Table 2-13 Operation Confirmation Conditions** 

| Item                       | Description                                                                |  |
|----------------------------|----------------------------------------------------------------------------|--|
| Memory                     | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory                    |  |
| Microcontroller used       | RL78/L1C Group (Program ROM: 256 KB/RAM: 16 KB)                            |  |
| Operating frequency        | Main system clock: 24 MHz                                                  |  |
|                            | CPU/peripheral hardware clock: 24 MHz                                      |  |
|                            | Serial clock: 6 MHz                                                        |  |
| Operating voltage          | 3.3 V                                                                      |  |
| Integrated development     | Renesas Electronics Corporation                                            |  |
| environment                | CubeSuite+ V2.01.00                                                        |  |
| C compiler                 | Renesas Electronics Corporation                                            |  |
|                            | CubeSuite+ RL78,78K0R Compiler CA78K0R V1.70                               |  |
|                            | Compiler options                                                           |  |
|                            | The integrated development environment default settings ("-qx2") are used. |  |
| Endian order               | Little endian                                                              |  |
| Sample code version number | Ver. 2.21.R01                                                              |  |
| Software                   | RL78/G14,RL78/G1C, RL78/L12, RL78/L13, RL78/L1C Group Clock                |  |
|                            | Synchronous Single Master Control Software Using CSI Mode of Serial        |  |
|                            | Array Unit (R01AN1195EJ0103), Ver. 2.03                                    |  |
| Board                      | Renesas Starter Kit for RL78/L1C                                           |  |

# (11) RL78/L1C Integrated Development Environment IAR Embedded Workbench

# **Table 2-14 Operation Confirmation Conditions**

| Item                       | Description                                                         |  |
|----------------------------|---------------------------------------------------------------------|--|
| Memory                     | Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory             |  |
| Microcontroller used       | RL78/L1C Group (Program ROM: 256 KB/RAM: 16 KB)                     |  |
| Operating frequency        | Main system clock: 24 MHz                                           |  |
|                            | CPU/peripheral hardware clock: 24 MHz                               |  |
|                            | Serial clock: 6 MHz                                                 |  |
| Operating voltage          | 3.3 V                                                               |  |
| Integrated development     | IAR Systems                                                         |  |
| environment                | IAR Embedded Workbench for Renesas RL78 (Ver.1.30.5)                |  |
| C compiler                 | IAR Systems                                                         |  |
|                            | IAR Assembler for Renesas RL78 (Ver.1.30.4.50715)                   |  |
|                            | IAR C/C++ Compiler for Renesas RL78 (Ver.1.30.5.50715)              |  |
|                            | Compiler options: The default settings (Low) for the integrated     |  |
|                            | development environment are used.                                   |  |
| Endian order               | Little endian                                                       |  |
| Sample code version number | Ver. 2.21.R01                                                       |  |
| Software                   | RL78/G14,RL78/G1C, RL78/L12, RL78/L13, RL78/L1C Group Clock         |  |
|                            | Synchronous Single Master Control Software Using CSI Mode of Serial |  |
|                            | Array Unit (R01AN1195EJ0103), Ver. 2.03                             |  |
| Board                      | Renesas Starter Kit for RL78/L1C                                    |  |

#### 3. Reference Application Notes

For additional information associated with this document, refer to the following application notes.

In the related application notes listed below, refer to the "Target Device" item on the cover for a listing of MCU models on which operation has been confirmed.

## 3.1 RX Family: List of Related Application Notes

- RX610 Group Clock Synchronous Single Master Control Software Using the SCI (R01AN0534EJ)
- RX62N Group Clock Synchronous Single Master Control Software Using the RSPI (R01AN0323EJ)
- RX62N Group Clock Synchronous Single Master Control Software Using the SCI (R01AN1088EJ)
- RX210, RX21A, RX220, RX63N, RX63T, RX111 Group Clock Synchronous Single Master Control Software Using the RSPI (R01AN1196EJ)
- RX210, RX21A, RX220, RX63N, RX63T, RX111 Group Clock Synchronous Single Master Control Software Using the SCI (R01AN1229EJ)

# 3.2 RL78 Family, 78K0R Family: List of Related Application Notes

- 78K0R/Kx3-L Clock Synchronous Single Master Control Software Using CSI Mode of Serial Array Unit (R01AN0708EJ)
- RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C Group Clock Synchronous Single Master Control Software Using CSI Mode of Serial Array Unit (R01AN1195EJ)

#### 4. Hardware

## 4.1 Hardware Configuration

An example hardware configuration is shown below.

## 4.1.1 Pin Assignments for Single-SPI Configuration

The following table lists the MCU pins used for single-SPI operation and their functions.

Table 4-1 Single-SPI Pins and Functions

| MCU Pin Name | I/O    | Description                |
|--------------|--------|----------------------------|
| CLK          | Output | Clock output               |
| DataOut      | Output | Master data output         |
| DataIn       | Input  | Master data input          |
| Port (CS#)   | Output | Slave device select output |

# 4.1.2 Single-SPI Connection Example

A connection example for single-SPI operation is shown below:



Figure 4.1 MCU and SPI Slave Device Connection Example for Single-SPI

## 4.1.3 Pin Assignments for Dual-SPI Configuration

The following table lists the MCU pins used for dual-SPI operation and their functions.

In order to use a dual-SPI configuration, the MCU must have a quad serial peripheral interface function.

Table 4-2 Dual-SPI Pins and Functions

| MCU Pin Name | 1/0          | Description                |
|--------------|--------------|----------------------------|
| CLK          | Output       | Clock output               |
| DataIn/Out0  | Input/output | Master data input/output 0 |
| DataIn/Out1  | Input/output | Master data input/output 1 |
| Port(CS#)    | Output       | Slave device select output |

#### 4.1.4 Dual-SPI Connection Example

A connection example for dual-SPI operation is shown below:



Figure 4.2 MCU and SPI Slave Device Connection Example for Dual-SPI

## 4.1.5 Pin Assignments for Quad-SPI Configuration

The following table lists the MCU pins used for quad-SPI operation and their functions.

In order to use a quad-SPI configuration, the MCU must have a quad serial peripheral interface function.

Table 4-3 Quad-SPI Pins and Functions

| MCU Pin Name | I/O          | Description                |
|--------------|--------------|----------------------------|
| CLK          | Output       | Clock output               |
| DataIn/Out0  | Input/output | Master data input/output 0 |
| DataIn/Out1  | Input/output | Master data input/output 1 |
| DataIn/Out2  | Input/output | Master data input/output 2 |
| DataIn/Out3  | Input/output | Master data input/output 3 |
| Port (CS#)   | Output       | Slave device select output |

#### 4.1.6 Quad-SPI Connection Example

A connection example for quad-SPI operation is shown below:



Figure 4.3 MCU and SPI Slave Device Connection Example for Quad-SPI

#### 5. Software

#### 5.1 Operation Overview

The MCU's clock synchronous serial communication function is used to control the S25FLxxxS MirrorBit® flash non-volatile memory.

The sample code performs the following types of control:

- The CS# pin of the SPI slave device is connected to the port of the MCU and is controlled by using MCU general port output. (This control is implemented by the sample code.)
- Data input and output is controlled in clock synchronous mode (using the internal clock of the MCU). (The sample code makes use of the MCU-specific clock synchronous single master control software.)

#### 5.1.1 Relationship Between Data Buffers and Transmit/Receive Data

This sample code is a block type device driver and passes the transmit or receive data pointer as an argument. The relationship between the data ordering in the data buffer in RAM and the transmit/receive order is shown below and this sample code both transmits in the order data is stored in the transmit buffer and writes data to the receive data buffer in the order received regardless of the endian order or serial communication function used

Figure 5.1 illustrates the storage of transfer data.



Figure 5.1 Storage of Transfer Data

# 5.1.2 Timing Generation in Clock Synchronous Mode

The timings generated in clock synchronous mode are shown below.

Refer to the data sheets of the MCU and SPI device when determining the serial clock frequency to be used.

#### (1) Single-SPI Operation

To control S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory, the SPI mode 3 (CPOL = 1, CPHA = 1) shown in Figure 5.2 is generated.



Figure 5.2 Single-SPI Clock Synchronous Mode Timing Settings

#### (2) **Dual-SPI Operation**

To control S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory, the SPI mode 3 (CPOL = 1, CPHA = 1) shown in Figure 5.3 is generated.



Figure 5.3 Dual-SPI Clock Synchronous Mode Timing Settings

The CLK pin is high-level when no transfer is taking place.

#### (3) Quad-SPI Operation

To control S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory, the SPI mode 3 (CPOL = 1, CPHA = 1) shown in Figure 5.4 is generated.



Figure 5.4 Quad-SPI Clock Synchronous Mode Timing Settings

# 5.1.3 S25FLxxxS MirrorBit<sup>®</sup> Flash Non-Volatile Memory S# Pin Control

The CS# pin of the S25FLxxxS MirrorBit® flash non-volatile memory is connected to the port of the MCU, and it is controlled by MCU general port output.

The duration from the falling edge of the CS# (MCU port (CS#)) signal of the S25FLxxxS MirrorBit® flash non-volatile memory to the falling edge of the SCK (MCU CLK) signal of the S25FLxxxS MirrorBit® flash non-volatile memory is controlled by means of software wait to accommodate the CS# setup time of the S25FLxxxS MirrorBit® flash non-volatile memory.

The duration from the rising edge of the SCK (MCU CLK) signal of the S25FLxxxS MirrorBit  $^{\$}$  flash non-volatile memory to the rising edge of the CS# (MCU port (CS#)) signal of the S25FLxxxS MirrorBit  $^{\$}$  flash non-volatile memory controlled by means of software wait to accommodate the CS# hold time of the S25FLxxxS MirrorBit  $^{\$}$  flash non-volatile memory.

Check the data sheet of the S25FLxxxS MirrorBit® flash non-volatile memory and set the software wait time as appropriate for the system.

# 5.1.4 S25FLxxxS MirrorBit® Flash Non-Volatile Memory Instruction Codes

Instruction codes are used to control the S25FLxxxS MirrorBit® flash non-volatile memory, and command control is implemented by using these codes.

Table 5-1 Instruction Set

| Instruction    | Description                                        | Instruction Format |
|----------------|----------------------------------------------------|--------------------|
| WREN           | Write Enable                                       | 0000 0110 (06 h)   |
| WRDI           | Write Disable                                      | 0000 0100 (04 h)   |
| RDSR1          | Read Status Register-1                             | 0000 0101 (05 h)   |
| RDSR2          | Read Status Register-2                             | 0000 0111 (07 h)   |
| RDCR           | Read Configuration Register-1                      | 0011 0101 (35 h)   |
| WRR            | Write Register (Status-1, Configuration-1)         | 0000 0001 (01 h)   |
| CLSR           | Clear Status Register-1 - Erase/Prog. Fail Reset   | 0011 0000 (30 h)   |
| FAST_READ      | Fast Read (3- or 4-byte address)                   | 0000 1011 (0b h)   |
| 4FAST_READ     | Fast Read (4-byte address)                         | 0000 1100 (0c h)   |
| 4DOR           | Read Dual Out (4-byte address)                     | 0011 1100 (3c h)   |
| 4QOR           | Read Quad Out (4-byte address)                     | 0110 1100 (6c h)   |
| PP             | Page Program (3- or 4-byte address)                | 0000 0010 (02 h)   |
| 4PP            | Page Program (4-byte address)                      | 0001 0010 (12 h)   |
| 4QPP           | Quad Page Program (4-byte address)                 | 0011 0100 (34 h)   |
| SE             | Erase 64 kB or 256 kB (3- or 4-byte address)       | 1101 1000 (d8 h)   |
| 4SE            | Erase 64 kB or 256 kB (4-byte address)             | 1101 1100 (dc h)   |
| P4E            | Parameter 4 kB-sector Erase (3- or 4-byte address) | 0010 0000 (20 h)   |
| 4P4E           | Parameter 4 kB-sector Erase (4-byte address)       | 0010 0001 (21 h)   |
| BE             | Bulk Erase                                         | 0110 0000 (60 h)   |
| BE             | Bulk Erase (alternate command)                     | 1100 0111 (c7 h)   |
| READ_ID (REMS) | Read Electronic Manufacturer Signature             | 1001 0000 (90 h)   |
| RESET          | Software Reset                                     | 1111 0000 (f0 h)   |

## **5.2** Software Configuration

The sample code operates as upper-layer control software for controlling the S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory (indicated as S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory control software in Figure 5.5).



Figure 5.5 Software Configuration

The control procedure is as follows:

- 1. Port (CS#) signal falling edge
- 2. Software wait
- 3. Transmission and reception of commands and data using clock synchronous single master software
- 4. Software wait
- 5. Port (CS#) rising edge

# 5.3 Required Memory Size

The following table lists the required memory size.

## 5.3.1 RX Family

(1) **RX63N** 

Table 5-2 Required Memory Size

| Memory Used                   | Size                        | Remarks                    |
|-------------------------------|-----------------------------|----------------------------|
| ROM                           | 3,957 bytes (little endian) | r_qspi_flash_s25fl_usr.c   |
|                               |                             | r_qspi_flash_s25fl_sub.c   |
|                               |                             | r_qspi_flash_s25fl_drvif.c |
| RAM                           | 6 bytes (little endian)     | r_qspi_flash_s25fl_usr.c   |
|                               |                             | r_qspi_flash_s25fl_sub.c   |
|                               |                             | r_qspi_flash_s25fl_drvif.c |
| Maximum user stack usage      | 144 bytes                   |                            |
| Maximum interrupt stack usage | _                           | No interrupts used         |

Note: The required memory size varies depending on the C compiler version and compile options. The indicated ROM and RAM sizes do not include the memory used by the lower-layer clock synchronous single master software.

The memory sizes listed above differ depending on the MCU type name.

#### (2) **RX111 RSPI**

Table 5-3 Required Memory Size

| Memory Used                   | Size                        | Remarks                    |
|-------------------------------|-----------------------------|----------------------------|
| ROM                           | 3,818 bytes (little endian) | r_qspi_flash_s25fl_usr.c   |
|                               |                             | r_qspi_flash_s25fl_sub.c   |
|                               |                             | r_qspi_flash_s25fl_drvif.c |
| RAM                           | 6 bytes (little endian)     | r_qspi_flash_s25fl_usr.c   |
|                               |                             | r_qspi_flash_s25fl_sub.c   |
|                               |                             | r_qspi_flash_s25fl_drvif.c |
| Maximum user stack usage      | 152 bytes                   |                            |
| Maximum interrupt stack usage | _                           | No interrupts used         |

Note: The required memory size varies depending on the C compiler version and compile options.

The indicated ROM and RAM sizes do not include the memory used by the lower-layer clock synchronous single master software.

The memory sizes listed above differ depending on the MCU type name.

The maximum usable user stack size includes the stack size of the lower-layer clock synchronous single master software.

#### (3) **RX111 SCI**

**Table 5-4 Required Memory Size** 

| Memory Used                   | Size                        | Remarks                    |
|-------------------------------|-----------------------------|----------------------------|
| ROM                           | 3,818 bytes (little endian) | r_qspi_flash_s25fl_usr.c   |
|                               |                             | r_qspi_flash_s25fl_sub.c   |
|                               |                             | r_qspi_flash_s25fl_drvif.c |
| RAM                           | 6 bytes (little endian)     | r_qspi_flash_s25fl_usr.c   |
|                               |                             | r_qspi_flash_s25fl_sub.c   |
|                               |                             | r_qspi_flash_s25fl_drvif.c |
| Maximum user stack usage      | 152 bytes                   |                            |
| Maximum interrupt stack usage | _                           | No interrupts used         |

Note: The required memory size varies depending on the C compiler version and compile options.

The indicated ROM and RAM sizes do not include the memory used by the lower-layer clock synchronous single master software.

The memory sizes listed above differ depending on the MCU type name.

#### 5.3.2 RL78 Family, 78K0R/Kx3-L

Show the memory size of the different MCU of the order. Check the order of the MCU and please refer to the following memory sizes.

#### (1) RL78/G14 Integrated Development Environment CS+ for CA,CX (Compiler: CA78K0R)

Table 5-5 Required Memory Size

| Memory Used                   | Size        | Remarks                       |
|-------------------------------|-------------|-------------------------------|
| ROM                           | 7,176 bytes | r_qspi_flash_s25fl_usr.c      |
|                               |             | r_qspi_flash_s25fl_sub.c      |
|                               |             | r_qspi_flash_s25fl_drvif.c    |
|                               |             | r_qspi_flash_s25fl_sfr_rl78.c |
| RAM                           | 6 bytes     | r_qspi_flash_s25fl_usr.c      |
|                               |             | r_qspi_flash_s25fl_sub.c      |
|                               |             | r_qspi_flash_s25fl_drvif.c    |
|                               |             | r_qspi_flash_s25fl_sfr_rl78.c |
| Maximum user stack usage      | 122 bytes   |                               |
| Maximum interrupt stack usage | _           | No interrupts used            |

Note: The required memory size varies depending on the C compiler version and compile options.

The indicated ROM and RAM sizes do not include the memory used by the lower-layer clock synchronous single master software.

The memory sizes listed above differ depending on the MCU type name.

The maximum usable user stack size includes the stack size of the lower-layer clock synchronous single master software.

# (2) RL78/G14 Integrated Development Environment CS+ for CC (Compiler: CC-RL)

Table 5-6 Required Memory Size

| Memory Used                   | Size        | Remarks                       |
|-------------------------------|-------------|-------------------------------|
| ROM                           | 5,131 bytes | r_qspi_flash_s25fl_usr.c      |
|                               |             | r_qspi_flash_s25fl_sub.c      |
|                               |             | r_qspi_flash_s25fl_drvif.c    |
|                               |             | r_qspi_flash_s25fl_sfr_rl78.c |
| RAM                           | 6 bytes     | r_qspi_flash_s25fl_usr.c      |
|                               |             | r_qspi_flash_s25fl_sub.c      |
|                               |             | r_qspi_flash_s25fl_drvif.c    |
|                               |             | r_qspi_flash_s25fl_sfr_rl78.c |
| Maximum user stack usage      | 90 bytes    |                               |
| Maximum interrupt stack usage | _           | No interrupts used            |

Note: The required memory size varies depending on the C compiler version and compile options.

The indicated ROM and RAM sizes do not include the memory used by the lower-layer clock synchronous single master software.

The memory sizes listed above differ depending on the MCU type name.

#### (3) RL78/G14 Integrated Development Environment IAR Embedded Workbench

**Table 5-7 Required Memory Size** 

| Memory Used                   | Size        | Remarks                       |
|-------------------------------|-------------|-------------------------------|
| ROM                           | 6,231 bytes | r_qspi_flash_s25fl_usr.c      |
|                               |             | r_qspi_flash_s25fl_sub.c      |
|                               |             | r_qspi_flash_s25fl_drvif.c    |
|                               |             | r_qspi_flash_s25fl_sfr_rl78.c |
| RAM                           | 6 bytes     | r_qspi_flash_s25fl_usr.c      |
|                               |             | r_qspi_flash_s25fl_sub.c      |
|                               |             | r_qspi_flash_s25fl_drvif.c    |
|                               |             | r_qspi_flash_s25fl_sfr_rl78.c |
| Maximum user stack usage      | 160 bytes   |                               |
| Maximum interrupt stack usage | _           | No interrupts used            |

Note: The required memory size varies depending on the C compiler version and compile options.

The indicated ROM and RAM sizes do not include the memory used by the lower-layer clock synchronous single master software.

The memory sizes listed above differ depending on the MCU type name.

The maximum user stack size is the stack size for the entire project. It includes the stack of the lower-layer clock synchronous single-master control software.

#### (4) RL78/L13 Integrated Development Environment CubeSuite+

**Table 5-8 Required Memory Size** 

| Memory Used                   | Size        | Remarks                       |
|-------------------------------|-------------|-------------------------------|
| ROM                           | 6,453 bytes | r_qspi_flash_s25fl_usr.c      |
|                               |             | r_qspi_flash_s25fl_sub.c      |
|                               |             | r_qspi_flash_s25fl_drvif.c    |
|                               |             | r_qspi_flash_s25fl_sfr_rl78.c |
| RAM                           | 6 bytes     | r_qspi_flash_s25fl_usr.c      |
|                               |             | r_qspi_flash_s25fl_sub.c      |
|                               |             | r_qspi_flash_s25fl_drvif.c    |
|                               |             | r_qspi_flash_s25fl_sfr_rl78.c |
| Maximum user stack usage      | 114 bytes   |                               |
| Maximum interrupt stack usage | _           | No interrupts used            |

Note: The required memory size varies depending on the C compiler version and compile options.

The indicated ROM and RAM sizes do not include the memory used by the lower-layer clock synchronous single master software.

The memory sizes listed above differ depending on the MCU type name.

# Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory Control Software

## (5) RL78/L13 Integrated Development Environment IAR Embedded Workbench

Table 5-9 Required Memory Size

| Memory Used                   | Size        | Remarks                       |
|-------------------------------|-------------|-------------------------------|
| ROM                           | 5,633 bytes | r_qspi_flash_s25fl_usr.c      |
|                               |             | r_qspi_flash_s25fl_sub.c      |
|                               |             | r_qspi_flash_s25fl_drvif.c    |
|                               |             | r_qspi_flash_s25fl_sfr_rl78.c |
| RAM                           | 6 bytes     | r_qspi_flash_s25fl_usr.c      |
|                               |             | r_qspi_flash_s25fl_sub.c      |
|                               |             | r_qspi_flash_s25fl_drvif.c    |
|                               |             | r_qspi_flash_s25fl_sfr_rl78.c |
| Maximum user stack usage      | 140 bytes   |                               |
| Maximum interrupt stack usage | _           | No interrupts used            |

Note: The required memory size varies depending on the C compiler version and compile options. The indicated ROM and RAM sizes do not include the memory used by the lower-layer clock synchronous single master software.

The memory sizes listed above differ depending on the MCU type name.

The maximum user stack size is the stack size for the entire project. It includes the stack of the lower-layer clock synchronous single-master control software.

## 5.4 File Structure

The following table lists the files used by the sample code.

Table 5-10 File Structure

| \an_r01an1529ej0104_mcu_serial <dir></dir> | Sample code folder                                                 |
|--------------------------------------------|--------------------------------------------------------------------|
| r01an1529ej0104_mcu.pdf                    | Application note                                                   |
| \source <dir></dir>                        | Program storage folder                                             |
| \r_qspi_flash_s25fl <dir></dir>            | S25FLxxxS MirrorBit <sup>®</sup> Flash Non-Volatile Memory control |
|                                            | software folder                                                    |
| r_qspi_flash_s25fl.h                       | Header file                                                        |
| r_qspi_flash_s25fl_drvif.c                 | Driver interface source file                                       |
| r_qspi_flash_s25fl_drvif.h                 | Driver interface header file                                       |
| r_qspi_flash_s25fl_sfr.h.rl78g14           | Common definition for registers (RL78/G14)                         |
| r_qspi_flash_s25fl_sfr.h.rl78g1c           | Common definition for registers (RL78/G1C)                         |
| r_qspi_flash_s25fl_sfr.h.rl78l1c           | Common definition for registers (RL78/L1C)                         |
| r_qspi_flash_s25fl_sfr.h.rl78l12           | Common definition for registers (RL78/L12)                         |
| r_qspi_flash_s25fl_sfr.h.rl78l13           | Common definition for registers (RL78/L13)                         |
| r_qspi_flash_s25fl_sfr.h.rx63n             | Common definition for registers (RX63N)                            |
| r_qspi_flash_s25fl_sfr.h.rx111             | Common definition for registers (RX111)                            |
| r_qspi_flash_s25fl_sfr_rl78g14.c           | Common definition source file for registers (RL78/G14)             |
| r_qspi_flash_s25fl_sfr_rl78g1c.c           | Common definition source file for registers (RL78/G1C)             |
| r_qspi_flash_s25fl_sfr_rl78l1c.c           | Common definition source file for registers (RL78/L1C)             |
| r_qspi_flash_s25fl_sfr_rl78l12.c           | Common definition source file for registers (RL78/L12)             |
| r_qspi_flash_s25fl_sfr_rl78l13.c           | Common definition source file for registers (RL78/L13)             |
| r_qspi_flash_s25fl_sub.c                   | Internal function source file                                      |
| r_qspi_flash_s25fl_sub.h                   | Internal function header file                                      |
| r_qspi_flash_s25fl_usr.c                   | User interface source file                                         |
| \sample <dir></dir>                        | Operation verification program storage folder                      |
| testmain.c                                 | Sample source file for operation verification                      |

Note: In addition, separate MCU-specific clock synchronous single master control software is required.

#### 5.5 Constants

#### 5.5.1 Return Value

The following table lists the return value used in the sample code.

Table 5-11 Return Value (Refer to r\_qspi\_flash\_s25fl.h)

| Constant Name     | Setting Value | Contents                              |
|-------------------|---------------|---------------------------------------|
| FLASH_OK          | (error_t)( 0) | Successful operation                  |
| FLASH_ERR_PARAM   | (error_t)(-1) | Parameter error                       |
| FLASH_ERR_HARD    | (error_t)(-2) | Hardware error                        |
| FLASH_ERR_WP      | (error_t)(-4) | Block Protection and OTP Locked error |
| FLASH_ERR_TIMEOUT | (error_t)(-6) | Time out error                        |
| FLASH_ERR_OTHER   | (error_t)(-7) | Other error                           |

#### 5.5.2 Command Definitions

The following table lists the command definitions used in the sample code.

Table 5-12 Command Definitions (Refer to r\_qspi\_flash\_s25fl\_sub.c)

| Constant Name    | Setting Value   | Contents                                                                                                                                     |
|------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| FLASH_CMD_WREN   | (uint8_t)(0x06) | Write Enable                                                                                                                                 |
| FLASH_CMD_WRDI   | (uint8_t)(0x04) | Write Disable                                                                                                                                |
| FLASH_CMD_RDSR1  | (uint8_t)(0x05) | Read Status Register-1                                                                                                                       |
| FLASH_CMD_RDSR2  | (uint8_t)(0x07) | Read Status Register-2                                                                                                                       |
| FLASH_CMD_RDCR   | (uint8_t)(0x35) | Read Configuration Register-1                                                                                                                |
| FLASH_CMD_WRR    | (uint8_t)(0x01) | Write Register (Status-1, Configuration-1)                                                                                                   |
| FLASH_CMD_CLSR   | (uint8_t)(0x30) | Clear Status Register-1                                                                                                                      |
| FLASH_CMD_FREAD  | (uint8_t)(0x0b) | Fast Read (3-byte address)                                                                                                                   |
| FLASH_CMD_4FREAD | (uint8_t)(0x0c) | Fast Read (4-byte address)                                                                                                                   |
| FLASH_CMD_4DOR   | (uint8_t)(0x3c) | Read Dual Out (4-byte address)                                                                                                               |
| FLASH_CMD_4QOR   | (uint8_t)(0x6c) | Read Quad Out (4-byte address)                                                                                                               |
| FLASH_CMD_PP     | (uint8_t)(0x02) | Page Program (3-byte address)                                                                                                                |
| FLASH_CMD_4PP    | (uint8_t)(0x12) | Page Program (4-byte address)                                                                                                                |
| FLASH_CMD_4QPP   | (uint8_t)(0x34) | Quad Page Program (4-byte address)                                                                                                           |
| FLASH_CMD_SE     | (uint8_t)(0xd8) | Erase 64 kB or 256 kB (3-byte address)                                                                                                       |
| FLASH_CMD_4SE    | (uint8_t)(0xdc) | Erase 64 kB or 256 kB (4-byte address)                                                                                                       |
| FLASH_CMD_P4E    | (uint8_t)(0x20) | Parameter 4 kB-sector Erase (3-byte address)                                                                                                 |
| FLASH_CMD_4P4E   | (uint8_t)(0x21) | Parameter 4 kB-sector Erase (4-byte address)                                                                                                 |
| FLASH_CMD_BE     | (uint8_t)(0x60) | Bulk Erase                                                                                                                                   |
|                  |                 | In the sample program supplied with this application note, bulk erase is performed by means of this command when using the 128 Mbit product. |
| FLASH_CMD_BE_ALT | (uint8_t)(0xc7) | Bulk Erase (alternate command)                                                                                                               |
|                  |                 | In the sample program supplied with this application note, bulk erase is performed by means of this command when using the 256 Mbit product. |
| FLASH_CMD_REMS   | (uint8_t)(0x90) | Read Electronic Manufacturer Signature                                                                                                       |
| FLASH_CMD_RESET  | (uint8_t)(0xf0) | Software Reset                                                                                                                               |

## 5.5.3 Other Definitions

The values of other definitions used in the sample code are listed below.

Table 5-13 Values Defined in r\_qspi\_flash\_s25fl.h

| Constant Name         | Setting Value          | Contents                                       |
|-----------------------|------------------------|------------------------------------------------|
| FLASH_DEV_NUM         | (1)                    | Number of connected devices                    |
| FLASH_DEV0            | (0)                    | Device number 0                                |
| FLASH_DEV1            | (1)                    | Device number 1                                |
| FLASH_DELAY_TASK      | (uint8_t)(1)           | Wait time of delay task [unit: ms]*1           |
| FLASH_LOG_ERR         | (1)                    | Log Type: Error                                |
| FLASH_TRUE            | (uint8_t)(0x01)        | Flag "ON"                                      |
| FLASH_FALSE           | (uint8_t)(0x00)        | Flag "OFF"                                     |
| FLASH_MODE_B_ERASE    | (uint8_t)(1)           | Erase Mode: Bulk Erase                         |
| FLASH_MODE_S_ERASE    | (uint8_t)(2)           | Erase Mode: Sector Erase                       |
| FLASH_MODE_SS_ERASE   | (uint8_t)(3)           | Erase Mode: Subsector Erase                    |
| FLASH_MODE_REG_WRITE  | (uint8_t)(0)           | Wait Mode: Register write mode                 |
| FLASH_MODE_PROG_ERASE | (uint8_t)(1)           | Wait Mode: Page Program or Erase mode          |
| FLASH_MEM_SIZE        | (uint32_t)(33554432)   | Memory size (byte units)                       |
|                       |                        | Value at left corresponds to size of 256 Mbit. |
| FLASH_SECT_ADDR       | (uint32_t)(0xffff0000) | Sector address mask value for sector erase     |
|                       |                        | Value at left corresponds to size of 256 Mbit. |
| FLASH_SSECT_ADDR      | (uint32_t)(0xfffff000) | Sector address mask value for subsector erase  |
|                       |                        | Value at left corresponds to size of 256 Mbit. |
| FLASH_PAGE_SIZE       | (uint32_t)(256)        | Page size (byte units)                         |
|                       |                        | Value at left corresponds to size of 256 Mbit. |
| FLASH_ADDR_SIZE       | (uint8_t)(4)           | Address size (byte units)                      |
|                       |                        | Value at left corresponds to size of 256 Mbit. |
| FLASH_WP_WHOLE_MEM    | (uint8_t)(0x07)        | Whole-chip write protect                       |
|                       |                        | Value at left corresponds to size of 256 Mbit. |
| FLASH_SECTOR_TYPE     | FLASH_TYPE_64_         | Sector Type                                    |
|                       | SECTOR                 | Value at left corresponds to size of 256 Mbit, |
|                       | ( 1 . 2 . ) ( 1 )      | Uniform 64-kB sectors                          |
| FLASH_CMD_SIZE        | (uint8_t)(1)           | Command size (byte units)                      |
| FLASH_REMSADDR_SIZE   | (uint8_t)(3)           | REMS command address size                      |
| FLASH_STSREG_SIZE     | (uint16_t)(2)          | Status register size (byte units)              |
| FLASH_CFGREG_SIZE     | (uint16_t)(2)          | Configuration register size (byte units)       |
| FLASH_IDDATA_SIZE     | (uint16_t)(2)          | ID data size (byte units)                      |

Note: 1. The delay task for OS control. The OS control used in the sample code assumes µITRON 4.0.

Table 5-14 Values Defined in r\_qspi\_flash\_s25fl\_sfr.h.rx63n

| Constant Name       | Setting Value     | Contents                                                                                                        |
|---------------------|-------------------|-----------------------------------------------------------------------------------------------------------------|
| FLASH_DR_CS0        | PORTA.PODR.BIT.B0 | Device number 0 port output data register SFR definition                                                        |
| FLASH_DDR_CS0       | PORTA.PDR.BIT.B0  | Device number 0 port direction register SFR definition                                                          |
| FLASH_DR_CS1        | _                 | Device number 1 port output data register SFR definition (This setting is needed when controlling two devices.) |
| FLASH_DDR_CS1       | _                 | Device number 1 port direction register SFR definition (This setting is needed when controlling two devices.)   |
| FLASH_HI            | (uint8_t)(0x01)   | Port "H"                                                                                                        |
| FLASH_LOW           | (uint8_t)(0x00)   | Port "L"                                                                                                        |
| FLASH_OUT           | (uint8_t)(0x01)   | Port Output Setting                                                                                             |
| FLASH_IN            | (uint8_t)(0x00)   | Port Input Setting                                                                                              |
| FLASH_BR            | (uint8_t)(0x01)   | Transfer rate for command transmission*1                                                                        |
| FLASH_BR_WRITE_DATA | (uint8_t)(0x01)   | Transfer rate for data transmission*1                                                                           |
| FLASH_BR_READ_DATA  | (uint8_t)(0x01)   | Transfer rate for data reception*1                                                                              |

Note: 1. This value is set in the RSPI bit rate register (SPBR) when using the clock synchronous single master control software with the RSPI. The value shown is for a peripheral module clock setting of 48 [MHz] and a transfer rate of 12 [MHz].

This value is set in the bit rate register (BRR) when using the clock synchronous single master control software with SCI. The value shown is for a peripheral module clock setting of 48 [MHz] and a transfer rate of 6 [MHz].

Table 5-15 Values Defined in r\_qspi\_flash\_s25fl\_sfr.h.rl78

| Constant Name       | Setting Value   | Contents                                                                                                        |
|---------------------|-----------------|-----------------------------------------------------------------------------------------------------------------|
| FLASH_DR_CS0        | P8.0            | Device number 0 port register SFR definition                                                                    |
| FLASH_DDR_CS0       | PM8.0           | Device number 0 port mode register SFR definition                                                               |
| FLASH_DR_CS1        | _               | Device number 1 port output data register SFR definition (This setting is needed when controlling two devices.) |
| FLASH_DDR_CS1       | _               | Device number 1 port direction register SFR definition (This setting is needed when controlling two devices.)   |
| FLASH_HI            | (uint8_t)(0x01) | Port "H"                                                                                                        |
| FLASH_LOW           | (uint8_t)(0x00) | Port "L"                                                                                                        |
| FLASH_OUT           | (uint8_t)(0x00) | Port Output Setting                                                                                             |
| FLASH_IN            | (uint8_t)(0x01) | Port Input Setting                                                                                              |
| FLASH_BR            | (uint8_t)(0x01) | Transfer rate for command transmission*1                                                                        |
| FLASH_BR_WRITE_DATA | (uint8_t)(0x01) | Transfer rate for data transmission*1                                                                           |
| FLASH_BR_READ_DATA  | (uint8_t)(0x01) | Transfer rate for data reception*1                                                                              |

Note: 1. This value is set in bits 15 to 9 of the serial data register (SDR) when using the clock synchronous single master control software in the serial array unit CSI mode. The sample code uses this value with an operation clock setting of 24 [MHz] and a transfer rate or 6 [MHz].

Table 5-16 Values Defined in r\_qspi\_flash\_s25fl\_sub.c

| Constant Name    | Setting Value          | Contents                                                            |
|------------------|------------------------|---------------------------------------------------------------------|
| FLASH_SHORT_SIZE | (uint32_t)(0x00008000) | Maximum transfer size setting for low-level functions (max.: 32 KB) |

Table 5-17 Values Defined in r\_qspi\_flash\_s25fl\_sub.h

| Constant Name       | Setting Value       | Contents                                     |
|---------------------|---------------------|----------------------------------------------|
| FLASH_BE_BUSY_WAIT  | (uint32_t)(330000)  | Bulk Erase Busy Timeout                      |
|                     |                     | $330000 \times 1 \text{ ms} = 330 \text{ s}$ |
| FLASH_SE_BUSY_WAIT  | (uint32_t)(10400)   | Sector Erase Busy Timeout                    |
|                     |                     | $10400 \times 1 \text{ ms} = 10.4 \text{ s}$ |
| FLASH_SSE_BUSY_WAIT | (uint32_t)(650)     | Subsector Erase Busy Timeout                 |
|                     |                     | $650 \times 1 \text{ ms} = 650 \text{ ms}$   |
| FLASH_PBUSY_WAIT    | (uint32_t)(750)     | Write Ready Timeout                          |
|                     |                     | $750 \times 1 \text{ us} = 750 \text{ us}$   |
| FLASH_WBUSY_WAIT    | (uint32_t)(500)     | Write Ready Timeout                          |
|                     |                     | $500 \times 1 \text{ ms} = 500 \text{ ms}$   |
| FLASH_T_PBUSY_WAIT  | (uint16_t)MTL_T_1US | Page Program Busy Polling Time               |
| FLASH_T_WBUSY_WAIT  | (uint16_t)MTL_T_1MS | Write Busy Polling Time                      |
| FLASH_T_EBUSY_WAIT  | (uint16_t)MTL_T_1MS | Erase Busy Polling Time                      |
| FLASH_T_CS_HOLD     | (uint16_t)MTL_T_1US | CS Stability Waiting Time                    |
| FLASH_T_R_ACCESS    | (uint16_t)MTL_T_1US | Reading Start Waiting Time                   |
| FLASH_STSREG_SRWD   | (uint8_t)(0x80)     | Status Register Write Disable                |
| FLASH_STSREG_P_ERR  | (uint8_t)(0x40)     | Programming Error Occurred                   |
| FLASH_STSREG_E_ERR  | (uint8_t)(0x20)     | Erase Error Occurred                         |
| FLASH_STSREG_BP2    | (uint8_t)(0x10)     | Block Protection Bit2                        |
| FLASH_STSREG_BP1    | (uint8_t)(0x08)     | Block Protection Bit1                        |
| FLASH_STSREG_BP0    | (uint8_t)(0x04)     | Block Protection Bit0                        |
| FLASH_STSREG_WEL    | (uint8_t)(0x02)     | Write Enable Latch Bit                       |
| FLASH_STSREG_WIP    | (uint8_t)(0x01)     | Write In Progress Bit                        |
| FLASH_STSREG        | (uint8_t)(0x9c)     | Write status fixed data                      |
| FLASH_STSREG_BPMASK | (uint8_t)(0x1c)     | Block Protect Bit Mask                       |
| FLASH_CFGREG_LC1    | (uint8_t)(0x80)     | Latency Code 1                               |
| FLASH_CFGREG_LC0    | (uint8_t)(0x40)     | Latency Code 0                               |
| FLASH_CFGREG_TBPROT | (uint8_t)(0x20)     | Configures Start of Block Protection         |
| FLASH_CFGREG_RFU    | (uint8_t)(0x10)     | Reserved for Future Use                      |
| FLASH_CFGREG_BPNV   | (uint8_t)(0x08)     | Configures BP2-0 in Status Register          |
| FLASH_CFGREG_TBPARM | (uint8_t)(0x04)     | Configures Parameter Sectors location        |
| FLASH_CFGREG_QUAD   | (uint8_t)(0x02)     | Puts the device into Quad I/O operation      |
| FLASH_CFGREG_FREEZE | (uint8_t)(0x01)     | Lock current state of BP2-0 bits             |
| FLASH_CFGREG        | (uint8_t)(0xef)     | Write configuration fixed data               |

#### 5.6 Structure/Union List

Show the Structure/Union Used in the Sample Code.

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

Figure 5.6 Union Used in the Sample Code (Refer to r\_qspi\_flash\_s25fl\_sub.c)

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

Figure 5.7 Structure Used in the Sample Code (Refer to r\_qspi\_flash\_s25fl.h)

| <b>Table 5-18</b> | Description | of Structure | "r qspi | flash | info | t" |
|-------------------|-------------|--------------|---------|-------|------|----|
|                   |             |              |         |       |      |    |

| Structure<br>Member | Allowable Setting Range     | Description                                                                                      |
|---------------------|-----------------------------|--------------------------------------------------------------------------------------------------|
| Addr                | 0000 0000h to<br>FFFF FFFFh | Write/read start address                                                                         |
| Cnt                 | 0000 0000h to<br>FFFF FFFFh | Write/read data counter (byte units)                                                             |
| DataCnt             | (Setting prohibited.)       | Write: Write data counter temp. (max. 1 page)                                                    |
|                     |                             | Read: Read data counter temp. (max. 32 KB)                                                       |
| rsv[2]              | (Setting has no effect.)    | For alignment adjustment                                                                         |
| pData               | _                           | Data storage buffer pointer                                                                      |
|                     |                             | Write: Storage source of data to be written in S25FLxxxS MirrorBit® flash non-volatile memory    |
|                     |                             | Read: Storage destination of data to be read from S25FLxxxS MirrorBit® flash non-volatile memory |

#### 5.7 Variable

The following table lists the static variable.

Table 5-19 Static Variable (Refer to r\_qspi\_flash\_s25fl\_sub.c)

| Туре           | Variable Name     | Contents       | Function Used         |
|----------------|-------------------|----------------|-----------------------|
| STATIC uint8_t | g_flash_cmdbuf[6] | Command buffer | r_qspi_flash_send_cmd |
|                |                   |                | r_qspi_flash_set_cmd  |

#### 5.8 Functions

The following table lists the functions.

Table 5-20 Functions

| Function Name                      | Outline                                       |
|------------------------------------|-----------------------------------------------|
| R_QSPI_FLASH_Init_Driver()         | Driver initialization processing              |
| R_QSPI_FLASH_Reset_Device()        | Device initialization processing              |
| R_QSPI_FLASH_Read_Status()         | Status register 1 read processing             |
| R_QSPI_FLASH_Read_Status2()        | Status register 2 read processing             |
| R_QSPI_FLASH_Set_Write_Protect()   | Write protect setting processing              |
| R_QSPI_FLASH_Read_Configuration()  | Configuration register read processing        |
| R_QSPI_FLASH_Write_Configuration() | Configuration register write processing       |
| R_QSPI_FLASH_Clear_Status()        | Status clear processing                       |
| R_QSPI_FLASH_Write_Di()            | WRDI command issue processing                 |
| R_QSPI_FLASH_Read_Data()           | Data read processing                          |
| R_QSPI_FLASH_Write_Data()          | Data write processing                         |
| R_QSPI_FLASH_Write_Data_Page()     | Data write processing (for single-page write) |
| R_QSPI_FLASH_Erase()               | Erase processing                              |
| R_QSPI_FLASH_Read_ID()             | ID read processing                            |
| R_QSPI_FLASH_Wait()                | Busy wait processing                          |

On cache-equipped MCUs, specify a non-cached area as the location of the read/write data storage buffer.

The read/write data storage buffer address is dependent on the lower-layer MCU-specific clock synchronous single master control software, and in some cases it is necessary to specify an address on a 4-byte boundary. For details, refer to the application note for the MCU-specific clock synchronous single master control software.

# 5.9 Function Specifications

The following tables list the sample code function specifications.

## 5.9.1 Driver Initialization Processing

| R_QSPI_FLASH_Init | t_Driver                                                                                                                                                                                      |  |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Outline           | Driver initialization processing                                                                                                                                                              |  |
| Header            | r_qspi_flash_s25fl.h, r_qspi_flash_s25fl_sub.h, r_qspi_flash_s25fl_sfr.h,                                                                                                                     |  |
|                   | r_qspi_flash_s25fl_drvif.h                                                                                                                                                                    |  |
| Declaration       | error_t R_QSPI_FLASH_Init_Driver(void)                                                                                                                                                        |  |
| Description       | <ul> <li>Calls the R_QSPI_FLASH_Init_Port() function to initialize the CS# pin.</li> </ul>                                                                                                    |  |
|                   | <ul> <li>Calls the initialization function of the clock synchronous single master control software to initialize the I/O ports.</li> <li>Call this function once at system startup</li> </ul> |  |
| Arguments         | None                                                                                                                                                                                          |  |
| Return Value      | The initialization result is returned.                                                                                                                                                        |  |
|                   | FLASH_OK ; Successful operation                                                                                                                                                               |  |
|                   | FLASH_ERR_OTHER ; Other error                                                                                                                                                                 |  |
|                   | The return value of r_qspi_flash_drvif_init_driver() is returned.                                                                                                                             |  |



Figure 5.8 Overview of Driver Initialization Processing

# 5.9.2 Device Initialization Processing

|                | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                      |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R_QSPI_FLASH_R | Reset_Device                                                                                                                                                                                                               |
| Outline        | Device initialization processing                                                                                                                                                                                           |
| Header         | r_qspi_flash_s25fl.h, r_qspi_flash_s25fl_sub.h, r_qspi_flash_s25fl_sfr.h,<br>r_qspi_flash_s25fl_drvif.h                                                                                                                    |
| Declaration    | error_t R_QSPI_FLASH_Reset_Device(uint8_t DevNo)                                                                                                                                                                           |
| Description    | <ul> <li>Issues the software reset (RESET) command, and returns the state of the device<br/>at power-on.</li> </ul>                                                                                                        |
|                | <ul> <li>Maintains the pre-processing values of the non-volatile bits (TBPROT, TBPARM,<br/>and BPNV) in the configuration register, without initializing them.</li> </ul>                                                  |
|                | <ul> <li>Can forcibly issue the RESET command. When issued while waiting for<br/>completion of a data write or erase operation, processing is halted and the data in<br/>the area being processed is undefined.</li> </ul> |
| Arguments      | uint8_t DevNo ; Device number                                                                                                                                                                                              |
| Return Value   | The initialization result is returned.                                                                                                                                                                                     |
|                | FLASH_OK ; Successful operation                                                                                                                                                                                            |
|                | FLASH_ERR_PARAM ; Parameter error                                                                                                                                                                                          |
|                | FLASH_ERR_HARD ; Hardware error                                                                                                                                                                                            |
|                | FLASH_ERR_OTHER ; Other error                                                                                                                                                                                              |



Figure 5.9 Overview of Device Initialization Processing

#### Status Register 1 Read Processing 5.9.3

| R_QSPI | _FLASH_ | Read | _Status |
|--------|---------|------|---------|
|--------|---------|------|---------|

**Outline** Status register 1 read processing

Header r\_qspi\_flash\_s25fl.h, r\_qspi\_flash\_s25fl\_sub.h, r\_qspi\_flash\_s25fl\_sfr.h,

r\_qspi\_flash\_s25fl\_drvif.h

Declaration error\_t R\_QSPI\_FLASH\_Read\_Status(uint8\_t DevNo, uint8\_t FAR\* pStatus) • Reads the status register 1 and stores the result in pStatus. Description

Set 2 bytes as a read buffer.

Stores the following information in the read status storage buffer (pStatus):

Bit 7: Status register write disable (SRWD)

1: BP, and configuration register bits are read-only

0: No protection

Bit 6: Programming Error Occurred (P\_ERR)

1: Programming Error Occurred

0: Programming Error not Occurred

Bit 5: Erase Error Occurred (E\_ERR)

1: Erase Error Occurred

0: Erase Error not Occurred

Bits 4 to 2: Block Protection 2 - 0 (BP2 - BP0)

Bit 1: Write Enable Latch (WEL)

1: Internal Write Enable Latch is set

0: Internal Write Enable Latch is reset

Bit 0: Write in Progress (WIP)

1: Program or Erase cycle is in progress

0: No Program or Erase cycle is in progress

Refer to the data sheet of the S25FLxxxS MirrorBit® flash non-volatile memory for the relationship between protect areas and protect bits.

uint8 t DevNo : Device number

uint8\_t FAR\* pStatus ; Read status storage buffer pointer

**Return Value** The status register 1 fetch result is returned.

> FLASH OK ; Successful operation FLASH\_ERR\_PARAM ; Parameter error FLASH ERR HARD : Hardware error FLASH\_ERR\_OTHER ; Other error

**Arguments** 



Figure 5.10 Overview of Status Register 1 Read Processing

**Description** 

# 5.9.4 Status Register 2 Read Processing

R\_QSPI\_FLASH\_Read\_Status2

Outline Status register 2 read processing

**Header** r\_qspi\_flash\_s25fl\_h, r\_qspi\_flash\_s25fl\_sub.h, r\_qspi\_flash\_s25fl\_sfr.h,

r\_qspi\_flash\_s25fl\_drvif.h

**Declaration** error\_t R\_QSPI\_FLASH\_Read\_Status2(uint8\_t DevNo, uint8\_t FAR\* pStatus)

• Reads the status register 2 and stores the result in pStatus.

Set 2 bytes as a read buffer.

• Stores the following information in the read status storage buffer (pStatus):

Bit 7 to 2: Reserved for Future Use

Bit 1: Erase Suspend (ES)

1: In erase suspend mode0: Not in erase suspend mode

Bit 0: Program Suspend (PS)

1: In program suspend mode0: Not in program suspend mode

Arguments uint8\_t DevNo ; Device number

uint8 t FAR\* pStatus ; Read status storage buffer pointer

**Return Value** The status register 2 fetch result is returned.

FLASH\_OK ; Successful operation
FLASH\_ERR\_PARAM ; Parameter error
FLASH\_ERR\_HARD ; Hardware error
FLASH\_ERR\_OTHER ; Other error



Figure 5.11 Overview of Status Register 2 Read Processing

#### **Write Protect Setting Processing** 5.9.5

R QSPI FLASH Set Write Protect

**Outline** 

Write protect setting processing

Header

r\_qspi\_flash\_s25fl.h, r\_qspi\_flash\_s25fl\_sub.h, r\_qspi\_flash\_s25fl\_sfr.h,

r\_qspi\_flash\_s25fl\_drvif.h

**Declaration Description**  error t R QSPI FLASH Set Write Protect(uint8 t DevNo, uint8 t WpSts)

- Makes write protect settings
- Make settings using the following write protect setting data (WpSts). Note that the protected area differs depending on the setting of the TBPROT\* bit.

**TBPROT = 0 (high-order address area protection)** 

|       | - (9 |     |     |              |          |          |
|-------|------|-----|-----|--------------|----------|----------|
| WpSts | BP2  | BP1 | BP0 | Memory Array | 128 Mbit | 256 Mbit |
|       |      |     |     |              | [kbytes] | [kbytes] |
| 0x00  | 0    | 0   | 0   | None         | 0        | 0        |
| 0x01  | 0    | 0   | 1   | Upper 64th   | 256      | 512      |
| 0x02  | 0    | 1   | 0   | Upper 32nd   | 512      | 1024     |
| 0x03  | 0    | 1   | 1   | Upper 16th   | 1024     | 2048     |
| 0x04  | 1    | 0   | 0   | Upper 8th    | 2048     | 4096     |
| 0x05  | 1    | 0   | 1   | Upper 4th    | 4096     | 8192     |
| 0x06  | 1    | 1   | 0   | Upper Half   | 8192     | 16384    |
| 0x07  | 1    | 1   | 1   | All Sectors  | 16384    | 32768    |

### **TBPROT** = 1 (low-order address area protection)

| WpSts | BP2 | BP1 | BP0 | Memory Array | 128 Mbit | 256 Mbit |
|-------|-----|-----|-----|--------------|----------|----------|
|       |     |     |     |              | [kbytes] | [kbytes] |
| 0x00  | 0   | 0   | 0   | None         | 0        | 0        |
| 0x01  | 0   | 0   | 1   | Lower 64th   | 256      | 512      |
| 0x02  | 0   | 1   | 0   | Lower 32nd   | 512      | 1024     |
| 0x03  | 0   | 1   | 1   | Lower 16th   | 1024     | 2048     |
| 0x04  | 1   | 0   | 0   | Lower 8th    | 2048     | 4096     |
| 0x05  | 1   | 0   | 1   | Lower 4th    | 4096     | 8192     |
| 0x06  | 1   | 1   | 0   | Lower Half   | 8192     | 16384    |
| 0x07  | 1   | 1   | 1   | All Sectors  | 16384    | 32768    |

Note: \* TBPROT

The TBPROT bit in the configuration register can be used to select the protect area. The default setting is the high-order address area (TBPROT = 0). To protect the low-order address area instead, set the TBPROT bit to 1.

Note that TBPROT is an OTP bit. Once it is overwritten, it cannot be overwritten again afterward.

- Clears SRWD to 0.
- Refer to the data sheet of the S25FLxxxS MirrorBit® flash non-volatile memory for the relationship between protect areas and protect bits. It is possible that the BP bits may not be allocated.
- There are two ways to wait for write completion. These are described below. Note that the next processing task (write, read, erase, etc.) should be executed after confirming write completion.
- To use the user API to wait for write completion, enable FLASH WAIT READY in r qspi flash s25fl.h.
- To wait for write completion without using the user API, disable FLASH WAIT READY in r gspi flash s25fl.h and call R QSPI FLASH Wait() after processing by the user API finishes. This processing method allows the use

**Arguments** 

# Spansion S25FLxxxS MirrorBit® Flash Non-Volatile Memory Control Software

of a user-defined duration when waiting for write completion. Refer to figure 5.13 for the usage method.

- To confirm whether or not protect was applied successfully, read the status register 1.
- If the return value is other than FLASH\_OK, read status register 1 to check the status.
- If the return value is FLASH\_ERR\_OTHER and the P\_ERR or E\_ERR bit in status register 1 is set to 1, write protect setting did not complete successfully. Execute clear status processing (R\_QSPI\_FLASH\_Clear\_Status()) before starting the next processing (write, read, erase, etc.). Also, if the WEL bit in status register 1 is set to 1, execute the processing to issue the WRDI command

(R\_QSPI\_FLASH\_Write\_Di()) to clear it.

uint8\_t DevNo ; Device number

uint8\_t WpSts ; Write protect setting data

**Return Value** The write protect setting result is returned.

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

FLASH\_ERR\_WP ; Block Protection and OTP Locked error

FLASH\_ERR\_TIMEOUT; Time out error (FLASH\_WAIT\_READY enabled)

FLASH\_ERR\_OTHER ; Other error



Figure 5.12 Overview of Write Protect Setting Processing



Figure 5.13 OUsing R\_QSPI\_FLASH\_Wait() to Wait for Write Protect Setting Completion

#### **Configuration Register Read Processing** 5.9.6

R QSPI FLASH Read Configuration

**Outline** Configuration register read processing

Header r gspi flash s25fl.h, r gspi flash s25fl sub.h, r gspi flash s25fl sfr.h,

r\_qspi\_flash\_s25fl\_drvif.h

**Declaration** error t R QSPI FLASH Read Configuration(uint8 t DevNo, uint8 t FAR\* pConfig) **Description** 

 Reads the configuration register and stores the result in pConfig. Set 2 bytes as a read buffer.

Stores the following information in the read configuration storage buffer (pConfig):

Bit 7 to 6: Latency Code 1 - 0(LC1 - LC0)

Selects number of initial read latency cycles

Bit 5: Configures Start of Block Protection (TBPROT)

1: BP starts at bottom (Low address)

0: BP starts at top (High address)

Bit 4: Reserved for Future Use

Bit 3: Configures BP2-0 in Status Register (BPNV)

1: Volatile

0: Non-Volatile

Bit 2: Configures Parameter Sectors location (TBPARM)

1: 4 kB physical sectors at top (high address)

0: 4 kB physical sectors at bottom (Low address)

RFU in uniform sector devices

Bit 1: Puts the device into Quad I/O operation (QUAD)

1: Quad

0: Dual or Serial

Bit 0: Lock current state of BP2-0 bits in Status Register, TBPROT and TBPARM in Configuration Register, and OTP regions (FREEZE)

1: Block Protection and OTP locked

0: Block Protection and OTP un-locked

**Arguments** uint8\_t DevNo : Device number

> uint8\_t FAR\* pConfig ; Read configuration storage buffer pointer

**Return Value** The configuration register fetch result is returned.

> FLASH OK : Successful operation FLASH\_ERR\_PARAM ; Parameter error FLASH ERR HARD ; Hardware error FLASH\_ERR\_OTHER ; Other error



Figure 5.14 Overview of Configuration Register Read Processing

# 5.9.7 Configuration Register Write Processing

R\_QSPI\_FLASH\_Write\_Configuration

Outline Header Configuration register write processing

r\_qspi\_flash\_s25fl.h, r\_qspi\_flash\_s25fl\_sub.h, r\_qspi\_flash\_s25fl\_sfr.h,

r\_qspi\_flash\_s25fl\_drvif.h

Declaration Description

error t R QSPI FLASH Write Configuration(uint8 t DevNo, uint8 t Config)

- · Writes Config data to the configuration register.
- Store the following information in the configuration data (Config) to be written:

Bit 7 to 6: Latency Code 1 - 0(LC1 - LC0)

Selects number of initial read latency cycles

Bit 5: Configures Start of Block Protection (TBPROT)

1: BP starts at bottom (Low address)

0: BP starts at top (High address)

Bit 4: Reserved for Future Use

Bit 3: Configures BP2-0 in Status Register (BPNV)

1: Volatile

0: Non-Volatile

Bit 2: Configures Parameter Sectors location (TBPARM)

1: 4 kB physical sectors at top (high address)

0: 4 kB physical sectors at bottom (Low address)

RFU in uniform sector devices

Bit 1: Puts the device into Quad I/O operation (QUAD)

1: Quad

0: Dual or Serial

Bit 0: Lock current state of BP2-0 bits in Status Register, TBPROT and TBPARM in Configuration Register, and OTP regions (FREEZE)

1: Block Protection and OTP locked

0: Block Protection and OTP un-locked

- Bits 2, 3, 4, and 5 are OTP bits. Once such a bit is set, it cannot be returned to the default value again. Before rewriting the configuration register, first read the register and set the OTB bit values.
- Bits 1, 6, and 7 are non-volatile bits. They can be overwritten, but they are non-volatile and retain their values even when the power is turned off.
- Bit 0 is a volatile bit. However, it functions as an OTB bit when the power is on.
   After this bit is set, it retains its value and cannot be overwritten until power is turned off. The value returns to the default when power is turned off.
- There are two ways to wait for write completion. These are described below. Note that the next processing task (write, read, erase, etc.) should be executed after confirming write completion.
- To use the user API to wait for write completion, enable FLASH\_WAIT\_READY in r\_qspi\_flash\_s25fl.h. If the value of an OTP bit is 1 but a write is performed to the register with 0 as the setting value of the bit, FLASH\_ERR\_TIMEOUT is returned.
- To wait for write completion without using the user API, disable FLASH\_WAIT\_READY in r\_qspi\_flash\_s25fl.h and call R\_QSPI\_FLASH\_Wait() after processing by the user API finishes. This processing method allows the use of a user-defined duration when waiting for write completion. Refer to figure 5.16 for the usage method.
- To confirm whether or not the write to the configuration register completed successfully, read the configuration register 1.
- If the return value is FLASH\_ERR\_OTHER or FLASH\_ERR\_TIMEOUT, and the P\_ERR or E\_ERR bit in status register 1 is set to 1, writing to the register did not complete successfully. Execute clear status processing (R\_QSPI\_FLASH\_Clear\_Status()) before starting the next processing (write,

read, erase, etc.). Also, if the WEL bit in status register 1 is set to 1, execute the

processing to issue the WRDI command (R\_QSPI\_FLASH\_Write\_Di()) to clear it.

**Arguments** uint8 t DevNo : Device number

> uint8 t Config ; Configuration data to be written

**Return Value** The configuration register write result is returned.

FLASH OK ; Successful operation FLASH\_ERR\_PARAM ; Parameter error FLASH ERR HARD : Hardware error

FLASH ERR TIMEOUT; Time out error (FLASH WAIT READY enabled)

FLASH\_ERR\_OTHER ; Other error



Figure 5.15 Overview of Configuration Register Write Processing



Figure 5.16 Using R\_QSPI\_FLASH\_Wait() to Wait for Write Protect Setting Completion

# 5.9.8 Status Clear Processing

| R_QSPI_FLASH_Cle | ear_Status                                                                                                                                          |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Outline          | Status clear processing                                                                                                                             |
| Header           | r_qspi_flash_s25fl.h, r_qspi_flash_s25fl_sub.h, r_qspi_flash_s25fl_sfr.h,                                                                           |
|                  | r_qspi_flash_s25fl_drvif.h                                                                                                                          |
| Declaration      | error_t R_QSPI_FLASH_Clear_Status(uint8_t DevNo)                                                                                                    |
| Description      | <ul> <li>Clears the error bits in the status register 1.</li> </ul>                                                                                 |
|                  | <ul> <li>When a programming error, erase error, or write protect error occurs, this function<br/>must be called to clear the error bits.</li> </ul> |
| Arguments        | uint8_t DevNo ; Device number                                                                                                                       |
| Return Value     | The clearing result is returned.                                                                                                                    |
|                  | FLASH_OK ; Successful operation                                                                                                                     |
|                  | FLASH_ERR_PARAM ; Parameter error                                                                                                                   |
|                  | FLASH_ERR_HARD ; Hardware error                                                                                                                     |
|                  | FLASH_ERR_OTHER ; Other error                                                                                                                       |



Figure 5.17 Overview of Status Clear Processing

# 5.9.9 WRDI Command Issue Processing

Declaration error\_t R\_QSPI\_FLASH\_Write\_Di(uint8\_t DevNo)

■ Clears the WEL bit in the status register 1.

• When a register write error, programming error, erase error, or write protect error

occurs, this function must be called to clear the WEL bit.

nt8 t DevNo ; Device number

Arguments uint8\_t DevNo
Return Value The clearing result is returned.

FLASH\_OK ; Successful operation
FLASH\_ERR\_PARAM ; Parameter error
FLASH\_ERR\_HARD ; Hardware error
FLASH\_ERR\_OTHER ; Other error



Figure 5.18 Overview of WRDI Command Issue Processing

# 5.9.10 Data Read Processing

| R_QSPI_FLASH_Re | ad_Data                             |                  | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------|-------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Outline         | Data read processing                |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Header          | -                                   |                  | fl_sub.h, r_qspi_flash_s25fl_sfr.h,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Declaration     | error_t R_QSPI_FLAS<br>pFlash_Info) | H_Read_Data(υ    | iint8_t DevNo, r_qspi_flash_info_t FAR*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Description     | address in the S25F pData.          | FLxxxS MirrorBit | Imber of bytes of data from the specified  Begin flash non-volatile memory, and stores it in the second stores it in the second |
|                 | memory capacity -                   | •                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                 |                                     |                  | g by means of a rollover. After reading the final then call the user API again after specifying a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Arguments       | uint8_t DevNo                       | )                | ; Device number                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                 | r_qspi_flash_info_t FA              | R* pFlash_Info   | ; FLASH communication information structure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                 | uint32_t                            | Addr             | ; Read start address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                 | uint32_t                            | Cnt              | ; Read byte count                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                 | uint16_t                            | DataCnt          | ; Read byte temp. (setting prohibited)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                 | uint8_t FAR*                        | pData            | ; Read data storage buffer pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Return Value    | The read result is retur            | ned.             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                 | FLASH_OK                            | ; Succ           | cessful operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                 | FLASH_ERR_PARAM                     | ; Para           | meter error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                 | FLASH_ERR_HARD                      | ; Hard           | ware error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                 | FLASH_ERR_OTHER                     | ; Othe           | er error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |



Figure 5.19 Overview of Data Read Processing

# 5.9.11 Data Write Processing

| R | QSPI | FLASH | Write | Data |
|---|------|-------|-------|------|
|   |      |       |       |      |

Outline Header Data write processing

 $r\_qspi\_flash\_s25fl.h, \, r\_qspi\_flash\_s25fl\_sub.h, \, r\_qspi\_flash\_s25fl\_sfr.h, \, r\_qs$ 

r\_qspi\_flash\_s25fl\_drvif.h

**Declaration** 

error\_t R\_QSPI\_FLASH\_Write\_Data(uint8\_t DevNo, r\_qspi\_flash\_info\_t FAR\*

pFlash\_Info)

Description

- Writes the specified number of bytes of the data in pData to the specified address in the S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory.
- Writing to the S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory can only be performed to areas with write protect disabled. It is not possible to write to a protected area. FLASH\_ERR\_WP is returned when a write is attempted.
- When a write to a protected area is attempted, no write is performed and FLASH\_ERR\_WP is returned.
- The final write address is equal to the S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory capacity – 1.
- The maximum value that can be set for the write byte count (Cnt) is equal to the S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory capacity.
- The user API performs a wait for write completion regardless of the setting of FLASH WAIT READY in r gspi flash s25fl.h.
- If the return value is other than FLASH\_OK, read status register 1 to check the status.
- If the return value is FLASH\_ERR\_OTHER and the P\_ERR bit in status register 1 is set to 1, either a programming error or an attempt to write to a protected area occurred. Execute clear status processing (R\_QSPI\_FLASH\_Clear\_Status()) before starting the next processing (write, read, erase, etc.). Also, if the WEL bit in status register 1 is set to 1, execute the processing to issue the WRDI command (R QSPI FLASH Write Di()) to clear it.

**Arguments** 

uint8 t DevNo : Device number

r\_qspi\_flash\_info\_t FAR\* pFlash\_Info ; Flash communication information structure

uint32\_t Addr ; Write start address uint32\_t Cnt ; Write byte count

uint16\_t DataCnt ; Write byte temp. (setting prohibited)
uint8 t FAR\* pData ; Write data storage buffer pointer

**Return Value** 

The write result is returned.

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



Figure 5.20 Overview of Data Write Processing

# 5.9.12 Data Write Processing (for Single-Page Write)

| R QSP | I_FLASH_ | Write | Data | Page |
|-------|----------|-------|------|------|
|       |          |       |      |      |

Outline Header Data write processing (for single-page write)

 $r\_qspi\_flash\_s25fl.h, r\_qspi\_flash\_s25fl\_sub.h, r\_qspi\_flash\_s25fl\_sfr.h, r\_qspi\_flash\_s25fl\_s$ 

r\_qspi\_flash\_s25fl\_drvif.h

**Declaration** 

error\_t R\_QSPI\_FLASH\_Write\_Data\_Page(uint8\_t DevNo, r\_qspi\_flash\_info\_t FAR\* pFlash\_Info)

**Description** 

- Writes the specified number of bytes (maximum: 1 page) of the data in pData to the specified address in the S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory.
- It is possible to avoid situations in which other processing cannot be performed during data communication because the communication is divided into page units when writing large volumes of data.
- Writing to the S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory can only be performed to areas with write protect disabled. It is not possible to write to a protected area. FLASH\_ERR\_WP is returned when a write is attempted.
- When a write to a protected area is attempted, no write is performed and FLASH ERR WP is returned.
- The final write address is equal to the S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory capacity – 1.
- The maximum value that can be set for the write byte count (Cnt) is equal to the S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory capacity.
- Even if a byte count that exceeds one page is specified, the remaining byte count and the next address information remains in the FLASH communication information structure (pFlash\_Info) after write processing of one page finishes. It is possible to write the remaining byte count by setting pFlash\_Info once again without modification.
- There are two ways to wait for write completion. These are described below. Note that the next processing task (write, read, erase, etc.) should be executed after confirming write completion.
- To use the user API to wait for write completion, enable FLASH\_WAIT\_READY in r gspi flash n25g.h.
- To wait for write completion without using the user API, disable FLASH\_WAIT\_READY in r\_qspi\_flash\_n25q.h and call R\_QSPI\_FLASH\_Wait() after processing by the user API finishes. This processing method allows the use of a user-defined duration when waiting for write completion. Refer to figure 5.22 for the usage method.
- If the return value is other than FLASH\_OK, read status register 1 to check the status
- If the return value is FLASH\_ERR\_OTHER and the P\_ERR bit in status register 1 is set to 1, either a programming error or an attempt to write to a protected area occurred. Execute clear status processing (R\_QSPI\_FLASH\_Clear\_Status()) before starting the next processing (write, read, erase, etc.). Also, if the WEL bit in status register 1 is set to 1, execute the processing to issue the WRDI command (R\_QSPI\_FLASH\_Write\_Di()) to clear it.

**Arguments** 

uint8 t DevNo ; Device number

r\_qspi\_flash\_info\_t FAR\* pFlash\_Info ; FLASH communication information structure

uint32\_t Addr ; Write start address uint32\_t Cnt ; Write byte count

uint16\_tDataCnt; Write byte temp. (setting prohibited)uint8\_t FAR\*pData; Write data storage buffer pointer

**Return Value** 

The write result is returned.

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

FLASH\_ERR\_HARD ; Hardware error

FLASH\_ERR\_TIMEOUT; Time out error (FLASH\_WAIT\_READY enabled)

FLASH\_ERR\_OTHER ; Other error



Figure 5.21 Overview of Data Write Processing (for Single-Page Write)



Figure 5.22 Using R\_QSPI\_FLASH\_Wait() to Wait for Data Write Processing (for Single-Page Write)

Completion

# 5.9.13 Erase Processing

### R\_QSPI\_FLASH\_Erase

# Outline Header

Erase processing

 $r\_qspi\_flash\_s25fl.h, r\_qspi\_flash\_s25fl\_sub.h, r\_qspi\_flash\_s25fl\_sfr.h,$ 

r\_qspi\_flash\_s25fl\_drvif.h

# Declaration Description

error\_t R\_QSPI\_FLASH\_Erase(uint8\_t DevNo, uint32\_t Addr, uint8\_t Mode)

- Erases all the data in the memory (bulk erase), all the data in a specified sector (sector erase), or all the data in a specified subsector (subsector erase) by using the Mode setting.
- For bulk erase, set Addr to 0x00000000.
- Erasing the S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory can only be performed on areas with write protect disabled.
- It is not possible to erase areas of the serial phase change memory where protect is enabled. Executing a wait for erase completion causes FLASH\_ERR\_OTHER to be returned.
- There are two ways to wait for erase completion. These are described below.
   Note that the next processing task (write, read, erase, etc.) should be executed after confirming erase completion.
- To use the user API to wait for completion, enable FLASH\_WAIT\_READY in r gspi flash n25q.h.
- To wait for completion without using the user API, disable FLASH\_WAIT\_READY in r\_qspi\_flash\_n25q.h and call R\_QSPI\_FLASH\_Wait() after processing by the user API finishes. This processing method allows the use of a user-defined duration when waiting for completion. Refer to figure 5.24 for the usage method.
- The argument setting (BusyCnt) when calling R\_QSPI\_FLASH\_Wait() differs depending on the erase mode.

Bulk Erase ; BusyCnt = FLASH\_BE\_BUSY\_WAIT
Sector Erase ; BusyCnt = FLASH\_SE\_BUSY\_WAIT
Subsector Erase ; BusyCnt = FLASH\_SSE\_BUSY\_WAIT

- If the return value is other than FLASH\_OK, read status register 1 to check the status.
- If the return value is FLASH\_ERR\_OTHER and the E\_ERR bit in status register 1 is set to 1, either an erase error or an attempt to erase a protected area occurred. Execute clear status processing (R\_QSPI\_FLASH\_Clear\_Status()) before starting the next processing (write, read, erase, etc.). Also, if the WEL bit in status register 1 is set to 1, execute the processing to issue the WRDI command (R\_QSPI\_FLASH\_Write\_Di()) to clear it.

### **Arguments**

uint8\_t DevNo ; Device number uint32\_t Addr ; Erase address

uint8 t Mode ; Erase mode (selectable from the following):

FLASH\_MODE\_B\_ERASE FLASH\_MODE\_S\_ERASE FLASH\_MODE\_SS\_ERASE

### **Return Value**

The erase result is returned.

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

FLASH\_ERR\_TIMEOUT; Time out error (FLASH\_WAIT\_READY enabled)

FLASH\_ERR\_OTHER ; Other error



Figure 5.23 Overview of Erase Processing



Figure 5.24 Using R\_QSPI\_FLASH\_Wait() to Wait for Erase Processing Completion

# 5.9.14 ID Read Processing

|                 | <u> </u>                                      |               |                                                                             |
|-----------------|-----------------------------------------------|---------------|-----------------------------------------------------------------------------|
| R_QSPI_FLASH_Re | adID                                          |               |                                                                             |
| Outline         | ID read proces                                | ssing         |                                                                             |
| Header          | r_qspi_flash_s<br>r_qspi_flash_s              |               | spi_flash_s25fl_sub.h, r_qspi_flash_s25fl_sfr.h,                            |
| Declaration     | error_t R_QSF                                 | PI_FLASH_     | Read_ID(uint8_t DevNo, uint8_t FAR* pData)                                  |
| Description     | <ul> <li>Reads the<br/>as a read b</li> </ul> |               | er ID and device ID, and stores them in pData. Set 2 bytes                  |
|                 | Stores the filter                             | •             | formation in the read status storage buffer (pData):<br>facturer ID<br>e ID |
| Arguments       | uint8_t                                       | DevNo         | ; Device number                                                             |
|                 | uint8_t FAR*                                  | pData         | ; Read data storage buffer pointer                                          |
| Return Value    | The read resul                                | lt is returne | d.                                                                          |
|                 | FLASH_OK                                      |               | ; Successful operation                                                      |
|                 | FLASH_ERR_                                    | PARAM         | ; Parameter error                                                           |
|                 | FLASH_ERR_                                    | HARD          | ; Hardware error                                                            |
|                 | FLASH_ERR_                                    | OTHER         | ; Other error                                                               |



Figure 5.25 Overview of ID Read Processing

# 5.9.15 Busy Wait Processing

| R QSPI FLASH W | ₩aıt |
|----------------|------|
|----------------|------|

Outline Header Busy wait processing

r\_qspi\_flash\_s25fl.h, r\_qspi\_flash\_s25fl\_sub.h, r\_qspi\_flash\_s25fl\_sfr.h,

r\_qspi\_flash\_s25fl\_drvif.h

Declaration Description

error\_t R\_QSPI\_FLASH\_Wait(uint8\_t DevNo, uint16\_t BusyTime, uint32\_t BusyCnt)

- Use this function to confirm completion of write or erase when FLASH WAIT READY is disabled.
- When BusyCnt = 0, a wait is performed for a busy period equal to the BusyTime interval.
- When BusyCnt ≠ 0, a wait is performed for a busy period equal to the BusyTime interval multiplied by BusyCnt. If the busy state exceeds the BusyCnt, FLASH\_ERR\_TIMEOUT is returned.
- In data write or erase mode, checks the error bits (P\_ERR and E\_ERR) in the status register 1 after ready state determination. If either error bit is set to 1, FLASH ERR OTHER is returned.
- The BusyCnt and BusyTime setting values are different for writing and erasing. A FLASH\_ERR\_TIMEOUT may be returned if busy wait takes place using other than the expected settings. Make settings according to the following table:

| State                                                     | BusyTime           | BusyCnt             |
|-----------------------------------------------------------|--------------------|---------------------|
| Initializing device                                       | FLASH_T_R_ACCESS   | FLASH_WBUSY_WAIT    |
| Status register write in progress (write protect bit set) | FLASH_T_WBUSY_WAIT | FLASH_WBUSY_WAIT    |
| Data write in progress                                    | FLASH_T_WBUSY_WAIT | FLASH_PBUSY_WAIT    |
| Erase in progress (bulk erase)                            | FLASH_T_EBUSY_WAIT | FLASH_BE_BUSY_WAIT  |
| Erase in progress (sector erase)                          | FLASH_T_EBUSY_WAIT | FLASH_SE_BUSY_WAIT  |
| Erase in progress (subsector erase)                       | FLASH_T_EBUSY_WAIT | FLASH_SSE_BUSY_WAIT |

**Arguments** 

uint8 t DevNo ; Device number

uint16 t BusyTime ; Wait duration (selectable from the following):

FLASH\_T\_WBUSY\_WAIT: Register write/Data write

FLASH T EBUSY WAIT: Erase

uint32\_t BusyCnt ; Counter (selectable from the following):

FLASH\_WBUSY\_WAIT: Register write/Data write FLASH\_BE\_BUSY\_WAIT: Erase (Bulk Erase) FLASH\_SE\_BUSY\_WAIT: Erase (Sector Erase) FLASH\_SSE\_BUSY\_WAIT: Erase (Subsector Erase)

**Return Value** 

The wait result is returned.

FLASH\_OK ; Successful operation

FLASH\_ERR\_PARAM ; Parameter error FLASH\_ERR\_HARD ; Hardware error

FLASH\_ERR\_TIMEOUT; Time out error (when BusyCnt  $\neq$  0)

FLASH\_ERR\_OTHER ; Other error



Figure 5.26 Overview of Busy Wait Processing

# 6. Application Example

Example settings for the S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory control portion are shown below. (The serial I/O control portion is not covered.)

Refer to the MCU-specific application note on the clock synchronous single master control software for details of the serial I/O control portion.

Note that the communication speed requires settings for each individual slave device, and these setting are included in the sample code.

The setting locations are designated in each file by the comment /\*\* SET \*\*/.

In addition, for functions used in common (mtl\_wait\_lp(), etc.), make sure to use the versions included in the MCU-specific clock synchronous single master control software.

# 6.1 S25FLxxxS MirrorBit® Flash Non-Volatile Memory Control Software Settings

The setting locations are designated in each file by the comment /\*\* SET \*\*/.

# 6.1.1 r\_qspi\_flash\_s25fl.h

This is the definition file for the S25FLxxxS MirrorBit<sup>®</sup> flash non-volatile memory.

The setting locations are designated in each file by the comment /\*\* SET \*\*/.

### (1) Definition of Number of Devices Used and Device Numbers

Specify the number of devices to be used, and allocate a number to each device.

In the example below, one device is used, and it is allocated the device number 0.

Up to two devices can be controlled.

```
/*----*/
/* Define number of required serial FLASH devices.(1~N devices)
/* Define the device number in accordance with the number of serial FLASH */
                                                     */
/* devices to be connected.
/*-----*/
/* Define no. of devices */
#define FLASH DEV NUM
                                        /* 1device
                      (1)
/* Define no. of slots */
                                        /* Device 0
/* Device 1
#define FLASH DEV0
                       (0)
#define FLASH DEV1
                       (1)
```

### (2) Definition of Capacity of Device Used

Specify the capacity of the device(s) used.

In the example below, a 128 Mbit device with a sector size of 64 kBytes is used.

# (3) Delay Task Wait Time Setting (Valid when OS Control is Used)

This setting specifies the OS control\* delay task wait time. The unit is ms.

In the example below, a setting of 1 ms is used.

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

Note: \* The OS control used in the sample code assumes μITRON 4.0.

### (4) Write/Erase Completion Wait Processing Integration Setting

The functions listed below support a setting designating waiting for completion following execution of a command. To designate waiting for completion, enable the setting.

Affected functions:

- Write protect setting processing (R\_QSPI\_FLASH\_Set\_Write\_Protect())
- Configuration register write processing (R\_QSPI\_FLASH\_Write\_Configuration())
- Data write processing (for single-page write) (R\_QSPI\_FLASH\_Write\_Data\_Page())
- Erase processing (R\_QSPI\_FLASH\_Erase())

In the example below, waiting for completion is enabled.

# 6.1.2 r\_qspi\_flash\_s25fl\_sfr.h

A separate version of r\_qspi\_flash\_s25fl\_sfr.h.XXX is provided for each MCU model. Rename the version appropriate for the system to r\_qspi\_flash\_s25fl\_sfr.h in order to use it. If there is no available version corresponding to the MCU to be used, refer to the information below and create an appropriate version of r\_qspi\_flash\_s25fl\_sfr.h.

The setting locations are designated in each file by the comment /\*\* SET \*\*/.

### (1) Chip Select Signal Setting

Define the port SFR of the chip select signal to be used.

When connecting two devices, two ports must be defined.

In the example below, port A0 is used on the RX63N.

In the example below, port 80 is used on the RL78/G14.

```
/*----*/
/* Define the CS port.
/*----*/
   def __CA78KOR__ /* Renesas RL78 Compiler */
#define FLASH_DR_CSO P8.0 /* FLASH CSO (Negative-true logic) */
#define FLASH_DDR_CSO PM8.0 /* FLASH CSO (Negative-true logic) */
#ifdef CA78K0R
   #if (FLASH DEV NUM > 1)
   \#endif /* \#if (FLASH DEV NUM > 1) */
#endif /* __CA78KOR__ */
#ifdof CCRL /* Renesas CC-RL Compiler

/* Renesas CC-RL Compiler

/* Negative-true logic)
   #define FLASH_DR_CS0 P8_bit.no0 /* FLASH CS0 (Negative-true logic) */
   #define FLASH DDR CS0 PM8 bit.no0 /* FLASH CS0 (Negative-true logic) */
   #if (FLASH DEV NUM > 1)
   #define FLASH_DR_CS1  /* FLASH CS1 (Negative-true logic) */
#define FLASH_DDR_CS1  /* FLASH CS1 (Negative-true logic) */
   #endif /* #if (FLASH_DEV_NUM > 1) */
#endif /* __CCRL__ */
#ifdef __ICCRL78__ /* IAR RL78 Compiler
                                                                  */
   #define FLASH DR CS0 P8 bit.no0 /* FLASH CS0 (Negative-true logic) */
   #define FLASH DDR CSO PM8 bit.no0 /* FLASH CSO (Negative-true logic) */
   #if (FLASH DEV NUM > 1)
   #endif /* #if (FLASH DEV NUM > 1) */
#endif /* ICCRL78 */
```

### (2) Communication Speed Settings

These settings define the communication speed. The unit is bits per second.

The appropriate setting values depend on the MCU and serial I/O interface used. Separate settings are provided for different communication applications. See Table 6-1 for details.

**Table 6-1 Communication Speed Settings** 

| #define Definition  | Application                                                                                  |
|---------------------|----------------------------------------------------------------------------------------------|
| FLASH_BR            | Communication processing for other than the following two items (command transmission, etc.) |
| FLASH_BR_WRITE_DATA | Data write processing                                                                        |
| FLASH_BR_READ_DATA  | Data read processing                                                                         |

In the example below, the RSPI of the RX63N is used.

In the example below, the CSI of the RL78/G14 is used.

Refer to the hardware manual of the MCU when determining the setting values.

# 6.1.3 r\_qspi\_flash\_s25fl\_sub.h

The setting locations are designated in each file by the comment /\*\* SET \*\*/.

# (1) Erase Timeout Duration Settings

These settings specify the timeout duration when erasing all the data in the memory (bulk erase), all the data in a specified sector (sector erase), and all the data in a specified subsector (subsector erase).

The settings below should be reevaluated if the erase duration differs according to the device.

In the example below, the bulk erase timeout duration is set to 330 seconds, the sector erase timeout duration is set to 10.4 seconds, and the subsector erase timeout duration is set to 650 milliseconds.

```
/*-----*/
/st Define the software timer value of erase or page program busy waiting. st/
/*----*/
/*---- Definitions of software timer value -----*/
/* Bulk Erase : 330s (According to the S25FL256S)
                                                              * /
/* Sector Erase : 10.4s (According to the 64 kB Top/Bottom)
                                                              */
/* Parameter 4-kB Sector Erase: 650ms
                                                              */
/* Page Program : 750us
                                                              */
/* WRR Write Time : 500ms
#define FLASH BE BUSY WAIT (uint32 t) (330000)
                      /* Bulk Erase busy timeout 330,000*1ms = 330s
#define FLASH SE BUSY WAIT (uint32 t) (10400)
                      /* Sector Erase busy timeout 10,400*1ms = 10.4s */
#define FLASH SSE BUSY WAIT (uint32 t) (650)
                      /* Parameter 4-kB Sector Erase busy timeout
                                          650*1ms = 650ms
                                                              * /
```

# (2) Write Timeout Duration and Device Initialization Timeout Duration Settings

The settings below should be reevaluated if the write duration or device initialization duration differs according to the device.

In the example below, the write timeout duration is set to 750 µs, and the register write timeout duration is set to 500 ms.

#### r\_qspi\_flash\_s25fl\_sub.c 6.1.4

This is the source file for internal functions of the S25FLxxxS MirrorBit® flash non-volatile memory.

The setting locations are designated in each file by the comment /\*\* SET \*\*/.

#### 6.1.5 r\_qspi\_flash\_s25fl\_drvif.c

This is the source file for the clock synchronous single control software interface of the S25FLxxxS MirrorBit® flash non-volatile memory.

The setting locations are designated in each file by the comment /\*\* SET \*\*/.

#### r\_qspi\_flash\_drvif\_init\_driver() Setting (1)

This specifies the driver initialization processing of the clock synchronous single master control software used.

If there is no corresponding item, add one as necessary.

```
error t r qspi flash drvif init driver(void)
   return R SIO Init Driver();
}
```

### (2) r\_qspi\_flash\_drvif\_disable() Setting

This specifies the serial I/O disable setting processing of the clock synchronous single master control software used.

If there is no corresponding item, add one as necessary.

```
error t r qspi flash drvif disable (void)
   return R SIO Disable();
```

### (3) r\_qspi\_flash\_drvif\_enable() Setting

This specifies the serial IO enable setting processing used by the clock-synchronous single master control software.

The value of the BrgData argument is set in the bit rate register.

If there is no corresponding item, add one as necessary.

```
error_t r_qspi_flash_drvif_enable(uint8_t BrgData)
   return R SIO Enable (BrgData);
```

### (4) r\_qspi\_flash\_drvif\_enable\_tx\_data() Setting

This specifies the data write-only serial IO enable setting processing of the clock synchronous single master control software used.

The value of the BrgData argument is set in the bit rate register.

If there is no corresponding item, add one as necessary.

```
error t r qspi flash drvif enable tx data(uint8 t BrgData)
   return R SIO Enable (BrgData);
}
```

### (5) r\_qspi\_flash\_drvif\_enable\_rx\_data() Setting

This specifies the data read-only serial IO enable setting processing of the clock synchronous single master control software used.

The value of the BrgData argument is set in the bit rate register.

If there is no corresponding item, add one as necessary.

```
error t r qspi flash drvif enable rx data(uint8 t BrgData)
   return R SIO Enable (BrgData);
}
```

### (6) r\_qspi\_flash\_drvif\_open\_port() Setting

This specifies the serial IO open setting processing of the clock synchronous single master control software used.

If there is no corresponding item, add one as necessary.

```
error t r qspi flash drvif open port(void)
   return R SIO Open Port();
}
```

### r\_qspi\_flash\_drvif\_tx() Setting

This specifies the serial IO data transmit processing used by the clock-synchronous single master control software. It is mainly used for command transmission and writing to the status register.

The TxCnt argument specifies the transmit data size (bytes), and the pData argument specifies the transmit data storage destination buffer address.

If there is no corresponding item, add one as necessary.

```
error t r qspi flash drvif tx(uint16 t TxCnt, uint8 t FAR * pData)
   return R SIO Tx Data(TxCnt, pData);
```

# r\_qspi\_flash\_drvif\_tx\_data() Setting

This specifies the serial IO data transmit processing exclusively for data writes used by the clock-synchronous single master control software. It is mainly used for writing data.

The TxCnt argument specifies the transmit data size (bytes), and the pData argument specifies the transmit data storage destination buffer address.

If there is no corresponding item, add one as necessary.

```
error_t r_qspi_flash_drvif_tx_data(uint16_t TxCnt, uint8 t FAR * pData)
   return R SIO Tx Data(TxCnt, pData);
}
```

### r\_qspi\_flash\_drvif\_rx() Setting

This specifies the serial IO data receive processing used by the clock-synchronous single master control software. It is mainly used for reading the status register.

The RxCnt argument specifies the receive data size (bytes), and the pData argument specifies the receive data storage destination buffer address.

If there is no corresponding item, add one as necessary.

```
error t r qspi flash drvif rx(uint16 t RxCnt, uint8 t FAR * pData)
   return R SIO Rx Data(RxCnt, pData);
}
```

### (10) r\_qspi\_flash\_drvif\_rx\_data() Settings

This specifies the serial IO data transmit processing exclusively for data reads used by the clock-synchronous single master control software. It is mainly used for reading data.

The RxCnt argument specifies the receive data size (bytes), and the pData argument specifies the receive data storage destination buffer address.

If there is no corresponding item, add one as necessary.

```
error t r qspi flash drvif rx data(uint16 t RxCnt, uint8 t FAR * pData)
   return R SIO Rx Data(RxCnt, pData);
```

# 6.1.6 r\_qspi\_flash\_s25fl\_sfr\_rl78.c

This is an I/O module file for this Serial Flash memory.

The settings to be made are identified by the comments header "/\*\* SET \*\*/" in the file.

### (1) 1. Setting the definition of SFR

When an RL78 family or 78K0R family microcontroller is used, there will be predefined preprocessor symbols in the C compiler used. The program is coded using these predefined preprocessor symbols.

Also, when the microcontroller used is an RL78 family or 78K0R family product and furthermore, the IAR Systems integrated development environment is used, it will be necessary to set the header file in which the SFRs for the microcontroller used are defined.

See the clock synchronous single master control software for the individual microcontroller.

These settings are used for the SPI slave device select control signals.

Table 6-2 Microcontroller and SFR Area Define Settings

| Integrated development |                 | SFR setting       |                                                                                    |
|------------------------|-----------------|-------------------|------------------------------------------------------------------------------------|
| environment            | Microcontroller | required?         | Method                                                                             |
| CubeSuite+             | RL78            | Not required      | Not required                                                                       |
| CS+                    | 78K0R           | Not required      | Not required                                                                       |
|                        | RX              | Not required      | Not required                                                                       |
| IAR                    | RL78            | Required          | #ifdefICCRL78                                                                      |
| Embedded<br>Workbench  |                 |                   | #include <ior5f104pj.h> ← Change to match the microcontroller used.</ior5f104pj.h> |
|                        |                 |                   | #include <ior5f104pj_ext.h> ← Change to match</ior5f104pj_ext.h>                   |
|                        |                 |                   | the microcontroller used.                                                          |
|                        |                 |                   | #endif                                                                             |
|                        | 78K0R           | Required          | #ifdefICC78K                                                                       |
|                        |                 |                   | #include <io78f1009_64.h> ← Change to match</io78f1009_64.h>                       |
|                        |                 |                   | the microcontroller used.                                                          |
|                        |                 |                   | #include <io78f1009_64_ext.h> ← Change to match</io78f1009_64_ext.h>               |
|                        |                 |                   | the microcontroller used.                                                          |
|                        |                 |                   | #endif                                                                             |
|                        | RX              | (Not supported    | (Not supported by this software)                                                   |
|                        |                 | by this software) |                                                                                    |

The example below is for the 100-pin RL78/G14 microcontroller.

# 7. Usage Notes

# 7.1 Notes on Integrating Sample Code

To integrate the sample code, include the following header files:

```
r_qspi_flash_s25fl.h
r_qspi_flash_s25fl_sub.h
r_qspi_flash_s25fl_sfr.h
r_qspi_flash_s25fl_drvif.h
```

# 7.2 Using an MCU with On-Chip Cache

Specify a non-cached area for the read/write data storage buffer.

# 7.3 Support for Other Capacities

To support other capacities, the following definitions must be reevaluated:

FLASH\_MEM\_SIZE
FLASH\_SECT\_ADDR
FLASH\_SSECT\_ADDR
FLASH\_PAGE\_SIZE
FLASH\_ADDR\_SIZE
FLASH\_E\_ADDR\_SIZE
FLASH\_WP\_WHOLE\_MEM
FLASH\_SECTOR\_TYPE

It may be necessary to reevaluate definitions other than those listed above as well. Obtain the data sheet of the memory, and reevaluate the definitions as appropriate.

# 7.4 Using Other Slave Devices

It is possible to control other slave devices connected to the same SPI bus.

Refer to the sample code when creating slave device control software.

Note that the communication speed may be set individually for each slave device control software program.

### 7.5 Appropriate Use of Control Commands

The sample code uses 3-byte addressing code commands for 128 Mbit devices and 4-byte addressing code commands for 256 Mbit devices.



# 7.6 Bit 3 (BPNV) in the Configuration Register and Write Protect

The operation of bits 2, 3, and 4 (BP0, BP1, and BP2) in the status register, which are the write protect bits, can be set to volatile or non-volatile by means of bit 3 (BPNV) in the configuration register. The default setting is BPNV = 0 (non-volatile).

TBPROT is an OTP bit. Once it is overwritten, it cannot be overwritten again afterward.

### 7.7 Notes on Write Protect Area Selection

Write protect areas are determined by write protect bits 2, 3, and 4 (BP0, BP1, and BP2) in the status register and bit 5 (TBPROT) in the configuration register.

The TBPROT bit selects the high-order address area or the low-order address area as the protect area. The default setting is the high-order address area (TBPROT = 0). To protect the low-order address area instead, set the TBPROT bit to 1.

Note that TBPROT is an OTP bit. Once it is overwritten, it cannot be overwritten again afterward.

### 7.8 Notes on the RESET Command

It is possible to forcibly issue the RESET command. When issued while waiting for completion of a data write or erase operation, processing is halted and the data in the area being processed is undefined.

# 7.9 Voltage Stabilization Time After Power-On

Make sure to allow sufficient time for the voltage to stabilize after power-on before calling the initialization function.

Check the data sheet of the slave device regarding the voltage stabilization wait time after power-on.

# **Website and Support**

Renesas Electronics Website <a href="http://www.renesas.com/">http://www.renesas.com/</a>

Inquiries

http://www.renesas.com/contact/

All trademarks and registered trademarks are the property of their respective owners.

# **Revision History**

| _   |              |    |   |    |              |   |
|-----|--------------|----|---|----|--------------|---|
| Des | $\mathbf{r}$ | ri | n | t۱ | $\mathbf{a}$ | n |
|     |              |    |   |    |              |   |

| Day  | Data             | Description |                                                                                |
|------|------------------|-------------|--------------------------------------------------------------------------------|
| Rev. | Date Son 26 2012 | Page        | Summary  First addition issued                                                 |
| 1.01 | Sep. 26, 2013    |             | First edition issued                                                           |
| 1.03 | Apr. 30, 2014    | 1           | Modified Introduction to add short address.                                    |
|      |                  | 1           | Added RX63N, RX63T, RX210, RX21A, RX220, RX111                                 |
|      |                  |             | RL78/G1C, RL78/L12, RL78/L13, RL78/L1C and RL78/G14 as supported devices.      |
|      |                  | 5, 7        | Added 2.1 RX Family and 2.2 RL78 Family, 78K0R/Kx3-L.                          |
|      |                  | 6           | ·                                                                              |
|      |                  | b           | Added the following conditions to section 2.1. (2) RX111 RSPI                  |
|      |                  |             | (3) RX111 SCI                                                                  |
|      |                  | 7 to 11     | Added the following conditions to section 2.1.                                 |
|      |                  | 7 10 11     | (2) RL78/G14 SAU Integrated Development Environment IAR                        |
|      |                  |             | Embedded Workbench                                                             |
|      |                  |             | (3) RL78/G1C SAU Integrated Development Environment CubeSuite+                 |
|      |                  |             | (4) RL78/G1C SAU Integrated Development Environment IAR<br>Embedded Workbench  |
|      |                  |             | (5) RL78/L12 SAU Integrated Development Environment<br>CubeSuite+              |
|      |                  |             | (6) RL78/L12 SAU Integrated Development Environment IAR<br>Embedded Workbench  |
|      |                  |             | (7) RL78/L13 SAU Integrated Development Environment CubeSuite+                 |
|      |                  |             | (8) RL78/L13 SAU Integrated Development Environment IAR<br>Embedded Workbench  |
|      |                  |             | (9) RL78/L1C SAU Integrated Development Environment CubeSuite+                 |
|      |                  |             | (10) RL78/L1C SAU Integrated Development Environment IAR<br>Embedded Workbench |
|      |                  | 12          | Updated application note title in section 3, Related Application Notes.        |
|      |                  |             | -RX210, RX21A, RX220, RX63N, RX63T, RX111 Group                                |
|      |                  |             | Clock Synchronous Single Master Control Software Using the RSPI (R01AN1196EJ)  |
|      |                  |             | -RX210, RX21A, RX220, RX63N, RX63T, RX111 Group                                |
|      |                  |             | Clock Synchronous Single Master Control Software Using the SCI (R01AN1229EJ)   |
|      |                  |             | -RL78/G14, RL78/G1C, RL78/L12, RL78/L13, RL78/L1C                              |
|      |                  |             | Group Clock Synchronous Single Master Control Software                         |
|      |                  |             | Using CSI Mode of Serial Array Unit (R01AN1195EJ)                              |
|      |                  | 22, 24      | Added 5.3.1 RX Family and 5.3.2 RL78 Family, 78K0R/Kx3-L.                      |
|      |                  | 23          | Added the following to section 5.3.1, Sizes of Required                        |
|      |                  |             | Memory.                                                                        |
|      |                  |             | (2) RX111 RSPI                                                                 |
|      |                  |             | (3) RX111 SCI                                                                  |
|      |                  | 24 to 25    | Added the following section 5.3.2, Sizes of Required Memory.                   |
|      |                  |             | (2) RL78/G14 SAU Integrated Development Environment IAR<br>Embedded Workbench  |
|      |                  |             | (3) RL78/L13 SAU Integrated Development Environment CubeSuite+                 |
|      |                  |             | (4) RL78/L13 SAU Integrated Development Environment IAR                        |
|      |                  | -05         | Embedded Workbench                                                             |
|      |                  | 26          | 5.4 File Structure                                                             |
|      |                  |             | Changed name for folder for the sample code.                                   |
|      |                  |             |                                                                                |

|      |               |          | Changed application note number.                                                          |  |  |
|------|---------------|----------|-------------------------------------------------------------------------------------------|--|--|
|      |               |          | Added new device register common definitions.  Added 6.1.6 r_qspi_flash_s25fl_sfr_rl78.c. |  |  |
|      |               | 70       |                                                                                           |  |  |
|      |               | -        | Changed "Table No" format.                                                                |  |  |
| 1.04 | Mar. 31, 2016 | 7        | Changed the following title to section 2.2                                                |  |  |
|      |               |          | (1) RL78/G14 SAU Integrated Development Environment CS+ for CA,CX (Compiler: CA78K0R)     |  |  |
|      |               |          | Added the following title to section 2.                                                   |  |  |
|      |               |          | (2) RL78/G14 SAU Integrated Development Environment CS+ for CC (Compiler: CC-RL)          |  |  |
|      |               | 25       | Changed the following title to section 5.3.2                                              |  |  |
|      |               |          | (1) RL78/G14 SAU Integrated Development Environment CS+ for CA,CX (Compiler: CA78K0R)     |  |  |
|      |               |          | Added the following title to section 5.3.2                                                |  |  |
|      |               |          | (2) RL78/G14 SAU Integrated Development Environment CS+ for CC (Compiler: CC-RL)          |  |  |
|      |               | 28       | Section 5.4 File Structure                                                                |  |  |
|      |               |          | Changed Application Note Number.                                                          |  |  |
|      |               |          | Changed Folder names.                                                                     |  |  |
|      |               | 66 to 67 | 6.1.2 r_qspi_flash_s25fl_sfr.h                                                            |  |  |
|      |               |          | Changed the example.                                                                      |  |  |
|      |               |          |                                                                                           |  |  |

### General Precautions in the Handling of Microprocessing Unit and Microcontroller Unit Products

The following usage notes are applicable to all Microprocessing unit and Microcontroller unit products from Renesas. For detailed usage notes on the products covered by this document, refer to the relevant sections of the document as well as any technical updates that have been issued for the products.

### 1. Handling of Unused Pins

Handle unused pins in accordance with the directions given under Handling of Unused Pins in the manual.

The input pins of CMOS products are generally in the high-impedance state. In operation with an unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of LSI, an associated shoot-through current flows internally, and malfunctions occur due to the false recognition of the pin state as an input signal become possible. Unused pins should be handled as described under Handling of Unused Pins in the manual.

### 2. Processing at Power-on

The state of the product is undefined at the moment when power is supplied.

- The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the moment when power is supplied.
  In a finished product where the reset signal is applied to the external reset pin, the states of pins are not guaranteed from the moment when power is supplied until the reset process is completed. In a similar way, the states of pins in a product that is reset by an on-chip power-on reset function are not guaranteed from the moment when power is supplied until the power reaches the level at which resetting has been specified.
- 3. Prohibition of Access to Reserved Addresses

Access to reserved addresses is prohibited.

The reserved addresses are provided for the possible future expansion of functions. Do not access
these addresses; the correct operation of LSI is not guaranteed if they are accessed.

### 4. Clock Signals

After applying a reset, only release the reset line after the operating clock signal has become stable. When switching the clock signal during program execution, wait until the target clock signal has stabilized.

When the clock signal is generated with an external resonator (or from an external oscillator) during a reset, ensure that the reset line is only released after full stabilization of the clock signal. Moreover, when switching to a clock signal produced with an external resonator (or by an external oscillator) while program execution is in progress, wait until the target clock signal is stable.

### 5. Differences between Products

Before changing from one product to another, i.e. to a product with a different part number, confirm that the change will not lead to problems.

The characteristics of Microprocessing unit or Microcontroller unit products in the same group but having a different part number may differ in terms of the internal memory capacity, layout pattern, and other factors, which can affect the ranges of electrical characteristics, such as characteristic values, operating margins, immunity to noise, and amount of radiated noise. When changing to a product with a different part number, implement a system-evaluation test for the given product.

### Notice

- 1. Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation of these circuits, software, and information in the design of your equipment. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from the use of these circuits, software, or information,
- 2. Renesas Electronics has used reasonable care in preparing the information included in this document, but Renesas Electronics does not warrant that such information is error free. Renesas Electronics assumes no liability whatsoever for any damages incurred by you resulting from errors in or omissions from the information included herein.
- 3. Renesas Electronics does not assume any liability for infringement of patents, copyrights, or other intellectual property rights of third parties by or arising from the use of Renesas Electronics products or technical information described in this document. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or
- 4. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from such alteration, modification, copy or otherwise misappropriation of Renesas Electronics product
- 5. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below

"Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment: and industrial robots etc.

"High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anti-crime systems; and safety equipment etc.

Renesas Electronics products are neither intended nor authorized for use in products or systems that may pose a direct threat to human life or bodily injury (artificial life support devices or systems, surgical implantations etc.), or may cause serious property damages (nuclear reactor control systems, military equipment etc.). You must check the quality grade of each Renesas Electronics product before using it in a particular application. You may not use any Renesas Electronics product for any application for which it is not intended. Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for which the product is not intended by Renesas Electronics.

- 6. You should use the Renesas Electronics products described in this document within the range specified by Renesas Electronics, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas Electronics shall have no liability for malfunctions or damages arising out of the use of Renesas Electronics products beyond such specified ranges.
- 7. Although Renesas Electronics endeavors to improve the quality and reliability of its products, semiconductor products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Further, Renesas Electronics products are not subject to radiation resistance design. Please be sure to implement safety measures to guard them against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas Electronics product, such as safety design for hardware and software including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult, lease evaluate the safety of the final products or systems manufactured by you.
- 8. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. Please use Renesas Electronics products in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. Renesas Electronics assumes no liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 9. Renesas Electronics products and technology may not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations. You should not use Renesas Electronics products or technology described in this document for any purpose relating to military applications or use by the military, including but not limited to the development of weapons of mass destruction. When exporting the Renesas Electronics products or technology described in this document, you should comply with the applicable export control laws and regulations and follow the procedures required by such laws and regulations.
- 10. It is the responsibility of the buyer or distributor of Renesas Electronics products, who distributes, disposes of, or otherwise places the product with a third party, to notify such third party in advance of the contents and conditions set forth in this document, Renesas Electronics assumes no responsibility for any losses incurred by you or third parties as a result of unauthorized use of Renesas Electronics
- 11. This document may not be reproduced or duplicated in any form, in whole or in part, without prior written consent of Renesas Electronics.
- 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products, or if you have any other inquiries.
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its majority-owned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics



### **SALES OFFICES**

# Renesas Electronics Corporation

http://www.renesas.com

Refer to "http://www.renesas.com/" for the latest and detailed information

Renesas Electronics America Inc. 2801 Scott Boulevard Santa Clara, CA 95050-2549, U.S.A. Tel: +1-408-588-6000, Fax: +1-408-588-6130

Renesas Electronics Canada Limited 9251 Yonge Street, Suite 8309 Richmond Hill, Ontario Canada L4C 9T3 Tel: +1-905-237-2004

Renesas Electronics Europe Limited
Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K
Tel: +44-1628-585-100, Fax: +44-1628-585-900

Renesas Electronics Europe GmbH

Arcadiastrasse 10, 40472 Düsseldorf, Germany Tel: +49-211-6503-0, Fax: +49-211-6503-1327

Renesas Electronics (China) Co., Ltd.
Room 1709, Quantum Plaza, No.27 ZhiChunLu Haidian District, Beijing 100191, P.R.China Tel: +86-10-8235-1155, Fax: +86-10-8235-7679

Renesas Electronics (Shanghai) Co., Ltd. Unit 301, Tower A, Central Towers, 555 Langao Road, Putuo District, Shanghai, P. R. China 200333 Tel: +86-21-2226-0888, Fax: +86-21-2226-0999

Renesas Electronics Hong Kong Limited
Unit 1601-1611, 16/F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong
Tel: +852-2265-6688, Fax: +852 2886-9022

Renesas Electronics Taiwan Co., Ltd. 13F, No. 363, Fu Shing North Road, Taipei 10543, Taiwan Tel: +886-2-8175-9600, Fax: +886 2-8175-9670

Renesas Electronics Singapore Pte. Ltd. 80 Bendemeer Road, Unit #06-02 Hyflux Ini Tel: +65-6213-0200, Fax: +65-6213-0300 Innovation Centre, Singapore 339949

Renesas Electronics Malaysia Sdn.Bhd.
Unit 1207, Block B, Menara Amcorp, Amcorp Trade Centre, No. 18, Jln Persiaran Barat, 46050 Petaling Jaya, Selangor Darul Ehsan, Malaysia Tel: +60-3-7955-9390, Fax: +60-3-7955-9510

Renesas Electronics India Pvt. Ltd.
No.777C, 100 Feet Road, HALII Stage, Indiranagar, Bangalore, India Tel: +91-80-67208700, Fax: +91-80-67208777

Renesas Electronics Korea Co., Ltd. 12F., 234 Teheran-ro, Gangnam-Gu, Seoul, 135-080, Korea Tel: +82-2-558-3737, Fax: +82-2-558-5141