

# **RZ/A1LU Group**

Example of Booting from Serial Flash Memory

# Abstract

This application note describes an example of booting from the serial flash memory via the SPI multi-I/O bus controller (hereinafter called "SPIBSC") of by using the boot mode 1 (serial flash boot) function.

#### Products

RZ/A1LU

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

R01AN3093EJ0100

Rev.1.00 Nov. 18, 2016



# Contents

| 1. Specifications                                                                |      |
|----------------------------------------------------------------------------------|------|
| 1.1 Booting from Serial Flash Memory                                             |      |
| 1.2 Peripheral Functions Used                                                    | 5    |
| 2. Operation Confirmation Conditions                                             | 6    |
| 3. Reference Application Notes                                                   | 6    |
| 4. Hardware                                                                      | 7    |
| 4.1 Hardware Configuration                                                       |      |
| 4.2 Pins Used                                                                    |      |
| 5. Software                                                                      |      |
| 5.1 Operation Overview                                                           |      |
| 5.1.1 Terms Related to Serial Flash Boot                                         |      |
| 5.1.2 Operation Overview of Sample Code Overall                                  | . 10 |
| 5.1.3 Operation Overview of SPIBSC Initial setting program                       |      |
| 5.1.4 Application Program (User Program)                                         |      |
| 5.2 Peripheral Functions and Memory Allocation in Sample Code                    | . 17 |
| 5.2.1 Setting for Peripheral Functions                                           | . 17 |
| 5.2.2 Memory Mapping                                                             | . 18 |
| 5.2.3 Section Assignment in Sample Code                                          | . 19 |
| 5.3 Interrupt Used                                                               | . 22 |
| 5.4 Constants Used by the SPIBSC Initial Setting Program                         | . 23 |
| 5.5 List of Structures/Unions Used by the SPIBSC Initial Setting Program         | . 26 |
| 5.6 List of Variables for SPIBSC Initial Setting Program                         |      |
| 5.7 List of Functions Used in the SPIBSC Initial Setting Program                 |      |
| 5.8 SPIBSC Initial Setting Program Functional Specifications                     |      |
| 5.9 SPIBSC Initial Setting Program Flowcharts                                    |      |
| 5.9.1 SPIBSC Initial setting program (Overall)                                   |      |
| 5.9.2 SPIBSC Initial Setting Program 1 (STEP1)                                   |      |
| 5.9.3 SPIBSC Initial Setting Program 2 (STEP2)                                   | . 48 |
| 6. Application Example                                                           | . 50 |
| 6.1 Operation of the Sample Code Used in its Initial State                       |      |
| 6.2 Changing the Sample Code without Changing the Serial Flash Memory            |      |
| 6.2.1 Changing to 2-Serial-Flash-Memory-Device Configuration (8-bit Access Mode) |      |
| 6.2.2 Changing the Access to Serial Flash Memory into DDR Transfer Mode          |      |
| 6.3 Changing the Sample Code When Changing the Serial Flash Memory               |      |
| 6.3.1 Signal Output when a Read Command is Issued                                |      |
| 6.3.2 Setting up the Serial Flash Memory Registers                               |      |
| 6.3.3 Serial Flash Memory Write Enable                                           |      |
| 6.3.4 Serial Flash Memory Write Completion Wait                                  | . 66 |
| 7. Sample Code                                                                   | . 67 |
| 8. Reference Documents                                                           | . 67 |



# 1. Specifications

# 1.1 Booting from Serial Flash Memory

In boot mode 1, the RZ/A1LU boots from the serial flash memory allocated to the SPI multi-I/O bus space (hereinafter called "serial flash boot"). Figure 1.1 shows the Conceptual Diagram of Serial Flash Boot Operation.

| Boot startup on-chip ROM<br>Boot startup on-chip ROM<br>program<br>(1) Execute boot startup on-chip ROM program.                                                   | e of module standby)<br>SPI multi-I/O bus<br>controller<br>(SPIBSC) | <ul><li>(3) Directly execute serial flash<br/>memory initial setting program.</li><li>(4) Transfer to large-capacity<br/>on-chip RAM.</li></ul>                                            | Serial flash memory<br>SPIBSC initial setting<br>program |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|
| (1) Execute boot startup on-chip ROM program.<br>(5) Branch to start of SPIBSC<br>initial setting program<br>(6) Change SPIBSC settings.<br>SPIBSC initial setting |                                                                     | <ul> <li>(7) Change serial flash<br/>memory settings (Quad<br/>operation setting and 4-<br/>byte addressing settings).</li> <li>(8) Branch to start of application<br/>program.</li> </ul> | Application program<br>(User program)                    |

Figure 1.1 Conceptual Diagram of Serial Flash Boot Operation

The conceptual diagram of serial flash boot operation is described below.

- (1) When the RZ/A1LU starts up by serial flash boot, the boot startup on-chip ROM program runs after power-on reset is canceled.
- (2) The boot startup on-chip ROM program sets the SPIBSC to external address space read mode to enable to directly run programs allocated to the SPI multi-I/O bus space.
- (3) The serial flash memory initial setting program is executed.
- (4) The SPIBSC initial setting program is transferred from the serial flash memory to the large-capacity on-chip RAM.
- (5) Execution branches to the start address of the SPIBSC initial setting program, which has been transferred to the large-capacity on-chip RAM.
- (6) The SPIBSC initial setting program changes the SPIBSC settings.
- (7) The SPIBSC initial setting program changes the serial flash memory settings.
- (8) Execution branches to the start address of the application program.



The boot startup on-chip ROM program makes settings to allow common access to typical serial flash memory devices, so it is necessary to provide the optimal settings to the serial flash memory used by the customer. For the purpose of this setting, this application note describes how to allocate the SPIBSC initial setting program which provides optimal settings to the serial flash memory used by the customer to the start address (H'1800\_0000) of the SPI multi-I/O bust space branched by the boot startup on-chip ROM program, and then branch to the customer-created application program (user program) after optimal settings are provided by the SPIBSC initial setting program.

This application provides a method for providing optimal settings to the serial flash memory used by the customer using the SPIBSC initial setting program and a method for creating the application program (user program).



# 1.2 Peripheral Functions Used

This sample code not only configures the SPIBSC but also initializes the clock pulse oscillator, interrupt controller, bus state controller, general-purpose input/output ports, memory management unit, primary cache (L1 cache), and secondary cache (L2 cache).

In this application note, the Clock pulse generator is referred to as the CPG, the Interrupt controller as the INTC, the Bus state controller as the BSC, the OS timer as the OSTM, the Serial communication interface with FIFO as the SCIF, the General I/O ports as the PORT, the Power-down modes as the STB, and the Memory management unit as the MMU.

Table 1.1 summarizes Peripheral Functions and Their Applications, and Figure 1.2 shows Operating Environment for the sample code.

| Peripheral Function                                     | Application                                                                                                                                                                |
|---------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPI multi-I/O bus controller (SPIBSC)                   | When set to external address space read mode, it generates signals that enable the CPU to directly read from serial flash memory connected to the SPI multi-I/O bus space. |
| Clock pulse generator (CPG)                             | Generate the operating frequency of the RZ/A1LU.                                                                                                                           |
| Interrupt controller (INTC)                             | Control OSTM channel 0 interrupt.                                                                                                                                          |
| Bus state controller (BSC)                              | Generate signals for using the SDRAM in the CS3 space (Note).                                                                                                              |
| OS timer (OSTM)                                         | Generate, from the OSTM channel 0 timer, the intervals at which the LED are turned on and off.                                                                             |
| Serial communication interface with FIFO (SCIF)         | Communicate between SCIF channel 0 and the host PC.                                                                                                                        |
| General I/O ports (PORT)                                | Switch multiplexed pin functions for SPIBSC, CS3, and SCIF channel 0.<br>Control pin for LED on/off.                                                                       |
| Power-down modes (STB)                                  | Cancel the module standby state of the RZ/A1LU's peripheral I/O.<br>Enable writing to the on-chip data retention RAM.                                                      |
| Memory management unit (MMU),<br>L1 cache, and L2 cache | Generate conversion tables such as specifying valid area of L1 cache or specifying memory type in the RZ/A1LU external address area. Enable the L1 and L2 caches.          |

#### Table 1.1 Peripheral Functions and Their Applications

Note: RZ/A1LU AVB board (JASMINE board) implements the SDRAM (ISSI IS42S16320F) in the CS3 space. The settings of the BSC and multiplexed pins for using the SDRAM, which lie in the configuration section of the source code, are initially disabled. When using the SDRAM, modify the source code accordingly. When two serial flash memory chips are to be used (in 8-bit access mode), the SDRAM is not available because it uses pins that are shared with the SDRAM control signals.



Figure 1.2 Operating Environment



# 2. Operation Confirmation Conditions

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

| Table 2.1 | <b>Operation Confirmation Conditions</b> |
|-----------|------------------------------------------|
|-----------|------------------------------------------|

| ltem                           | Contents                                                                     |  |  |
|--------------------------------|------------------------------------------------------------------------------|--|--|
| MCU used                       | RZ/A1LU                                                                      |  |  |
| Operating frequency*           | CPU clock (Iø): 400 MHz                                                      |  |  |
|                                | Internal bus clock (Βφ): 133.33MHz                                           |  |  |
|                                | Peripheral clock 1 (P1φ): 66.67MHz                                           |  |  |
|                                | Peripheral clock 0 (P0φ): 33.33MHz                                           |  |  |
| Operating voltage              | Power supply voltage (I/O): 3.3V                                             |  |  |
|                                | Power supply voltage (internal): 1.18V                                       |  |  |
| Integrated development         | ARM <sup>®</sup> integrated development environment                          |  |  |
| environment                    | ARM Development Studio 5 (DS-5TM) Version 5.24                               |  |  |
| C compiler                     | ARM C/C++ Compiler/Linker/Assembler Ver.5.06 update 2 [Build 183]            |  |  |
|                                | Compiler option                                                              |  |  |
|                                | -O3 -Ospacecpu=Cortex-A9littleendarmapcs=/interwork                          |  |  |
|                                | no_unaligned_accessfpu=vfpv3_fp16 -gasm                                      |  |  |
| Operating mode                 | Boot mode 1 (Serial flash boot)                                              |  |  |
| Board used                     | RZ/A1LU AVB board                                                            |  |  |
|                                | RTK772103FC00000BR (hereinafter called "JASMINE board")                      |  |  |
| Communications settings of the | Baud rate: 115200bps                                                         |  |  |
| terminal software              | Data length: 8 bits                                                          |  |  |
|                                | Parity: None                                                                 |  |  |
|                                | Stop bits: 1 bit                                                             |  |  |
|                                | Flow control: None                                                           |  |  |
| Devices used                   | <ul> <li>Serial flash memory allocated to SPI multi-I/O bus space</li> </ul> |  |  |
| (functions used on the board)  | - Manufacturer: Macronix Inc.                                                |  |  |
|                                | - Product No.: MX25L51245G                                                   |  |  |
|                                | <ul> <li>RL78/G1C (Convert between USB communication and serial</li> </ul>   |  |  |
|                                | communication to communicate with the host PC.)                              |  |  |
|                                | LED1                                                                         |  |  |

Note: \* The operating frequency used in clock mode 0 (Clock input of 13.33MHz from EXTAL pin)

# 3. Reference Application Notes

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

- RZ/A1H Group I/O definition header file <iodefine.h> (R01AN1860EJ)
- RZ/A1H Group: Example of Initialization (R01AN1864EJ)



# 4. Hardware

# 4.1 Hardware Configuration

Figure 4.1 shows the Connection Example for Booting from Serial Flash Memory by using boot mode 1.



Figure 4.1 Connection Example for Booting from Serial Flash Memory



# 4.2 Pins Used

Table 4.1 lists the Pins Used and Their Functions.

| Pin Name           | I/O    | Function                                                                                              |
|--------------------|--------|-------------------------------------------------------------------------------------------------------|
| SPBCLK_0           | Output | Clock output                                                                                          |
| SPBSSL_0           | Output | Slave select                                                                                          |
| SPBMO0_0/SPBIO00_0 | I/O    | Master send data: data 0                                                                              |
| SPBMI0_0/SPBIO10_0 | I/O    | Master input data: data 1                                                                             |
| SPBIO20_0          | I/O    | Data 2                                                                                                |
| SPBIO30_0          | I/O    | Data 3                                                                                                |
| MD_BOOT1           | Input  | Select boot mode                                                                                      |
| MD_BOOT0/RxD0      | Input  | MD_BOOT1: "H", MD_BOOT0: "L"                                                                          |
|                    |        | (Set to boot mode 1)                                                                                  |
|                    |        | After boot-up, MD_BOOT0 is switched to the function of the serial receive data signal as RxD0 (Note). |
| P8_12              | Output | Turns on and off LED1.                                                                                |
| TxD0               | Output | Serial transmit data signal                                                                           |

#### Table 4.1 Pins Used and Their Functions

Note: The P0\_0 pin is multiplexed with the MD\_BOOT0 and RxD0 functions. At power-on reset release time, it serves as the MD\_BOOT0 function and is used to select the boot mode. In the sample code, the pin is configured by selecting and controlling the multiplexer/demultiplexer (SN74CB3Q3257) on the JASMINE board so that the boot function select signal is input through a switch on the board at power-on reset time and, after the power-on reset is released, the pin is pulled up and used as the RxD0 function.



#### 5. Software

#### 5.1 **Operation Overview**

This section provides an overview of the sample code operation presented in this application note.

#### 5.1.1 **Terms Related to Serial Flash Boot**

Table 5.1 lists the Terms Related to Serial Flash Boot Operation described in this application note.

| Term                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Boot startup on-chip ROM program   | This program provides settings to directly execute the programs<br>stored in the serial flash memory connected to the SPI multi-I/O<br>bus space when started up in boot mode 1 (serial flash boot).<br>The RZ/A1LU branches to the address of H'1800_0000 which is<br>the start address of the SPI multi-I/O bus space after the boot<br>startup on-chip ROM program has been executed.<br>Note that the boot startup on-chip ROM program makes settings<br>to enable common access to typical serial flash memory<br>devices. Since this program is stored in the on-chip ROM of the<br>RZ/A1LU, it does not need to be created by the customer.                                                                     |
| SPIBSC initial setting program     | This program is executed after the processing of the boot<br>startup on-chip ROM program has been completed. The<br>SPIBSC initial setting program makes settings to the SPIBSC<br>and to the registers in the serial flash memory corresponding to<br>the serial flash memory used by the customer, and then<br>branches to the start address of the application program.<br>SPIBSC The SPIBSC initial setting program should be created<br>by the customer according to the specifications of the serial<br>flash memory to be used while referring to this application note.<br>In the sample code, the initial settings are optimized for use with<br>the Macronix serial flash memory (product No.: MX25L51245G). |
| Application program (User program) | This program should be created by customers depending on their system to be used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

Table 5.1 Terms Related to Serial Flash Boot Operation



### 5.1.2 Operation Overview of Sample Code Overall

The sample code comprises the SPIBSC initial setting program executed from the boot startup on-chip ROM program and the application program.

(1) SPIBSC initial setting program

The SPIBSC initial setting program provides optimal settings to the serial flash memory used (Macronix serial flash memory (product No.: MX25L51245G)). The SPIBSC initial setting program is located at the start address (H'1800\_0000) of the SPI multi-I/O bus space, which is branched from the boot startup on-chip ROM program. After the SPIBSC initial setting program runs, it branches to the start address of the application program.

(2) Application program (User program)

This is an application program to be executed after optimal settings for the serial flash memory are provided in the SPIBSC initial setting program. In the sample code, the application program is located at address H'1801\_0000.

Figure 5.1 shows the Operation Overview of Sample Code presented in this application note.



Figure 5.1 Operation Overview of Sample Code



#### 5.1.3 Operation Overview of SPIBSC Initial setting program

The SPIBSC initial setting program is executed after the boot startup on-chip ROM program. The SPIBSC initial setting program should be located at the start address (H'1800\_0000) of the SPI multi-I/O bus space branched from the boot startup on-chip ROM program.

The boot startup on-chip ROM program makes settings to enable the SPIBSC to operate in external address space read mode. These settings cause the RZ/A1LU to convert read operations targeting the SPI multi-I/O bus space to SPI communication so that the direct read operations are enabled to the connected serial flash memory. This makes it possible for the RZ/A1LU to directly run programs allocated to the SPI multi-I/O bus space. The settings for commands targeting the serial flash memory used in SPI communication conversion allow common access to typical serial flash memory devices, so it is necessary to provide the optimal settings to the serial flash memory used by the customer.

Refer to Table 5.2, Table 5.3, and Table 5.4 for the settings made after the boot startup on-chip ROM program has been executed.

The optimal settings for the serial flash memory are provided in two places: the registers in the SPIBSC module (hereinafter called "SPIBSC settings") and the registers in the serial flash memory (hereinafter called "serial flash memory settings"). In the SPIBSC initial setting program of the sample code, the optimal settings are required when Macronix serial flash memory (product No.: MX25L51245G) is used.

The SPIBSC initial setting program comprises SPIBSC initial setting program 1 and SPIBSC initial setting program 2, as described below. Each is designed to be transferred from the SPI multi-I/O bus space to the large-capacity on-chip RAM and then executed from the large-capacity on-chip RAM.

(1) SPIBSC initial setting program 1

The SPIBSC initial setting program 1 sets up the SPIBSC registers so as to shorten the delay times (next access delay, SPBSSL negate delay, and clock delay), specify the transfer bit rate, and enable the read cache. The program size is comparatively compact because the content of processing is small.

(2) SPIBSC initial setting program 2

The SPIBSC initial setting program 2 sets up the SPIBSC registers so as to specify a data bus width of 4 bits, optimize the transfer bit rate according to the read command to be used, and output 4-byte addresses. It also sets up the registers in the serial flash memory (MX25L51245G) so as to specify the number of dummy cycles for the serial flash memory, enable quad operation, and make changes for 4-byte addressing. The program size is larger than that of the initial setting program 1 because the volume of its processing is great.

The SPIBSC initial setting program 1 and 2 cannot be set by the program allocated to the SPI multi-I/O bus space, so these programs should be executed from the large-capacity on-chip RAM. In the sample code, the SPIBSC initial setting program 1 is transferred to the large-capacity on-chip RAM to be executed. Then the SPIBSC initial setting program 2 is transferred to the large-capacity on-chip RAM to be executed after the possible optimal settings have been provided to the serial flash memory used. This reduces the overall running time of the SPIBSC initial setting program.



Table 5.2, Table 5.3 and Table 5.4 list the settings made by the SPIBSC initial setting program.

After the settings listed in Table 5.2, Table 5.3 and Table 5.4 are made, the SPIBSC initial setting program branches to the start address of the application program. In the sample code, the application program is allocated to the area starting at H'1801\_0000, which is to be the branch target.

# Table 5.2 Settings for the Boot Startup On-Chip ROM Program and SPIBSC Initial setting Programs (1/3)

|          | Item                                         | Boot Startup On-Chip          | SPIBSC Initial setting          | SPIBSC Initial setting        |
|----------|----------------------------------------------|-------------------------------|---------------------------------|-------------------------------|
|          |                                              | ROM Program                   | program 1                       | program 2                     |
| SPIBSC   | Delay settings                               |                               |                                 |                               |
| settings | Next access delay setting :                  |                               |                                 |                               |
|          | SSLDR.SPNDL[2:0]                             | B'111 (8SPBCLK)               | B'000 (1SPBCLK)                 | B'000 (1SPBCLK)               |
|          | SPBSSL negate delay setting :                |                               |                                 |                               |
|          | SSLDR.SLNDL[2:0]                             | B'111 (8.5SPBCLK)             | B'000 (1.5SPBCLK)               | B'000 (1.5SPBCLK)             |
|          | Clock delay setting :                        |                               |                                 |                               |
|          | SSLDR.SCKDL[2:0]                             | B'111 (8SPBCLK)               | B'000 (1SPBCLK)                 | B'000 (1SPBCLK)               |
|          | Serial clock :                               |                               |                                 |                               |
|          | (@B\$ = 133.33MHz)                           | Bφ/8 = 16.67 [MHz]            | Bφ/4 = 33.33 [MHz]              | Bφ/2 = 66.67 [MHz]            |
|          | SPBCR.SPBR[7:0]                              | 0                             | 2                               | 1                             |
|          | SPBCR.BRDV[1:0]                              | 3                             | 0                               | 0                             |
|          | CPOL : CMNCR.CPOL                            | 0                             | 0                               | 0                             |
|          | CPHAT : CMNCR.CPHAT                          | 0                             | 0                               | 0                             |
|          | CPHAR : CMNCR.CPHAR                          | 0                             | 0                               | 1                             |
|          | SPBSSL output idle value fix :               | Sets output values in         | Sets output values in           | Sets output values in         |
|          |                                              | SPBSSL negation period to     | SPBSSL negation period to       | SPBSSL negation period to     |
|          |                                              | the last bit value of the     | the last bit value of the       | Hi-z                          |
|          |                                              | previous transfer             | previous transfer               |                               |
|          | SPBIO30 and SPBIO31 setting                  | CMNCR.MOIIO3[1:0]=B'10        | CMNCR.MOIIO3[1:0]=B'10          | CMNCR.MOIIO3[1:0]=B'11        |
|          | SPBIO20 and SPBIO21 setting                  | CMNCR.MOIIO2[1:0]=B'10        | CMNCR.MOIIO2[1:0]=B'10          | CMNCR.MOIIO2[1:0]=B'11        |
|          | SPBIO10 and SPBIO11 setting                  | CMNCR.MOIIO1[1:0]=B'10        | CMNCR.MOIIO1[1:0]=B'10          | CMNCR.MOIIO1[1:0]=B'11        |
|          | SPBIO00 and SPBIO01 setting                  | CMNCR.MOIIO0[1:0]=B'10        | CMNCR.MOIIO0[1:0]=B'10          | CMNCR.MOIIO0[1:0]=B'11        |
|          | Fixes the output value of the                | Sets the terminal output      | Sets the terminal output        | Sets the terminal output      |
|          | terminal :                                   | value for 1-bit/2-bit size to | value for 1-bit/2-bit size to   | value for 1-bit/2-bit size to |
|          |                                              | the last bit value of the     | the last bit value of the       | Hi-z                          |
|          | SPRIC20 and SPRIC21 patting                  | previous transfer             | previous transfer               | CMNCR.IO3FV[1:0]=B'11         |
|          | SPBIO30 and SPBIO31 setting                  | CMNCR.IO3FV[1:0]=B'10         | CMNCR.IO3FV[1:0]=B'10           |                               |
|          | SPBIO20 and SPBIO21 setting                  | CMNCR.IO2FV[1:0]=B'10         | CMNCR.IO2FV[1:0]=B'10           | CMNCR.IO2FV[1:0]=B'11         |
|          | SPBIO00 and SPBIO01 setting                  | CMNCR.IO0FV[1:0]=B'10         | CMNCR.IO0FV[1:0]=B'10           | CMNCR.IO0FV[1:0]=B'11         |
|          | Number of serial flash :                     | 1                             | 1                               | 1                             |
|          | CMNCR.BSZ[1:0]                               |                               | B'00                            | B'00                          |
|          | Read cache : DRCR.RBE                        | 0 (Disabled)                  | 1 (Enabled)                     | 1 (Enabled)                   |
|          | Read data burst length :<br>DRCR.RBURST[3:0] | 1 data unit (8 bytes)         | 1 data unit (8 bytes)<br>B'0000 | 4 data unit (32 bytes)        |
|          | DRCR.RBURST[3:0]                             | B'0000                        |                                 | B'0011                        |
|          | DRENR.DRDB[1:0]                              | 1 [bit]<br>B'00               | 1 [bit]<br>B'00                 | 4 [bits]<br>B'10              |
|          | Read command :                               | Read (03H)                    | Read (03H)                      | Quad I/O read (ECH)           |
|          | DRCMR.CMD[7:0]                               | H'03                          | H'03                            | H'EC                          |
|          | Command :                                    | Output enabled                | Output enabled                  | Output enabled                |
|          | DRENR.CDE                                    | 1                             | 1                               | 1                             |
|          |                                              |                               |                                 |                               |
|          |                                              | •                             |                                 |                               |
|          | Optional command :<br>DRENR.OCDE             | Output disabled               | Output disabled                 | Output disabled               |



|          | ltem                        | Boot Startup On-Chip<br>ROM Program | SPIBSC Initial setting<br>program 1 | SPIBSC Initial setting<br>program 2 |
|----------|-----------------------------|-------------------------------------|-------------------------------------|-------------------------------------|
| SPIBSC   | Address specification :     | Output address[23:0]                | Output address[23:0]                | Output address[31:0]                |
| settings | DRENR.ADE[3:0]              | B'0111                              | B'0111                              | B'1111                              |
|          | Address bit size :          | 1 [bit]                             | 1 [bit]                             | 4 [bit]                             |
|          | DRENR.ADB[1:0]              | B'00                                | B'00                                | B'10                                |
|          | Option data :               | Output disabled                     | Output disabled                     | Output OPD3 *                       |
|          | DRENR.OPDE[3:0]             | B'0000                              | B'0000                              | B'1000                              |
|          | Option data bit size :      | -                                   | -                                   | 4 [bit]                             |
|          | DRENR.OPDB[1:0]             |                                     |                                     | B'10                                |
|          | Option data :               |                                     |                                     |                                     |
|          | DROPR.OPD3[7:0]             | -                                   | _                                   | H'00                                |
|          | DROPR.OPD2[7:0]             | -                                   | _                                   | _                                   |
|          | DROPR.OPD1[7:0]             | _                                   | _                                   | _                                   |
|          | DROPR.OPD0[7:0]             | _                                   | _                                   | _                                   |
|          | Dummy cycle enable :        | Insertion disabled                  | Insertion disabled                  | Insertion enabled                   |
|          | DRENR.DME                   | 0                                   | 0                                   | 1                                   |
|          | Dummy cycle bit size :      | -                                   | _                                   | 1 [bit]                             |
|          | DRDMCR.DMDB[1:0]            |                                     |                                     | B'00                                |
|          | Number of dummy cycles :    | _                                   | _                                   | 2 cycles                            |
|          | DRDMCR.DMCYC[2:0]           |                                     |                                     | B'001                               |
|          | Extended external Address : | External address bits [24:0]        | External address bits [24:0]        | External address bits [25:0]        |
|          |                             | enabled                             | enabled                             | enabled                             |
|          |                             | (Directly accessible 32MB           | (Directly accessible 32MB           | (Directly accessible 64MB           |
|          |                             | spaces)                             | spaces)                             | spaces)                             |
|          | DREAR.EAC[2:0]              | B'000                               | B'000                               | B'001                               |
|          | DREAR.EAV[7:0]              | H'00                                | H'00                                | H'00                                |
|          | Transfer format :           | Address, option data, and           | Address, option data, and           | Address, option data, and           |
|          |                             | data are transferred in SDR         | data are transferred in SDR         | data are transferred in SDR         |
|          |                             | mode.                               | mode.                               | mode.                               |
|          | DRDRENR.ADDRE               | 0                                   | 0                                   | 0                                   |
|          | DRDRENR.OPDRE               | 0                                   | 0                                   | 0                                   |
|          | DRDRENR.DRDRE               | 0                                   | 0                                   | 0                                   |
|          | AC input characteristics    |                                     |                                     |                                     |
|          | adjustment :                |                                     |                                     | <b></b>                             |
|          | CKDLY.CKDLY[3:0]            | B'0100                              | B'0100                              | B'0100                              |
|          | AC output characteristics   |                                     |                                     |                                     |
|          | adjustment :                | 1.110000                            |                                     |                                     |
|          | SPODLY.SPODLY[15:0]         | H'0000                              | H'0000                              | H'0000                              |

| Table 5.3 | Settings for the Boot Startup On-Chip ROM Program and SPIBSC Initial setting Programs |
|-----------|---------------------------------------------------------------------------------------|
|           | (2/3)                                                                                 |

Note: \* The MX25L51245G transits to the Performance Enhance Mode when data (e.g., H'A5, H'5A, H'F0, H'0F, etc.) that toggles between bits 7-4 and bits 3-0 is input during the performance enhance indicator cycle that follows the address cycle. Since the RZ/A1LU's external address space read mode does not support the data transfer in Performance Enhance Mode, the sample code makes configuration so that the MX25L51245G will not switch into the Performance Enhance Mode by making configuration so that H'00 is output from the OPD3 when a QuadIO Read command is issued.

|           | ltem                          | Boot Startup On-Chip<br>ROM Program | SPIBSC Initial setting<br>program 1 | SPIBSC Initial setting<br>program 2 |
|-----------|-------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|
| Multiplex | P4_4                          | SPBCLK_0                            | SPBCLK_0                            | SPBCLK_0                            |
| ed pin    | P4_5                          | SPBSSL_0                            | SPBSSL_0                            | SPBSSL_0                            |
| settings  | P4_6                          | SPBMO0_0 / SPBIO00_0                | SPBMO0_0 / SPBIO00_0                | SPBMO0_0 / SPBIO00_0                |
|           | P4_7                          | SPBMI0_0 / SPBIO10_0                | SPBMI0_0 / SPBIO10_0                | SPBMI0_0 / SPBIO10_0                |
|           | P4_2                          | P4_2                                | P4_2                                | SPBIO20_0                           |
|           | P4_3                          | P4_3                                | P4_3                                | SPBIO30_0                           |
| Serial    | Status Register               | No change *                         | No change *                         | Quad operation enabled.             |
| flash     |                               |                                     |                                     | QE=1                                |
| memory    | Configuration Register        | No change *                         | No change *                         | DC[1:0] = B'01                      |
| settings  |                               |                                     |                                     | ODS[2:0] = B'110                    |
| Other     | Operating clock settings      | Ιφ=133.33[MHz]                      | Ιφ=400[MHz]                         | Ιφ=400[MHz]                         |
|           | Clock input of 13.33MHz from  | Bφ=133.33[MHz]                      | Bφ=133.33[MHz]                      | Bφ=133.33[MHz]                      |
|           | EXTAL pin                     | P1¢=66.67[MHz]                      | P1φ=66.67[MHz]                      | Ρ1φ=66.67[MHz]                      |
|           |                               | P0φ=33.33[MHz]                      | P0\$=33.33[MHz]                     | P0φ=33.33[MHz]                      |
|           | CPU exception vector position | High vector                         | Low vector                          | Low vector                          |
|           |                               | (from H' FFFF_0000)                 | (from H'0000_0000)                  | (from H'0000_0000)                  |

| Table 5.4 | Settings for the Boot Startup On-Chip ROM Program and SPIBSC Initial setting Programs |
|-----------|---------------------------------------------------------------------------------------|
| (         | (3/3)                                                                                 |

Note: \* In serial flash booting (boot mode 1) of RZ/A1LU, the boot program sets the SPIBSC register to issue a read command (opcode: 03H, address: 3 bytes, dummy cycle: none) as the command to the serial flash memory. Therefore if the condition of the serial flash memory can not be received the above read command by the register value in serial flash booting, it is a possibility that can not be normal boot.



### 5.1.4 Application Program (User Program)

(1) Operation of the application program (user program)

After a reset is cancelled, the boot startup on-chip ROM program and SPIBSC initial setting program are executed in that order. Execution then transfers to the application program that is allocated to address H'1801\_0000. The application program executes the settings for the stack pointer and the MMU. It branches to the C standard library function \_\_\_\_main which is provided from the ARM integrated development environment DS-5 compiler toolchain.

The \_\_main function initializes the section area with the scatter-loading function and the library functions. It branches to the \$Sub\$\$main function to initialize the hardware.

In this sample code, the \$Sub\$\$main function initializes the peripheral functions such as STB, BSC, INTC, and PORT, and sets the L1 and L2 caches to enabled, and enables the IRQ and FIQ interrupts. It branches to the main function by calling the \$Super\$\$main function (in the sample code, the configuration for setting up the MMU and enabling the cache is executed by the application program and not by the SPIBSC initial setting program). The main function outputs the character strings to the terminal on the host PC connected with the serial interface and

The main function outputs the character strings to the terminal on the host PC connected with the serial interface and sets the OSTM channel 0 timer to interval timer mode to activate the timer. It generates the OSTM channel 0 interrupt with a cycle of 500ms and repeats turning on/off the LED on the JASMINE board board every 500ms using such interrupt.

For details on the initialization executed by the application program, refer to the application note entitled "RZ/A1H Group Example of Initialization (R01AN1864EJ)".



(2) Notes to be observed when creating an application program (user program)

The application program should be allocated to the address branched from the SPIBSC initial setting program. Note that the application program should be allocated to the different sector in the serial flash memory from the one in the SPIBSC initial setting program.

The sector size of the Macronix serial flash memory (MX25L51245G) mounted on the JASMINE board is 4KB. In the sample code, the application program is allocated to the address of H'1801\_0000 (Sector no. 16). Figure 5.2 shows the Sample Code Program Allocation.



Figure 5.2 Sample Code Program Allocation

The start address of the application program can be changed by making the following changes:

• Project for the SPIBSC initial setting program

The branch to the starting address of the application program is executed by the initial setting program 2 (spibsc\_init2.c). Specify the destination of branch with the macro definition "DEF\_USER\_PROGRAM\_TOP" in spibsc\_config.h.

• Project for the application program Change the allocation address so that the VECTOR\_TABLE section of the application program matches the address that is specified in "DEF\_USER\_PROGRAM\_TOP."



# 5.2 Peripheral Functions and Memory Allocation in Sample Code

### 5.2.1 Setting for Peripheral Functions

Table 5.5 lists the Setting for Peripheral Functions during execution of the sample code.

| Table 5.5 Setting for Peripheral Functions | Table 5.5 | Setting for | Peripheral | Functions |
|--------------------------------------------|-----------|-------------|------------|-----------|
|--------------------------------------------|-----------|-------------|------------|-----------|

| Module | Settings                                                                                                                                                                                                                                                                                       |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPG    | CPU clock (I                                                                                                                                                                                                                                                                                   |
|        | Internal bus clock (B                                                                                                                                                                                                                                                                          |
|        | Peripheral clock 1 (P1): 66.67 MHz                                                                                                                                                                                                                                                             |
|        | Peripheral clock 0 (P0): 33.33 MHz                                                                                                                                                                                                                                                             |
| SPIBSC | When set to the external address space read mode, it generates the signals which enable the CPU to read directly from the serial flash memory connected to the SPI multi-I/O bus space.<br>See Table 5.2, Table 5.3 and Table 5.4 for details.                                                 |
| PORT   | Multiplexed pin functions are enabled on PORT4, PORT8, PORT6, and<br>PORT0.<br>P4_4:SPBCLK_0<br>P4_5:SPBSSL_0<br>P4_6:SPBMO0_0/SPBIO00_0<br>P4_7:SPBMI0_0/SPBIO10_0<br>P4_2:SPBIO20_0<br>P4_3:SPBIO30_0<br>P4_3:SPBIO30_0<br>P8_12:LED on/off<br>P6_15:TxD0<br>P0_0:RxD0 *                     |
| STB    | Writing to the on-chip RAM used for retention is enabled and clock<br>supply to peripheral functions is enabled.<br>Clock supply is enabled to all peripheral functions for which clock supply<br>and stop control are supported by using STBCR2 to STBCR12.                                   |
| OSTM   | Sets the channel 0 in interval timer mode.<br>Sets the timer counter to have interrupt request generated every 500ms when $P0\phi=33.33$ MHz.                                                                                                                                                  |
| INTC   | Initializes INTC, and registers and executes OSTM channel 0 interrupt (interrupt ID is 134) handler                                                                                                                                                                                            |
| SCIF   | <ul> <li>Sets the channel 0 in asynchronous communication mode.</li> <li>Data length: 8 bits</li> <li>Stop bit length: 1 bit</li> <li>Parity: None</li> <li>Sets the clock source without frequency dividing and the bit rate value at 17. Sets the bit rate to be 115200bps when P1</li></ul> |

Note: \* The P0\_0 pin is multiplexed with the MD\_BOOT0 and RxD0 functions. At power-on reset release time, it serves as the MD\_BOOT0 function and is used to select the boot mode. In the sample code, the pin is configured by selecting and controlling the multiplexer/demultiplexer (SN74CB3Q3257) on the JASMINE board so that the boot function select signal is input through a switch on the board at power-on reset time and, after the power-on reset is released, the pin is pulled up and used as the RxD0 function.

# 5.2.2 Memory Mapping

Figure 5.3 shows the RZ/A1LU Group Address Space and JASMINE board.

| Mirror         RZA1LU group<br>Address space         JASMINE board<br>Memory map           HFFFF FFFF         Others<br>(2557MB)         Others<br>(2557MB)         Others<br>(2557MB)           H6000 0000         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)           H5000 0000         H5000 0000         SPI multi-I/O-bus<br>space 1 (64MB)         -           H5000 0000         H5000 0000         CS3 space (64MB)         -           H4000 0000         CS2 space (64MB)         -         -           H4000 0000         CS2 space (64MB)         -         -           H4000 0000         CS2 space (64MB)         -         -           H4000 0000         CS1 space (64MB)         -         -           H4000 0000         H4000 0000         CS1 space (64MB)         -           H4000 0000         Large-capacity on-<br>chip RAM (3MB)         Chiers<br>(509MB)         Others<br>(509MB)         Others<br>(509MB)         Chiers<br>(509MB)         -           Normal<br>space         H11000 0000         SPI multi-I/O-bus<br>space 1 (64MB)         -         -           H1400 0000         CS5 space (64MB)         -         -         -           H1400 0000         H1400 0000         CS5 space (64MB)         -         - <th></th> <th></th> <th></th> <th></th> <th></th> |       |           |                    |          |                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------|--------------------|----------|---------------------|
| HIFFFF FFFF         Others<br>(2557MB)         Others<br>(2557MB)           H6030 0000         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)           H5000 0000         SPI multi-I/O-bus<br>space 2 (64MB)         -           H5000 0000         CS5 space (64MB)         -           H5000 0000         CS3 space (64MB)         -           H4000 0000         CS2 space (64MB)         -           H4000 0000         CS2 space (64MB)         -           H4000 0000         CS1 space (64MB)         -           H4000 0000         CS0 space (64MB)         -           H1000 0000         CS0 space (64MB)         -           H1000 0000         CS5 space (64MB)         -           H1000 0000         CS3 space (64MB)         -           H1000 0000         CS2 space (64MB)         -                                                                                                                                                            |       |           |                    |          |                     |
| Others<br>(2557MB)         Others<br>(2557MB)         Others<br>(2557MB)           H6030 0000<br>H6000 0000<br>H6000 0000<br>H500 0000         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)           Mirror<br>space 1 (64MB)         -         SPI multi-I/O-bus<br>space 1 (64MB)         -           H5000 0000<br>H4000 0000         CS4 space (64MB)         -         -           H15000 0000<br>H4000 0000         CS3 space (64MB)         -         -           CS1 space (64MB)         -         -         -           H14000 0000         CS1 space (64MB)         -         -           H14000 0000         CS0 space (64MB)         -         -           H14000 0000         CS0 space (64MB)         -         -           H14000 0000         CS1 space (64MB)         -         -           H14000 0000         CS0 space (64MB)         -         -           H14000 0000         CS1 space (64MB)         -         -           H11000 0000         SPI multi-I/O-bus<br>space 1 (64MB)         Serial flash memory<br>(64MB)         -           H11000 0000         CS2 space (64MB)         -         -         -           H1400 0000         CS4 space (64MB)         -         -         - <t< td=""><td></td><td>שיבכב כב</td><td></td><td><b>1</b></td><td></td></t<>                |       | שיבכב כב  |                    | <b>1</b> |                     |
| Mirror         H6030 0000         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM mirror           Mirror         H5000 0000         SPI multi-I/O-bus         -           H5000 0000         H5000 0000         SPI multi-I/O-bus         -           Mirror         SPI multi-I/O-bus         SPI multi-I/O-bus         -           Spi multi-I/O-bus         SPI multi-I/O-bus         SPI multi-I/O-bus         -           Mirror         H5000 0000         CS3 space (64MB)         -         -           H4000 0000         H4000 0000         CS3 space (64MB)         -         -           H4000 0000         H4000 0000         CS1 space (64MB)         -         -           H4000 0000         H4000 0000         CS0 space (64MB)         -         -           H1000 0000         H1000 0000         Large-capacity on-<br>chip RAM (3MB)         Serial flash memory<br>space 1 (64MB)         -           H1100 0000         H1000 0000         CS3 space (64MB)         -         -           H1400 0000         CS3 space (64MB)         -         -         -           H1400 0000         Large-capacity on-<br>chip RAM (3MB)         Serial flash memory<br>space 1 (64MB)         -         -           CS1 space (64MB)         -         -                                                                                                  |       |           |                    |          |                     |
| Mirror<br>space         H6030 0000<br>H6000 0000         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM mirror           Mirror<br>space         H5000 0000         SPI multi-I/O-bus<br>space 2 (64MB)         -           H5000 0000         H5000 0000         SPI multi-I/O-bus<br>space 1 (64MB)         -           H5000 0000         H5000 0000         CS4 space (64MB)         -           H4000 0000         H4000 0000         CS3 space (64MB)         -           H4000 0000         H4000 0000         CS1 space (64MB)         -           H4000 0000         CS0 space (64MB)         -         -           H4000 0000         CS0 space (64MB)         -         -           H4000 0000         CS1 space (64MB)         -         -           H4000 0000         CS1 space (64MB)         -         -           H2030 0000         Large-capacity on-<br>chip RAM (3MB)         Serial flash memory<br>space 1 (64MB)         -           H1000 0000         H1000 0000         CS3 space (64MB)         -         -           H1400 0000         CS3 space (64MB)         -         -         -           H1400 0000         CS5 space (64MB)         -         -         -           H1400 0000         CS3 space (64MB)         -         -                                                                                                      |       |           |                    |          |                     |
| Mirror         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)           Mirror         SPI multi-I/O-bus<br>space 1 (64MB)         -           Mirror         SPI multi-I/O-bus<br>space 1 (64MB)         SPI multi-I/O-bus<br>mirror space 1           Mirror         CS5 space (64MB)         -           H5000 0000         CS4 space (64MB)         -           H4000 0000         CS3 space (64MB)         -           H4000 0000         CS1 space (64MB)         -           H4000 0000         Large-capacity on-<br>chip RAM (3MB)         Chips RAM (3MB)           H2000 0000         Large-capacity on-<br>chip RAM (3MB)         -           H1000 0000         SPI multi-I/O-bus<br>space 1 (64MB)         -           H1400 0000         CS5 space (64MB)         -           H1400 0000         CS4 space (64MB)         -           H1000 0000         CS2 space (64MB)         -                                                                                                               |       |           | (2557MB)           |          | (2557MB)            |
| Mirror         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM mirror           Mirror         SPI multi-I/O-bus         -           H5000 0000         SPI multi-I/O-bus         SPI multi-I/O-bus           H5000 0000         CS5 space (64MB)         -           H5000 0000         CS4 space (64MB)         -           H4000 0000         CS3 space (64MB)         -           H4000 0000         CS2 space (64MB)         -           H4000 0000         CS1 space (64MB)         -           H2000 0000         Large-capacity on-<br>chip RAM (3MB)         Chip RAM (3MB)           H1000 0000         SPI multi-I/O-bus         Serial flash memory<br>(64MB)           Space 1 (64MB)         -         -           H1800 0000         SPI multi-I/O-bus         Serial flash memory<br>(64MB)           Space 1 (64MB)         -         -           H14                                                                                                                                                  |       | H'6030.00 | 000                |          |                     |
| Mirror<br>space         SPI multi-I/O-bus<br>space 2 (64MB)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       | $\int$    | Large-capacity on- |          |                     |
| Mirror<br>space         H*5C00 0000<br>H*5800 0000         space 2 (64MB)<br>SPI multi-I/O-bus<br>space 1 (64MB)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       | H'6000 00 |                    |          | chip RAM mirror     |
| Mirror<br>space         SPI multi-I/O-bus<br>space 1 (64MB)         SPI multi-I/O-bus<br>mirror space 1           Mirror<br>space         H'5000 0000<br>H'4000 0000         CS3 space (64MB)         -           H'4000 0000<br>H'4000 0000         CS3 space (64MB)         -           H'4000 0000<br>H'4000 0000         CS2 space (64MB)         -           H'4000 0000<br>H'4000 0000         CS1 space (64MB)         -           H'4000 0000<br>H'4000 0000         CS0 space (64MB)         -           H'2030 0000<br>H'2000 0000         Large-capacity on-<br>chip RAM (3MB)         Others<br>(509MB)         Others<br>(509MB)           H'1000 0000         H'1000 0000         SPI multi-I/O-bus<br>space 2 (64MB)         -           Normal<br>space         H'1400 0000         CS5 space (64MB)         -           H'1000 0000         CS2 space (64MB)         -           H'1000 0000         CS2 space (64MB)         -           H'1000 0000         CS2 space (64MB)         -           H'0000 0000         CS2 space (64MB)         -           H'0000 0000                                                                        |       | H'5C00 00 |                    |          | -                   |
| Mirror<br>space         CS5 space (64MB)            H*000 0000<br>H*4000 0000<br>H*4600 0000<br>H*4600 0000<br>H*4400 0000         CS3 space (64MB)            Kirror space         CS2 space (64MB)            CS1 space (64MB)             CS1 space (64MB)             CS1 space (64MB)             CS1 space (64MB)             CS0 space (64MB)             CS1 space (64MB)             H*4000 0000         CS0 space (64MB)            H*2030 0000         Large-capacity on-<br>chip RAM (3MB)         Chip RAM (3MB)           H*2000 0000         SPI multi-I/O-bus<br>space 2 (64MB)            H*1000 0000         CS5 space (64MB)            H*1000 0000         CS3 space (64MB)            H*1000 0000         CS3 space (64MB)            H*1000 0000         CS3 space (64MB)            H*1000 0000         CS2 space (64MB)            H*1000 0000         CS2 space (64MB)            H*0000000         CS1 space (64MB)                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |           | SPI multi-I/O-bus  |          |                     |
| Mirror<br>space         H 5000 0000<br>H 4200 0000         CS4 space (64MB)         -           H 4C00 0000         CS3 space (64MB)         CS3 mirror space           H 4800 0000         CS1 space (64MB)         -           H 4400 0000         CS0 space (64MB)         -           H 4000 0000         CS0 space (64MB)         -           H 2000 0000         Large-capacity on-<br>chip RAM (3MB)         Chip RAM (3MB)           H 12000 0000         Large-capacity on-<br>chip RAM (3MB)         -           SPI multi-I/O-bus<br>space 2 (64MB)         -         -           H 11000 0000         CS5 space (64MB)         -           H 11000 0000         CS5 space (64MB)         -           H 1000 0000         CS4 space (64MB)         -           H 1000 0000         CS3 space (64MB)         -           H 1000 0000         CS2 space (64MB)         -           H 1000 0000         CS2 space (64MB)         -           H 1000 0000         CS2 space (64MB)         -           H 0400 0000         CS1 space (64MB)         -                                                                                                                                                             |       | H'5800 00 |                    |          | mirror space 1      |
| Mirror         H5000 0000         CS3 space (64MB)         CS3 mirror space           H'4C00 0000         CS2 space (64MB)         -           H'4000 0000         CS1 space (64MB)         -           H'4000 0000         CS1 space (64MB)         -           H'4000 0000         CS0 space (64MB)         -           H'4000 0000         CS0 space (64MB)         -           H'4000 0000         Others         Others           H'2030 0000         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)           H'1000 0000         SPI multi-I/O-bus<br>space 2 (64MB)         -           H'1800 0000         SPI multi-I/O-bus<br>space 1 (64MB)         -           H'1800 0000         CS5 space (64MB)         -           H'1800 0000         CS4 space (64MB)         -           H'1000 0000         CS3 space (64MB)         -           H'000 0000         CS2 space (64MB)         -           H'000 0000         CS1 space (64MB)         -           H'000 0000         CS1 space (64MB)         -                                                                                                                                                                                                                                                                                                                                             |       |           | CS5 space (64MB)   |          | -                   |
| Normal space         H'4C00 0000         CS3 space (64MB)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       | H'5000 00 | CS4 space (64MB)   |          | _                   |
| Normal<br>space         H'4800 0000<br>H'4400 0000         CS1 space (64MB)         -           Normal<br>space         H'4800 0000         CS0 space (64MB)         -           Normal<br>space         H'12000 0000         CS0 space (64MB)         -           Normal<br>space         H'12000 0000         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)           H'1000 0000         SPI multi-I/O-bus<br>space 2 (64MB)         -           H'1800 0000         SPI multi-I/O-bus<br>space 1 (64MB)         -           H'1400 0000         CS5 space (64MB)         -           H'1000 0000         CS1 space (64MB)         -           H'0000 0000         CS2 space (64MB)         -           H'0000 0000         CS1 space (64MB)         -           H'0400 0000         CS1 space (64MB)         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | space | H'4C00 00 | CS3 space (64MB)   |          | CS3 mirror space    |
| Normal<br>space         H'4400 0000         CS0 space (64MB)         -           H'4000 0000         CS0 space (64MB)         -           H'2030 0000         H'2030 0000         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)           H'12000 0000         H'1000 0000         SPI multi-I/O-bus<br>space 2 (64MB)         -           H'1400 0000         H'1000 0000         SPI multi-I/O-bus<br>space 1 (64MB)         Serial flash memory<br>(64MB)           H'1400 0000         H'1400 0000         CS5 space (64MB)         -           H'1000 0000         CS3 space (64MB)         -           H'1000 0000         CS2 space (64MB)         -           H'0800 0000         CS1 space (64MB)         -           H'0400 0000         CS1 space (64MB)         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       | H'4800 00 | CS2 space (64MB)   |          | _                   |
| H'4000 0000         Others<br>(509MB)         Others<br>(509MB)           H'2030 0000         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)           H'2000 0000         H'2000 0000         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)           Normal<br>space         H'1000 0000         SPI multi-I/O-bus<br>space 2 (64MB)         -           H'1800 0000         CS5 space (64MB)         -           H'1000 0000         CS4 space (64MB)         -           H'1000 0000         CS2 space (64MB)         -           H'000 0000         CS1 space (64MB)         -           H'0400 0000         CS1 space (64MB)         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       | H'4400 00 | CS1 space (64MB)   |          | _                   |
| H'2030 0000         (509MB)         (509MB)           H'2030 0000         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)           H'2000 0000         SPI multi-I/O-bus         -           H'1000 0000         SPI multi-I/O-bus         -           H'1800 0000         SPI multi-I/O-bus         Serial flash memory<br>(64MB)           H'1800 0000         Space 1 (64MB)         -           H'1400 0000         CS5 space (64MB)         -           H'1000 0000         CS3 space (64MB)         -           H'0000 0000         CS2 space (64MB)         -           H'0000 0000         CS1 space (64MB)         -           H'0400 0000         CS1 space (64MB)         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       | H'4000 00 | CS0 space (64MB)   |          | _                   |
| H'2030 0000         (509MB)         (509MB)           H'2030 0000         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)           H'2000 0000         SPI multi-I/O-bus         -           H'1000 0000         SPI multi-I/O-bus         -           H'1800 0000         SPI multi-I/O-bus         Serial flash memory<br>(64MB)           H'1800 0000         SPI space 1 (64MB)         -           H'1400 0000         CS5 space (64MB)         -           H'1000 0000         CS3 space (64MB)         -           H'0000 0000         CS2 space (64MB)         -           H'0400 0000         CS1 space (64MB)         -           CS0 space (64MB)         -         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       | $\int$    | Others             |          | Others              |
| H'2030 0000         Large-capacity on-<br>chip RAM (3MB)         Large-capacity on-<br>chip RAM (3MB)           H'2000 0000         SPI multi-I/O-bus<br>space 2 (64MB)         -           H'1000 0000         SPI multi-I/O-bus<br>space 1 (64MB)         -           H'1400 0000         CS5 space (64MB)         -           H'1000 0000         CS4 space (64MB)         -           H'1000 0000         CS3 space (64MB)         -           H'000 0000         CS2 space (64MB)         -           H'000 0000         CS2 space (64MB)         -           H'000 0000         CS2 space (64MB)         -           H'0400 0000         CS1 space (64MB)         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |           |                    |          |                     |
| H2000 0000         chip RAM (3MB)         chip RAM (3MB)           H2000 0000         chip RAM (3MB)         chip RAM (3MB)           H2000 0000         SPI multi-I/O-bus         -           SPI multi-I/O-bus         Serial flash memory           Space 1 (64MB)         -           H1400 0000         CS5 space (64MB)         -           H1400 0000         CS4 space (64MB)         -           H1000 0000         CS3 space (64MB)         -           H1000 0000         CS2 space (64MB)         -           H1000 0000         CS1 space (64MB)         -           H10400 0000         CS1 space (64MB)         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       | H'2030 00 |                    |          |                     |
| Normal<br>space         H'1C00 0000<br>H'1800 0000         space 2 (64MB)         -           Normal<br>space         H'1C00 0000         SPI multi-I/O-bus<br>space 1 (64MB)         Serial flash memory<br>(64MB)           H'1400 0000         CS5 space (64MB)         -           H'1000 0000         CS4 space (64MB)         -           H'1000 0000         CS3 space (64MB)         -           H'0000 0000         CS2 space (64MB)         SDRAM (64MB)           H'0800 0000         CS1 space (64MB)         -           H'0400 0000         CS1 space (64MB)         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       | H'2000 00 |                    |          |                     |
| Normal<br>space         H'1800 0000<br>H'1400 0000         SPI multi-I/O-bus<br>space 1 (64MB)         Serial flash memory<br>(64MB)           H'1400 0000         CS5 space (64MB)         -           H'1000 0000         CS4 space (64MB)         -           H'0000 0000         CS3 space (64MB)         -           H'0000 0000         CS2 space (64MB)         -           H'0000 0000         CS2 space (64MB)         -           H'0400 0000         CS1 space (64MB)         -           CS0 space (64MB)         -         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |           |                    |          | _                   |
| Normal<br>space         H'1800 0000<br>H'1400 0000         space 1 (64MB)         (64MB)           H'1400 0000         CS5 space (64MB)         -           H'1000 0000         CS4 space (64MB)         -           H'000 0000         CS3 space (64MB)         -           H'000 0000         CS2 space (64MB)         -           H'000 0000         CS1 space (64MB)         -           CS1 space (64MB)         -         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       | H'1C00 00 |                    | +        | Serial flash memory |
| space       H'1400 0000       CS0 space (04MB)       -         H'1000 0000       CS4 space (64MB)       -         H'0C00 0000       CS3 space (64MB)       SDRAM (64MB)         H'0800 0000       CS2 space (64MB)       -         H'0400 0000       CS1 space (64MB)       -         CS0 space (64MB)       -       -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       | H'1800 00 |                    |          | -                   |
| H'1000 0000       CS4 space (64MB)       -         H'0C00 0000       CS3 space (64MB)       SDRAM (64MB)         H'0800 0000       CS2 space (64MB)       -         H'0400 0000       CS1 space (64MB)       -         CS0 space (64MB)       -       -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       | H'1400 00 | CS5 space (64MB)   |          | _                   |
| H'0C00 0000<br>H'0800 0000<br>H'0400 0000<br>CS2 space (64MB) -<br>CS1 space (64MB) -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 57400 | H'1000 00 | CS4 space (64MB)   | <br>     | _                   |
| H'0800 0000         CS2 space (64MB)         -           H'0400 0000         CS1 space (64MB)         -           CS0 space (64MB)         -         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       | H'0C00 00 | CS3 space (64MB)   |          | SDRAM (64MB)        |
| H'0400 0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       | H'0800 00 | CS2 space (64MB)   |          | _                   |
| H'0000 0000 CS0 space (64MB) –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       | H'0400 00 | CS1 space (64MB)   |          | -                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       | H'0000 00 | CS0 space (64MB)   |          | _                   |

Figure 5.3 RZ/A1LU Group Address Space and JASMINE board Memory Mapping

### 5.2.3 Section Assignment in Sample Code

Table 5.6 shows the Sections to be Used by SPIBSC Initial setting program. Table 5.7 and Table 5.8 show the Sections to be Used by application program.

| Area Name         | Description                                                                                                                                   | Туре    | Loading<br>Area | Execution<br>Area |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------------|-------------------|
| VECTOR_TABLE      | Exception processing vector table                                                                                                             | Code    | S-FLASH         | S-FLASH           |
| CODE_SPIBSC_INIT1 | Code area for SPIBSC initial setting<br>program 1                                                                                             | Code    | S-FLASH         | LRAM              |
| CODE_IO_REGRW     | Program code area for read/write<br>functions of I/O register                                                                                 | Code    | S-FLASH         | LRAM              |
| CODE_SPIBSC_INIT2 | Code area for SPIBSC initial setting<br>program 2                                                                                             | Code    | S-FLASH         | LRAM              |
| DATA_SPIBSC_INIT2 | DATA area for SPIBSC initial setting<br>program 2                                                                                             | RW Data | S-FLASH         | LRAM              |
| BSS_SPIBSC_INIT2  | BSS area for SPIBSC initial setting<br>program 2                                                                                              | ZI Data | -               | LRAM              |
| RESET_HANDLER     | Program code area of reset handler processing                                                                                                 | Code    | S-FLASH         | S-FLASH           |
| CODE              | Program code area for defaults<br>All the Code type sections which do not<br>define section names with C source are<br>assigned in this area. | Code    | S-FLASH         | S-FLASH           |
| SVC_STACK         | Stack area                                                                                                                                    | ZI Data | -               | LRAM              |

Note: "S-FLASH" and "LRAM" shown in Loading Area and Execution Area indicate the serial flash memory area and the large-capacity on-chip RAM area respectively.



| Area Name        | Description                                                                                                                                                                                                                              | Туре                   | Loading<br>Area | Execution<br>Area |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----------------|-------------------|
| VECTOR_TABLE     | Exception processing vector table                                                                                                                                                                                                        | Code                   | S-FLASH         | S-FLASH           |
| RESET_HANDLER    | <ul> <li>Program code area of reset handler processing</li> <li>This area consists of the following sections.</li> <li>INITCA9CACHE (L1 cache setting)</li> <li>INIT_TTB (MMU setting)</li> <li>RESET_HANDLER (Reset handler)</li> </ul> | Code                   | S-FLASH         | S-FLASH           |
| CODE_BASIC_SETUP | Program code area to optimize operating frequency and flash memory                                                                                                                                                                       | Code                   | S-FLASH         | S-FLASH           |
| InRoot           | This area consists of the sections located<br>in the root area such as C standard<br>library.                                                                                                                                            | Code<br>and<br>RO Data | S-FLASH         | S-FLASH           |
| CODE_FPU_INIT    | <ul> <li>Program code area for NEON and VFP initializations</li> <li>This area consists of the following sections.</li> <li>CODE_FPU_INIT</li> <li>FPU_INIT</li> </ul>                                                                   | Code                   | S-FLASH         | S-FLASH           |
| CODE_RESET       | <ul> <li>Program code area for hardware<br/>initialization</li> <li>This area consists of the following<br/>sections.</li> <li>CODE_RESET (Startup processing)</li> <li>INIT_VBAR (Vector base setting)</li> </ul>                       | Code                   | S-FLASH         | S-FLASH           |
| CODE             | Program code area for defaults<br>All the Code type sections which do not<br>define section names with C source are<br>assigned in this area.                                                                                            | Code                   | S-FLASH         | S-FLASH           |
| CONST            | Constant data area for defaults<br>All the RO Data type sections which do<br>not define section names with C source<br>are assigned in this area.                                                                                        | RO Data                | S-FLASH         | S-FLASH           |

 Table 5.7 Sections to be Used by application program (1/2)



| Area Name                | Description                                                                                                                                                                  | Туре    | Loading<br>Area | Execution<br>Area |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------------|-------------------|
| VECTOR_MIRROR_<br>TABLE  | Exception processing vector table<br>(Section to transfer data to large-capacity<br>on-chip RAM)                                                                             | Code    | S-FLASH         | LRAM              |
| CODE_HANDLER_<br>JMPTBL  | Program code area for user-defined<br>functions of IRQ interrupt handler                                                                                                     | Code    | S-FLASH         | LRAM              |
| CODE_HANDLER             | <ul> <li>Program code area of IRQ interrupt<br/>handler</li> <li>This area consists of the following<br/>sections.</li> <li>CODE_HANDLER</li> <li>IRQ_FIQ_HANDLER</li> </ul> | Code    | S-FLASH         | LRAM              |
| CODE_IO_REGRW            | Program code area for read/write<br>functions of I/O register                                                                                                                | Code    | S-FLASH         | LRAM              |
| CODE_CACHE_<br>OPERATION | Program code area for setting the L1 and L2 caches (see Note3)                                                                                                               | Code    | S-FLASH         | LRAM              |
| DATA_HANDLER_<br>JMPTBL  | Registration table data area for user-<br>defined functions of IRQ interrupt handler                                                                                         | RW Data | S-FLASH         | LRAM              |
| ARM_LIB_STACK            | Application stack area                                                                                                                                                       | ZI Data | -               | LRAM              |
| IRQ_STACK                | IRQ mode stack area                                                                                                                                                          | ZI Data | -               | LRAM              |
| FIQ_STACK                | FIQ mode stack area                                                                                                                                                          | ZI Data | -               | LRAM              |
| SVC_STACK                | Supervisor (SVC) mode stack area                                                                                                                                             | ZI Data | -               | LRAM              |
| ABT_STACK                | Abort (ABT) mode stack area                                                                                                                                                  | ZI Data | -               | LRAM              |
| TTB                      | MMU translation table area                                                                                                                                                   | ZI Data | -               | LRAM              |
| ARM_LIB_HEAP             | Application heap area                                                                                                                                                        | ZI Data | -               | LRAM              |
| DATA                     | Data area with initial value for defaults<br>All the RW Data type sections which do<br>not define section names with C source<br>are assigned in this area.                  | RW Data | S-FLASH         | LRAM              |
| BSS                      | Data area without initial value for defaults<br>All the ZI Data type sections which do not<br>define section names with C source area<br>assigned in this area.              | ZI Data | -               | LRAM              |

| Table 5.8 | 3 Sections to be Used by application program (2/2 | 2) |
|-----------|---------------------------------------------------|----|
|-----------|---------------------------------------------------|----|

Notes: 1. "S-FLASH" and "LRAM" shown in Loading Area and Execution Area indicate the serial flash memory area and the large-capacity on-chip RAM area respectively.

2. Basically the section name is set to be the same as the region's, however it consists of some sections in the areas of RESET\_HANDLER, InRoot, CODE\_FPU\_INIT, CODE\_RESET, CODE, CONST, CODE\_HANDLER, DATA, and BSS. Refer to the ARM compiler toolchain manual about the region and the section.

3. This section should be placed in the cache-disabled area.

### 5.3 Interrupt Used

Table 5.9 lists the Interrupt Used in Sample Code (Application Program).

#### Table 5.9 Interrupt Used in Sample Code (Application Program)

| Interrupt Source (Interrupt ID) | Priority | Processing Outline                        |
|---------------------------------|----------|-------------------------------------------|
| OSTM0 (134)                     | 5        | Generates interrupts at 500 ms intervals. |



# 5.4 Constants Used by the SPIBSC Initial Setting Program

Table 5.10, Table 5.11 and Table 5.12 list the constants used by SPIBSC initial setting program in the sample code.

| Constant                 | Setting Value | Description                                                                                                                 |
|--------------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------|
| DEF_USER_PROGRAM_TOP     | 0x18010000    | Start address of the application program                                                                                    |
| SPIBSC_1BIT              | 0             | Sets the bit width used when issuing read commands                                                                          |
|                          |               | to 1 bit.                                                                                                                   |
| SPIBSC_4BIT              | 2             | Sets the bit width used when issuing read commands to 4 bits.                                                               |
| SPIBSC_CMNCR_BSZ_SINGLE  | 0             | Sets the number of serial flash devices connected to SPIBSC to 1.                                                           |
| SPIBSC_CMNCR_BSZ_DUAL    | 1             | Sets the number of serial flash devices connected to SPIBSC to 2.                                                           |
| SPIBSC_OUTPUT_ADDR_24    | 0x07          | Specifies 24-bit address output.                                                                                            |
| SPIBSC_OUTPUT_ADDR_32    | 0x0f          | Specifies 32-bit address output.                                                                                            |
| SPIBSC_OUTPUT_DISABLE    | 0             | Specifies that no command, optional command, address, option data are output.                                               |
| SPIBSC_OUTPUT_ENABLE     | 1             | Specifies that a command, optional command, address, option data are output.                                                |
| SPIBSC_OUTPUT_OPD_3      | 0x08          | Specifies that option data OPD3 is output when a read command is issued.                                                    |
| SPIBSC_OUTPUT_OPD_32     | 0x0c          | Specifies that option data OPD3 and OPD2 are output when a read command is issued.                                          |
| SPIBSC_OUTPUT_OPD_321    | 0x0e          | Specifies that option data OPD3, OPD2, and OPD1 are output when a read command is issued.                                   |
| SPIBSC_OUTPUT_OPD_3210   | 0x0f          | Specifies that option data OPD3, OPD2, OPD1, and OPD0 are output when a read command is issued.                             |
| SPIBSC_OUTPUT_SPID_8     | 0x08          | Enables 8- (or 16-) bit transfer of data in SPI operation mode.                                                             |
| SPIBSC_OUTPUT_SPID_16    | 0x0c          | Enables 16- (or 32-) bit transfer of data in SPI operation mode.                                                            |
| SPIBSC_OUTPUT_SPID_32    | 0x0f          | Enables 32- (or 64-) bit transfer of data in SPI operation mode.                                                            |
| SPIBSC_SPISSL_NEGATE     | 0             | Sets the SPBSSL signal state at transfer end to negate in SPI operation mode.                                               |
| SPIBSC_SPISSL_KEEP       | 1             | Specifies that the SPBSSL signal level is maintained<br>from transfer end to start of next access in SPI<br>operation mode. |
| SPIBSC_SPIDATA_DISABLE   | 0             | Disables data read/write operations in SPI operation mode.                                                                  |
| SPIBSC_SPIDATA_ENABLE    | 1             | Enables data read/write operations in SPI operation mode.                                                                   |
|                          | 0             | Specifies that no dummy avalage are incerted                                                                                |
| SPIBSC_DUMMY_CYC_DISABLE | 0             | Specifies that no dummy cycles are inserted.                                                                                |

Table 5.10 Constants Used in Sample Code (1/3)

| Constant              | Setting Value | Description                                                                                                        |
|-----------------------|---------------|--------------------------------------------------------------------------------------------------------------------|
| SPIBSC_SDR_TRANS      | 0             | Transfers the read from the serial flash memory in SDR mode.                                                       |
| SPIBSC_DDR_TRANS      | 1             | Transfers the read from the serial flash memory in DDR mode.                                                       |
| SF_REQ_SERIALMODE     | 2             | Specifies "single mode" for the serial flash memory registers.                                                     |
| SF_REQ_QUADMODE       | 3             | Specifies "quad mode" for the serial flash memory registers.                                                       |
| SPIBSC_CKDLY_DEFAULT  | 0x0000A504    | Defines the value to be loaded into the CKDLY register.<br>Sets "B'0100" (initial value) to the CKDLY[3:0] bit.    |
| SPIBSC_CKDLY_TUNING   | 0x0000A50A    | Defines the value to be loaded into the CKDLY register.<br>Sets "B'1010" to the CKDLY[3:0] bit.                    |
| SPIBSC_SPODLY_DEFAULT | 0xA5000000    | Defines the value to be loaded into the SPODLY register.<br>Sets "H'0000" (initial value) to the SPODLY[15:0] bit. |
| SPIBSC_SPODLY_TUNING  | 0xA5001111    | Defines the value to be loaded into the SPODLY register.<br>Sets "H'1111" to the SPODLY[15:0] bit.                 |
| SFLASH_MODECYC        |               | Specifies the period of the MX25L51245G<br>Performance Enhance Indicator.                                          |
|                       | 2             | When SPIBSC_TRANS_MODE is set to<br>SPIBSC_SDR_TRANS                                                               |
|                       | 1             | When SPIBSC_TRANS_MODE is set to<br>SPIBSC_DDR_TRANS                                                               |

# Table 5.11 Constants Used in Sample Code (2/3)



| Constant               | Setting Value | Description                                     |
|------------------------|---------------|-------------------------------------------------|
| SFLASHCMD_READ_STATUS  | 0x05          | MX25L51245G Status Register Read command        |
| SFLASHCMD_READ_CONFIG  | 0x15          | MX25L51245G Configuration Register Read command |
| SFLASHCMD_WRITE_STATUS | 0x01          | MX25L51245G Write Status command                |
| SFLASHCMD_WRITE_ENABLE | 0x06          | MX25L51245G Write Enable command                |
| STREG_SRWD_BIT         | 0x80          | MX25L51245G Status Register, SRWD bit           |
| STREG_QE_BIT           | 0x40          | MX25L51245G Status Register, QE bit             |
| STREG_BPROTECT_BIT     | 0x3C          | MX25L51245G Status Register, BP bit             |
| STREG_WEL_BIT          | 0x02          | MX25L51245G Status Register, WEL bit            |
| STREG_WIP_BIT          | 0x01          | MX25L51245G Status Register, WIP bit            |
| CFREG_DC_BIT           | 0xC0          | MX25L51245G Configuration Register, DC bit      |
| CFREG_4BYTE_BIT        | 0x20          | MX25L51245G Configuration Register, 4BYTE bit   |
| CFREG_PBE_BIT          | 0x10          | MX25L51245G Configuration Register, PBE bit     |
| CFREG_TB_BIT           | 0x08          | MX25L51245G Configuration Register, TB bit      |
| CFREG_ODS_BIT          | 0x07          | MX25L51245G Configuration Register, ODS bit     |

### Table 5.12 Constants Used in Sample Code (3/3)



# 5.5 List of Structures/Unions Used by the SPIBSC Initial Setting Program

Table 5.13 to Table 5.21 list the structures used by SPIBSC initial setting program in the sample code.

# Table 5.13 Structure for Configuring the SPIBSC External Address Space Read Mode (st\_spibsc\_cfg\_t) (1/4)

| Member                                                                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| uint8_t udef_cmd                                                                 | <ul> <li>Read command</li> <li>Specifies the read command output to the serial flash memory when converting read operations targeting the SPI multi-I/O bus space to SPI communication.</li> <li>The setting value of this member is set in the CMD[7:0] bit field in the data read command setting register (DRCMR).</li> </ul>                                                                                                                                                                                                              |
| uint8_t udef_cmd_width                                                           | <ul> <li>Read command bit width</li> <li>Specifies the bit width used when issuing read commands.</li> <li>Settable values:<br/>SPIBSC_1BIT: 1-bit width<br/>SPIBSC_4BIT: 4-bit width</li> <li>The setting value of this member is set in the CDB[1:0] bit field in the data read enable setting register (DRENR).</li> </ul>                                                                                                                                                                                                                 |
| uint8_t udef_opd3<br>uint8_t udef_opd2<br>uint8_t udef_opd1<br>uint8_t udef_opd0 | <ul> <li>Option data</li> <li>Specifies the option data output to the serial flash memory when converting read operations targeting the SPI multi-I/O bus space to SPI communication.</li> <li>The setting values of these members are set in the OPD3[7:0], OPD2[7:0], OPD1[7:0], and OPD0[7:0] bit fields in the data read option setting register (DROPR).</li> </ul>                                                                                                                                                                      |
| uint8_t udef_opd_enable                                                          | <ul> <li>Option data enable</li> <li>Specifies whether or not option data is issued.</li> <li>Settable values:<br/>SPIBSC_OUTPUT_DISABLE: No option data output.<br/>SPIBSC_OUTPUT_OPD_3: OPD3 is output.<br/>SPIBSC_OUTPUT_OPD_32: OPD3 and OPD2 are output.<br/>SPIBSC_OUTPUT_OPD_321: OPD3, OPD2, and OPD1 are output.<br/>SPIBSC_OUTPUT_OPD_3210: OPD3, OPD2, OPD1, and OPD0 are<br/>output.</li> <li>The setting value of this member is set in the OPDE[3:0] bit field in<br/>the data read enable setting register (DRENR).</li> </ul> |
| uint8_t udef_opd_width                                                           | <ul> <li>Option data bit width</li> <li>Specifies the bit width used when issuing option data.</li> <li>Settable values:<br/>SPIBSC_1BIT: 1-bit width<br/>SPIBSC_4BIT: 4-bit width</li> <li>The setting value of this member is set in the OPDB[1:0] bit field in<br/>the data read enable setting register (DRENR).</li> </ul>                                                                                                                                                                                                               |

| Member                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| uint8_t udef_dmycyc_num    | <ul> <li>Number of dummy cycles</li> <li>Specifies the number of dummy cycles output to the serial flash memory when converting read operations targeting the SPI multi-I/O bus space to SPI communication.</li> <li>Settable values:<br/>To be loaded with the results of calculating the value to be set in the DMCYC[2:0] bit field of the data read dummy cycle setting register (DRDMCR) based on the value defined in SPIBSC_DMYCYC_SETTING. Values that will resultantly yield number of 0 to 7 are allowed. For details on the calculation, see "Table 6.2 List of Macros for Customizing the Sample Code (1/2)".</li> </ul> |  |
| uint8_t udef_dmycyc_enable | <ul> <li>Dummy cycle enable</li> <li>Specifies whether or not dummy cycles are inserted.</li> <li>Settable values:<br/>SPIBSC_DUMMY_CYC_DISABLE: Insertion of dummy cycles<br/>disabled.</li> <li>SPIBSC_DUMMY_CYC_ENABLE: Insertion of dummy cycles<br/>enabled.</li> <li>The setting value of this member is set in the DME bit field in the<br/>data read enable setting register (DRENR).</li> </ul>                                                                                                                                                                                                                             |  |
| uint8_t udef_dmycyc_width  | <ul> <li>Dummy cycle bit width</li> <li>Specifies the bit width used when issuing dummy cycles.</li> <li>Settable values:<br/>SPIBSC_1BIT: 1-bit width<br/>SPIBSC_4BIT: 4-bit width</li> <li>The setting value of this member is set in the DMDB[1:0] bit field in<br/>the data read dummy cycle setting register (DRDMCR).</li> </ul>                                                                                                                                                                                                                                                                                               |  |
| uint8_t udef_data_width    | <ul> <li>Data read bit width</li> <li>The serial flash memory data read bit width used when converting read operations targeting the SPI multi-I/O bus space to SPI communication.</li> <li>Settable values:<br/>SPIBSC_1BIT: 1-bit width<br/>SPIBSC_4BIT: 4-bit width</li> <li>The setting value of this member is set in the DRDB[1:0] bit field in the data read enable setting register (DRENR).</li> </ul>                                                                                                                                                                                                                      |  |

# Table 5.14 Structure for Configuring the SPIBSC External Address Space Read Mode (st\_spibsc\_cfg\_t) (2/4)



| Member                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| uint8_t udef_spbr       | <ul> <li>Bit rate</li> <li>Specifies the bit rate of the serial clock (SPBCLK) output to the serial flash memory when converting read operations targeting the SPI multi-I/O bus space to SPI communication.</li> <li>Settable value:<br/>Used in conjunction with the bit rate division ratio setting (udef_brdv).</li> <li>The setting value of this member is set in the SPBR[7:0] bit field in the bit rate setting register (SPBCR).</li> </ul>           |  |  |
| uint8_t udef_brdv       | <ul> <li>Bit rate division ratio setting</li> <li>Specifies the bit rate of the serial clock (SPBCLK) output to the serial flash memory when converting read operations targeting the SPI multi-I/O bus space to SPI communication.</li> <li>Settable value:<br/>Used in conjunction with the bit rate (udef_spbr).</li> </ul>                                                                                                                                 |  |  |
| uint8_t udef_addr_width | <ul> <li>The setting value of this member is set in the BRDV[1:0] bit field in<br/>the bit rate setting register (SPBCR).</li> <li>Address bit width</li> </ul>                                                                                                                                                                                                                                                                                                |  |  |
|                         | <ul> <li>Specifies the bit width used to output addresses to the serial flash memory when converting read operations targeting the SPI multi-I/O bus space to SPI communication.</li> <li>Settable values:<br/>SPIBSC_1BIT: 1-bit width<br/>SPIBSC_4BIT: 4-bit width</li> </ul>                                                                                                                                                                                |  |  |
|                         | • The setting value of this member is set in the ADB[1:0] bit field in the data read enable setting register (DRENR).                                                                                                                                                                                                                                                                                                                                          |  |  |
| uint8_t udef_addr_mode  | <ul> <li>Address enable</li> <li>Specifies the format of address output to the serial flash memory when converting read operations targeting the SPI multi-I/O bus space to SPI communication.</li> <li>Settable values:<br/>SPIBSC_OUTPUT_ADDR_24: 24-bit address output SPIBSC_OUTPUT_ADDR_32: 32-bit address output</li> <li>The setting value of this member is set in the ADE[3:0] bit field in the data read enable setting register (DRENR).</li> </ul> |  |  |

# Table 5.15 SPIBSC External Address Read Mode Settings Structure (st\_spibsc\_cfg\_t) (3/4)



| Member                | Description                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| uint8_t udef_drdrenr_ | <ul> <li>Address DDR enable</li> <li>Selects the SDR/DDR transfer mode for addresses to be output in external address space read mode.</li> <li>Settable values:<br/>SPIBSC_SDR_TRANS: SDR transfer<br/>SPIBSC_DDR_TRANS: DDR transfer</li> <li>The setting value of this member is set in the ADDRE bit of the data read DDR enable register (DRDRENR).</li> </ul> |
| uint8_t udef_drdrenr_ | • • •                                                                                                                                                                                                                                                                                                                                                               |
| uint8_t udef_drdrenr_ |                                                                                                                                                                                                                                                                                                                                                                     |

# Table 5.16 Structure for Configuring the SPIBSC External Address Space Read Mode (st\_spibsc\_cfg\_t) (4/4)



| Member         | Description                                                                                                                                  |  |  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| uint32_t cdb   | Command bit width                                                                                                                            |  |  |
|                | Specifies the command bit width in SPI operation mode.                                                                                       |  |  |
|                | Settable values:                                                                                                                             |  |  |
|                | SPIBSC_1BIT: 1-bit width                                                                                                                     |  |  |
|                | SPIBSC_4BIT: 4-bit width                                                                                                                     |  |  |
|                | • The setting value of this member is set in the CDB[1:0] bit field in the SPI mode enable setting register (SMENR).                         |  |  |
| uint32_t ocdb  | Optional command bit width                                                                                                                   |  |  |
|                | Specifies the optional command bit width in SPI operation mode.                                                                              |  |  |
|                | <ul> <li>Settable values:<br/>SPIBSC_1BIT: 1-bit width</li> </ul>                                                                            |  |  |
|                | SPIBSC_4BIT: 4-bit width                                                                                                                     |  |  |
|                | <ul> <li>The setting value of this member is set in the OCDB[1:0] bit field in</li> </ul>                                                    |  |  |
|                | the SPI mode enable setting register (SMENR).                                                                                                |  |  |
| uint32_t adb   | Address bit width                                                                                                                            |  |  |
|                | Specifies the address bit width in SPI operation mode.                                                                                       |  |  |
|                | Settable values:     SDIPSC 4 DIT: 4 bit width                                                                                               |  |  |
|                | SPIBSC_1BIT: 1-bit width<br>SPIBSC_4BIT: 4-bit width                                                                                         |  |  |
|                | <ul> <li>The setting value of this member is set in the ADB[1:0] bit field in the</li> </ul>                                                 |  |  |
|                | SPI mode enable setting register (SMENR).                                                                                                    |  |  |
| uint32_t opdb  | Option data bit width                                                                                                                        |  |  |
|                | • Specifies the option data bit width in SPI operation mode.                                                                                 |  |  |
|                | <ul> <li>Settable values:<br/>SPIBSC_1BIT: 1-bit width</li> </ul>                                                                            |  |  |
|                | SPIBSC_4BIT: 4-bit width                                                                                                                     |  |  |
|                | <ul> <li>The setting value of this member is set in the OPDB[1:0] bit field in</li> </ul>                                                    |  |  |
|                | the SPI mode enable setting register (SMENR).                                                                                                |  |  |
| uint32_t spidb | Transfer data bit width                                                                                                                      |  |  |
|                | Specifies the transfer data bit width in SPI operation mode.                                                                                 |  |  |
|                | Settable values:                                                                                                                             |  |  |
|                | SPIBSC_1BIT: 1-bit width                                                                                                                     |  |  |
|                | SPIBSC_4BIT: 4-bit width<br>The patting value of this member is get in the SPIDPI1(0) bit field in                                           |  |  |
|                | <ul> <li>The setting value of this member is set in the SPIDB[1:0] bit field in<br/>the SPI mode enable setting register (SMENR).</li> </ul> |  |  |
| uint32_t cde   | Command enable                                                                                                                               |  |  |
|                | <ul> <li>Specifies whether or not commands are output in SPI operation</li> </ul>                                                            |  |  |
|                | mode.                                                                                                                                        |  |  |
|                | Settable values:                                                                                                                             |  |  |
|                | SPIBSC_OUTPUT_DISABLE: Output disabled.                                                                                                      |  |  |
|                | SPIBSC_OUTPUT_ENABLE: Output enabled.                                                                                                        |  |  |
|                | • The setting value of this member is set in the CDE bit field in the SPI                                                                    |  |  |
|                | mode enable setting register (SMENR).                                                                                                        |  |  |

# Table 5.17 SPIBSC SPI Operating Mode Settings Structure (st\_spibsc\_spimd\_reg\_t) (1/5)

| Member         | Description                                                                                                                                                                       |  |  |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| uint32_t ocde  | Optional command enable                                                                                                                                                           |  |  |
|                | • Specifies whether or not the optional command is output in SPI operation mode.                                                                                                  |  |  |
|                | Settable values:<br>SPIBSC_OUTPUT_DISABLE: Output disabled.                                                                                                                       |  |  |
|                | <ul> <li>SPIBSC_OUTPUT_ENABLE: Output enabled.</li> <li>The setting value of this member is set in the OCDE bit field in the SPI mode enable setting register (SMENR).</li> </ul> |  |  |
| uint32_t ade   | Address enable                                                                                                                                                                    |  |  |
|                | <ul> <li>Specifies whether or not the address is output in SPI operation<br/>mode.</li> </ul>                                                                                     |  |  |
|                | <ul> <li>Settable values:<br/>SPIBSC_OUTPUT_DISABLE: Output disabled.</li> </ul>                                                                                                  |  |  |
|                | SPIBSC_OUTPUT_ADDR_24: ADR[23:0] is output<br>SPIBSC_OUTPUT_ADDR_32: ADR[31:0] is output                                                                                          |  |  |
|                | • The setting value of this member is set in the ADE[3:0] bit field in the SPI mode enable setting register (SMENR).                                                              |  |  |
| uint32_t opde  | Option data enable                                                                                                                                                                |  |  |
|                | <ul> <li>Specifies whether or not the option data is output in SPI operation<br/>mode.</li> </ul>                                                                                 |  |  |
|                | Settable values:     SPIRSC OUTPUT DISARIE: Output disabled                                                                                                                       |  |  |
|                | SPIBSC_OUTPUT_DISABLE: Output disabled.<br>SPIBSC_OUTPUT_OPD_3: OPD3 is output                                                                                                    |  |  |
|                | SPIBSC_OUTPUT_OPD_32: OPD3 and OPD2 are output                                                                                                                                    |  |  |
|                | SPIBSC_OUTPUT_OPD_321: OPD3, OPD2, and OPD1 are output                                                                                                                            |  |  |
|                | SPIBSC_OUTPUT_OPD_3210: OPD3, OPD2, OPD1, and OPD0 are output                                                                                                                     |  |  |
|                | • The setting value of this member is set in the OPDE[3:0] bit field in the SPI mode enable setting register (SMENR).                                                             |  |  |
| uint32_t spide | Transfer data enable                                                                                                                                                              |  |  |
|                | • Specifies whether or not data transfers occur in SPI operation mode.                                                                                                            |  |  |
|                | <ul> <li>Settable values:<br/>SPIBSC_OUTPUT_DISABLE: Transfers disabled.</li> </ul>                                                                                               |  |  |
|                | SPIBSC_OUTPUT_SPID_8: 8- (or 16-) bit transfers enabled.                                                                                                                          |  |  |
|                | SPIBSC_OUTPUT_SPID_16: 16- (or 32-) bit transfers enabled.                                                                                                                        |  |  |
|                | SPIBSC_OUTPUT_SPID_32: 32- (or 64-) bit transfers enabled.                                                                                                                        |  |  |
|                | • The setting value of this member is set in the SPIDE[3:0] bit field in the SPI mode enable setting register (SMENR).                                                            |  |  |
| uint32_t sslkp | SPBSSL signal level hold                                                                                                                                                          |  |  |
|                | <ul> <li>Specifies the SPBSSL signal state at transfer end in SPI operation<br/>mode.</li> </ul>                                                                                  |  |  |
|                | Settable values:     DIPCO DECATE: Nameta at transformeral                                                                                                                        |  |  |
|                | SPIBSC_SPISSL_NEGATE: Negate at transfer end.<br>SPIBSC_SPISSL_KEEP: Maintain SPBSSL signal level from                                                                            |  |  |
|                | transfer end to start of next access.                                                                                                                                             |  |  |
|                | • The setting value of this member is set in the SSLKP bit in the SPI mode control register (SMCR).                                                                               |  |  |

## Table 5.18 SPIBSC SPI Operating Mode Settings Structure (st\_spibsc\_spimd\_reg\_t) (2/5)

| Member          | Description                                                                                                                                                                                                                                                                                                                                             |  |  |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| uint32_t spire  | Data read enable                                                                                                                                                                                                                                                                                                                                        |  |  |
|                 | <ul> <li>Specifies whether or not data reads occur in SPI operation mode.</li> <li>Settable values:<br/>SPIBSC_SPIDATA_DISABLE: Data reads disabled.<br/>SPIBSC_SPIDATA_ENABLE: Data reads enabled.</li> <li>The setting value of this member is set in the SPIRE bit in the SPI</li> </ul>                                                             |  |  |
|                 | mode control register (SMCR).                                                                                                                                                                                                                                                                                                                           |  |  |
| uint32_t spiwe  | <ul> <li>Data write enable</li> <li>Specifies whether or not data writes occur in SPI operation mode.</li> <li>Settable values:<br/>SPIBSC_SPIDATA_DISABLE: Data writes disabled.<br/>SPIBSC_SPIDATA_ENABLE: Data writes enabled.</li> <li>The setting value of this member is set in the SPIWE bit in the SPI mode control register (SMCR).</li> </ul> |  |  |
| uint32_t dme    | <ul> <li>Dummy cycle enable</li> <li>Specifies whether or not dummy cycles are inserted in SPI operation mode.</li> <li>Settable values:<br/>SPIBSC_DUMMY_CYC_DISABLE: Insertion disabled.<br/>SPIBSC_DUMMY_CYC_ENABLE: Insertion enabled.</li> </ul>                                                                                                   |  |  |
| uint32_t adder  | <ul> <li>The setting value of this member is set in the DME bit field in the SPI<br/>mode enable setting register (SMENR).</li> <li>Address DDR enable</li> </ul>                                                                                                                                                                                       |  |  |
|                 | <ul> <li>Selects either SDR or DDR transfer when outputting addresses in SPI operation mode.</li> <li>Settable value:<br/>SPIBSC_SDR_TRANS: SDR transfer</li> <li>The setting value of this member is set in the ADDRE bit in the SPI mode DDR enable register (SMDRENR).</li> </ul>                                                                    |  |  |
| uint32_t opdre  | <ul> <li>Option data DDR enable</li> <li>Selects either SDR or DDR transfer when outputting option data in SPI operation mode.</li> <li>Settable value:<br/>SPIBSC_SDR_TRANS: SDR transfer</li> <li>The setting value of this member is set in the OPDRE bit in the SPI mode DDR enable register (SMDRENR).</li> </ul>                                  |  |  |
| uint32_t spidre | <ul> <li>Transfer data DDR enable</li> <li>Selects either SDR or DDR transfer when transferring data in SPI operation mode.</li> <li>Settable value:<br/>SPIBSC_SDR_TRANS: SDR transfer</li> <li>The setting value of this member is set in the SPIDRE bit in the SPI mode DDR enable register (SMDRENR).</li> </ul>                                    |  |  |

# Table 5.19 SPIBSC SPI Operating Mode Settings Structure (st\_spibsc\_spimd\_reg\_t) (3/5)

| Member         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| uint8_t dmdb   | <ul> <li>Dummy cycle bit width</li> <li>Specifies the bit width of dummy cycles in SPI operation mode.</li> <li>Settable values:<br/>SPIBSC_1BIT: 1-bit width<br/>SPIBSC_4BIT: 4-bit width</li> <li>The setting value of this member is set in the DMDB[1:0] bit field in</li> </ul>                                                                                                                                                             |  |  |
| uint8_t dmcyc  | <ul> <li>The setting value of this member is set in the DMDB[1:0] bit held in<br/>the SPI mode dummy cycle setting register (SMDMCR).</li> <li>Number of dummy cycles</li> </ul>                                                                                                                                                                                                                                                                 |  |  |
|                | <ul> <li>Settable values:<br/>To be loaded with the results of calculating the value to be set in the<br/>DMCYC[2:0] bit field of the SPI mode dummy cycle setting register<br/>(SMDMCR) based on the value defined in<br/>SPIBSC_DMYCYC_SETTING. Values that will resultantly yield<br/>number of 0 to 7 are allowed. For details on the calculation, see<br/>"Table 6.2 List of Macros for Customizing the Sample Code (1/2)".     </li> </ul> |  |  |
| uint8_t cmd    | <ul> <li>Command</li> <li>Specifies the command output in SPI operation mode.</li> <li>The setting value of this member is set in the CMD[7:0] bit field in the SPI mode command setting register (SMCMR).</li> </ul>                                                                                                                                                                                                                            |  |  |
| uint8_t ocmd   | <ul> <li>Optional command</li> <li>Specifies the optional command output in SPI operation mode.</li> <li>The setting value of this member is set in the OCMD[7:0] bit field in the SPI mode command setting register (SMCMR).</li> </ul>                                                                                                                                                                                                         |  |  |
| uint32_t addr  | <ul> <li>Address</li> <li>Specifies the address output in SPI operation mode.</li> <li>The setting value of this member is set in the ADR[31:0] bit field in the SPI mode address setting register (SMADR).</li> </ul>                                                                                                                                                                                                                           |  |  |
| uint8_t opd[4] | <ul> <li>Option data</li> <li>Specifies the option data output in SPI operation mode.</li> <li>The setting value of this member is set in the OPDn[7:0] bit field in the SPI mode option setting register (SMOPR).<br/>OPD3[7:0] &lt;== opd[0]<br/>OPD2[7:0] &lt;== opd[1]<br/>OPD1[7:0] &lt;== opd[2]<br/>OPD0[7:0] &lt;== opd[3]</li> </ul>                                                                                                    |  |  |

## Table 5.20 SPIBSC SPI Operating Mode Settings Structure (st\_spibsc\_spimd\_reg\_t) (4/5)



| Member            | Description                                                                                                                                                                                                             |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| uint32_t smrdr[2] | Read data store buffer                                                                                                                                                                                                  |  |
|                   | <ul> <li>The data read in SPI operation mode (SPI mode read data register n<br/>(SMRDRn)) is stored as follows:<br/>SMRDR0 ==&gt; smrdr[0]<br/>SMRDR1 ==&gt; smrdr[1]</li> </ul>                                        |  |
| uint32_t smwdr[2] | <ul> <li>Write data store buffer</li> <li>The data to be written in SPI operation mode (SPI mode write data register n (SMWDRn)) is stored as follows:<br/>SMWDR0 &lt;== smwdr[0]<br/>SMWDR1 &lt;== smwdr[1]</li> </ul> |  |

# Table 5.21 SPIBSC SPI Operating Mode Settings Structure (st\_spibsc\_spimd\_reg\_t) (5/5)



# 5.6 List of Variables for SPIBSC Initial Setting Program

Table 5.22 lists the Global Variables.

#### Table 5.22 Global Variables

| Туре                  | Variable Name      | Contents                                                                                                                                                                                                                                                                                               |
|-----------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| st_spibsc_cfg_t       | g_spibsc_cfg       | <ul> <li>SPIBSC external address space read mode settings storage variable</li> <li>Stores the register configuration information to be used in the SPIBSC external address space read mode.</li> </ul>                                                                                                |
| st_spibsc_spimd_reg_t | g_spibsc_spimd_reg | <ul> <li>SPIBSC SPI operation mode settings storage variable</li> <li>Stores the SPIBSC settings used in SPI operation mode.<br/>In the sample code, these settings are also used as arguments when running serial flash control functions within API functions and user-defined functions.</li> </ul> |



# 5.7 List of Functions Used in the SPIBSC Initial Setting Program

The sample code comprises interface functions (API functions) for using peripheral functions, user-defined functions (functions called by API functions) which must be prepared by the user for the purpose of the target system, and sample functions which are necessary for the sample code to operate.

For the sample code of SPIBSC initial setting program, Table 5.23, Table 5.24, and Table 5.25 list the Sample Functions, the API Functions, and the user-defined functions respectively. The function specification of the application program is basically the same as the function of the "RZ/A1H Group Example of Initialization". Refer to the application note for more information.

| Function                  | Description                                                        |  |
|---------------------------|--------------------------------------------------------------------|--|
| reset_handler             | Reset handler                                                      |  |
| init_spibsc_init1_section | SPIBSC initial setting program 1 deployment function               |  |
|                           | Deploys the SPIBSC initial setting program 1 from the ROM area     |  |
|                           | (serial flash memory) to the large-capacity on-chip RAM so that it |  |
|                           | can run from the large-capacity on-chip RAM.                       |  |
| spibsc_init1              | SPIBSC initial setting program 1 execution function                |  |
|                           | Makes settings (STEP1) to optimize the serial flash memory.        |  |
| init_spibsc_init2_section | SPIBSC initial setting program 2 deployment function               |  |
|                           | Deploys the SPIBSC initial setting program 2 from the ROM area     |  |
|                           | (serial flash memory) to the large-capacity on-chip RAM so that it |  |
|                           | can run from the large-capacity on-chip RAM.                       |  |
| spibsc_init2              | SPIBSC initial setting program 2 execution function                |  |
|                           | Makes settings (STEP2) to optimize the serial flash memory.        |  |

#### Table 5.23 Sample Functions



#### Table 5.24 API Functions

| Function                 | Description                                                               |
|--------------------------|---------------------------------------------------------------------------|
| R_SFLASH_Exmode_Setting  | SPIBSC initial setting function                                           |
|                          | Makes initial settings necessary to control the serial flash memory       |
|                          | with the SPIBSC and initial settings necessary to use the SPIBSC in       |
|                          | external address space read mode. The function makes settings to          |
|                          | the registers in the serial flash memory according to the initial         |
|                          | settings in the SPIBSC-related registers. After the initial settings, the |
|                          | SPIBSC is set to external address space read mode.                        |
| R_SFLASH_WaitTend        | Wait function for SPIBSC data transfer-end                                |
|                          | Waits until the data has been transferred from the SPIBSC.                |
| R_SFLASH_Exmode          | SPIBSC external address space read mode switching function                |
|                          | Switches the SPIBSC from SPI operating mode to external address           |
|                          | space read mode.                                                          |
| R_SFLASH_Set_Config      | SPIBSC external address space read mode setting function                  |
|                          | Loads g_spibsc_cfg with the register configuration information            |
|                          | necessary for using the SPIBSC in external address space read             |
|                          | mode.                                                                     |
| R_SFLASH_SpibscStop      | SPIBSC stop function                                                      |
|                          | Negates the SSL to stop the access to the serial flash memory.            |
| R_SFLASH_Exmode_Init     | SPIBSC external address space read mode initial setting function          |
|                          | Makes initial settings necessary for using the SPIBSC in external         |
|                          | address space read mode. After the initial settings are made, the         |
|                          | SPIBSC enters the external address space read mode.                       |
| R_SFLASH_Spibsc_Transfer | Serial flash control function                                             |
|                          | Issues a command to the serial flash memory in the SPI operation          |
|                          | mode according to the contents of the arguments                           |



| Function                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Userdef_SPIBSC_Set_Config   | SPIBSC external address space read mode register information storage function                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                             | This function must store the register configuration information to be<br>set in the SPIBSC-related registers in SPIBSC external address<br>space read mode according to the serial flash memory to be used<br>into the area specified by the argument.                                                                                                                                                                                                                                                                  |
|                             | This function in the sample code stores the register configuration information to be set in the SPIBSC-related registers assuming Macronix serial flash memory (MX25L51245G).                                                                                                                                                                                                                                                                                                                                           |
| Userdef_SFLASH_Set_Mode     | Serial flash memory register setting function<br>Implement the processing that sets to the serial flash memory<br>registers that are necessary to use the SPIBSC in external address<br>space read mode according to the serial flash memory to be used.<br>The function in the sample code configures the registers for the<br>Macronix serial flash memory (MX25L51245G).                                                                                                                                             |
| Userdef_SFLASH_Write_Enable | Serial flash memory write enable function<br>Implement the processing that enables the serial flash memory<br>registers for writes according to the serial flash memory to be used.<br>In the sample code, this function issues a Write Status Register<br>(WRSR) command to the Macronix serial flash memory<br>(MX25L51245G).                                                                                                                                                                                         |
| Userdef_SFLASH_Busy_Wait    | Serial flash memory write completion wait function<br>Implement the processing that waits for the write to the serial flash<br>memory register to be completed while reading the required serial<br>flash memory register according to the serial flash memory to be<br>used.<br>In the sample code, this function waits for the write to be completed<br>by issuing a Read Status Register (RDSR) command to the<br>Macronix serial flash memory (MX25L51245G) and referencing the<br>contents of the Status Register. |



# 5.8 SPIBSC Initial Setting Program Functional Specifications

Specifications of the functions of the sample code are listed below.

| reset_handler         |                                                                                                                                                                                |  |  |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Outline               | SPIBSC initial setting program reset handler                                                                                                                                   |  |  |
| Declaration           | reset_handler                                                                                                                                                                  |  |  |
| Description           | The entry function of the SPIBSC initial setting program.                                                                                                                      |  |  |
| Arguments             | None                                                                                                                                                                           |  |  |
| Return Value          | None                                                                                                                                                                           |  |  |
| init_spibsc_init1_sec | tion                                                                                                                                                                           |  |  |
| Outline               | SPIBSC initial setting program 1 deployment function                                                                                                                           |  |  |
| Declaration           | void init_spibsc_init1_section (void);                                                                                                                                         |  |  |
| Description           | Deploys the SPIBSC initial setting program 1 from the ROM area (serial flash memory) to the large-capacity on-chip RAM so that it can run from the large-capacity on-chip RAM. |  |  |
| Arguments             | None                                                                                                                                                                           |  |  |
| Return Value          | None                                                                                                                                                                           |  |  |
| spibsc_init1          |                                                                                                                                                                                |  |  |
| Outline               | SPIBSC initial setting program 1 execution function                                                                                                                            |  |  |
| Declaration           | void spibsc_init1 (void);                                                                                                                                                      |  |  |
| Description           | Makes settings (STEP1) to optimize the serial flash memory.                                                                                                                    |  |  |
|                       | Specifies various SSL delay cycle counts.                                                                                                                                      |  |  |
|                       | • Changes the SPBCLK operating frequency: $B\phi/8 \rightarrow B\phi/4$                                                                                                        |  |  |
|                       | Enables the SPIBSC read cache.                                                                                                                                                 |  |  |
| Arguments             | None                                                                                                                                                                           |  |  |
| Return Value          | None                                                                                                                                                                           |  |  |
|                       |                                                                                                                                                                                |  |  |
| init_spibsc_init2_sec | ction                                                                                                                                                                          |  |  |
| Outline               | SPIRSC initial setting program 2 section initialization function                                                                                                               |  |  |

| Outline      | SPIBSC initial setting program 2 section initialization function              |
|--------------|-------------------------------------------------------------------------------|
| Declaration  | void init_spibsc_init2_section (void);                                        |
| Description  | Transfers SPIBSC initial setting program 2 to the large-capacity on-chip RAM. |
| Arguments    | None                                                                          |
| Return Value | None                                                                          |
|              |                                                                               |



| spibsc_init2 |                                                                                                                                                                                                |  |  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Outline      | SPIBSC initial setting program 2 execution function                                                                                                                                            |  |  |
| Declaration  | void spibsc_init2 (void);                                                                                                                                                                      |  |  |
| Description  | Makes settings (STEP2) to optimize the serial flash memory.                                                                                                                                    |  |  |
|              | • Changes the SPBCLK operating frequency: $B\phi/4 \rightarrow B\phi/2$                                                                                                                        |  |  |
|              | • Changes the read command: $H'03 \rightarrow H'EC$                                                                                                                                            |  |  |
|              | <ul> <li>Makes serial flash memory internal register settings.</li> </ul>                                                                                                                      |  |  |
|              | Status register: Sets QE bit to 1.                                                                                                                                                             |  |  |
|              | Configuration register: Sets for DC[1:0] and ODS[2:0] bit.                                                                                                                                     |  |  |
|              | (The setting value of DC[1:0] bit is different depending on the read command. See<br>"Table 6.6 List of Numbers of Dummy Cycles Necessary for the Operating<br>Frequency of the MX25L51245G".) |  |  |
| Arguments    | None                                                                                                                                                                                           |  |  |
| Return Value | None                                                                                                                                                                                           |  |  |

| R_SFLASH_Exmode | e Setting                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                |  |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | a function                                                                                                                                                                                                                                     |  |
| Outline         | SPIBSC initial setting function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                |  |
| Declaration     | int32_t R_SFLASH_<br>*spibsccfg);                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Exmode_Setting (uint32_t ch_no, uint32_t dual, st_spibsc_cfg_t                                                                                                                                                                                 |  |
| Description     | Makes initial settings necessary to control the serial flash memory with the SPIBSC<br>and initial settings necessary to use the SPIBSC in external address space read<br>mode. The function also configures the registers in the serial flash memory according<br>to the initial values of the SPIBSC-related registers. The function must switch the<br>SPIBSC mode from external address space read mode to SPI operation mode<br>before configuring the serial flash memory registers and switch the SPIBSC mode<br>from SPI operation mode to external address space read mode after configuring the<br>serial flash memory registers.<br>The SPIBSC external address space read mode initial setting function<br>(R_SFLASH_Exmode_Init) is run from within this function. |                                                                                                                                                                                                                                                |  |
| Arguments       | uint32_t ch_no<br>uint32_t dual<br>st_spibsc_cfg_t                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | SPIBSC channel number (only 0 is allowed.)<br>Number of serial flash devices connected to the channel<br>One device: SPIBSC_CMNCR_BSZ_SINGLE (0)<br>Two devices: SPIBSC_CMNCR_BSZ_DUAL (1)<br>SPIBSC external address space read mode settings |  |
| Return Value    | *spibsccfg<br>0: Normal end<br>-1: Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Refer to Table 5.13 to Table 5.16 for setting details                                                                                                                                                                                          |  |



| R_SFLASH_WaitTend | <u>ــــــــــــــــــــــــــــــــــــ</u>                                          |  |  |
|-------------------|--------------------------------------------------------------------------------------|--|--|
| Outline           | Wait function for SPIBSC data transfer-end                                           |  |  |
| Declaration       | void R_SFLASH_WaitTend(uint32_t ch_no);                                              |  |  |
| Description       | Waits until the data has been transferred from the SPIBSC.                           |  |  |
| Arguments         | uint32_t ch_no SPIBSC channel number (only 0 is allowed.)                            |  |  |
| Return Value      | None                                                                                 |  |  |
|                   |                                                                                      |  |  |
|                   |                                                                                      |  |  |
| R_SFLASH_Exmode   |                                                                                      |  |  |
| Outline           | SPIBSC external address space read mode switching function                           |  |  |
| Declaration       | int32_t R_SFLASH_Exmode(uint32_t ch_no);                                             |  |  |
| Description       | Switches the SPIBSC from SPI operation mode to external address space read           |  |  |
|                   | mode. All the entries in the read cache are cleared until the read access to the SPI |  |  |
|                   | multi I/O bus space after the switching to the external address space read mode.     |  |  |
| Arguments         | uint32_t ch_no SPIBSC channel number (only 0 is allowed.)                            |  |  |
| Return Value      | 0: Setting successful                                                                |  |  |
|                   |                                                                                      |  |  |
|                   |                                                                                      |  |  |
| R_SFLASH_Set_Conf | -                                                                                    |  |  |
| Outline           | SPIBSC external address space read setting function                                  |  |  |
| Declaration       | void R_SFLASH_Set_Config(uint32_t ch_no, st_spibsc_cfg_t *spibsccfg);                |  |  |
| Description       | Loads g_spibsc_cfg with the register configuration information necessary for using   |  |  |
|                   | the SPIBSC in external address space read mode according to the serial flash         |  |  |
|                   | memory to be used.                                                                   |  |  |
|                   | This function executes the user-defined function Userdef_SPIBSC_Set_Config           |  |  |
|                   | (SPIBSC external address space read mode register information storage function)      |  |  |
| •                 | during its execution.                                                                |  |  |
| Arguments         | uint32_t ch_no SPIBSC channel number (only 0 is allowed.)                            |  |  |
|                   | st_spibsc_cfg_t SPIBSC external address space read mode settings                     |  |  |
|                   | *spibsccfg Refer to Table 5.13 to Table 5.16 for setting details                     |  |  |
| Return Value      | 0: Normal end                                                                        |  |  |
|                   | -1: Error                                                                            |  |  |

| R_SFLASH_Spibsc | Stop                                                           |                                            |
|-----------------|----------------------------------------------------------------|--------------------------------------------|
| Outline         | SPIBSC stop function                                           | n                                          |
| Declaration     | int32_t R_SFLASH_SpibscStop(uint32_t ch_no);                   |                                            |
| Description     | Negates the SSL to stop the access to the serial flash memory. |                                            |
| Arguments       | uint32_t ch_no                                                 | SPIBSC channel number (only 0 is allowed.) |
| Return Value    | None                                                           |                                            |



| R_SFLASH_Exmod | e_Init                                                                                                                                                                     |                                                                                                                                                                                            |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Outline        | SPIBSC external address space read mode initial setting function                                                                                                           |                                                                                                                                                                                            |
| Declaration    | int32_t R_SFLASH_Exmode_Init(uint32_t ch_no, uint32_t dual, st_spibsc_cfg_t<br>*spibsccfg)                                                                                 |                                                                                                                                                                                            |
| Description    | Makes initial settings necessary to use the SPIBSC in external address space read mode. After the initial settings, the SPIBSC is set to external address space read mode. |                                                                                                                                                                                            |
| Arguments      | uint32_t ch_no<br>uint32_t dual                                                                                                                                            | SPIBSC channel number (only 0 is allowed.)<br>Number of serial flash devices connected to the channel<br>One device: SPIBSC_CMNCR_BSZ_SINGLE (0)<br>Two devices: SPIBSC_CMNCR_BSZ_DUAL (1) |
| Return Value   | st_spibsc_cfg_t<br>*spibsccfg<br>0: Normal end<br>-1: Error                                                                                                                | SPIBSC external address space read mode settings<br>Refer to Table 5.13 to Table 5.16 for setting details                                                                                  |

| R_SFLASH_Spibsc_Transfer |                                                                                                                                                                  |                                                        |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|
| Outline                  | Serial flash control function                                                                                                                                    |                                                        |
| Declaration              | int32_t R_SFLASH_Spibsc_Transfer(uint32_t ch_no, st_spibsc_spimd_reg_t *<br>regset);                                                                             |                                                        |
| Description              | Issues a command to the serial flash memory in SPI operation mode according to the contents of the argument regset.                                              |                                                        |
| Arguments                | uint32_t ch_no                                                                                                                                                   | SPIBSC channel number (only 0 is allowed.)             |
|                          | st_spibsc_spimd_reg                                                                                                                                              | SPIBSC SPI operation mode                              |
|                          | _t * regset                                                                                                                                                      | Refer to Table 5.17 to Table 5.21 for setting details. |
| Return Value             | 0: Setting successful                                                                                                                                            |                                                        |
|                          | <ul> <li>-1: Settings failure</li> </ul>                                                                                                                         |                                                        |
| Remarks                  | When this function is called in external address space read mode, it switches into the SPI operation mode before issuing the command to the serial flash memory. |                                                        |



| Userdef_SPIBSC_Set | _Config                                                                               |                                                                                                                   |  |
|--------------------|---------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--|
| Outline            | SPIBSC external address space read mode register information storage function         |                                                                                                                   |  |
| Declaration        | void Userdef_SPIBSC_Set_Config(uint32_t ch_no, st_spibsc_cfg_t *spibsccfg);           |                                                                                                                   |  |
| Description        | This function must store the register configuration information to be set in the      |                                                                                                                   |  |
|                    | SPIBSC-related registers in SPIBSC external address space read mode according to      |                                                                                                                   |  |
|                    | the serial flash memory to be used into the area specified by the argument spibsccfg. |                                                                                                                   |  |
|                    | For the value to be specified in spibsccfg, see Table 5.13 to Table 5.16 and "6.3.1   |                                                                                                                   |  |
|                    | Signal Output when a Read Command is Issued".                                         |                                                                                                                   |  |
| Arguments          | uint32_t ch_no                                                                        | SPIBSC channel number (only 0 is allowed.)                                                                        |  |
|                    | st_spibsc_cfg_t                                                                       | SPIBSC external address read settings                                                                             |  |
|                    | *spibsccfg                                                                            | Refer to Table 5.13 to Table 5.16 for setting details                                                             |  |
| Return Value       | None                                                                                  | -                                                                                                                 |  |
| Remarks            |                                                                                       | mple code stores the register configuration information to be ted registers assuming Macronix serial flash memory |  |



| Outline      | Serial flash memory re                                                                                                                                                                            | egister setting function                                                                                                                 |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Declaration  |                                                                                                                                                                                                   | int32_t Userdef_SFLASH_Set_Mode(uint32_t ch_no, uint32_t dual, en_sf_req_t re                                                            |  |  |
|              | uint8_t data_width, ui                                                                                                                                                                            |                                                                                                                                          |  |  |
| Description  | Implement the processing that sets to the serial flash memory registers that are necessary to use the SPIBSC in external address space read mode according to the serial flash memory to be used. |                                                                                                                                          |  |  |
| Arguments    | uint32_t ch_no                                                                                                                                                                                    | SPIBSC channel number (only 0 is allowed.)                                                                                               |  |  |
|              | uint32_t dual                                                                                                                                                                                     | Number of serial flash devices connected to the channel<br>SPIBSC_CMNCR_BSZ_SINGLE: one device<br>SPIBSC_CMNCR_BSZ_DUAL: two devices     |  |  |
|              | en_sf_req_t req                                                                                                                                                                                   | Register setting information<br>SF_REQ_SERIALMODE: Specifies serial mode.<br>SF_REQ_QUADMODE: Specifies quad mode.                       |  |  |
|              | uint8_t data_width                                                                                                                                                                                | Width of the bus for transferring data between SPIBSC and<br>serial flash memory<br>SPIBSC_1BIT: 1-bit width<br>SPIBSC_4BIT: 4-bit width |  |  |
|              | uint8_t addr_mode                                                                                                                                                                                 | Bit width of the addresses to be issued to the serial flash memory                                                                       |  |  |
|              |                                                                                                                                                                                                   | Specify the bit width of the address to be output when issuing a read command.                                                           |  |  |
|              |                                                                                                                                                                                                   | SPIBSC_OUTPUT_ADDR_24: 24-bit address output<br>SPIBSC_OUTPUT_ADDR_32: 32-bit address output                                             |  |  |
| Return Value | 0: Setting successful<br>-1: Settings failure                                                                                                                                                     |                                                                                                                                          |  |  |
| Remarks      | The sample code makes settings to the registers of Macronix serial flash memory (product No.: MX25L51245G).                                                                                       |                                                                                                                                          |  |  |



| Userdef_SFLASH_Write_Enable |                                                                                                                                       |  |  |  |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Outline                     | Serial flash memory write enable function                                                                                             |  |  |  |
| Declaration                 | int32_t Userdef_SFLASH_Write_Enable(uint32_t ch_no);                                                                                  |  |  |  |
| Description                 | Implement the processing that enables the serial flash memory registers for writes according to the serial flash memory to be used.   |  |  |  |
| Arguments                   | uint32_t ch_no SPIBSC channel number (only 0 is allowed.)                                                                             |  |  |  |
| Return Value                | 0: Setting successful<br>-1: Settings failure                                                                                         |  |  |  |
| Remarks                     | This function in the sample code issues the "Write Status Register (WRSR)" command to the Macronix serial flash memory (MX25L51245G). |  |  |  |

| Outline                 | Serial flash memory                                                                                                                                                                                                                             | write completion wait function                                                                                                                                                     |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Declaration             | int32_t Userdef_SFLASH_Busy_Wait(uint32_t ch_no, uint32_t dual, uint8_t<br>data_width);                                                                                                                                                         |                                                                                                                                                                                    |  |
| Description             | Implement the processing that waits for the write to the serial flash memory to be<br>completed while reading the required serial flash memory register according to the<br>serial flash memory to be used.                                     |                                                                                                                                                                                    |  |
| Arguments               | uint32_t ch_no<br>uint32_t dual                                                                                                                                                                                                                 | SPIBSC channel number (only 0 is allowed.)<br>Number of serial flash devices connected to the channel<br>SPIBSC_CMNCR_BSZ_SINGLE: one device<br>SPIBSC_CMNCR_BSZ_DUAL: two devices |  |
|                         | uint8_t data_width                                                                                                                                                                                                                              | Width of the bus for transferring data between SPIBSC and<br>serial flash memory<br>SPIBSC_1BIT: 1-bit width<br>SPIBSC_4BIT: 4-bit width                                           |  |
| Return Value<br>Remarks | None<br>This function in the sample code waits write processing to be completed while<br>referencing the contents of the Status Register by issuing "Read Status Register<br>(RDSR)" command to the Macronix serial flash memory (MX25L51245G). |                                                                                                                                                                                    |  |



# 5.9 SPIBSC Initial Setting Program Flowcharts

# 5.9.1 SPIBSC Initial setting program (Overall)

Figure 5.4 shows the Flowchart of SPIBSC Initial setting program (Overall).





## 5.9.2 SPIBSC Initial Setting Program 1 (STEP1)

In the SPIBSC initial setting program 1, the read cache is enabled after changing the delay cycle count to be inserted during the communication and setting the SPI clock frequency to  $B\phi/4$ .

The process executed in the SPIBSC initial setting program 1 cannot be performed by the program allocated to the SPI multi-I/O bus space due to the change in SPIBSC register settings, therefore this program should be transferred to the large-capacity on-chip RAM to be executed.

Figure 5.5 shows the Flowchart of SPIBSC Initial setting program 1.



Figure 5.5 Flowchart of SPIBSC Initial setting program 1



# 5.9.3 SPIBSC Initial Setting Program 2 (STEP2)

The SPIBSC initial setting program 2 sets up the serial flash memory registers (Status Register, QE bit, Configuration Register, DC[1:0] and ODS[2:0] bit) and changes the bus bit width from 1 bit to 4 bits so that the serial flash memory can be accessed at a higher speed. After setting up the serial flash memory registers, the program sets the type of read command to be issued to the serial flash memory when using the SPIBSC in external address space read mode to "Quad Read (4B address)" (H'EC) and changes the SPI clock frequency to  $B\phi/2$ .

Since the SPIBSC initial setting program 2 modifies the SPIBSC registers during its processing, it cannot run in the SPI multi-I/O bus space. Accordingly, it is expanded in large-capacity on-chip RAM for execution.

Figure 5.6 shows the Flowchart of SPIBSC Initial setting program 2.





Figure 5.6 Flowchart of SPIBSC Initial setting program 2

# 6. Application Example

# 6.1 Operation of the Sample Code Used in its Initial State

The sample code in its initial state accesses the Macronix serial flash memory (product No.: MX25L51245G) according to the settings that are summarized in Table 6.1.

| Table 6.1 | Sample | Code | Access | Settings |
|-----------|--------|------|--------|----------|
|-----------|--------|------|--------|----------|

| Item                                                                                    | Setting                                                                                                                                                                                                                                                  |
|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Serial flash memory                                                                     | <ul> <li>Macronix serial flash memory</li> <li>Model name: MX25L51245G</li> <li>Read command used: H'EC<br/>4-bit bus, SDR transfer<br/>Number of dummy cycles required: 4<br/>(When running at a maximum operating frequency of 70<br/>MHz.)</li> </ul> |
| Number of serial flash memory devices to be connected to the SPI multi-I/O bus space    | 1                                                                                                                                                                                                                                                        |
| Data bus width                                                                          | 4 bits                                                                                                                                                                                                                                                   |
| Number of address bytes<br>(Number of bytes to be issued when<br>specifying an address) | 4 bytes                                                                                                                                                                                                                                                  |
| Transfer format in read mode                                                            | SDR transfer mode                                                                                                                                                                                                                                        |
| Output level of the SPBCLK pin in idle state                                            | SPBCLK is set to 0 when SPBSSL is negated.<br>(CMNCR.CPOL = 0)                                                                                                                                                                                           |
| SPIBSC data transmission timing                                                         | Data transmission at even edge during SDR transfer.<br>(CMNCR.CPHAT = 0)                                                                                                                                                                                 |
| SPIBSC data reception timing                                                            | Data reception at even edge during SDR transfer.<br>(CMNCR.CPHAR = 1)                                                                                                                                                                                    |

Figure 6.1 shows the Read Operation in SDR Transfer Mode (Initial State of the Sample Code). In a read operation, the command, address, and dummy cycles are output from the SPIBSC before a data cycle begins and read data is output from the MX25L51245G.

The MX25L51245G samples the input data at the rising edge of the clock in SDR transfer mode. The SPIBSC begins data output with respect to the falling edge of the clock and continues data output processing at the rising edge. CPOL=0 and CPHAT=0 are set so that the MX25L51245G can sample the MSB of the output data from the SPIBSC at the rising edge of the first SPBCLK.

The MX25L51245G also begins data output with respect to the falling edge of the clock in SDR transfer mode. To keep the output data present, in the data cycle, till the falling edge of the next clock with respect to the falling edge of the last clock of the dummy cycle, CPHAR=1 is set in the SPIBSC so that the input data can be sampled at an even edge (falling edge when CPOL=0).





Figure 6.1 Read Operation in SDR Transfer Mode (Initial State of the Sample Code)



# 6.2 Changing the Sample Code without Changing the Serial Flash Memory

The sample code can be subject to customization by changing the macro definitions (defined in spibsc\_config.h) which are shown in Table 6.2 and Table 6.3. " " in the tables denotes a setting for using the sample code in its initial state.

The user -defined function Userdef\_SFLASH\_Set\_Mode is called to set up the serial flash memory registers within the R\_SFLASH\_Exmode\_Setting function which is executed during initialization. The Userdef\_SFLASH\_Set\_Mode function configures the Status Register and Configuration Register of the MX25L51245G, shown in Table 6.2 and Table 6.3, so that their values match the values of the SPIBSC macros which are defined according to the specifications for the read command to be used. This enables read accesses to the MX25L51245G shown in Table 6.4 and Table 6.5.

| Macro Name             | Value                                  | Setting                 |
|------------------------|----------------------------------------|-------------------------|
| DEF_SPIBSC_DUAL_MODE   | SPIBSC_CMNCR_BSZ_SINGLE: 1             | CMNCR.BSZ[1:0] = B'00   |
|                        | SPIBSC_CMNCR_BSZ_DUAL: 2               | CMNCR.BSZ[1:0] = B'01   |
| SPIBSC_BUS_WITDH       | SPIBSC_1BIT: 1 bit                     | DRENR.ADB[1:0] = B'00   |
| (Note 2)               |                                        | DRENR.OPDB[1:0] = B'00  |
|                        |                                        | DRENR.DRDB[1:0] = B'00  |
|                        | SPIBSC_4BIT: 4 bits                    | DRENR.ADB[1:0] = B'10   |
|                        |                                        | DRENR.OPDB[1:0] = B'10  |
|                        |                                        | DRENR.DRDB[1:0] = B'10  |
| SPIBSC_OUTPUT_ADDR     | SPIBSC_OUTPUT_ADDR_24: 3 bytes         | DRENR.ADE[3:0] = B'0111 |
| (Note 2)               | SPIBSC_OUTPUT_ADDR_32: 4 bytes         | DRENR.ADE[3:0] = B'1111 |
| SPIBSC_TRANS_MODE      | SPIBSC_SDR_TRANS: SDR transfer         | DRDRENR.ADDRE = 0       |
| (Note 2)               |                                        | DRDRENR.OPDRE = 0       |
|                        |                                        | DRDRENR.DRDRE = 0       |
|                        | SPIBSC_DDR_TRANS: DDR transfer         | DRDRENR.ADDRE = 1       |
|                        |                                        | DRDRENR.OPDRE = 1       |
|                        |                                        | DRDRENR.DRDRE = 1       |
| SPIBSC_READCMD_SETTING | Serial flash memory read command to be | DRCMR.CMD[7:0] = H'EC   |
| (Note 1) (Note 2)      | specified in DRCMR.CMD                 |                         |
|                        | ("0xEC" in initial state)              |                         |
| SPIBSC_DMYCYC_SETTING  | Number of dummy cycles                 | DRDMCR.DMCYC[2:0] =     |
| (Note 2)               | (4 in initial state)                   | B'001 (Note 3)          |

| Table 6.2 | List of Macros | for Customizing | the Sam      | ple Code (1/2 | 2) |
|-----------|----------------|-----------------|--------------|---------------|----|
|           |                |                 | , <b>e</b> a |               | ·/ |

Notes: 1. The sample code supports the commands H'0B (FAST READ), H'0C (FAST READ4B), H'0D (FASTDTRD), H'0E (FRDTRD4B), H'EB (4READ), H'EC (4READ4B), H'ED (4DTRD), and H'EE (4DTRD4B) as the commands that can be issued to the MX25L51245G.

 SPIBSC\_DMYCYC\_SETTING, SPIBSC\_BUS\_WITDH, SPIBSC\_TRANS\_MODE, and SPIBSC\_OUTPUT\_ADDR need be configured according to the contents of the read command to be defined in SPIBSC\_READCMD\_SETTING.

3. The value to be specified in RDMCR.DMYCYC[2:0] is dependent on the read command to be used and must be calculated from the number of dummy cycles and "Performance enhance indicator" that are necessary for theMX25L51245G. In the sample code, the number of dummy cycles is defined in SPIBSC\_DMYCYC\_SETTING and "Performance enhance indicator" in SFLASH\_MODECYC. Their values are obtained using the following formulas which are separately available for the different read commands:

- For H'0B, H'0C, H'0D, and H'0E commands

DRDMCR.DMYCYC[2:0] = SPIBSC\_DMYCYC\_SETTING - 1

- For H'EB, H'EC, H'ED, and H'EE commands

DRDMCR.DMYCYC[2:0] = SPIBSC\_DMYCYC\_SETTING - SFLASH\_MODECYC - 1 (SFLASH\_MODECYC is set to 2 for SDR transfers and 1 for DDR transfers.)

| Macro Name                         | Value                                                                                                                                               | Setting                         |  |
|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|--|
| SPIBSC_OUTPUT_OPTION_              | Specifies the option data to be output from among OPD3, OPD3/OPD2, OPD3/OPD2/OPD1, OPD3/OPD2/OPD1/OPD0, and "output disabled".                      |                                 |  |
| SETTING                            |                                                                                                                                                     |                                 |  |
|                                    | SPIBSC_OUTPUT_DISABLE                                                                                                                               | DRENR.OPDE[3:0] = B'0000        |  |
|                                    | SPIBSC_OUTPUT_OPD_3                                                                                                                                 | DRENR.OPDE[3:0] = B'1000        |  |
|                                    | SPIBSC_OUTPUT_OPD_32                                                                                                                                | DRENR.OPDE[3:0] = B'1100        |  |
|                                    | SPIBSC_OUTPUT_OPD_321                                                                                                                               | DRENR.OPDE[3:0] = B'1110        |  |
|                                    | SPIBSC_OUTPUT_OPD_3210                                                                                                                              | DRENR.OPDE[3:0] = B'1111        |  |
| SPIBSC_OUTPUT_OPTION_<br>DATA_OPD3 | 0x00                                                                                                                                                | DROPR.OPD3[7:0] = H'00          |  |
| SPIBSC_OUTPUT_OPTION_<br>DATA_OPD2 | 0x00                                                                                                                                                | DROPR.OPD2[7:0] = H'00          |  |
| SPIBSC_OUTPUT_OPTION_<br>DATA_OPD1 | 0x00                                                                                                                                                | DROPR.OPD1[7:0] = H'00          |  |
| SPIBSC_OUTPUT_OPTION_<br>DATA_OPD0 | 0x00                                                                                                                                                | DROPR.OPD0[7:0] = H'00          |  |
| SPIBSC_CPOL_SETTING                | SPIBSC_CMNCR_CPOL_LOW:<br>SPBCLK is set to 0 when SPBSSL is<br>negated.                                                                             | CMNCR.CPOL = 0                  |  |
|                                    | SPIBSC_CMNCR_CPOL_HIGH:<br>SPBSSL is set to 1 when SPBCLK is<br>negated.                                                                            | CMNCR.CPOL = 1                  |  |
| SPIBSC_CPHAT_SETTING               | SPIBSC_CMNCR_CPHAT_EVEN:<br>Data transmission at even edge during<br>SDR transfer.<br>Data transmission starts at even edge<br>during DDR transfer. | CMNCR.CPHAT = 0                 |  |
|                                    | SPIBSC_CMNCR_CPHAT_ODD:<br>Data transmission at odd edge during<br>SDR transfer.<br>Data transmission starts at odd edge<br>during DDR transfer.    | CMNCR.CPHAT = 1                 |  |
| SPIBSC_CPHAR_SETTING               | SPIBSC_CMNCR_CPHAR_ODD:<br>Data reception at odd edge during<br>SDR transfer.<br>Data reception starts at odd edge<br>during DDR transfer.          | CMNCR.CPHAR = 0                 |  |
|                                    | SPIBSC_CMNCR_CPHAR_EVEN:<br>Data reception at even edge during<br>SDR transfer.<br>Data reception starts at even edge<br>during DDR transfer        | CMNCR.CPHAR = 1                 |  |
| SPIBSC_CKDLY_SETTING               | SPIBSC_CKDLY_DEFAULT: Initial value                                                                                                                 | CKDLY.CKDLY[3:0] = B'0100       |  |
|                                    | SPIBSC_CKDLY_TUNING:<br>Makes the data input setup time shorter<br>and the data input hold time longer.                                             | CKDLY.CKDLY[3:0] = B'1010       |  |
| SPIBSC_SPODLY_SETTING              | SPIBSC_SPODLY_DEFAULT: Initial value                                                                                                                | SPODLY.SPODLY[15:0] =<br>H'0000 |  |
|                                    | SPIBSC_SPODLY_TUNING:                                                                                                                               | SPODLY.SPODLY[15:0] =           |  |
|                                    | The delay, hold, buffer on and buffer off times for data output are lengthened.                                                                     | H'1111                          |  |

| Table 6.5 List of Macros for Customizing the Sample Code (2/2) | Table 6.3 | List of Macros for Customizing the Sample Code (2/2) |
|----------------------------------------------------------------|-----------|------------------------------------------------------|
|----------------------------------------------------------------|-----------|------------------------------------------------------|

Table 6.4 shows MX25L51245G Status Register and Table 6.5 shows MX25L51245G Configuration Register. The Userdef\_SFLASH\_Set\_Mode function is used to set the bits denoted by "\_\_\_\_\_" in the tables and the other bits are left to hold their initial value.

| Bit<br>Position | Bit Name        | Attribute<br>(Note) | Description                        |
|-----------------|-----------------|---------------------|------------------------------------|
| 7               | SRWD            | NV                  | Status register write protect      |
|                 |                 |                     | 1 = Status register write disabled |
|                 |                 |                     | 0 = Status register write enabled  |
| 6               | QE              | NV                  | Quad enable                        |
|                 |                 |                     | 1 = Quad enable                    |
|                 |                 |                     | 0 = Not Quad enable                |
| 5,4,3,2         | BP3,BP2,BP1,BP0 | NV                  | Level of protected block           |
| 1               | WEL             | V                   | Write enable latch                 |
|                 |                 |                     | 1 = Write enable                   |
|                 |                 |                     | 0 = Not write enable               |
| 0               | WIP             | V                   | Write in progress bit              |
|                 |                 |                     | 1 = Write operation                |
|                 |                 |                     | 0 = Not in write operation         |

| Table 6.4 | MX25L51245G Status Register |
|-----------|-----------------------------|
|-----------|-----------------------------|

Note: "NV" in the attribute column denotes "Non-volatile bit" and "V" denotes "Volatile bit."

| Bit<br>Position | Bit Name            | Attribute<br>(Note 1) | Description                                                            |
|-----------------|---------------------|-----------------------|------------------------------------------------------------------------|
| 7,6             | DC1, DC0            | V                     | Dummy cycle 1, Dummy cycle 0<br>DC[1:0] = B'01 (Note 2)                |
| 5               | 4BYTE               | V                     | 0 = 3-byte address mode<br>1 = 4-byte address mode                     |
| 4               | PBE                 | V                     | Preamble bit enable<br>0 = Disable<br>1 = Enable                       |
| 3               | ТВ                  | OTP                   | Top/bottom selected<br>0 = Top area protect<br>1 = Bottom area protect |
| 2,1,0           | ODS2, ODS1,<br>ODS0 | V                     | Output driver strength<br>(OSD2 = 1, OSD1 = 1, OSD0 = 0) (Note 3)      |

Notes: 1. "NV" in the attribute column denotes "Non-volatile bit" and "OTP" denotes "One-time programmable bit".

2. As seen from Table 6.6 the number of dummy cycles differs depending on the read command to be used. The sample code uses H'EC as the read command and therefore loads DC[1:0] bit with a value of B'01 so that an optimum dummy cycle count can be obtained.

3. The sample code uses the settings ODS2 = 1, ODS1 = 1, and ODS0 = 0 to obtain optimum AC timing characteristics about the data hold time (tCHDX) and data output delay time (tCLQV) of the MX25L51245G when connected to the RZ/A1LU. (This setting is possible when the load capacity of the device to be connected to the MX25L51245G is 15pF or less and 3.0 to 3.6V is applied to the power source (VCC) of the MX25L51245G.)

Table 6.6 shows a List of Numbers of Dummy Cycles Necessary for the Operating Frequency of the MX25L51245G. The number of necessary dummy cycles differ depending on the read command and operating frequency to be used. Since the sample code uses the H'EC command as the read command and sets SPBCLK to 66.66 MHz, its optimum setting is DC[1:0] = B'01 which yields a dummy cycle count of 4 cycles.

When changing the read command to be used, resets the number of dummy cycles according to the new read command and the frequency of SPBCLK.

| Table 6.6 | List of  | Numbers | of I | Dummy | Cycles | Necessary | for | the | Operating | Frequency | of the |  |
|-----------|----------|---------|------|-------|--------|-----------|-----|-----|-----------|-----------|--------|--|
| M>        | (25L5124 | 15G     |      |       |        |           |     |     |           |           |        |  |

| Read Command       | DC[1:0]  |          |          |           |  |  |
|--------------------|----------|----------|----------|-----------|--|--|
| Read Command       | B'00     | B'01     | B'10     | B'11      |  |  |
| FAST READ (H'0B)   | 8 cycles | 6 cycles | 8 cycles | 10 cycles |  |  |
| FAST READ4B (H'0C) | /133MHz  | /133MHz  | /133MHz  | /166MHz   |  |  |
| FASTDTRD (H'0D)    | 8 cycles | 6 cycles | 8 cycles | 10 cycles |  |  |
| FRDTRD4B (H'0E)    | /66MHz   | /66MHz   | /66MHz   | /83MHz    |  |  |
| 4READ (H'EB)       | 6 cycles | 4 cycles | 8 cycles | 10 cycles |  |  |
| 4READ4B (H'EC)     | /84MHz   | /70MHz   | /104MHz  | /133MHz   |  |  |
| 4DTRD (H'ED)       | 6 cycles | 4 cycles | 8 cycles | 10 cycles |  |  |
| 4DTRD4B (H'EE)     | /52MHz   | /42MHz   | /66MHz   | /100MHz   |  |  |



#### 6.2.1 Changing to 2-Serial-Flash-Memory-Device Configuration (8-bit Access Mode)

Serial flash memory can be made accessible in 8-bit width by using 2 serial flash memory devices when connecting to the SPI multi-I/O bus space.

Figure 6.2 shows an Example of Connecting 2 Serial Flash Memory Devices (8-bit Access Width).



#### Figure 6.2 Example of Connecting 2 Serial Flash Memory Devices (8-bit Access Width)

To connect 2 flash memory devices, it is necessary to configure the pins P3\_10 to P3\_13 for pin functions SPBMO1\_0/SPBIO01\_0, SPBMI1\_0/SPBIO11\_0, SPBIO21\_0, and SPBIO31\_0, respectively. In the sample code, the function "io\_spibsc\_port\_setting" is used to configure the multiplexed pin functions.



When changing the configuration for connecting to the SPI multi-I/O bus space to 2-serial-flash-memory-device configuration, change the macro definitions listed in Table 6.7 from the initial values defined for the sample code.

| Table 6.7 | List of Macros for | <b>Customizing the S</b> | Sample Coe ( | 2-Device Configuration) |
|-----------|--------------------|--------------------------|--------------|-------------------------|
|-----------|--------------------|--------------------------|--------------|-------------------------|

| Macro Name           | Value                    | Setting               |  |
|----------------------|--------------------------|-----------------------|--|
| DEF_SPIBSC_DUAL_MODE | SPIBSC_CMNCR_BSZ_DUAL: 2 | CMNCR.BSZ[1:0] = B'01 |  |



The addresses that are allocated to the SPI multi-I/O bus space for the serial flash memory differs for the configuration in which one serial flash memory device is connected and the configuration in which two serial flash memory devices are connected. After the boot startup on-chip ROM program is executed, however, the SPIBSC causes a branch to address H'1800\_0000 (address H'0000\_0000 of the serial flash memory) when the number of address bytes is 3 bytes (16MB area maximum) and one serial flash memory device is connected. The SPIBSC initial setting program need be allocated within the 16MB area starting at address H'0000\_0000 of the serial flash memory which is connected to SPBMO0\_0/SPBIO00\_0 and SPBMI0\_0/SPBIO10\_0. In the sample code, it is allocated to sectors 0 to 7 (addresses H'0000\_0000 to H'0000\_7FFF) of the serial flash memory.

Since the application program starts execution after the SPIBSC initial setting program set the number of address bytes to 4 and the number of serial flash memory devices connected to 2, it can be allocated to an area that is available in the 2-serial-flash-memory configuration.



Figure 6.3 shows an Example of Allocating Programs in 2-Serial-Flash-Memory Configuration.

Figure 6.3 Example of Allocating Programs in 2-Serial-Flash-Memory Configuration



#### 6.2.2 Changing the Access to Serial Flash Memory into DDR Transfer Mode

The MX25L51245G supports DDR transfer in data read mode and can output data with respect to both rising and falling edges of SPBCLK.

By changing the macro definitions (defined in spibsc\_config.h) listed in Table 6.8, it is possible for the RZ/A1LU to access the MX25L51245G for reads in DDR transfer mode.

| Macro Name             | Value                                                      | Setting                   |
|------------------------|------------------------------------------------------------|---------------------------|
| SPIBSC_BUS_WITDH       | SPIBSC_4BIT                                                | DRENR.ADB[1:0] = B'10     |
| (Note)                 |                                                            | DRENR.OPDB[1:0] = B'10    |
|                        |                                                            | DRENR.DRDB[1:0] = B'10    |
| SPIBSC_OUTPUT_ADDR     | SPIBSC_OUTPUT_ADDR_32                                      | DRENR.ADE[3:0] = B'1111   |
| (Note)                 |                                                            |                           |
| SPIBSC_TRANS_MODE      | SPIBSC_DDR_TRANS: DDR transfer                             | DRDRENR.ADDRE=1           |
| (Note)                 |                                                            | DRDRENR.OPDRE=1           |
|                        |                                                            | DRDRENR.DRDRE=1           |
| SPIBSC_READCMD_SETTING | 0xEE                                                       | DRCMR.CMD[7:0] = H'EE     |
| (Note)                 |                                                            |                           |
| SPIBSC_DMYCYC_SETTING  | 8                                                          | DRDMCR.DMCYC[2:0] =       |
| (Note)                 |                                                            | B'110                     |
| SPIBSC_OUTPUT_OPTION_  | SPIBSC_OUTPUT_OPD_3:                                       | DRENR.OPDE[3:0] = B'1000  |
| SETTING                | Specifies the option data to OPD3.                         |                           |
| SPIBSC_OUTPUT_OPTION_  | 0x00                                                       | DROPR.OPD3[7:0] = H'00    |
| DATA_OPD3              |                                                            |                           |
| SPIBSC_CPOL_SETTING    | SPIBSC_CMNCR_CPOL_LOW:                                     | CMNCR.CPOL = 0            |
|                        | SPBCLK is set to 0 when SPBSSL is                          |                           |
|                        | negated.                                                   |                           |
| SPIBSC_CPHAT_SETTING   | SPIBSC_CMNCR_CPHAT_EVEN:                                   | CMNCR.CPHAT = 0           |
|                        | Data transmission starts at even edge during DDR transfer. |                           |
| SPIBSC CPHAR SETTING   | SPIBSC CMNCR CPHAR ODD:                                    | CMNCR.CPHAR = 0           |
| SFIBSC_CFIAR_SETTING   | Data reception starts at odd edge                          | CIVINCK.CFTIAR = 0        |
|                        | during DDR transfer.                                       |                           |
| SPIBSC_CKDLY_SETTING   | SPIBSC CKDLY TUNING:                                       | CKDLY.CKDLY[3:0] = B'1010 |
|                        | Makes the data input setup time                            |                           |
|                        | shorter and the data input hold time                       |                           |
|                        | longer.                                                    |                           |
| SPIBSC_SPODLY_SETTING  | SPIBSC_SPODLY_TUNING:                                      | SPODLY.SPODLY[15:0] =     |
|                        | The delay, hold, buffer on and buffer                      | H'1111                    |
|                        | off times for data output are                              |                           |
|                        | lengthened.                                                |                           |

Note: It is necessary to define SPIBSC\_BUS\_WITDH, SPIBSC\_TRANS\_MODE, SPIBSC\_OUTPUT\_ADDR, and SPIBSC\_DMYCYC\_SETTING according to the read command that is defined in SPIBSC\_READCMD\_SETTING for use.



Figure 6.4 shows the outline of DDR Transfer Mode Read Operation.

An SDR transfer is performed in the command cycle and the MX25L51245G samples the input data at the rising edge of the clock. The SPIBSC begins data output with respect to the falling edge of the clock and holds the data at the rising edge. The settings CPOL=0 and CPHAT=0 are used so that the MX25L51245G can sample the MSB of the output data from the SPIBSC at the rising edge of the first SPBCLK clock.

DDR transfers are performed in the address and data cycles. In the address cycle, the SPIBSC starts generating the address with respect to the falling edge of the clock occurring after the end of the command cycle. Subsequently, it outputs the address with respect to both the rising and falling edges of the clock. The MX25L51245G starts sampling the input in the address cycle at the rising edge of the clock. Subsequently, it samples the input at both edges of the clock.

The MX25L51245G starts the output of the data at the falling edge of the last clock in the dummy cycle. Subsequently, data is output on both the rising and falling edges of the clock. The SPIBSC sets CPHAR to 0 and samples the input data at the rising edge of the first clock in the data cycle. Subsequently, it samples the data at both edges of the clock.



Figure 6.4 DDR Transfer Mode Read Operation



# 6.3 Changing the Sample Code When Changing the Serial Flash Memory

When changing the serial flash memory, the sample code should be changed according to the specifications of the serial flash memory to be used.

Table 6.9 lists the Points for Changing Sample Code.

Table 6.9 Points for Changing Sample Code

| Change Point                                    | Description                                                                                                                                                                                                                    |
|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Signal Output when a Read Command is Issued     | Change the output signal to be sent to the serial flash<br>memory when a read command is issued in external address<br>space read mode according to the specifications for the<br>serial flash memory read command to be used. |
| Setting up the Serial Flash Memory<br>Registers | The registers in the serial flash memory required to use the SPIBSC in external address read mode are made according to the serial flash memory to be used.                                                                    |
| Serial flash memory write enable                | The settings for the registers in the serial flash memory are<br>made to enable write operations according to the serial flash<br>memory to be used. (Note)                                                                    |
| Serial Flash Memory Write                       | The registers in the serial flash memory are read according<br>to the serial flash memory to be used.<br>Read the registers in the flash memory and wait for the write<br>to the serial flash memory to be completed.          |

Note: In some cases, it is necessary to enable write operations to the serial flash memory in order to make settings to the registers in the serial flash memory.

Processing summarized in Table 6.2 is executed by the SPIBSC initial setting program 2 (spibsc\_init2 function). It can be handled by changing the processing of the user-defined function in the sample code according to the serial flash memory to be used. Figure 6.5 shows the Hierarchical Module Diagram of the SPIBSC Initial Setting Program 2. Subsections 6.3.1 to 6.3.4 show the outline of the processing executed by the sample program.



Figure 6.5 Hierarchical Module Diagram of the SPIBSC Initial Setting Program 2

#### 6.3.1 Signal Output when a Read Command is Issued

In external address space read mode, a read access to the SPI multi-I/O bus space is initiated by sending a signal, which is converted for SPI communication, to the serial flash memory when issuing the read command. When changing the serial flash memory to be used, change the signal to be output when issuing a read command according to the specifications for the serial flash memory read command.

The SPIBSC allows the signal to be output to the serial flash memory by setting up the SPIBSC control register in the external address space read mode.

In the sample code, the value to be specified in the SPIBSC control register can be changed through a global variable (variable for storing the SPIBSC external address space read mode settings: g\_spibsc\_cfg). g\_spibsc\_cfg can be configured using the user-defined function (the SPIBSC external address space read mode register information storage function: Userdef\_SPIBSC\_Set\_Config) which is the executed by the SPIBSC external address space read mode setting function (R\_SFLASH\_Set\_Config). Modify the implementation of the Userdef\_SPIBSC\_Set\_Config function according to the contents of Table 5.13 to Table 5.21 and the specifications for the serial flash memory to be used.



Figure 6.6 shows the Correspondence between SPIBSC Control Register Settings and Waveforms Output to Serial Flash Memory during SPIBSC External Address Read Operation. Refer to these example settings when determining the g\_spibsc\_cfg settings that match the read command of the serial flash memory used.



Figure 6.6 Correspondence between SPIBSC Control Register Settings and Waveforms Output to Serial Flash Memory during SPIBSC External Address Read Operation

RENESAS

# 6.3.2 Setting up the Serial Flash Memory Registers

In the sample code, the user-defined function Userdef\_SFLASH\_Set\_Mode is called by the R\_SFLASH\_Exmode\_Setting function which is executed during the initialization processing in order to set up the serial flash memory.

Set up the registers in the serial flash memory according to the contents of the global variable g\_spibsc\_cfg which is described in "6.3.1 Signal Output when a Read Command is Issued".

The write\_status function which is called from the Userdef\_SFLASH\_Set\_Mode function calls Userdef\_SFLASH\_Write\_Enable to issue a Write Enable command so that the serial flash memory can be enabled for writes before writing data into Status Register and Configuration Register. Subsequently the Userdef\_SFLASH\_Busy\_Wait function is called to verify that the memory is enabled for writes. Implement the Userdef\_SFLASH\_Set\_Mode function according to the specifications for the serial flash memory to be used.

Figure 6.7 shows the Userdef\_SFLASH\_Set\_Mode Function Processing Flow of the sample code.



Figure 6.7 Userdef\_SFLASH\_Set\_Mode Function Processing Flow



#### 6.3.3 Serial Flash Memory Write Enable

It is necessary to enable the serial flash memory for writes before writing data to the registers (Status Register and Configuration Register) of the serial flash memory.

Implement the Userdef\_SFLASH\_Write\_Enable function according to the specifications for the serial flash memory to be used so that it can be enabled for writes.

The sample code uses the serial flash control function (R\_SFLASH\_Spibsc\_Transfer) to issue a Write Enable command (H'06) whereby enabling writes (setting the WEL bit of the Status Register to 1).

Figure 6.8 shows the Userdef\_SFLASH\_Write\_Enable of the sample code.



Figure 6.8 Userdef\_SFLASH\_Write\_Enable Function Processing Flow



#### 6.3.4 Serial Flash Memory Write Completion Wait

The serial flash memory switches into the busy state when a write is performed on its register (Status Register or Configuration Register). A wait need be inserted between the time the serial flash memory enters the busy state and the time the written data is reflected in the register.

Implement the Userdef\_SFLASH\_Busy\_Wait function so that the sample code waits until the write to the serial flash memory gets completed according to the specifications for the serial flash memory to be used.

The sample code waits for the completion of the write by reading the WIP bit of the Status Register.

Figure 6.9 shows the Userdef\_SFLASH\_Busy\_Wait of the sample code.



Figure 6.9 Userdef\_SFLASH\_Busy\_Wait Function Processing Flow



# 7. Sample Code

Sample code can be downloaded from the Renesas Electronics website.

## 8. Reference Documents

User's Manual: Hardware

RZ/A1L Group, RZ/A1LU Group User's Manual: Hardware The latest version can be downloaded from the Renesas Electronics website.

RZ/A1LU AVB board RTK772103FC00000BR (JASMINE) User's Manual The latest version can be downloaded from the Renesas Electronics website.

ARM Architecture Reference Manual ARMv7-A and ARMv7-R edition Issue C The latest version can be downloaded from the ARM website.

ARM Generic Interrupt Controller Architecture Specification Architecture version 1.0 The latest version can be downloaded from the ARM website.

ARM CortexTM-A9 (Revision: r3p0) Technical Reference Manual The latest version can be downloaded from the ARM website.

ARM CoreLinkTM Level 2 Cache Controller L2C-310 (Revision: r3p2) Technical Reference Manual The latest version can be downloaded from the ARM website.

Technical Update/Technical News

The latest information can be downloaded from the Renesas Electronics website.

User's Manual: Development Tools

ARM Software Development Tools (ARM Compiler toolchain, ARM DS-5 etc) can be downloaded from the ARM website.

The latest version can be downloaded from the ARM website.



# Website and Support

Renesas Electronics website http://www.renesas.com

Inquiries

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

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



# **Revision History**

|          |               |      | Description                                                                                                                                                  |
|----------|---------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev.     | Date          | Page | Summary                                                                                                                                                      |
| Rev.0.50 | Jul. 15, 2016 |      | First edition issued                                                                                                                                         |
| Rev.1.00 | Nov. 18, 2016 | _    | Updated the application note by supporting the following integrated development environment in the sample code.                                              |
|          |               |      | <ul> <li>Renesas integrated development environment<br/>e<sup>2</sup> studio (GNUARM-NONE Toolchain)</li> </ul>                                              |
|          |               |      | <ul> <li>IAR SYSTEMS, Inc. integrated development environment<br/>IAR Embedded Workbench<sup>®</sup> for ARM<sup>®</sup> (IAR C/C++<br/>Compiler)</li> </ul> |
|          |               | P41  | 5.8 SPIBSC Initial Setting Program Functional Specifications<br>R_SFLASH_Exmode                                                                              |
|          |               |      | <ul> <li>Added explanation of operation for clearing the read cache<br/>of SPIBSC to the description of the function.</li> </ul>                             |
|          |               |      | <ul> <li>Updated the sample code in accordance with the above<br/>description.</li> </ul>                                                                    |
|          |               | P47  | Figure 5.5 Flowchart of SPIBSC Initial setting program 1                                                                                                     |
|          |               |      | <ul> <li>Added the process of performing to clear the read cache of SPIBSC.</li> </ul>                                                                       |
|          |               |      | <ul> <li>Added the process of performing the dummy read after<br/>writing of DRCR.</li> </ul>                                                                |
|          |               |      | <ul> <li>Updated the sample code in accordance with the above<br/>description.</li> </ul>                                                                    |

#### 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 others
- 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, please 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 products
- 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.

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



#### SALES OFFICES

**Renesas Electronics Corporation** 

http://www.renesas.com

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 Dusseldorf, German 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 Cent Tel: +852-2265-6688, Fax: +852 2886-9022 ntury Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong 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 Hyllux Innovation Centre, Singapore 339949 Tel: +65-6213-0200, Fax: +65-6213-0300 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