

## Simple I<sup>2</sup>C Module Using Firmware Integration Technology

## Introduction

This application note describes the simple I<sup>2</sup>C module using firmware integration technology (FIT) for communications between devices using the serial communications interface (SCI).

## **Target Device**

This API supports the following device.

- RX110, RX111, RX113 Groups
- RX130, RX13T Groups
- RX140 Groups
- RX230, RX231, RX23E-A, RX23E-B, RX23T, RX23W Groups
- RX24T, RX24U Groups
- RX26T Group
- RX64M Group
- RX65N, RX651 Groups
- RX660 Group
- RX66T Group
- RX66N Group
- RX671 Group
- RX71M Group
- RX72T Group
- RX72M Group
- RX72N Group

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

## **Target Compilers**

- Renesas Electronics C/C++ Compiler Package for RX Family
- GCC for Renesas RX
- IAR C/C++ Compiler for Renesas RX

For details of the confirmed operation contents of each compiler, refer to "6.3 Operating Test Environment".



## Contents

| 1. Ov      | erview                                                            | 4   |
|------------|-------------------------------------------------------------------|-----|
| 1.1        | SCI Simple I <sup>2</sup> C Mode FIT Module                       | 4   |
| 1.2        | Outline of the API                                                | 4   |
| 1.3        | Overview of SCI Simple I <sup>2</sup> C Mode FIT Module           | 5   |
| 1.3        | 3.1 Specifications of SCI Simple I <sup>2</sup> C Mode FIT Module | 5   |
| 1.3        | 3.2 Master Transmission                                           | . 6 |
| 1.3        | 3.3 Master Reception                                              | 10  |
| 1.3        | 3.4 State Transition                                              | 13  |
| 1.3        | 3.5 Flags when Transitioning States                               | 14  |
| 1.4        | Using SCI Simple I2C Mode FIT Module                              | 14  |
| 1.4        | 4.1 Using SCI Simple I2C Mode FIT Module in C++ project           | 14  |
|            |                                                                   |     |
|            | I Information                                                     |     |
| 2.1        | Hardware Requirements                                             |     |
| 2.2        | Software Requirements                                             |     |
| 2.3        | Supported Toolchains                                              |     |
| 2.4        | Usage of Interrupt Vector                                         |     |
| 2.5        | Header Files                                                      |     |
| 2.6        | Integer Types                                                     |     |
| 2.7        | Configuration Overview                                            |     |
| 2.8        | Code Size                                                         |     |
| 2.9        | Parameters                                                        | 28  |
| 2.10       | Return Values                                                     |     |
| 2.11       | Adding the FIT Module to Your Project                             | 29  |
| 2.12       | "for", "while" and "do while" statements                          | 30  |
| 3. AP      | I Eurotiona                                                       | 21  |
| -          | I Functions<br>R_SCI_IIC_Open()                                   |     |
| 3.1        |                                                                   |     |
| 3.2<br>3.3 | R_SCI_IIC_MasterSend()<br>R SCI_IIC_MasterReceive()               |     |
| 3.3<br>3.4 | R_SCI_IIC_INASIERRECEIVE()                                        |     |
|            |                                                                   |     |
| 3.5        | R_SCI_IIC_GetStatus()                                             |     |
| 3.6<br>3.7 | R_SCI_IIC_Control()<br>R_SCI_IIC_GetVersion()                     |     |
| 3.7        |                                                                   | 49  |
| 4. Pir     | n Settings                                                        | 50  |
|            | <u> </u>                                                          |     |
|            | mo Projects                                                       |     |
| 5.1        | sciiic_send_demo_rskrx64m, sciiic_send_demo_rskrx64m_gcc          |     |
| 5.2        | scilic_receive_demo_rskrx64m, scilic_receive_demo_rskrx64m_gcc    |     |
| 5.3        | sciiic_send_demo_rskrx231, sciiic_send_demo_rskrx231_gcc          |     |
| 5.4        | sciiic_receive_demo_rskrx231, sciiic_receive_demo_rskrx231_gcc    |     |
| 5.5        | sciiic_send_demo_rskrx671, sciiic_send_demo_rskrx671_gcc          |     |
| 5.6        | scilic_receive_demo_rskrx671, scilic_receive_demo_rskrx671_gcc    | 54  |
| 5.7        | sciiic_send_demo_rskrx72n, sciiic_send_demo_rskrx72n_gcc          | 54  |
| 5.8        | sciiic_receive_demo_rskrx72n, sciiic_receive_demo_rskrx72n_gcc    | 54  |

|    | 5.9     | Add   | ling a Demo to a Workspace                                         | 54 |
|----|---------|-------|--------------------------------------------------------------------|----|
|    | 5.10    | Dov   | vnloading Demo Projects                                            | 55 |
|    |         |       |                                                                    |    |
| 6. | Арр     |       | ices                                                               |    |
|    | 6.1     | Cor   | nmunication Method                                                 |    |
|    | 6.1     | 1.1   | States for API Operation                                           |    |
|    | 6.1     | 1.2   | Events During API Operation                                        |    |
|    | 6.1     | 1.3   | Protocol State Transitions                                         |    |
|    | 6.1     | 1.4   | Protocol State Transition Table                                    | 61 |
|    | 6.1     | 1.5   | Functions Used on Protocol State Transitions                       | 61 |
|    | 6.1     | 1.6   | Flag States on State Transitions                                   | 62 |
|    | 6.2     | Inte  | rrupt Request Generation Timing                                    | 64 |
|    | 6.2     | 2.1   | Master Transmission                                                | 64 |
|    | 6.2     | 2.2   | Master Reception                                                   | 65 |
|    | 6.2     | 2.3   | Master Transmit/Receive                                            | 66 |
|    | 6.3     | Ope   | erating Test Environment                                           | 67 |
|    | 6.4     | Tro   | ubleshooting                                                       | 77 |
| 7. | Sar     | nple  | Code                                                               |    |
|    | 7.1     | Exa   | mple when Accessing One Slave Device Continuously with One Channel |    |
|    | 7.2     | Exa   | mple when Accessing Two Slave Devices with One Channel             | 82 |
|    | 7.3     | Exa   | mple when Accessing Two Slave Devices with Two Channels            | 87 |
| 8. | Ref     | ferer | ce Documents                                                       | 93 |
| R  | elated  | Тес   | hnical Updates                                                     |    |
| R  | evisior | n His | tory                                                               | 95 |



### 1. Overview

The simple I<sup>2</sup>C module using firmware integration technology (SCI simple I<sup>2</sup>C mode FIT module <sup>(1)</sup>) provides a method to transmit and receive data between the master and slave devices using the SCI. The SCI simple I<sup>2</sup>C mode is in compliance with single master mode of the NXP I<sup>2</sup>C-bus (Inter-IC-Bus) interface.

Note:

1. When the description says "module" in this document, it indicates the SCI simple I<sup>2</sup>C mode FIT module.

Features supported by this module are as follows:

- Single master mode (slave transmission or slave reception is not supported).
- Bus condition waveform generation
- Communication mode can be standard or fast mode and the maximum communication rate is 384 kbps.

### **Limitations**

- This module cannot be used with the DMAC and the DTC.
- This module does not support transmission with 10-bit address.
- Multiple interrupts are not supported.
- API function calls except for the R\_SCI\_IIC\_GetStatus function are disabled in the callback function.
- The I flag must be set to 1 to use interrupts.

- When using SCI (Simple I<sup>2</sup>C Mode) FIT Module and SCI Module Firmware Integration Technology (R01AN1815) in combination, the same channel cannot be used at the same time.

## 1.1 SCI Simple I<sup>2</sup>C Mode FIT Module

This module is implemented in a project and used as the API. Refer to 2.11 Adding the FIT Module to Your Project for details on implementing the module to the project.

### 1.2 Outline of the API

Table 1.1 lists the API Functions.

#### Table 1.1 API Functions

| Item                      | Contents                                                                                                                                                                                              |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R_SCI_IIC_Open()          | The function initializes the SCI simple I <sup>2</sup> C mode FIT module. This function must be called before calling any other API functions.                                                        |
| R_SCI_IIC_MasterSend()    | Starts master transmission. Changes the transmit pattern according to the parameters. Operates batched processing until stop condition generation.                                                    |
| R_SCI_IIC_MasterReceive() | Starts master reception. Changes the receive pattern according to the parameters. Operates batched processing until stop condition generation.                                                        |
| R_SCI_IIC_Close()         | This function completes the simple I <sup>2</sup> C communication and releases the SCI used.                                                                                                          |
| R_SCI_IIC_GetStatus()     | Returns the state of this module.                                                                                                                                                                     |
| R_SCI_IIC_Control()       | This function outputs conditions, Hi-Z from the SSDA pin, and one-shot of the SSCL clock. Also it resets the settings of this module. This function is mainly used when a communication error occurs. |
| R_SCI_IIC_GetVersion()    | Returns the current version of this module.                                                                                                                                                           |



## 1.3 Overview of SCI Simple I<sup>2</sup>C Mode FIT Module

### **1.3.1** Specifications of SCI Simple I<sup>2</sup>C Mode FIT Module

1. This module supports master transmission and reception.

- There are four transmit patterns that can be used for master transmission. Refer to 1.3.2 for details on master transmission.

- Master reception and master transmit/receive can be selected for master reception. Refer to 1.3.3 for details on master reception.

- 2. An interrupt occurs when any of the following operations completes: start condition generation, slave address transmission, data reception, or stop condition generation. In the SCI (simple l<sup>2</sup>C mode) interrupt handling, the communication control function is called and the operation is continued.
- 3. The module supports multiple channels. When the device used has multiple channels, simultaneous communication is available using multiple channels.
- 4. Multiple slave devices on the same channel bus can be controlled. However, while communication is in progress (the period from start condition generation to stop condition generation), communication with other devices is not available. Figure 1.1 shows an Example of Controlling Multiple Slave Devices.



Figure 1.1 Example of Controlling Multiple Slave Devices



### **RX** Family

#### 1.3.2 Master Transmission

Data is transmitted from the master device (master (RX MCU)) to the slave device (slave).

With this module, four patterns of waveforms can be generated for master transmission. A pattern is selected according to the arguments set in the parameters which are members of the I<sup>2</sup>C communication information structure. Refer to 2.9 Parameters for details on the I<sup>2</sup>C communication information structure. Figure 1.2 to Figure 1.5 show the transmit patterns.

(1) Pattern 1

Data is transmitted from the master (RX MCU) to the slave.

A start condition is generated and then the slave address is transmitted. The eighth bit specifies the transfer direction. This bit is set to 0 (write) when transmitting. Then the first data is transmitted. The first data is used when there is data to be transmitted in advance before performing the data transmission. For example, if the slave is an EEPROM, the EEPROM internal address can be transmitted. Next the second data is transmitted. The second data is the data to be written to the slave. When a data transmission has started and all data transmissions have completed, a stop condition is generated, and the bus is released.



SP: Stop condition generation

ACK: Acknowledge: 0

\* A signal with an underline indicates data transmission from the slave to the master.

Figure 1.2 Signals for Pattern 1 of Master Transmission



### (2) Pattern 2

Data is transmitted from the master (RX MCU) to the slave. However, when the first data is not set, transmission for the first data is not performed.

Operations from start condition generation through to slave address transmission are the same as the operations for pattern 1. Then the second data is transmitted without transmitting the first data. When all data transmissions have completed, a stop condition is generated and the bus is released.



### Figure 1.3 Signals for Pattern 2 of Master Transmission

(3) Pattern 3

Operations from start condition generation through to slave address transmission are the same as the operations for pattern 1. When neither the first data nor the second data are set, data transmission is not performed, then a stop condition is generated, and the bus is released.

This pattern is useful for detecting connected devices or when performing acknowledge polling to verify the EEPROM rewriting state.



n: Channel number ST: Start condition generation SP: Stop condition generation ACK: Acknowledge: 0 \* A signal with an underline indicates data transmission from the slave to the master.

Figure 1.4 Signals for Pattern 3 of Master Transmission



#### (4) Pattern 4

After a start condition is generated, when the slave address, first data, and second data are not set, slave address transmission and data transmission are not performed. Then a stop condition is generated and the bus is released.

This pattern is useful for just releasing the bus.



Figure 1.5 Signals for Pattern 4 of Master Transmission

Figure 1.6 shows the procedure of master transmission. The callback function is called after generating a stop condition. Specify the function name in the CallBackFunc of the I<sup>2</sup>C communication information structure member.





Figure 1.6 Example of Master Transmission



### **RX Family**

## 1.3.3 Master Reception

The master (RX MCU) receives data from the slave. This module supports master reception and master transmit/receive. The receive pattern is selected according to the arguments set in the parameters which are members of the I<sup>2</sup>C communication information structure. Refer to 2.9 Parameters for details on the I<sup>2</sup>C communication information structure. Figure 1.7 and Figure 1.8 show receive patterns.

(1) Master Reception

The master (RX MCU) receives data from the slave.

A start condition is generated and then the slave address is transmitted. The eighth bit specifies the transfer direction. This bit is set to 1 (read) when receiving. Then data reception starts. An ACK is transmitted each time 1-byte data is received except the last data. A NACK is transmitted when the last data is received to notify the slave that all data receptions have completed. Then a stop condition is generated and the bus is released.



Figure 1.7 Signals for Master Reception



### (2) Master Transmit/Receive

The master (RX MCU) transmits data to the slave (master transmission). After the transmission completes, a restart condition is generated, the transfer direction is changed to 1 (read), and the master receives data from the slave (master reception).

A start condition is generated and then the slave address is transmitted. The eighth bit is the bit specifies the transfer direction. This bit is set to 0 (write) when transmitting. Then the first data is transmitted. When the data transmission completes, a restart condition is generated and the slave address is transmitted. Then the eighth bit is set to 1 (read) and a data reception starts. An ACK is transmitted each time 1-byte data is received except the last data. A NACK is transmitted when the last data is received to notify the slave that all data receptions have completed. Then a stop condition is generated and the bus is released.



Figure 1.8 Signals for Master Transmit/Receive



Figure 1.9 shows the procedure of master reception. The callback function is called after generating a stop condition. Specify the function name in the CallBackFunc of the I<sup>2</sup>C communication information structure member.



Figure 1.9 Example of Master Reception



### 1.3.4 State Transition

States entered in this module are uninitialized state, idle state, and communicating state.

Figure 1.10 shows the State Transition Diagram.



Figure 1.10 State Transition Diagram



### **RX Family**

### **1.3.5** Flags when Transitioning States

dev\_sts is the device state flag and is one of the I<sup>2</sup>C communication information structure members. The flag stores the communication state of the device. Using this flag enables controlling multiple slaves on the same channel.

Table 1.2 lists the Device State Flags when Transitioning States.

Table 1.2 Device State Flags when Transitioning States

| State                                   | Device State Flag (dev_sts) |
|-----------------------------------------|-----------------------------|
| Uninitialized state                     | SCI_IIC_NO_INIT             |
|                                         | SCI_IIC_IDLE                |
| Idle states                             | SCI_IIC_FINISH              |
|                                         | SCI_IIC_NACK                |
| Communicating (master transmission)     | SCI_IIC_COMMUNICATION       |
| Communicating (master reception)        | SCI_IIC_COMMUNICATION       |
| Communicating (master transmit/receive) | SCI_IIC_COMMUNICATION       |
| Error                                   | SCI_IIC_ERROR               |

## 1.4 Using SCI Simple I2C Mode FIT Module

## 1.4.1 Using SCI Simple I2C Mode FIT Module in C++ project

For C++ project, add SCI Simple I2C Mode FIT module interface header file within extern "C"{}:

```
extern "C"
{
    #include "r_smc_entry.h"
    #include "r_sci_iic_rx_if.h"
}
```



## 2. API Information

This driver API adheres to the Renesas API naming standards.

### 2.1 Hardware Requirements

This driver requires your MCU supports the following feature:

- SCI

### 2.2 Software Requirements

This driver is dependent upon the following packages:

- Board Support Package Module (r\_bsp) Rev.5.20 or higher

### 2.3 Supported Toolchains

This driver has been confirmed to work with the toolchain listed in 6.3 Operating Test Environment for details.

## 2.4 Usage of Interrupt Vector

The TXI interrupt and TEI interrupt are enabled by execution of R\_SCI\_IIC\_MasterSend function or R\_SCI\_IIC\_MasterReceive function (with specified condition)(while the macro definition SCI\_IIC\_CFG\_CHi\_INCLUDE (i = 0 to 12) is 1).

Table 2.1 to Table 2.6 shows the interrupt vectors used by the Simple I<sup>2</sup>C FIT module.

#### Table 2.1 List of Usage of Interrupt Vectors - 1 -

| Device  | Contents                                       |
|---------|------------------------------------------------|
| RX110   | TXI1 interrupt [channel 1] (vector no.: 220)   |
| RX111   | TEI1 interrupt [channel 1] (vector no.: 221)   |
| RX13T   | TXI5 interrupt [channel 5] (vector no.: 224)   |
|         | TEI5 interrupt [channel 5] (vector no.: 225)   |
|         | TXI12 interrupt [channel 12] (vector no.: 240) |
|         | TEI12 interrupt [channel 12] (vector no.: 241) |
| RX113   | TXI0 interrupt [channel 0] (vector no.: 216)   |
| RX130   | TEI0 interrupt [channel 0] (vector no.: 217)   |
| RX230   | TXI1 interrupt [channel 1] (vector no.: 220)   |
| RX231   | TEI1 interrupt [channel 1] (vector no.: 221)   |
| RX23E-B | TXI5 interrupt [channel 5] (vector no.: 224)   |
|         | TEI5 interrupt [channel 5] (vector no.: 225)   |
|         | TXI6 interrupt [channel 6] (vector no.: 228)   |
|         | TEI6 interrupt [channel 6] (vector no.: 229)   |
|         | TXI8 interrupt [channel 8] (vector no.: 232)   |
|         | TEI8 interrupt [channel 8] (vector no.: 233)   |
|         | TXI9 interrupt [channel 9] (vector no.: 236)   |
|         | TEI9 interrupt [channel 9] (vector no.: 237)   |
|         | TXI12 interrupt [channel 12] (vector no.: 240) |
|         | TEI12 interrupt [channel 12] (vector no.: 241) |



| RX140   | TXI1 interrupt [channel 1] (vector no.: 220)   |
|---------|------------------------------------------------|
|         | TEI1 interrupt [channel 1] (vector no.: 221)   |
|         | TXI5 interrupt [channel 5] (vector no.: 224)   |
|         | TEI5 interrupt [channel 5] (vector no.: 225)   |
|         | TXI6 interrupt [channel 6] (vector no.: 228)   |
|         | TEI6 interrupt [channel 6] (vector no.: 229)   |
|         | TXI8 interrupt [channel 8] (vector no.: 232)   |
|         | TEI8 interrupt [channel 8] (vector no.: 233)   |
|         | TXI9 interrupt [channel 9] (vector no.: 236)   |
|         | TEI9 interrupt [channel 9] (vector no.: 237)   |
|         | TXI12 interrupt [channel 12] (vector no.: 240) |
|         | TEI12 interrupt [channel 12] (vector no.: 241) |
| RX23E-A | TXI1 interrupt [channel 1] (vector no.: 220)   |
|         | TEI1 interrupt [channel 1] (vector no.: 221)   |
|         | TXI5 interrupt [channel 5] (vector no.: 224)   |
|         | TEI5 interrupt [channel 5] (vector no.: 225)   |
|         | TXI6 interrupt [channel 6] (vector no.: 228)   |
|         | TEI6 interrupt [channel 6] (vector no.: 229)   |
|         | TXI12 interrupt [channel 12] (vector no.: 240) |
|         | TEI12 interrupt [channel 12] (vector no.: 241) |
| RX23T   | TXI1 interrupt [channel 1] (vector no.: 220)   |
|         | TEI1 interrupt [channel 1] (vector no.: 221)   |
|         | TXI5 interrupt [channel 5] (vector no.: 224)   |
|         | TEI5 interrupt [channel 5] (vector no.: 225)   |



## Table 2.2 List of Usage of Interrupt Vectors - 2 -

| Device | Contents                                                                        |
|--------|---------------------------------------------------------------------------------|
| RX23W  | TXI1 interrupt [channel 1] (vector no.: 220)                                    |
|        | TEI1 interrupt [channel 1] (vector no.: 221)                                    |
|        | TXI5 interrupt [channel 5] (vector no.: 224)                                    |
|        | TEI5 interrupt [channel 5] (vector no.: 225)                                    |
|        | TXI8 interrupt [channel 8] (vector no.: 232)                                    |
|        | TEI8 interrupt [channel 8] (vector no.: 233)                                    |
|        | TXI12 interrupt [channel 12] (vector no.: 240)                                  |
|        | TEI12 interrupt [channel 12] (vector no.: 241)                                  |
| RX24T  | TXI1 interrupt [channel 1] (vector no.: 220)                                    |
|        | TEI1 interrupt [channel 1] (vector no.: 221)                                    |
|        | TXI5 interrupt [channel 5] (vector no.: 224)                                    |
|        | TEI5 interrupt [channel 5] (vector no.: 225)                                    |
|        | TXI6 interrupt [channel 6] (vector no.: 228)                                    |
|        | TEI6 interrupt [channel 6] (vector no.: 229)                                    |
| RX24U  | TXI1 interrupt [channel 1] (vector no.: 220)                                    |
|        | TEI1 interrupt [channel 1] (vector no.: 221)                                    |
|        | TXI5 interrupt [channel 5] (vector no.: 224)                                    |
|        | TEI5 interrupt [channel 5] (vector no.: 225)                                    |
|        | TXI6 interrupt [channel 6] (vector no.: 228)                                    |
|        | TEI6 interrupt [channel 6] (vector no.: 229)                                    |
|        | TXI8 interrupt [channel 8] (vector no.: 232)                                    |
|        | TEI8 interrupt [channel 8] (vector no.: 233)                                    |
|        | TXI9 interrupt [channel 9] (vector no.: 236)                                    |
|        | TEI9 interrupt [channel 9] (vector no.: 237)                                    |
|        | TXI11 interrupt [channel 11] (vector no.: 252)                                  |
|        | TEI11 interrupt [channel 11] (vector no.: 253)                                  |
| RX64M  | TXI0 interrupt [channel 0] (vector no.: 59)                                     |
| RX71M  | TXI1 interrupt [channel 1] (vector no.: 61)                                     |
|        | TXI2 interrupt [channel 2] (vector no.: 63)                                     |
|        | TXI3 interrupt [channel 3] (vector no.: 81)                                     |
|        | TXI4 interrupt [channel 4] (vector no.: 83)                                     |
|        | TXI5 interrupt [channel 5] (vector no.: 85)                                     |
|        | TXI6 interrupt [channel 6] (vector no.: 87)                                     |
|        | TXI7 interrupt [channel 7] (vector no.: 99)                                     |
|        | TXI12 interrupt [channel 12] (vector no.: 117)                                  |
|        | GROUPBL0 interrupt (vector no.: 110)                                            |
|        | • TEI0 interrupt [channel 0] (group interrupt source no.: 0)                    |
|        | • TEI1 interrupt [channel 1] (group interrupt source no.: 2)                    |
|        | • TEI2 interrupt [channel 2] (group interrupt source no.: 4)                    |
|        | • TEI3 interrupt [channel 3] (group interrupt source no.: 6)                    |
|        | • TEI4 interrupt [channel 4] (group interrupt source no.: 8)                    |
|        | • TEI5 interrupt [channel 5] (group interrupt source no.: 10)                   |
|        | <ul> <li>TEI6 interrupt [channel 6] (group interrupt source no.: 12)</li> </ul> |
|        | • TEI7 interrupt [channel 7] (group interrupt source no.: 14)                   |
|        | • TEI12 interrupt [channel 12] (group interrupt source no.: 16)                 |

## Table 2.3 List of Usage of Interrupt Vectors - 3 -

| RX65N       TXI0 interrupt [channel 0] (vector no.: 59)         RX651       TXI1 interrupt [channel 1] (vector no.: 61)         RX660       TXI2 interrupt [channel 2] (vector no.: 63)         RX671       TXI3 interrupt [channel 3] (vector no.: 83)         TXI4 interrupt [channel 4] (vector no.: 83)         TXI5 interrupt [channel 5] (vector no.: 85)         TXI6 interrupt [channel 6] (vector no.: 87)         TXI7 interrupt [channel 8] (vector no.: 101)         TXI9 interrupt [channel 9] (vector no.: 103)         TXI10 interrupt [channel 10] (vector no.: 105)         TXI11 interrupt [channel 10] (vector no.: 115)         TXI12 interrupt [channel 1] (vector no.: 117)         GROUPBL0 interrupt [channel 0] (group interrupt source no.: 0)         TEI2 interrupt [channel 1] (group interrupt source no.: 4)         TEI3 interrupt [channel 3] (group interrupt source no.: 6)         TEI4 interrupt [channel 3] (group interrupt source no.: 10)         TEI5 interrupt [channel 3] (group interrupt source no.: 10)         TEI5 interrupt [channel 5] (group interrupt source no.: 110)         TEI5 interrupt [channel 6] (group interrupt source no.: 10)         TEI5 interrupt [channel 3] (group interrupt source no.: 10)         TEI5 interrupt [channel 6] (group interrupt source no.: 12)         TEI6 interrupt [channel 7] (group interrupt source no.: 14)         TEI12 interrupt [channel 8] (group interrup                                                                                                                                                 | Device | Contents                                                      |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------------------------------------------------------------|
| RX660       TXI2 interrupt [channel 2] (vector no.: 63)         RX671       TXI3 interrupt [channel 3] (vector no.: 81)         TXI4 interrupt [channel 4] (vector no.: 83)       TXI5 interrupt [channel 5] (vector no.: 87)         TXI7 interrupt [channel 7] (vector no.: 87)       TXI7 interrupt [channel 8] (vector no.: 101)         TXI9 interrupt [channel 9] (vector no.: 103)       TXI10 interrupt [channel 9] (vector no.: 103)         TXI10 interrupt [channel 10] (vector no.: 103)       TXI11 interrupt [channel 10] (vector no.: 105)         TXI12 interrupt [channel 10] (vector no.: 115)       TXI12 interrupt [channel 1] (vector no.: 117)         GROUPBL0 interrupt (vector no.: 110)       TEI0 interrupt [channel 2] (group interrupt source no.: 0)         TEI2 interrupt [channel 3] (group interrupt source no.: 4)       TEI3 interrupt [channel 3] (group interrupt source no.: 4)         TEI3 interrupt [channel 3] (group interrupt source no.: 6)       TEI4 interrupt [channel 3] (group interrupt source no.: 10)         TEI5 interrupt [channel 6] (group interrupt source no.: 10)       TEI6 interrupt [channel 6] (group interrupt source no.: 12)         TEI6 interrupt [channel 6] (group interrupt source no.: 12)       TEI6 interrupt [channel 6] (group interrupt source no.: 14)         TEI2 interrupt [channel 7] (group interrupt source no.: 14)       TEI12 interrupt [channel 7] (group interrupt source no.: 14)         TEI2 interrupt [channel 7] (group interrupt source no.: 14)       TEI12 interrupt [channel 7] (group interrupt source no | RX65N  | TXI0 interrupt [channel 0] (vector no.: 59)                   |
| RX671TXI3 interrupt [channel 3] (vector no.: 81)<br>TXI4 interrupt [channel 4] (vector no.: 83)<br>TXI5 interrupt [channel 5] (vector no.: 83)<br>TXI6 interrupt [channel 6] (vector no.: 87)<br>TXI7 interrupt [channel 7] (vector no.: 99)<br>TXI8 interrupt [channel 7] (vector no.: 101)<br>TXI9 interrupt [channel 9] (vector no.: 103)<br>TXI10 interrupt [channel 9] (vector no.: 103)<br>TXI11 interrupt [channel 10] (vector no.: 105)<br>TXI11 interrupt [channel 12] (vector no.: 115)<br>TXI12 interrupt [channel 12] (vector no.: 117)GROUPBL0 interrupt (vector no.: 110)<br>• TEI0 interrupt [channel 3] (group interrupt source no.: 0)<br>• TEI1 interrupt [channel 3] (group interrupt source no.: 4)<br>• TEI3 interrupt [channel 3] (group interrupt source no.: 6)<br>• TEI4 interrupt [channel 3] (group interrupt source no.: 10)<br>• TEI6 interrupt [channel 3] (group interrupt source no.: 10)<br>• TEI6 interrupt [channel 3] (group interrupt source no.: 10)<br>• TEI3 interrupt [channel 3] (group interrupt source no.: 10)<br>• TEI6 interrupt [channel 3] (group interrupt source no.: 110)<br>• TEI6 interrupt [channel 3] (group interrupt source no.: 110)<br>• TEI6 interrupt [channel 3] (group interrupt source no.: 10)<br>• TEI6 interrupt [channel 3] (group interrupt source no.: 110)<br>• TEI6 interrupt [channel 3] (group interrupt source no.: 111)<br>• TEI12 interrupt [channel 7] (group interrupt source no.: 14)                                                                                                                                          | RX651  | TXI1 interrupt [channel 1] (vector no.: 61)                   |
| TXI4 interrupt [channel 4] (vector no.: 83)TXI5 interrupt [channel 5] (vector no.: 85)TXI6 interrupt [channel 6] (vector no.: 87)TXI7 interrupt [channel 7] (vector no.: 99)TXI8 interrupt [channel 8] (vector no.: 101)TXI9 interrupt [channel 9] (vector no.: 103)TXI10 interrupt [channel 9] (vector no.: 105)TXI11 interrupt [channel 10] (vector no.: 115)TXI12 interrupt [channel 12] (vector no.: 117)GROUPBL0 interrupt [channel 1] (group interrupt source no.: 0)TEI1 interrupt [channel 3] (group interrupt source no.: 4)TEI2 interrupt [channel 3] (group interrupt source no.: 6)TEI3 interrupt [channel 4] (group interrupt source no.: 10)TEI4 interrupt [channel 4] (group interrupt source no.: 10)TEI5 interrupt [channel 6] (group interrupt source no.: 10)TEI5 interrupt [channel 7] (group interrupt source no.: 10)TEI5 interrupt [channel 7] (group interrupt source no.: 10)TEI5 interrupt [channel 6] (group interrupt source no.: 10)TEI6 interrupt [channel 7] (group interrupt source no.: 12)TEI7 interrupt [channel 7] (group interrupt source no.: 14)TEI7 interrupt [channel 7] (group interrupt source no.: 14)TEI12 interrupt [channel 7] (group interrupt source no.: 16)                                                                                                                                                                                                                                                                                                                                                                                                  | RX660  | TXI2 interrupt [channel 2] (vector no.: 63)                   |
| TXI5 interrupt [channel 5] (vector no.: 85)TXI6 interrupt [channel 6] (vector no.: 87)TXI7 interrupt [channel 7] (vector no.: 99)TXI8 interrupt [channel 8] (vector no.: 101)TXI9 interrupt [channel 9] (vector no.: 103)TXI10 interrupt [channel 10] (vector no.: 105)TXI11 interrupt [channel 11] (vector no.: 115)TXI2 interrupt [channel 12] (vector no.: 117)GROUPBL0 interrupt (vector no.: 110)• TEI0 interrupt [channel 0] (group interrupt source no.: 0)• TEI1 interrupt [channel 1] (group interrupt source no.: 4)• TEI2 interrupt [channel 3] (group interrupt source no.: 6)• TEI3 interrupt [channel 3] (group interrupt source no.: 10)• TEI5 interrupt [channel 4] (group interrupt source no.: 10)• TEI5 interrupt [channel 5] (group interrupt source no.: 12)• TEI6 interrupt [channel 6] (group interrupt source no.: 14)• TEI7 interrupt [channel 7] (group interrupt source no.: 14)• TEI12 interrupt [channel 7] (group interrupt source no.: 16)• TEI2 interrupt [channel 7] (group interrupt source no.: 16)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RX671  | TXI3 interrupt [channel 3] (vector no.: 81)                   |
| TXI6 interrupt [channel 6] (vector no.: 87)TXI7 interrupt [channel 7] (vector no.: 99)TXI8 interrupt [channel 8] (vector no.: 101)TXI9 interrupt [channel 9] (vector no.: 103)TXI10 interrupt [channel 10] (vector no.: 105)TXI11 interrupt [channel 11] (vector no.: 115)TXI12 interrupt [channel 12] (vector no.: 117)GROUPBL0 interrupt (vector no.: 110)• TEI0 interrupt [channel 0] (group interrupt source no.: 0)• TEI1 interrupt [channel 1] (group interrupt source no.: 4)• TEI2 interrupt [channel 2] (group interrupt source no.: 4)• TEI3 interrupt [channel 3] (group interrupt source no.: 6)• TEI4 interrupt [channel 4] (group interrupt source no.: 10)• TEI5 interrupt [channel 5] (group interrupt source no.: 10)• TEI6 interrupt [channel 6] (group interrupt source no.: 10)• TEI5 interrupt [channel 7] (group interrupt source no.: 12)• TEI6 interrupt [channel 6] (group interrupt source no.: 14)• TEI2 interrupt [channel 7] (group interrupt source no.: 14)• TEI2 interrupt [channel 7] (group interrupt source no.: 16)• TEI2 interrupt [channel 7] (group interrupt source no.: 24)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        | TXI4 interrupt [channel 4] (vector no.: 83)                   |
| <ul> <li>TXI7 interrupt [channel 7] (vector no.: 99)</li> <li>TXI8 interrupt [channel 8] (vector no.: 101)</li> <li>TXI9 interrupt [channel 9] (vector no.: 103)</li> <li>TXI10 interrupt [channel 10] (vector no.: 105)</li> <li>TXI11 interrupt [channel 11] (vector no.: 115)</li> <li>TXI12 interrupt [channel 12] (vector no.: 117)</li> <li>GROUPBL0 interrupt (vector no.: 110)</li> <li>TEI0 interrupt [channel 0] (group interrupt source no.: 0)</li> <li>TEI1 interrupt [channel 1] (group interrupt source no.: 2)</li> <li>TEI2 interrupt [channel 2] (group interrupt source no.: 4)</li> <li>TEI3 interrupt [channel 3] (group interrupt source no.: 6)</li> <li>TEI4 interrupt [channel 4] (group interrupt source no.: 10)</li> <li>TEI5 interrupt [channel 5] (group interrupt source no.: 12)</li> <li>TEI6 interrupt [channel 6] (group interrupt source no.: 14)</li> <li>TEI7 interrupt [channel 7] (group interrupt source no.: 14)</li> <li>TEI12 interrupt [channel 7] (group interrupt source no.: 16)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |        | TXI5 interrupt [channel 5] (vector no.: 85)                   |
| TXI8 interrupt [channel 8] (vector no.: 101)TXI9 interrupt [channel 9] (vector no.: 103)TXI10 interrupt [channel 10] (vector no.: 105)TXI11 interrupt [channel 11] (vector no.: 115)TXI12 interrupt [channel 12] (vector no.: 117)GROUPBL0 interrupt (vector no.: 110)• TEI0 interrupt [channel 0] (group interrupt source no.: 0)• TEI1 interrupt [channel 1] (group interrupt source no.: 2)• TEI2 interrupt [channel 2] (group interrupt source no.: 4)• TEI3 interrupt [channel 3] (group interrupt source no.: 6)• TEI4 interrupt [channel 4] (group interrupt source no.: 10)• TEI5 interrupt [channel 5] (group interrupt source no.: 10)• TEI6 interrupt [channel 6] (group interrupt source no.: 12)• TEI7 interrupt [channel 7] (group interrupt source no.: 14)• TEI12 interrupt [channel 7] (group interrupt source no.: 14)• TEI12 interrupt [channel 7] (group interrupt source no.: 14)• TEI12 interrupt [channel 7] (group interrupt source no.: 16)GROUPBL1 interrupt (vector no.: 111)• TEI8 interrupt [channel 8] (group interrupt source no.: 24)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |        | TXI6 interrupt [channel 6] (vector no.: 87)                   |
| TXI9 interrupt [channel 9] (vector no.: 103)TXI10 interrupt [channel 10] (vector no.: 105)TXI11 interrupt [channel 11] (vector no.: 115)TXI12 interrupt [channel 12] (vector no.: 117)GROUPBL0 interrupt (vector no.: 110)• TEI0 interrupt [channel 0] (group interrupt source no.: 0)• TEI1 interrupt [channel 1] (group interrupt source no.: 2)• TEI2 interrupt [channel 2] (group interrupt source no.: 4)• TEI3 interrupt [channel 3] (group interrupt source no.: 6)• TEI4 interrupt [channel 4] (group interrupt source no.: 10)• TEI5 interrupt [channel 5] (group interrupt source no.: 10)• TEI6 interrupt [channel 6] (group interrupt source no.: 12)• TEI7 interrupt [channel 7] (group interrupt source no.: 14)• TEI2 interrupt [channel 7] (group interrupt source no.: 12)• TEI6 interrupt [channel 7] (group interrupt source no.: 12)• TEI7 interrupt [channel 7] (group interrupt source no.: 14)• TEI2 interrupt [channel 7] (group interrupt source no.: 16)• TEI2 interrupt [channel 7] (group interrupt source no.: 16)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        | TXI7 interrupt [channel 7] (vector no.: 99)                   |
| <ul> <li>TXI10 interrupt [channel 10] (vector no.: 105)</li> <li>TXI11 interrupt [channel 11] (vector no.: 115)</li> <li>TXI12 interrupt [channel 12] (vector no.: 117)</li> <li>GROUPBL0 interrupt (vector no.: 110)</li> <li>TEI0 interrupt [channel 0] (group interrupt source no.: 0)</li> <li>TEI1 interrupt [channel 1] (group interrupt source no.: 2)</li> <li>TEI2 interrupt [channel 2] (group interrupt source no.: 4)</li> <li>TEI3 interrupt [channel 3] (group interrupt source no.: 6)</li> <li>TEI4 interrupt [channel 4] (group interrupt source no.: 10)</li> <li>TEI5 interrupt [channel 5] (group interrupt source no.: 12)</li> <li>TEI6 interrupt [channel 6] (group interrupt source no.: 14)</li> <li>TEI7 interrupt [channel 7] (group interrupt source no.: 14)</li> <li>TEI12 interrupt [channel 7] (group interrupt source no.: 16)</li> <li>GROUPBL1 interrupt (vector no.: 111)</li> <li>TEI8 interrupt [channel 8] (group interrupt source no.: 24)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |        | TXI8 interrupt [channel 8] (vector no.: 101)                  |
| <ul> <li>TXI11 interrupt [channel 11] (vector no.: 115)<br/>TXI12 interrupt [channel 12] (vector no.: 117)</li> <li>GROUPBL0 interrupt (vector no.: 110)</li> <li>TEI0 interrupt [channel 0] (group interrupt source no.: 0)</li> <li>TEI1 interrupt [channel 1] (group interrupt source no.: 2)</li> <li>TEI2 interrupt [channel 2] (group interrupt source no.: 4)</li> <li>TEI3 interrupt [channel 3] (group interrupt source no.: 6)</li> <li>TEI4 interrupt [channel 4] (group interrupt source no.: 8)</li> <li>TEI5 interrupt [channel 5] (group interrupt source no.: 10)</li> <li>TEI6 interrupt [channel 6] (group interrupt source no.: 12)</li> <li>TEI7 interrupt [channel 7] (group interrupt source no.: 14)</li> <li>TEI12 interrupt [channel 7] (group interrupt source no.: 16)</li> <li>GROUPBL1 interrupt (vector no.: 111)</li> <li>TEI8 interrupt [channel 8] (group interrupt source no.: 24)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        | TXI9 interrupt [channel 9] (vector no.: 103)                  |
| TXI12 interrupt [channel 12] (vector no.: 117)GROUPBL0 interrupt (vector no.: 110)• TEI0 interrupt [channel 0] (group interrupt source no.: 0)• TEI1 interrupt [channel 1] (group interrupt source no.: 2)• TEI2 interrupt [channel 2] (group interrupt source no.: 4)• TEI3 interrupt [channel 3] (group interrupt source no.: 6)• TEI4 interrupt [channel 4] (group interrupt source no.: 8)• TEI5 interrupt [channel 5] (group interrupt source no.: 10)• TEI6 interrupt [channel 6] (group interrupt source no.: 12)• TEI7 interrupt [channel 7] (group interrupt source no.: 14)• TEI12 interrupt [channel 7] (group interrupt source no.: 14)• TEI12 interrupt [channel 7] (group interrupt source no.: 16)GROUPBL1 interrupt (vector no.: 111)• TEI8 interrupt [channel 8] (group interrupt source no.: 24)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        | TXI10 interrupt [channel 10] (vector no.: 105)                |
| <ul> <li>GROUPBL0 interrupt (vector no.: 110)</li> <li>TEI0 interrupt [channel 0] (group interrupt source no.: 0)</li> <li>TEI1 interrupt [channel 1] (group interrupt source no.: 2)</li> <li>TEI2 interrupt [channel 2] (group interrupt source no.: 4)</li> <li>TEI3 interrupt [channel 3] (group interrupt source no.: 6)</li> <li>TEI4 interrupt [channel 4] (group interrupt source no.: 8)</li> <li>TEI5 interrupt [channel 5] (group interrupt source no.: 10)</li> <li>TEI6 interrupt [channel 6] (group interrupt source no.: 12)</li> <li>TEI7 interrupt [channel 7] (group interrupt source no.: 14)</li> <li>TEI12 interrupt [channel 12] (group interrupt source no.: 14)</li> <li>TEI12 interrupt [channel 7] (group interrupt source no.: 16)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        | TXI11 interrupt [channel 11] (vector no.: 115)                |
| <ul> <li>TEI0 interrupt [channel 0] (group interrupt source no.: 0)</li> <li>TEI1 interrupt [channel 1] (group interrupt source no.: 2)</li> <li>TEI2 interrupt [channel 2] (group interrupt source no.: 4)</li> <li>TEI3 interrupt [channel 3] (group interrupt source no.: 6)</li> <li>TEI4 interrupt [channel 4] (group interrupt source no.: 8)</li> <li>TEI5 interrupt [channel 5] (group interrupt source no.: 10)</li> <li>TEI6 interrupt [channel 6] (group interrupt source no.: 12)</li> <li>TEI7 interrupt [channel 7] (group interrupt source no.: 14)</li> <li>TEI12 interrupt [channel 12] (group interrupt source no.: 16)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        | TXI12 interrupt [channel 12] (vector no.: 117)                |
| <ul> <li>TEI0 interrupt [channel 0] (group interrupt source no.: 0)</li> <li>TEI1 interrupt [channel 1] (group interrupt source no.: 2)</li> <li>TEI2 interrupt [channel 2] (group interrupt source no.: 4)</li> <li>TEI3 interrupt [channel 3] (group interrupt source no.: 6)</li> <li>TEI4 interrupt [channel 4] (group interrupt source no.: 8)</li> <li>TEI5 interrupt [channel 5] (group interrupt source no.: 10)</li> <li>TEI6 interrupt [channel 6] (group interrupt source no.: 12)</li> <li>TEI7 interrupt [channel 7] (group interrupt source no.: 14)</li> <li>TEI12 interrupt [channel 12] (group interrupt source no.: 16)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        | GROUPBL0 interrupt (vector no.: 110)                          |
| <ul> <li>TEI1 interrupt [channel 1] (group interrupt source no.: 2)</li> <li>TEI2 interrupt [channel 2] (group interrupt source no.: 4)</li> <li>TEI3 interrupt [channel 3] (group interrupt source no.: 6)</li> <li>TEI4 interrupt [channel 4] (group interrupt source no.: 8)</li> <li>TEI5 interrupt [channel 5] (group interrupt source no.: 10)</li> <li>TEI6 interrupt [channel 6] (group interrupt source no.: 12)</li> <li>TEI7 interrupt [channel 7] (group interrupt source no.: 14)</li> <li>TEI12 interrupt [channel 12] (group interrupt source no.: 16)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |                                                               |
| <ul> <li>TEI2 interrupt [channel 2] (group interrupt source no.: 4)</li> <li>TEI3 interrupt [channel 3] (group interrupt source no.: 6)</li> <li>TEI4 interrupt [channel 4] (group interrupt source no.: 8)</li> <li>TEI5 interrupt [channel 5] (group interrupt source no.: 10)</li> <li>TEI6 interrupt [channel 6] (group interrupt source no.: 12)</li> <li>TEI7 interrupt [channel 7] (group interrupt source no.: 14)</li> <li>TEI12 interrupt [channel 12] (group interrupt source no.: 16)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        |                                                               |
| <ul> <li>TEI3 interrupt [channel 3] (group interrupt source no.: 6)</li> <li>TEI4 interrupt [channel 4] (group interrupt source no.: 8)</li> <li>TEI5 interrupt [channel 5] (group interrupt source no.: 10)</li> <li>TEI6 interrupt [channel 6] (group interrupt source no.: 12)</li> <li>TEI7 interrupt [channel 7] (group interrupt source no.: 14)</li> <li>TEI12 interrupt [channel 12] (group interrupt source no.: 16)</li> <li>GROUPBL1 interrupt (vector no.: 111)</li> <li>TEI8 interrupt [channel 8] (group interrupt source no.: 24)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |        |                                                               |
| <ul> <li>TEl4 interrupt [channel 4] (group interrupt source no.: 8)</li> <li>TEl5 interrupt [channel 5] (group interrupt source no.: 10)</li> <li>TEl6 interrupt [channel 6] (group interrupt source no.: 12)</li> <li>TEl7 interrupt [channel 7] (group interrupt source no.: 14)</li> <li>TEl12 interrupt [channel 12] (group interrupt source no.: 16)</li> <li>GROUPBL1 interrupt (vector no.: 111)</li> <li>TEl8 interrupt [channel 8] (group interrupt source no.: 24)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |                                                               |
| <ul> <li>TEI5 interrupt [channel 5] (group interrupt source no.: 10)</li> <li>TEI6 interrupt [channel 6] (group interrupt source no.: 12)</li> <li>TEI7 interrupt [channel 7] (group interrupt source no.: 14)</li> <li>TEI12 interrupt [channel 12] (group interrupt source no.: 16)</li> <li>GROUPBL1 interrupt (vector no.: 111)</li> <li>TEI8 interrupt [channel 8] (group interrupt source no.: 24)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |        |                                                               |
| <ul> <li>TEl6 interrupt [channel 6] (group interrupt source no.: 12)</li> <li>TEI7 interrupt [channel 7] (group interrupt source no.: 14)</li> <li>TEI12 interrupt [channel 12] (group interrupt source no.: 16)</li> <li>GROUPBL1 interrupt (vector no.: 111)</li> <li>TEI8 interrupt [channel 8] (group interrupt source no.: 24)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |                                                               |
| <ul> <li>TEI7 interrupt [channel 7] (group interrupt source no.: 14)</li> <li>TEI12 interrupt [channel 12] (group interrupt source no.: 16)</li> <li>GROUPBL1 interrupt (vector no.: 111)</li> <li>TEI8 interrupt [channel 8] (group interrupt source no.: 24)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |        |                                                               |
| GROUPBL1 interrupt (vector no.: 111)<br>• TEI8 interrupt [channel 8] (group interrupt source no.: 24)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |        |                                                               |
| TEl8 interrupt [channel 8] (group interrupt source no.: 24)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |        | TEI12 interrupt [channel 12] (group interrupt source no.: 16) |
| TEl8 interrupt [channel 8] (group interrupt source no.: 24)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |        | GROUPBL1 interrupt (vector no.: 111)                          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        |                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        |                                                               |
| GROUPAL0 interrupt (vector no.: 112)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        | CROURAL 0 interrupt (vector po : 112)                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        |                                                               |
| <ul> <li>TEI10 Interrupt [channel 10] (group interrupt source no.: 8)</li> <li>TEI11 interrupt [channel 11] (group interrupt source no.: 12)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        |                                                               |



## Table 2.4 List of Usage of Interrupt Vectors - 4 -

| Device | Contents                                                        |
|--------|-----------------------------------------------------------------|
| RX66T  | TXI1 interrupt [channel 1] (vector no.: 61)                     |
| RX72T  | TXI5 interrupt [channel 5] (vector no.: 85)                     |
|        | TXI6 interrupt [channel 6] (vector no.: 87)                     |
|        | TXI8 interrupt [channel 8] (vector no.: 101)                    |
|        | TXI9 interrupt [channel 9] (vector no.: 103)                    |
|        | TXI11 interrupt [channel 11] (vector no.: 115)                  |
|        | TXI12 interrupt [channel 12] (vector no.: 117)                  |
|        | GROUPBL0 interrupt (vector no.: 110)                            |
|        | TEI1 interrupt [channel 1] (group interrupt source no.: 2)      |
|        | TEI5 interrupt [channel 5] (group interrupt source no.: 10)     |
|        | TEI6 interrupt [channel 6] (group interrupt source no.: 12)     |
|        | • TEI12 interrupt [channel 12] (group interrupt source no.: 16) |
|        | GROUPBL1 interrupt (vector no.: 111)                            |
|        | TEI8 interrupt [channel 8] (group interrupt source no.: 24)     |
|        | • TEI9 interrupt [channel 9] (group interrupt source no.: 26)   |
|        | GROUPAL0 interrupt (vector no.: 112)                            |
|        | TEI11 interrupt [channel 11] (group interrupt source no.: 12)   |



## Table 2.5 List of Usage of Interrupt Vectors - 5 -

| Device | Contents                                                        |
|--------|-----------------------------------------------------------------|
| RX66N  | TXI0 interrupt [channel 0] (vector no.: 59)                     |
| RX72M  | TXI1 interrupt [channel 1] (vector no.: 61)                     |
| RX72N  | TXI2 interrupt [channel 2] (vector no.: 63)                     |
|        | TXI3 interrupt [channel 3] (vector no.: 81)                     |
|        | TXI4 interrupt [channel 4] (vector no.: 83)                     |
|        | TXI5 interrupt [channel 5] (vector no.: 85)                     |
|        | TXI6 interrupt [channel 6] (vector no.: 87)                     |
|        | TXI7 interrupt [channel 7] (vector no.: 99)                     |
|        | TXI8 interrupt [channel 8] (vector no.: 101)                    |
|        | TXI9 interrupt [channel 9] (vector no.: 103)                    |
|        | TXI10 interrupt [channel 10] (vector no.: 105)                  |
|        | TXI11 interrupt [channel 11] (vector no.: 115)                  |
|        | TXI12 interrupt [channel 12] (vector no.: 117)                  |
|        |                                                                 |
|        | GROUPBL0 interrupt (vector no.: 110)                            |
|        | • TEI0 interrupt [channel 0] (group interrupt source no.: 0)    |
|        | • TEI1 interrupt [channel 1] (group interrupt source no.: 2)    |
|        | • TEI2 interrupt [channel 2] (group interrupt source no.: 4)    |
|        | • TEI3 interrupt [channel 3] (group interrupt source no.: 6)    |
|        | • TEI4 interrupt [channel 4] (group interrupt source no.: 8)    |
|        | • TEI5 interrupt [channel 5] (group interrupt source no.: 10)   |
|        | • TEI6 interrupt [channel 6] (group interrupt source no.: 12)   |
|        | • TEI12 interrupt [channel 12] (group interrupt source no.: 16) |
|        | GROUPAL0 interrupt (vector no.: 112)                            |
|        | • TEI7 interrupt [channel 7] (group interrupt source no.: 14)   |
|        | • TEI8 interrupt [channel 8] (group interrupt source no.: 24)   |
|        | • TEI9 interrupt [channel 9] (group interrupt source no.: 26)   |
|        | • TEI10 interrupt [channel 10] (group interrupt source no.: 8)  |
|        | • TEI11 interrupt [channel 11] (group interrupt source no.: 12) |
|        |                                                                 |
|        |                                                                 |
| L      |                                                                 |



| Device | Contents                                                      |
|--------|---------------------------------------------------------------|
| RX26T  | TXI1 interrupt [channel 1] (vector no.: 61)                   |
|        | TXI5 interrupt [channel 5] (vector no.: 85)                   |
|        | TXI6 interrupt [channel 6] (vector no.: 87)                   |
|        | TXI12 interrupt [channel 12] (vector no.: 117)                |
|        | GROUPBL0 interrupt (vector no.: 110)                          |
|        | TEI1 interrupt [channel 1] (group interrupt source no.: 2)    |
|        | TEI5 interrupt [channel 5] (group interrupt source no.: 10)   |
|        | TEI6 interrupt [channel 6] (group interrupt source no.: 12)   |
|        | TEI12 interrupt [channel 12] (group interrupt source no.: 16) |
|        |                                                               |
|        |                                                               |



## 2.5 Header Files

All API calls and their supporting interface definitions are located in r\_sci\_iic\_rx\_if.h.

## 2.6 Integer Types

This project uses ANSI C99. These types are defined in stdint.h.



## 2.7 Configuration Overview

The configuration options in this module are specified in r\_sci\_iic\_rx\_config.h and r\_sci\_iic\_rx\_pin\_config.h. The option names and setting values are listed in the table below.

| Configuration options in <i>r_sci_iic_rx_config.h</i> (1/2)                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| <pre>SCI_IIC_CFG_PARAM_CHECKING_ENABLE - Default value = 1 SCI_IIC_CFG_CHi_INCLUDED i = 0 to 12 - When i = 0 to 12, the default value = 0</pre> | <ul> <li>Selectable whether to include parameter checking in the code.</li> <li>When this is set to 0, parameter checking is omitted.</li> <li>When this is set to 1, parameter checking is included.</li> <li>Selectable whether to use available channels.</li> <li>When this is set to 0, relevant processes for the channel are omitted from the code.</li> <li>When this is set to 1, relevant processes for the channel are included in the code.</li> <li>To use a channel, please change the definition value of the channel to be used to 1.</li> </ul>                                                                                             |  |  |  |  |  |  |
| SCI_IIC_CFG_CHi_BITRATE_BPS<br>i = 0 to 12                                                                                                      | Specifies the bit rate. Specify a value less than or equal to 384000 (384 kbit/sec.).<br>The bit rate setting should be based on this definition value and the clock setting definition value specified by RX Family                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| - Default value = 384000 for all                                                                                                                | Board Support Package Module (BSP FIT module ).<br>Depending on the target device to be used and the BSP FIT module clock setting, the actual bit rate may differ from the expected bit rate.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
| SCI_IIC_CFG_CHi_INT_PRIORITY<br>i = 0 to 12<br>- Default value = 2 for all                                                                      | Specifies interrupt priority levels for condition generation, receive-data-full, transmit-data-empty, and transmit-end interrupts.<br>Specify the level between 1 and 15.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| SCI_IIC_CFG_CHi_DIGITAL_FILTER<br>i = 0 to 12<br>- Default value = 1 for all                                                                    | <ul> <li>Selectable whether to use the noise cancellation function for the SSCL and SSDA input signals.</li> <li>When this is set to 0, the noise cancellation function is disabled.</li> <li>When this is set to 1, the noise cancellation function is enabled.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| SCI_IIC_CFG_CHi_FILTER_CLOCK<br>i = 0 to 12<br>- Default value = 1 for all                                                                      | <ul> <li>Select the sampling clock used for digital noise filter.</li> <li>When this is set to 1, the clock divided by 1 is used.</li> <li>When this is set to 2, the clock divided by 2 is used.</li> <li>When this is set to 3, the clock divided by 4 is used.</li> <li>When this is set to 4, the clock divided by 8 is used.</li> </ul>                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
| SCI_IIC_CFG_CHi_SSDA_DELAY_SELECT<br>i = 0 to 12<br>- Default value = 18 for all                                                                | Select the delay time for output on the SSDA pin relative to the<br>falling edge of the output on the SSCL pin.<br>Specify the delay between 1 and 31.<br>The default value is a value based on PCLK which operates in<br>60 MHz and is the clock source of the on-chip baud rate<br>generator.<br>The SSDA delay time is increased or decreased according to<br>the clock source of the on-chip baud rate generator.<br>When the bit rate or the PCLK frequency is set to low speed,<br>the SSDA falling timing may occur after the SSCL falling timing<br>in the start condition.<br>Confirm and set an appropriate value depending on the user<br>system. |  |  |  |  |  |  |



| Configuration options in <i>r_sci_iic_rx_config.h</i> (2/2)            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| SCI_IIC_CFG_BUS_CHECK_COUNTER<br>i = 0 to 12<br>- Default value = 1000 | Specifies the timeout counter (number of times to perform bus<br>checking) when the simple I <sup>2</sup> C API function performs bus<br>checking.<br>Specify a value less than or equal to 0xFFFFFFF.<br>The bus checking is performed after generating each condition<br>using the simple I <sup>2</sup> C control function (R_SCI_IIC_Control<br>function).<br>With the bus checking, the timeout counter is decremented<br>after generating each condition. When the counter reaches 0,<br>the API determines that a timeout has occurred and returns an<br>error (Busy) as the return value.<br>* The timeout counter is used for the bus not to be locked by<br>the bus lock or others. Therefore specify the value greater<br>than or equal to the time for that the other device holds the<br>SCL pin low. |  |  |  |  |  |
|                                                                        | Setting time for the timeout (ns) $\approx (\frac{1}{ICLK} (Hz)) \times counter value \times 10$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| SCI_IIC_CFG_PORT_SETTING_PROCESSING<br>- Default value = 1             | <ul> <li>Specifies whether to include processing for port setting <sup>(*)</sup> in the code.</li> <li>* Processing for port setting is the setting to use ports selected by R_SCI_IIC_CFG_SCIi_SSCLi_PORT, R_SCI_IIC_CFG_SCIi_SSDAi_PORT, and R_SCI_IIC_CFG_SCIi_SSDAi_PORT, and R_SCI_IIC_CFG_SCIi_SSDAi_BIT as pins SSCL and SSDA.</li> <li>When this is set to 0, processing for port setting is omitted from the code.</li> <li>When this is set to 1, processing for port setting is included in the code.</li> <li>When you assume this setting 0, please set four definitions mentioned above.</li> </ul>                                                                                                                                                                                                  |  |  |  |  |  |



| Configuration options in <i>r_sci_iic_rx_pin_config.h</i> (1/2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                              |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| <pre>R_SCI_IIC_CFG_SCIi_SSCLi_PORT<br/>i = 0 to 12<br/>- When i = 0, the default value = `2'<br/>- When i = 1, the default value = `1'<br/>- When i = 2, the default value = `5'<br/>- When i = 3, the default value = `2'<br/>- When i = 4, the default value = `B'<br/>- When i = 5, the default value = `B'<br/>- When i = 6, the default value = `B'<br/>- When i = 7, the default value = `9'<br/>- When i = 8, the default value = `C'<br/>- When i = 9, the default value = `B'<br/>- When i = 10, the default value = `8'<br/>- When i = 11, the default value = `7'<br/>- When i = 12, the default value = `E'</pre> | Selects port groups used as the SSCL pins.<br>Specify the value as an ASCII code in the range<br>'0' to 'K'. |  |  |  |  |  |  |
| <pre>R_SCI_IIC_CFG_SCIi_SSCLi_BIT<br/>i = 0 to 12<br/>- When i = 0, the default value = `1'<br/>- When i = 1, the default value = `5'<br/>- When i = 2, the default value = `2'<br/>- When i = 3, the default value = `5'<br/>- When i = 4, the default value = `0'<br/>- When i = 5, the default value = `1'<br/>- When i = 6, the default value = `1'<br/>- When i = 6, the default value = `1'<br/>- When i = 7, the default value = `2'<br/>- When i = 8, the default value = `6'<br/>- When i = 10, the default value = `1'<br/>- When i = 11, the default value = `6'<br/>- When i = 12, the default value = `2'</pre>  | Selects pins used as the SSCL pins.<br>Specify the value as an ASCII code in the range<br>'0' to '7'.        |  |  |  |  |  |  |
| <pre>R_SCI_IIC_CFG_SCIi_SSDAi_PORT<br/>i = 0 to 12<br/>- When i = 0, the default value = `2'<br/>- When i = 1, the default value = `1'<br/>- When i = 2, the default value = `5'<br/>- When i = 3, the default value = `2'<br/>- When i = 4, the default value = `B'<br/>- When i = 5, the default value = `B'<br/>- When i = 6, the default value = `B'<br/>- When i = 7, the default value = `9'<br/>- When i = 8, the default value = `2'<br/>- When i = 9, the default value = `C'<br/>- When i = 10, the default value = `8'<br/>- When i = 11, the default value = `7'<br/>- When i = 12, the default value = `E'</pre> | Selects port groups used as the SSDA pin.<br>Specify the value as an ASCII code in the range<br>'0' to 'K'.  |  |  |  |  |  |  |

| Configuration options in r_sci_iic_rx_pin_config.h (2/2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                             |  |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| <pre>R_SCI_IIC_CFG_SCIi_SSDAi_BIT<br/>i = 0 to 12<br/>- When i = 0, the default value = `0'<br/>- When i = 1, the default value = `0'<br/>- When i = 2, the default value = `0'<br/>- When i = 3, the default value = `3'<br/>- When i = 4, the default value = `1'<br/>- When i = 5, the default value = `2'<br/>- When i = 6, the default value = `2'<br/>- When i = 7, the default value = `0'<br/>- When i = 8, the default value = `7'<br/>- When i = 9, the default value = `7'<br/>- When i = 10, the default value = `2'<br/>- When i = 11, the default value = `1'</pre> | Selects port groups used as the SSDA pin.<br>Specify the value as an ASCII code in the range<br>'0' to '7'. |  |  |  |  |  |  |



### 2.8 Code Size

Typical code sizes associated with this module are listed below. Information is listed for a single representative device of the RX100 Series, RX200 Series, and RX600 Series, respectively.

The ROM (code and constants) and RAM (global data) sizes are determined by the build-time configuration options described in 2.7 Configuration Overview. The table lists reference values when the C compiler's compile options are set to their default values, as described in 2.3, Supported Toolchains. The compile option default values are optimization level: 2, optimization type: for size, and data endianness: little-endian. The code size varies depending on the C compiler version and compile options.

The values in the table below are confirmed under the following conditions.

Module Revision: r\_sci\_iic\_rx rev2.70

Compiler Version: Renesas Electronics C/C++ Compiler Package for RX Family V3.05.00

(The option of "-lang = c99" is added to the default settings of the integrated development environment.)

GCC for Renesas RX 8.03.00.202204

(The option of "-std=gnu99" is added to the default settings of the integrated development environment.)

IAR C/C++ Compiler for Renesas RX version 4.20.03

(The default settings of the integrated development environment.)

Configuration Options: Default settings

|        |          |                 | ROM, RA                       | M and Stac                       | k Memory U                    | sage                             |                               |                                  |  |
|--------|----------|-----------------|-------------------------------|----------------------------------|-------------------------------|----------------------------------|-------------------------------|----------------------------------|--|
| Device | Catego   | Category        |                               | Memory Used                      |                               |                                  |                               |                                  |  |
|        |          |                 |                               | Renesas Compiler                 |                               | GCC                              |                               | IAR Compiler                     |  |
|        |          |                 | With<br>Parameter<br>Checking | Without<br>Parameter<br>Checking | With<br>Parameter<br>Checking | Without<br>Parameter<br>Checking | With<br>Parameter<br>Checking | Without<br>Parameter<br>Checking |  |
| RX130  | DOM      | 1 channel used  | 5360 bytes                    | 5235 bytes                       | 10336 bytes                   | 10200 bytes                      | 7292 bytes                    | 7040 bytes                       |  |
|        | ROM      | 2 channels used | 5533 bytes                    | 5408 bytes                       | 10484 bytes                   | 10356 bytes                      | 7425 bytes                    | 7173 bytes                       |  |
|        | RAM      | 1 channel used  | 41 bytes                      |                                  | 44 bytes                      |                                  | 28 bytes                      |                                  |  |
|        | RAW      | 2 channels used | 69 bytes                      |                                  | 72 bytes                      |                                  | 44 bytes                      |                                  |  |
|        | STAC     | STACK *1        |                               | 48 bytes                         |                               | -                                |                               | 444 bytes                        |  |
| RX231  | DOM      | 1 channel used  | 4384 bytes                    | 4259 bytes                       | 8736 bytes                    | 8600 bytes                       | 6411 bytes                    | 6161 bytes                       |  |
|        | ROM      | 2 channels used | 4557 bytes                    | 4432 bytes                       | 8884 bytes                    | 8748 bytes                       | 6544 bytes                    | 6294 bytes                       |  |
|        | DAM      | 1 channel used  | 41 bytes                      |                                  | 44 bytes                      |                                  | 28 bytes                      |                                  |  |
|        | RAM      | 2 channels used | 69 bytes                      |                                  | 72 bytes                      |                                  | 44 bytes                      |                                  |  |
|        | STACK *1 |                 | 48 bytes                      |                                  | -                             |                                  | 284 bytes                     |                                  |  |
| RX64M  |          | 1 channel used  | 4450 bytes                    | 4325 bytes                       | 8808 bytes                    | 8680 bytes                       | 6443 bytes                    | 6229 bytes                       |  |
|        | ROM      | 2 channels used | 4619 bytes                    | 4494 bytes                       | 8964 bytes                    | 8836 bytes                       | 6576 bytes                    | 6362 bytes                       |  |
|        | RAM      | 1 channel used  | 41 bytes                      |                                  | 44 bytes                      | 1                                | 32 bytes                      |                                  |  |
|        |          | 2 channels used | 69 bytes                      |                                  | 72 bytes                      |                                  | 48 bytes                      |                                  |  |
|        | STAC     | < *1            | 48 bytes                      |                                  | -                             |                                  | 444 bytes                     |                                  |  |

Note 1. The sizes of maximum usage stack of Interrupts functions is included.



### 2.9 Parameters

This section describes the structure whose members are API parameters. This structure is located in r\_sci\_iic\_rx\_if.h as are the prototype declarations of API functions.

The contents of the structure are referred and updated during communication. Do not rewrite the structure during communication (SCI\_IIC\_COMMUNICATION).

```
typedef struct
{
    uint8_t rsv2; /* Reserved area */
    uint8_t rsv1; /* Reserved area */
    sci_iic_ch_dev_status_t dev_sts; /* Device state flag */
    uint8_t ch_no; /* Channel number for the device used */
    sci_iic_callback callbackfunc; /* Callback function */
    uint32_t cnt2nd;/* Second data counter (number of bytes) */
    uint32_t cnt1st;/* First data counter (number of bytes) */
    uint8_t * p_data2nd; /* Pointer to the buffer to store the second data */
    uint8_t * p_data1st; /* Pointer to the buffer to store the first data */
    uint8_t * p_slv_adr; /* Pointer to the buffer to store the slave address */
} sci_iic_info_t;
```

### 2.10 Return Values

This section describes return values of API functions. This enumeration is located in r\_sci\_iic\_rx\_if.h as are the prototype declarations of API functions.



## 2.11 Adding the FIT Module to Your Project

This module must be added to each project in which it is used. Renesas recommends the method using the Smart Configurator described in (1) or (2) or (4) below. However, the Smart Configurator only supports some RX devices. Please use the methods of (3) for RX devices that are not supported by the Smart Configurator.

- (1) Adding the FIT module to your project using the Smart Configurator in e<sup>2</sup> studio By using the Smart Configurator in e<sup>2</sup> studio, the FIT module is automatically added to your project. Refer to "RX Smart Configurator User's Guide: e<sup>2</sup> studio (R20AN0451)" for details.
- (2) Adding the FIT module to your project using the Smart Configurator in CS+ By using the Smart Configurator Standalone version in CS+, the FIT module is automatically added to your project. Refer to "RX Smart Configurator User's Guide: CS+ (R20AN0470)" for details.
- (3) Adding the FIT module to your project in CS+ In CS+, please manually add the FIT module to your project. Refer to "RX Family Adding Firmware Integration Technology Modules to CS+ Projects (R01AN1826)" for details.
- (4) Adding the FIT module to your project using the Smart Configurator in IAREW By using the Smart Configurator Standalone version, the FIT module is automatically added to your project. Refer to "RX Smart Configurator User's Guide: IAREW (R20AN0535)" for details.



## 2.12 "for", "while" and "do while" statements

In this module, "for", "while" and "do while" statements (loop processing) are used in processing to wait for register to be reflected and so on. For these loop processing, comments with "WAIT\_LOOP" as a keyword are described. Therefore, if user incorporates fail-safe processing into loop processing, user can search the corresponding processing with "WAIT\_LOOP".

The following shows example of description.

```
while statement example :
/* WAIT LOOP */
while(0 == SYSTEM.OSCOVFSR.BIT.PLOVF)
{
    /* The delay period needed is to make sure that the PLL has stabilized. */
}
for statement example :
/* Initialize reference counters to 0. */
/* WAIT LOOP */
for (i = 0; i < BSP_REG_PROTECT_TOTAL_ITEMS; i++)</pre>
{
    g_protect_counters[i] = 0;
}
do while statement example :
/* Reset completion waiting */
do
{
    reg = phy_read(ether_channel, PHY_REG_CONTROL);
    count++;
} while ((reg & PHY CONTROL RESET) && (count < ETHER CFG PHY DELAY RESET)); /* WAIT LOOP */
```



### 3. API Functions

## 3.1 R\_SCI\_IIC\_Open()

The function initializes the simple I<sup>2</sup>C FIT module. This function must be called before calling any other API functions.

### Format

)

### Parameters

\* p\_sci\_iic\_info

This is the pointer to the I<sup>2</sup>C communication information structure. Only the member of the structure used in this function is described here. Refer to 2.9 Parameters for details on the structure.

The contents of the structure are referred and updated during communication. Do not rewrite the structure during communication (SCI\_IIC\_COMMUNICATION).

For the parameter which has '(to be updated)' in the comment below, the argument for the parameter will be updated during the API execution.

```
sci_iic_ch_dev_status_t dev_sts; /* Device state flag (to be updated) */
uint8_t ch_no; /* Channel number */
```

### **Return Values**

SCI\_IIC\_SUCCESS /\* Processing completed successfully \*/ SCI\_IIC\_ERR\_LOCK\_FUNC /\* The API is locked by the other task. \*/ SCI\_IIC\_ERR\_INVALID\_CHAN /\* Nonexistent channel \*/ SCI\_IIC\_ERR\_INVALID\_ARG /\* Invalid parameter \*/ SCI\_IIC\_ERR\_OTHER /\* The event occurred is invalid in the current state. \*/

### **Properties**

Prototyped in r\_sci\_iic\_rx\_if.h.

### Description

Performs the initialization to start the simple I<sup>2</sup>C-bus communication. Sets the SCI channel specified by the parameter. If the state of the channel is 'uninitialized (SCI\_IIC\_NO\_INIT)', the following processes are performed.

- Setting the state flag
- Setting I/O ports
- Allocating I<sup>2</sup>C output ports
- Cancelling SCI module-stop state
- Initializing variables used by the API
- Initializing the SCI registers used for the simple I<sup>2</sup>C-bus communication
- Disabling the SCI interrupt

The bit rate set in initial setting to start simple I<sup>2</sup>C-bus communication.

The bit rate is set based on the setting value of "2.7 Configuration Overview" and the clock setting definition value specified by BSP FIT module.



## Example

```
volatile sci_iic_return_t ret;
sci iic info t
                   siic info;
siic_info.dev_sts = SCI_IIC_NO_INIT;
siic_info.ch_no = 1;
ret = R_SCI_IIC_Open(&siic_info);
```

# **Special Notes**

None



## 3.2 **R\_SCI\_IIC\_MasterSend()**

Starts master transmission. Changes the transmit pattern according to the parameters. Operates batched processing until stop condition generation.

### Format

sci\_iic\_return\_t R\_SCI\_IIC\_MasterSend(

sci\_iic\_info\_t \* p\_sci\_iic\_info /\* Structure data \*/

)

### Parameters

\* p\_sci\_iic\_info

This is the pointer to the I<sup>2</sup>C communication information structure. The transmit patterns can be selected from four patterns by the parameter. Refer to the Special Notes in this section for available settings and the setting values for each transmit pattern. Also refer to 1.3.2 Master Transmission for details of each pattern.

Only members of the structure used in this function are described here. Refer to 2.9 Parameters for details on the structure.

The contents of the structure are referred and updated during communication. Do not rewrite the structure during communication (SCI\_IIC\_COMMUNICATION).

When setting the slave address, store it without shifting 1 bit to left.

For the parameter which has '(to be updated)' in the comment below, the argument for the parameter will be updated during the API execution.

### **Return Values**

SCI\_IIC\_SUCCESS /\* Processing completed successfully \*/ SCI\_IIC\_ERR\_INVALID\_CHAN /\* The channel is nonexistent. \*/ SCI\_IIC\_ERR\_INVALID\_ARG /\* The parameter is invalid. \*/ SCI\_IIC\_ERR\_NO\_INIT /\* Uninitialized state \*/ SCI\_IIC\_ERR\_BUS\_BUSY /\* The bus state is busy. \*/ SCI\_IIC\_ERR\_OTHER /\* The event occurred is invalid in the current state. \*/

### **Properties**

Prototyped in r\_sci\_iic\_rx\_if.h.



### Description

Starts the simple I<sup>2</sup>C-bus master transmission. The transmission is performed with the SCI channel and transmit pattern specified by parameters. If the state of the channel is 'idle (SCI\_IIC\_IDEL)', the following processes are performed.

- Setting the state flag
- Initializing variables used by the API
- Enabling the SCI interrupts
- Releasing the I<sup>2</sup>C reset
- Allocating I<sup>2</sup>C output ports
- Generating a start condition

This function returns SCI\_IIC\_SUCCESS as a return value when the processing up to the start condition generation ends normally. This function returns SCI\_IIC\_ERR\_BUS\_BUSY as a return value when the following conditions are met to the start condition generation ends normally. <sup>(1)</sup>

- Either SCL or SDA line is in low state.

The transmission processing is performed sequentially in subsequent interrupt processing after this function return SCI\_IIC\_SUCCESS. Section "2.4 Usage of Interrupt Vector" should be referred for the interrupt to be used. For master transmission, the interrupt generation timing should be referred from "6.2.1 Master transmission".

After issuing a stop condition at the end of transmission, the callback function specified by the argument is called.

The transmission completion is performed normally or not, can be confirmed by checking the device status flag specified by the argument or the channel status flag g\_sci\_iic\_ChStatus [], that is to be "SCI\_IIC\_FINISH" for normal completion.

Notes:

1. When SCL and SDA pin is not external pull-up, this function may return SCI\_IIC\_ERR\_BUS\_BUSY by detecting either SCL or SDA line is as in low state.

### Example

```
- Casel: Transmit pattern 1
                            // NULL definition
#include <stddef.h>
#include "platform.h"
#include "r sci iic rx if.h"
void main(void);
void Callback ch1(void);
void main (void)
{
    volatile sci iic return t ret;
    sci iic info t
                                    siic info;
    uint8_t slave_addr_eeprom[1] = \{0x50\}; /* Slave address for EEPROM */
uint8_t access_addr1[1] = \{0x00\}; /* 1st data field */
    uint8 t send data[5]
                                      = \{0x81, 0x82, 0x83, 0x84, 0x85\};
    /* Sets IIC Information (Send pattern 1) */
    siic_info.p_slv_adr = slave_addr_eeprom;
siic_info.p_data1st = access_addr1;
```



```
siic_info.p_data2nd = send_data;
siic_info.dev_sts = SCI_IIC_NO_INIT;
siic_info_cont_1ct
    siic_info.cnt1st = 1;
siic_info.cnt2nd = 3;
    siic info.callbackfunc = &Callback ch1;
                             = 1;
    siic_info.ch_no
    /* SCI open */
    ret = R_SCI_IIC_Open(&siic_info);
    /* Start Master Send */
    ret = R SCI IIC MasterSend(&siic info);
    if (SCI IIC SUCCESS == ret)
    {
        while(SCI IIC FINISH != siic info.dev sts);
    }
    else
    {
       /* error */
    }
    /* Master send complete */
    while(1);
}
void Callback ch1(void)
{
    volatile sci_iic_return_t ret;
    sci_iic_mcu_status_t iic_status;
sci_iic_info_t iic_info_ch;
    iic info ch.ch no = 1;
    ret = R SCI IIC GetStatus(&iic info ch, &iic status);
    if (SCI IIC SUCCESS != ret)
    {
        /* Call error processing for the R SCI IIC GetStatus()function*/
    }
    else
    {
        if (1 == iic status.BIT.NACK)
         {
         /* Processing when a NACK is detected
           by verifying the iic status flag. */
         }
    }
}
```

### **RX** Family

```
- Case2: Transmitting data to two slave devices (Slave 1 and slave 2)
        continuously.
#include <stddef.h>
                         // NULL definition
                             /* For printf */
#include <stdio.h>
#include "platform.h"
#include "r_sci_iic_rx_if.h"
void main(void);
void Callback ch1(void);
void main(void)
{
    volatile sci iic return t ret;
    volatile sci_iic_info_t
                                        siic info slavel;
    volatile sci iic info t
                                        siic info slave2;
    uint8_t slave_addr_eeprom[1] = {0x50}; /* Slave address for EEPROM */
    uint8_t slave_addr_m16c[1] = {0x01}; /* Slave address for M16C */
    uint8_t write_addr_slave1[1] = {0x01}; /* 1st data field */
uint8_t write_addr_slave2[1] = {0x02}; /* 1st data field */
    uint8 t data area slave1[5] = {0x81,0x82,0x83,0x84,0x85};
    uint8_t data_area_slave2[5] = {0x18,0x28,0x38,0x48,0x58};
    /* Sets 'Slave 1' Information (Send pattern 1) */
    siic_info_slave1.p_slv_adr = slave_addr_eeprom;
    siic info slave1.p data1st = write addr slave1;
    siic info slave1.p data2nd = data area slave1;
    siic_info_slave1.dev_sts = SCI_IIC_NO_INIT;
    siic_info_slave1.cnt1st = 1;
    siic info slave1.cnt2nd = 3;
    siic info slave1.callbackfunc = &Callback ch1;
    siic_info_slave1.ch no = 1;
    uint8_t timeout cnt1 = 0;
    /* SCI open */
    ret = R SCI IIC Open(&siic info slave1);
    /* Start Master Send */
    ret = R_SCI_IIC_MasterSend(&siic_info_slave1);
                                                                To access multiple slave
                                                                devices, rewrite the information
    while((SCI IIC FINISH != siic info slave1.dev sts) &&
                                                                structure for each slave device to
          (SCI IIC NACK != siic info slave1.dev sts))
                                                                be accessed.
    {
        timeout cnt1 = timeout cnt1 + 1; /*timeout counter is added*/
        if (timeout cnt1 >= 100)
        {
            printf("Timeout Happend\n");
            break;
        }
        else
        {
            R BSP SoftwareDelay(10, BSP DELAY MICROSECS); /*BSP delay*/
        }
    }
    /* Sets 'Slave 2' Information (Send pattern 1)
    siic info slave2.p slv adr = slave addr m16c;
    siic info slave2.p data1st = write addr slave2;
```



```
siic info slave2.p data2nd = data area slave2;
    siic info slave2.dev sts = SCI IIC NO INIT;
   siic info slave2.cnt1st = 1;
   siic info slave2.cnt2nd = 3;
   siic info slave2.callbackfunc = &Callback ch1;
   siic info slave2.ch no = 1;
   uint8 t timeout cnt2 = 0;
    /* Start Master Send */
   ret = R SCI IIC MasterSend(&siic info slave2);
   while((SCI IIC FINISH != siic info slave2.dev sts) &&
          (SCI IIC NACK != siic info slave2.dev sts))
    {
        timeout cnt2 = timeout cnt2 + 1; /*timeout counter is added*/
        if (timeout cnt2 >= 100)
        {
            printf("Timeout Happend\n");
           break;
        }
        else
        {
            R BSP SoftwareDelay(10, BSP DELAY MICROSECS); /*BSP delay*/
        }
    }
   while(1);
}
void Callback_ch1(void)
{
   volatile sci iic return t ret;
   sci_iic_mcu_status_t iic_status;
   sci iic info t
                             iic info ch;
   iic info ch.ch no = 1;
   ret = R SCI IIC GetStatus(&iic info ch, &iic status);
   if (SCI IIC SUCCESS != ret)
    {
        /* Call error processing for the R SCI IIC GetStatus()function*/
    }
   else
    {
        if (1 == iic status.BIT.NACK)
        {
        /* Processing when a NACK is detected
           by verifying the iic status flag. */
        }
   }
}
```

# **Special Notes**

The table below lists available settings for each pattern.

| Structure    | Available Settings for Each Pattern of the Master Transmission |                   |                           |                           |
|--------------|----------------------------------------------------------------|-------------------|---------------------------|---------------------------|
| Member       | lember Pattern 1 Pattern 2                                     |                   | Pattern 3                 | Pattern 4                 |
| *p_slv_adr   | Buffer pointer to the slave address storage                    |                   |                           | FIT_NO_PTR <sup>(1)</sup> |
| *p_data1st   | Buffer pointer to the first data storage                       |                   | FIT_NO_PTR <sup>(1)</sup> | FIT_NO_PTR <sup>(1)</sup> |
| *p_data2nd   | Buffer pointer to the second data (transmit data) storage      |                   | FIT_NO_PTR <sup>(1)</sup> | FIT_NO_PTR <sup>(1)</sup> |
| dev_sts      | Device state flag                                              | Device state flag |                           |                           |
| cnt1st       | 0000 0001h to<br>FFFF FFFFh (2) 0                              |                   | 0                         | 0                         |
| cnt2nd       | 0000 0001h to FFFF FFFFh (2)                                   |                   | 0                         | 0                         |
| callbackfunc | Specify the function name used                                 |                   |                           |                           |
| ch_no        | 00h to FFh                                                     |                   |                           |                           |
| rsv1, rsv2   | Reserved (value set here has no effect )                       |                   |                           |                           |

Notes:

1. When using pattern 2, 3, or 4, set 'FIT\_NO\_PTR' as the argument of the parameter.

2. Do not set to 0.



# 3.3 **R\_SCI\_IIC\_MasterReceive()**

Starts master reception. Changes the receive pattern according to the parameters. Operates batched processing until stop condition generation.

#### Format

sci\_iic\_return\_t R\_SCI\_IIC\_MasterRecive(

sci\_iic\_info\_t \* p\_sci\_iic\_info /\* Structure data \*/

)

#### **Parameters**

\* p\_sci\_iic\_info

This is the pointer to the I<sup>2</sup>C communication information structure. The receive pattern can be selected from master reception and master transmit/receive. Refer to the Special Notes in this section for available settings and the setting values for each receive pattern. Also refer to 1.3.3 Master Reception for details of each receive pattern.

Only members of the structure used in this function are described here. Refer to 2.9 Parameters for details on the structure.

The contents of the structure are referred and updated during communication. Do not rewrite the structure during communication (SCI\_IIC\_COMMUNICATION).

When setting the slave address, store it without shifting 1 bit to left.

For the parameter which has '(to be updated)' in the comment below, the argument for the parameter will be updated during the API execution.

**Return Values** SCI\_IIC\_SUCCESS /\* Processing completed successfully \*/ SCI\_IIC\_ERR\_INVALID\_CHAN /\* The channel is nonexistent. \*/ SCI\_IIC\_ERR\_INVALID\_ARG /\* The parameter is invalid. \*/ SCI\_IIC\_ERR\_NO\_INIT /\* Uninitialized state \*/ SCI\_IIC\_ERR\_BUS\_BUSY /\* The bus state is busy. \*/ SCI\_IIC\_ERR\_OTHER /\* The event occurred is invalid in the current state. \*/

uint8\_t ch\_no; /\* Channel number \*/

#### **Properties**

Prototyped in r\_sci\_iic\_rx\_if.h.



### Description

Starts the simple I<sup>2</sup>C-bus master reception. The reception is performed with the SCI channel and receive pattern specified by parameters. If the state of the channel is 'idle (SCI\_IIC\_IDEL)', the following processes are performed.

- Setting the state flag
- Initializing variables used by the API
- Enabling the SCI interrupts
- Releasing the I<sup>2</sup>C reset
- Allocating I<sup>2</sup>C output ports
- Generating a start condition

This function returns SCI\_IIC\_SUCCESS as a return value when the processing up to the start condition generation ends normally. This function returns SCI\_IIC\_ERR\_BUS\_BUSY as a return value when the following conditions are met to the start condition generation ends normally. <sup>(1)</sup>

- Either SCL or SDA line is in low state.

The reception processing is performed sequentially in subsequent interrupt processing after this function return SCI\_IIC\_SUCCESS. Section "2.4 Usage of Interrupt Vector" should be referred for the interrupt to be used. For master transmission, the interrupt generation timing should be referred from "6.2.2 Master Reception".

After issuing a stop condition at the end of reception, the callback function specified by the argument is called.

The reception completion is performed normally or not, can be confirmed by checking the device status flag specified by the argument or the channel status flag g\_sci\_iic\_ChStatus [], that is to be "SCI\_IIC\_FINISH" for normal completion.

Notes:

1. When SCL and SDA pin is not external pull-up, this function may return SCI\_IIC\_ERR\_BUS\_BUSY by detecting either SCL or SDA line is as in low state.

## Example

```
#include <stddef.h>
                      // NULL definition
#include "platform.h"
#include "r sci iic rx if.h"
void main(void);
void Callback ch1(void);
void main(void)
{
   volatile sci iic return t ret;
   sci iic info t
                            siic info;
   uint8 t slave addr eeprom[1] = \{0x50\}; /* Slave address for EEPROM */
   uint8_t access_addr1[1] = {0x00}; /* 1st data field
                                                                      */
   uint8 t store area[5]
                               = \{0xFF, 0xFF, 0xFF, 0xFF, 0xFF\};
    /* Sets IIC Information (Ch1) */
   siic info.p slv adr = slave addr eeprom;
    siic info.p data1st = access addr1;
    siic info.p data2nd = store area;
```



```
siic info.dev_sts = SCI_IIC_NO_INIT;
    siic info.cnt1st = 1;
    siic info.cnt2nd = 3;
    siic info.callbackfunc = &Callback ch1;
    siic info.ch no = 1;
    /* SCI open */
    ret = R_SCI_IIC_Open(&siic_info);
    /* Start Master Receive */
    ret = R SCI IIC MasterReceive(&siic info);
    if (SCI IIC SUCCESS == ret)
    {
        while(SCI IIC FINISH != siic info.dev sts);
    }
    else
    {
       /* error */
    }
    /* Master receive complete */
    while(1);
}
void Callback ch1(void)
{
    volatile sci iic return t ret;
    sci_iic_mcu_status_t iic_status;
    sci_iic_info_t
                             iic_info_ch;
    iic info ch.ch no = 1;
    ret = R SCI IIC GetStatus(&iic info ch, &iic status);
    if (SCI IIC SUCCESS != ret)
    {
        /* Call error processing for the R SCI IIC GetStatus()function*/
    }
    else
    {
        if (1 == iic_status.BIT.NACK)
        {
        /* Processing when a NACK is detected
          by verifying the iic status flag. */
        }
    }
}
```

# **Special Notes**

The table below lists available settings for each receive pattern.

| Structure    | Available Settings for Each Pattern of the Master Reception             |                          |  |
|--------------|-------------------------------------------------------------------------|--------------------------|--|
| Member       | Master Reception                                                        | Master Transmit/Receive  |  |
| *p_slv_adr   | Buffer pointer to the slave address storage                             |                          |  |
| *p_data1st   | (Value set here has no effect) Buffer pointer to the first data storage |                          |  |
| *p_data2nd   | Buffer pointer to the second data (receive data) storage                |                          |  |
| dev_sts      | Device state flag                                                       |                          |  |
| cnt1st (1)   | 0                                                                       | 0000 0001h to FFFF FFFFh |  |
| cnt2nd (2)   | 0000 0001h to FFFF FFFFh                                                | 0000 0001h to FFFF FFFFh |  |
| callbackfunc | Specify the function name used                                          |                          |  |
| ch_no        | 00h to FFh                                                              |                          |  |
| rsv1, rsv2   | Reserved (value set here has no effect)                                 |                          |  |

Notes:

1. The receive pattern is determined by whether cnt1st is 0 or not.

2. Do not set to 0.



# 3.4 R\_SCI\_IIC\_Close()

This function completes the simple I<sup>2</sup>C communication and releases the SCI used.

### Format

```
sci_iic_return_t R_SCI_IIC_Close(
```

sci\_iic\_info\_t \* p\_sci\_iic\_info /\* Structure data \*/

)

### Parameters

\* p\_sci\_iic\_info

This is the pointer to the I<sup>2</sup>C communication information structure. Only the member of the structure used in this function is described here. Refer to 2.9 Parameters for details on the structure.

The contents of the structure are referred and updated during communication. Do not rewrite the structure during communication (SCI\_IIC\_COMMUNICATION).

For the parameter which has '(to be updated)' in the comment below, the argument for the parameter will be updated during the API execution.

```
sci_iic_ch_dev_status_t dev_sts; /* Device state flag (to be updated) */
uint8 t ch no; /* Channel number */
```

## **Return Values**

SCI\_IIC\_SUCCESS /\* Processing completed successfully \*/ SCI\_IIC\_ERR\_INVALID\_CHAN /\* The channel is nonexistent. \*/ SCI\_IIC\_ERR\_INVALID\_ARG /\* The parameter is invalid. \*/

## **Properties**

Prototyped in r\_sci\_iic\_rx\_if.h.

## Description

Configures the settings to complete the simple I<sup>2</sup>C-bus communication. Disables the SCI channel specified by the parameter. The following processes are performed in this function.

- Entering the SCI module-stop state
- Releasing I<sup>2</sup>C output ports
- Disabling the SCI interrupt

To restart the communication, call the R\_SCI\_IIC\_Open() function (initialization function). If the communication is forcibly terminated, that communication is not guaranteed.



# Example

```
volatile sci_iic_return_t ret;
sci_iic_info_t siic_info;
siic_info.ch_no = 1;
ret = R_SCI_IIC_Close(&siic_info);
```

# **Special Notes**

None



# 3.5 **R\_SCI\_IIC\_GetStatus()**

Returns the state of this module.

#### Format

sci\_iic\_return\_t R\_SCI\_IIC\_GetStatus(

sci\_iic\_info\_t \* p\_sci\_iic\_info /\* Structure data \*/

sci\_iic\_mcu\_status\_t \*p\_sci\_iic\_status /\* State of this module \*/

### )

Parameters

\* p\_sci\_iic\_info

This is the pointer to the I<sup>2</sup>C communication information structure. Only the member of the structure used in this function is described here. Refer to 2.9 Parameters for details on the structure.

The contents of the structure are referred and updated during communication. Do not rewrite the structure during communication (SCI\_IIC\_COMMUNICATION).

uint8\_t ch\_no; /\* Channel number \*/

#### \*p\_sci\_iic\_status

This contains the address to store the I<sup>2</sup>C state flag. If the argument is 'FIT\_NO\_PTR', the state is not returned.

Use the structure members listed below to specify parameters.

typedef union

```
{
    uint32_t LONG;
    struct st_sci_iic_status_flag
{
    uint32_t rsv :27 /* Reserve bit */
    uint32_t SCLI:1; /* SSCL pin level */
    uint32_t SDAI:1; /* SSDA pin level */
    uint32_t NACK:1; /* NACK detection flag */
    uint32_t TRS :1; /* Transmit/receive mode level */
    uint32_t BSY :1; /* Bus state flag */
    }BIT;
} sci_iic_mcu_status_t;
```

#### **Return Values**

SCI\_IIC\_SUCCESS /\* Processing completed successfully \*/ SCI\_IIC\_ERR\_INVALID\_CHAN /\* The channel is nonexistent. \*/ SCI\_IIC\_ERR\_INVALID\_ARG /\* The parameter is invalid. \*/ SCI\_IIC\_ERR\_OTHER /\* The event occurred is invalid in the current state. \*/

#### **Properties**

Prototyped in r\_sci\_iic\_rx\_if.h.

#### Description

Returns the state of this module.

By reading the register, pin level, variable, or others, obtains the state of the SCI channel which specified by the parameter, and returns the obtained state as 32-bit structure.



# Example

```
volatile sci_iic_return_t ret;
sci_iic_info_t siic_info;
sci_iic_mcu_status_t iic_status;
siic_info.ch_no = 1
ret = R SCI IIC GetStatus(&siic info, &iic status);
```

## **Special Notes**

The following shows the state flag allocation.

| b31 to b16 |
|------------|
| Reserved   |
| Reserved   |
| Rsv        |
| Always 0   |

| b15 to b8 |
|-----------|
| Reserved  |
| Reserved  |
| Rsv       |
| Always 0  |

| b7 to b5 | b4                            | b3                | b2                                | b1                        | b0                 |
|----------|-------------------------------|-------------------|-----------------------------------|---------------------------|--------------------|
| Reserved | Pin level                     |                   | Event<br>detection                | Mode                      | Bus state          |
| Reserved | SSCL pin<br>level             | SSDA pin<br>level | NACK<br>detection                 | Send/<br>receive<br>mode  | Bus<br>busy/ready  |
| Rsv      | SCLI                          | SDAI              | NACK                              | TRS                       | BSY                |
| Always 0 | 0: Low level<br>1: High level |                   | 0: Not<br>detected<br>1: Detected | 0: Receive<br>1: Transmit | 0: Idle<br>1: Busy |



# 3.6 R\_SCI\_IIC\_Control()

This function outputs conditions, Hi-Z from the SSDA pin, and one-shot of the SSCL clock. Also it resets the settings of this module. This function is mainly used when a communication error occurs.

### Format

sci\_iic\_return\_t R\_SCI\_IIC\_Control(

r\_sci\_iic\_info\_t \* p\_sci\_iic\_info /\* Structure data \*/

sci\_iic\_ctrl\_ptn\_t ctrl\_ptn /\* Output pattern \*/

);

## Parameters

#### \* p\_sci\_iic\_info

This is the pointer to the I<sup>2</sup>C communication information structure. Only the member of the structure used in this function is described here. Refer to 2.9 Parameters for details on the structure.

The contents of the structure are referred and updated during communication. Do not rewrite the structure during communication (SCI\_IIC\_COMMUNICATION).

For the parameter which has '(to be updated)' in the comment below, the argument for the parameter will be updated during the API execution.

```
sci_iic_ch_dev_status_t dev_sts; /* Device state flag (to be updated) */
uint8 t ch no; /* Channel number */
```

#### ctrl\_ptn

Specifies the output pattern. When selecting multiple options, specify them with '|'.

The following options can be selected simultaneously:

- The following three options can be specified simultaneously. Then they will be processed in the order listed.

- SCI\_IIC\_GEN\_START\_CON
- SCI\_IIC\_GEN\_RESTART\_CON

- SCI\_IIC\_GEN\_STOP\_CON

- The following two options can be specified simultaneously.

- SCI\_IIC\_GEN\_SDA\_HI\_Z

- SCI\_IIC\_GEN\_SSCL\_ONESHOT



#### **Return Values**

SCI\_IIC\_SUCCESS /\* Processing completed successfully \*/ SCI\_IIC\_ERR\_INVALID\_CHAN /\* The channel is nonexistent. \*/ SCI\_IIC\_ERR\_INVALID\_ARG /\* The parameter is invalid. \*/ SCI\_IIC\_ERR\_BUS\_BUSY /\* The bus state is busy. \*/ SCI\_IIC\_ERR\_OTHER /\* The event occurred is invalid in the current state. \*/

### **Properties**

Prototyped in r\_sci\_iic\_rx\_if.h.

### Description

Outputs control signals of the simple I<sup>2</sup>C mode. Outputs conditions specified by the argument, Hi-Z from the SSDA pin, and one-shot of the SSCL clock. Also resets the simple I<sup>2</sup>C mode settings.

## Example

volatile sci\_iic\_return\_t ret; sci\_iic\_info\_t siic\_info;

siic\_info.ch\_no = 1;

```
/* Output an extra SSCL clock cycle after changes the SSDA pin in a high-
impedance state */
ret = R_SCI_IIC_Control(&siic_info, SCI_IIC_GEN_SSDA_HI_Z |
SCI_IIC_SSCL_ONESHOT);
```

## **Special Notes**

None



# 3.7 R\_SCI\_IIC\_GetVersion()

Returns the current version of this module.

## Format

uint32\_t R\_SCI\_IIC\_GetVersion(void)

### Parameters

None

# **Return Values**

Version number

### **Properties**

Prototyped in r\_sci\_iic\_rx\_if.h.

### Description

This function will return the version of the currently installed SCI (simple I<sup>2</sup>C mode) FIT module. The version number is encoded where the top 2 bytes are the major version number and the bottom 2 bytes are the minor version number. For example, Version 4.25 would be returned as 0x00040019.

# Example

uint32\_t version;

version = R\_SCI\_IIC\_GetVersion();

Special Notes None.



# 4. Pin Settings

To use the SCI (Simple I<sup>2</sup>C Mode) FIT module, assign input/output signals of the peripheral function to pins with the multi-function pin controller (MPC). The pin assignment is referred to as the "Pin Setting" in this document.

The SCI (Simple I<sup>2</sup>C Mode) FIT module can choose whether or not to perform the pin setting in the R\_SCI\_IIC\_Open / R\_SCI\_IIC\_MasterSend / R\_SCI\_IIC\_MasterReceive / R\_SCI\_IIC\_Close / R\_SCI\_IIC\_Control function depending on the setting of the configuration option SCI\_IIC\_CFG\_PORT\_SET\_PROCESSING.

For details of the configuration options, refer to "2.7 Configuration Overview".

When performing the Pin Setting in the e<sup>2</sup> studio, the Pin Setting feature of the Smart Configurator can be used. When using the pin setting feature, pins selected in the Pin Setting pane can be used in the Smart Configurator. The information of selected pins is reflected in the r\_sci\_iic\_pin\_config.h file. Values of the macro definitions listed in Table 4.1 and Table 4.2 are overwritten with values corresponding to the pins selected.



| Channel Selected | Pin Selected | Macro Definition              |
|------------------|--------------|-------------------------------|
| Channel 0        | SSCL0 Pin    | R_SCI_IIC_CFG_SCI0_SSCL0_PORT |
|                  |              | R_SCI_IIC_CFG_SCI0_SSCL0_BIT  |
|                  | SSDA0 Pin    | R_SCI_IIC_CFG_SCI0_SSDA0_PORT |
|                  |              | R_SCI_IIC_CFG_SCI0_SSDA0_BIT  |
| Channel 1        | SSCL1 Pin    | R_SCI_IIC_CFG_SCI1_SSCL1_PORT |
|                  |              | R_SCI_IIC_CFG_SCI1_SSCL1_BIT  |
|                  | SSDA1 Pin    | R_SCI_IIC_CFG_SCI1_SSDA1_PORT |
|                  |              | R_SCI_IIC_CFG_SCI1_SSDA1_BIT  |
| Channel 2        | SSCL2 Pin    | R_SCI_IIC_CFG_SCI2_SSCL2_PORT |
|                  |              | R_SCI_IIC_CFG_SCI2_SSCL2_BIT  |
|                  | SSDA2 Pin    | R_SCI_IIC_CFG_SCI2_SSDA2_PORT |
|                  |              | R_SCI_IIC_CFG_SCI2_SSDA2_BIT  |
| Channel 3        | SSCL3 Pin    | R_SCI_IIC_CFG_SCI3_SSCL3_PORT |
|                  |              | R_SCI_IIC_CFG_SCI3_SSCL3_BIT  |
|                  | SSDA3 Pin    | R_SCI_IIC_CFG_SCI3_SSDA3_PORT |
|                  |              | R_SCI_IIC_CFG_SCI3_SSDA3_BIT  |
| Channel 4        | SSCL4 Pin    | R_SCI_IIC_CFG_SCI4_SSCL4_PORT |
|                  |              | R_SCI_IIC_CFG_SCI4_SSCL4_BIT  |
|                  | SSDA4 Pin    | R_SCI_IIC_CFG_SCI4_SSDA4_PORT |
|                  |              | R_SCI_IIC_CFG_SCI4_SSDA4_BIT  |
| Channel 5        | SSCL5 Pin    | R_SCI_IIC_CFG_SCI5_SSCL5_PORT |
|                  |              | R_SCI_IIC_CFG_SCI5_SSCL5_BIT  |
|                  | SSDA5 Pin    | R_SCI_IIC_CFG_SCI5_SSDA5_PORT |
|                  |              | R_SCI_IIC_CFG_SCI5_SSDA5_BIT  |
| Channel 6        | SSCL6 Pin    | R_SCI_IIC_CFG_SCI6_SSCL6_PORT |
|                  |              | R_SCI_IIC_CFG_SCI6_SSCL6_BIT  |
|                  | SSDA6 Pin    | R_SCI_IIC_CFG_SCI6_SSDA6_PORT |
|                  |              | R_SCI_IIC_CFG_SCI6_SSDA6_BIT  |



| Channel Selected | Pin Selected | Macro Definition                |
|------------------|--------------|---------------------------------|
| Channel 7        | SSCL7 Pin    | R_SCI_IIC_CFG_SCI7_SSCL7_PORT   |
|                  |              | R_SCI_IIC_CFG_SCI7_SSCL7_BIT    |
|                  | SSDA7 Pin    | R_SCI_IIC_CFG_SCI7_SSDA7_PORT   |
|                  |              | R_SCI_IIC_CFG_SCI7_SSDA7_BIT    |
| Channel 8        | SSCL8 Pin    | R_SCI_IIC_CFG_SCI8_SSCL8_PORT   |
|                  |              | R_SCI_IIC_CFG_SCI8_SSCL8_BIT    |
|                  | SSDA8 Pin    | R_SCI_IIC_CFG_SCI8_SSDA8_PORT   |
|                  |              | R_SCI_IIC_CFG_SCI8_SSDA8_BIT    |
| Channel 9        | SSCL9 Pin    | R_SCI_IIC_CFG_SCI9_SSCL9_PORT   |
|                  |              | R_SCI_IIC_CFG_SCI9_SSCL9_BIT    |
|                  | SSDA9 Pin    | R_SCI_IIC_CFG_SCI9_SSDA9_PORT   |
|                  |              | R_SCI_IIC_CFG_SCI9_SSDA9_BIT    |
| Channel 10       | SSCL10 Pin   | R_SCI_IIC_CFG_SCI10_SSCL10_PORT |
|                  |              | R_SCI_IIC_CFG_SCI10_SSCL10_BIT  |
|                  | SSDA10 Pin   | R_SCI_IIC_CFG_SCI10_SSDA10_PORT |
|                  |              | R_SCI_IIC_CFG_SCI10_SSDA10_BIT  |
| Channel 11       | SSCL11 Pin   | R_SCI_IIC_CFG_SCI11_SSCL11_PORT |
|                  |              | R_SCI_IIC_CFG_SCI11_SSCL11_BIT  |
|                  | SSDA11 Pin   | R_SCI_IIC_CFG_SCI11_SSDA11_PORT |
|                  |              | R_SCI_IIC_CFG_SCI11_SSDA11_BIT  |
| Channel 12       | SSCL12 Pin   | R_SCI_IIC_CFG_SCI12_SSCL12_PORT |
|                  |              | R_SCI_IIC_CFG_SCI12_SSCL12_BIT  |
|                  | SSDA12 Pin   | R_SCI_IIC_CFG_SCI12_SSDA12_PORT |
|                  |              | R_SCI_IIC_CFG_SCI12_SSDA12_BIT  |

| Table 4.2 | Macro Definitions | for the Pin Setting Feature - 2 - |
|-----------|-------------------|-----------------------------------|
|-----------|-------------------|-----------------------------------|

Pins selected in the r\_sci\_iic\_pin\_config.h file are configured as peripheral function pins SSCL and SSDA after calling the R\_SCI\_IIC\_MasterSend / R\_SCI\_IIC\_MasterReceive / R\_SCI\_IIC\_Control function.

The pins assigned to the peripheral function are released when the communication operation executed by the R\_SCI\_IIC\_MasterSend / R\_SCI\_IIC\_MasterReceive / R\_SCI\_IIC\_Control function is completed or upon calling the R\_SCI\_IIC\_Close function and then become general I/O pins (as input pins).

Pins SSCL and SSDA must be pulled up with an external resistor.

When the pin setting feature in this FIT module is not used according to the SCI\_IIC\_CFG\_PORT\_SET\_PROCESSING setting, pins used in user processing must be configured after calling the R\_SCI\_IIC\_Open function before calling the other APIs.



# 5. Demo Projects

Demo projects are complete stand-alone programs. They include function main() that utilizes the module and its dependent modules (e.g., r\_bsp).

In this section, it explains about GUI operation when you use e<sup>2</sup> studio.

# 5.1 sciiic\_send\_demo\_rskrx64m, sciiic\_send\_demo\_rskrx64m\_gcc

#### Description

A simple demo of the RX64M SCI Simple I<sup>2</sup>C Mode Master Transmission for the RSKRX64M starter kit (FIT module "r\_sci\_iic\_rx"). The demo uses the Simple I<sup>2</sup>C API from r\_sci\_iic\_rx\_if.h to start master transmission. The master device (RX MCU) transmits data to the slave device. When the master transmission is finished, print the finished message to the debug console by main().

#### Setup and Execution

- 1. Compile and download the sample code.
- 2. Click 'Reset Go' to start the software. If PC stops at Main, press F8 to resume.
- 3. Set breakpoints and watch global variables

### **Boards Supported**

RSKRX64M

## 5.2 scilic\_receive\_demo\_rskrx64m, scilic\_receive\_demo\_rskrx64m\_gcc

#### Description

A simple demo of the RX64M SCI Simple I<sup>2</sup>C Mode Master Reception for the RSKRX64M starter kit (FIT module "r\_sci\_iic\_rx"). The demo uses the Simple I<sup>2</sup>C API from r\_sci\_iic\_rx\_if.h to start master reception. The master (RX MCU) receives data from the slave device .When the master reception is finished, print the received data to the debug console by main().

## **Boards Supported**

RSKRX64M

# 5.3 sciiic\_send\_demo\_rskrx231, sciiic\_send\_demo\_rskrx231\_gcc

#### Description

A simple demo of the RX231 SCI Simple I<sup>2</sup>C Mode Master Transmission for the RSKRX231 starter kit (FIT module "r\_sci\_iic\_rx"). This demo is identical to the RX64M for demo above.

## **Boards Supported**

RSKRX231



## 5.4 sciiic\_receive\_demo\_rskrx231, sciiic\_receive\_demo\_rskrx231\_gcc

#### Description

A simple demo of the RX231 SCI Simple I<sup>2</sup>C Mode Master Reception for the RSKRX231 starter kit (FIT module "r\_sci\_iic\_rx"). This demo is identical to the RX64M for demo above.

### **Boards Supported**

RSKRX231

# 5.5 sciiic\_send\_demo\_rskrx671, sciiic\_send\_demo\_rskrx671\_gcc

### Description

A simple demo of the RX671 SCI Simple I<sup>2</sup>C Mode Master Transmission for the RSKRX671 starter kit (FIT module "r\_sci\_iic\_rx"). This demo is identical to the RX64M for demo above.

### **Boards Supported**

RSKRX671

## 5.6 sciiic\_receive\_demo\_rskrx671, sciiic\_receive\_demo\_rskrx671\_gcc

A simple demo of the RX671 SCI Simple I<sup>2</sup>C Mode Master Reception for the RSKRX671 starter kit (FIT module "r\_sci\_iic\_rx"). This demo is identical to the RX64M for demo above.

### **Boards Supported**

RSKRX671

## 5.7 sciiic\_send\_demo\_rskrx72n, sciiic\_send\_demo\_rskrx72n\_gcc

### Description

A simple demo of the RX72N SCI Simple I<sup>2</sup>C Mode Master Transmission for the RSKRX72N starter kit (FIT module "r\_sci\_iic\_rx"). This demo is identical to the RX64M for demo above.

#### **Boards Supported**

RSKRX72N

## 5.8 scilic\_receive\_demo\_rskrx72n, scilic\_receive\_demo\_rskrx72n\_gcc

#### Description

A simple demo of the RX72N SCI Simple I<sup>2</sup>C Mode Master Reception for the RSKRX72N starter kit (FIT module "r\_sci\_iic\_rx"). This demo is identical to the RX64M for demo above.

## **Boards Supported**

RSKRX72N

# 5.9 Adding a Demo to a Workspace

Demo projects are found in the FITDemos subdirectory of the distribution file for this application note. To add a demo project to a workspace, select File>Import>General>Existing Projects into Workspace, then click "Next". From the Import Projects dialog, choose the "Select archive file" radio button. "Browse" to the FITDemos subdirectory, select the desired demo zip file, then click "Finish".



# 5.10 Downloading Demo Projects

Demo projects are not included in the RX Driver Package. When using the demo project, the FIT module needs to be downloaded. To download the FIT module, right click on the required application note and select "Sample Code (download)" from the context menu in the Smart Brower >> Application Notes tab.



# 6. Appendices

# 6.1 Communication Method

This API controls each processing such as start condition generation, slave address transmission, and others as a single protocol, and performs communication by combining these protocols.

## 6.1.1 States for API Operation

Table 6.1 lists the States Used for Protocol Control.

| Table 6.1 | States Used for Protocol Control (enum sci_iic_api_status_t) |
|-----------|--------------------------------------------------------------|
|-----------|--------------------------------------------------------------|

| No.  | Constant Name                  | Description                                                       |
|------|--------------------------------|-------------------------------------------------------------------|
| STS0 | SCI_IIC_STS_NO_INIT            | Uninitialized state                                               |
| STS1 | SCI_IIC_STS_IDLE               | Idle state                                                        |
| STS2 | SCI_IIC_STS_ST_COND_WAIT       | Wait state for a start condition to be generated                  |
| STS3 | SCI_IIC_STS_SEND_SLVADR_W_WAIT | Wait state for the slave address [write] transmission to complete |
| STS4 | SCI_IIC_STS_SEND_SLVADR_R_WAIT | Wait state for the slave address [read] transmission to complete  |
| STS5 | SCI_IIC_STS_SEND_DATA_WAIT     | Wait state for the data transmission to complete                  |
| STS6 | SCI_IIC_STS_RECEIVE_DATA_WAIT  | Wait state for the data reception to complete                     |
| STS7 | SCI_IIC_STS_SP_COND_WAIT       | Wait state for a stop condition to be generated                   |

# 6.1.2 Events During API Operation

Table 6.2 lists the Events Used for Protocol Control. When the interface functions accompanying this module are called, they are defined as events as well as interrupts.

| No. | Event                     | Event Definition                               |
|-----|---------------------------|------------------------------------------------|
| EV0 | SCI_IIC_EV_INIT           | sci_iic_init_driver() called                   |
| EV1 | SCI_IIC_EV_GEN_START_COND | sci_iic_generate_start_cond() called           |
| EV2 | SCI_IIC_EV_INT_START      | STI interrupt occurred (interrupt flag: START) |
| EV3 | SCI_IIC_EV_INT_ADD        | TXI interrupt occurred                         |
| EV4 | SCI_IIC_EV_INT_SEND       | TXI interrupt occurred                         |
| EV5 | SCI_IIC_EV_INT_STOP       | STI interrupt occurred (interrupt flag: STOP)  |
| EV6 | SCI_IIC_EV_INT_NACK       | STI interrupt occurred (interrupt flag: NACK)  |



## **RX Family**

# 6.1.3 Protocol State Transitions

In this module, a state transition occurs when an interface function provided is called or when an SCI (simple  $I^2C$  mode) interrupt request is generated. Figure 6.1 to Figure 6.4 show protocol state transitions.



Figure 6.1 State Transition on Initialization





Figure 6.2 State Transition on Master Transmission





Oct.09.23



Figure 6.4 State Transition on Master Transmit/Receive

## **RX Family**

# 6.1.4 Protocol State Transition Table

The processing when the events in Table 6.2 occur in the states in Table 6.1 is shown in the Table 6.3 Protocol State Transition. Refer to Table 6.4 for details of each function.

| Table 6.3 | Protocol State | Transition | Table (gc_sc | i_iic_mtx_tbl[][]) <sup>(1)</sup> |
|-----------|----------------|------------|--------------|-----------------------------------|
|-----------|----------------|------------|--------------|-----------------------------------|

| State |                                                                                                          | Event |       |       |       |       |       |       |
|-------|----------------------------------------------------------------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|
|       | State                                                                                                    |       | EV1   | EV2   | EV3   | EV4   | EV5   | EV6   |
| STS0  | Uninitialized state<br>[SCI_IIC_STS_NO_INIT]                                                             | Func0 | ERR   | ERR   | ERR   | ERR   | ERR   | ERR   |
| STS1  | Idle state<br>[SCI_IIC_STS_IDLE]                                                                         | ERR   | Func1 | ERR   | ERR   | ERR   | ERR   | ERR   |
| STS2  | Wait state for a start condition to be<br>generated<br>SCI_IIC_STS_ST_COND_WAIT                          | ERR   | ERR   | Func2 | ERR   | ERR   | ERR   | Func7 |
| STS3  | Wait state for the slave address [write]<br>transmission to complete<br>[SCI_IIC_STS_SEND_SLVADR_W_WAIT] | ERR   | ERR   | ERR   | Func3 | ERR   | ERR   | Func7 |
| STS4  | Wait state for the slave address [read]<br>transmission to complete<br>[SCI_IIC_STS_SEND_SLVADR_R_WAIT]  | ERR   | ERR   | ERR   | Func3 | ERR   | ERR   | Func7 |
| STS5  | Wait state for the data transmission to<br>complete<br>[SCI_IIC_STS_SEND_DATA_WAIT]                      | ERR   | ERR   | ERR   | ERR   | Func4 | ERR   | Func7 |
| STS6  | Wait state for the data reception to complete<br>[SCI_IIC_STS_RECEIVE_DATA_WAIT]                         | ERR   | ERR   | ERR   | Func5 | ERR   | ERR   | Func7 |
| STS7  | Wait state for the stop condition to be<br>generated<br>[SCI_IIC_STS_SP_COND_WAIT]                       | ERR   | ERR   | ERR   | ERR   | ERR   | Func6 | Func7 |

Note:

1. ERR indicates SCI\_IIC\_ERR\_OTHER. When an unexpected event is notified in a state, error processing will be performed.

# 6.1.5 Functions Used on Protocol State Transitions

Table 6.4 lists the Functions Used on Protocol State Transition.

| Table 6.4 | Functions Used on Protocol State Transition |
|-----------|---------------------------------------------|
|-----------|---------------------------------------------|

| Processing | Function                                  | Overview                                        |
|------------|-------------------------------------------|-------------------------------------------------|
| Func0      | sci_iic_init_driver()                     | Initialization                                  |
| Func1      | <pre>sci_iic_generate_start_cond()</pre>  | Start condition generation                      |
| Func2      | <pre>sci_iic_after_gen_start_cond()</pre> | Processing after generating a start condition   |
| Func3      | sci_iic_after_send_slvadr()               | Processing after transmitting the slave address |
| Func4      | <pre>sci_iic_write_data_sending()</pre>   | Data transmission                               |
| Func5      | <pre>sci_iic_read_data_receiving()</pre>  | Data reception                                  |
| Func6      | sci_iic_release()                         | Communication end processing                    |
| Func7      | sci_iic_nack()                            | NACK error processing                           |

# 6.1.6 Flag States on State Transitions

1) Controlling states of channels

Multiple slaves on the same bus can be exclusively controlled using the channel state flag 'g\_sci\_iic\_ChStatus[]'. Each channel has the channel state flag and the flag is controlled by the global variable. When the initialization for this module has completed and the target bus is not being used for a communication, the flag becomes 'SCI\_IIC\_IDLE/SCI\_IIC\_FINISH/SCI\_IIC\_NACK' (idle state) and communication is available. When the bus is being used for communication, the flag becomes 'SCI\_IIC\_COMMUNICATION' (communicating). When communication is started, the flag is always verified. Thus, if a device is communication can be achieved by controlling the channel state flag for each channel.

2) Controlling states of devices

Multiple slaves on the same channel can be controlled using the device state flag 'dev\_sts' in the I<sup>2</sup>C communication information structure. The device state flag stores the state of communication for the device.

Table 6.5 lists States of Flags on State Transitions.



|                                               | Channel State Flag                             | Device State Flag<br>(Communication Device)                           | I <sup>2</sup> C Protocol Operating<br>Mode                 | Current State of the Protocol Control                                                                                                                                                   |  |
|-----------------------------------------------|------------------------------------------------|-----------------------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| State                                         | g_sci_iic_ChStatus[]                           | I <sup>2</sup> C Communication<br>Information Structure<br>*p_dev_sts | Internal Communication<br>Information Structure<br>api_Mode | Internal Communication Information<br>Structure<br>api_N_status                                                                                                                         |  |
| Uninitialized state                           | SCI_IIC_NO_INIT                                | SCI_IIC_NO_INIT                                                       | SCI_IIC_MODE_NONE                                           | SCI_IIC_STS_NO_INIT                                                                                                                                                                     |  |
| Idle state                                    | SCI_IIC_IDLE<br>SCI_IIC_FINISH<br>SCI_IIC_NACK | SCI_IIC_IDLE<br>SCI_IIC_FINISH<br>SCI_IIC_NACK                        | SCI_IIC_MODE_NONE                                           | SCI_IIC_STS_IDLE                                                                                                                                                                        |  |
| Communicating<br>(master<br>transmission)     | SCI_IIC_<br>COMMUNICATION                      | SCI_IIC_<br>COMMUNICATION                                             | SCI_IIC_MODE_WRITE                                          | SCI_IIC_STS_ST_COND_WAIT<br>SCI_IIC_STS_SEND_SLVADR_W_WAIT<br>SCI_IIC_STS_SEND_DATA_WAIT<br>SCI_IIC_STS_SP_COND_WAIT                                                                    |  |
| Communicating<br>(master reception)           | SCI_IIC_<br>COMMUNICATION                      | SCI_IIC_<br>COMMUNICATION                                             | SCI_IIC_MODE_READ                                           | SCI_IIC_STS_ST_COND_WAIT<br>SCI_IIC_STS_SEND_SLVADR_R_WAIT<br>SCI_IIC_STS_RECEIVE_DATA_WAIT<br>SCI_IIC_STS_SP_COND_WAIT                                                                 |  |
| Communicating<br>(master<br>transmit/receive) | SCI_IIC_<br>COMMUNICATION                      | SCI_IIC_<br>COMMUNICATION                                             | SCI_IIC_MODE_<br>COMBINED                                   | SCI_IIC_STS_ST_COND_WAIT<br>SCI_IIC_STS_SEND_SLVADR_W_WAIT<br>SCI_IIC_STS_SEND_SLVADR_R_WAIT<br>SCI_IIC_STS_SEND_DATA_WAIT<br>SCI_IIC_STS_RECEIVE_DATA_WAIT<br>SCI_IIC_STS_SP_COND_WAIT |  |
| Error state                                   | SCI_IIC_ERROR                                  | SCI IIC ERROR                                                         | _                                                           | _                                                                                                                                                                                       |  |

# Table 6.5 States of Flags on State Transitions



# 6.2 Interrupt Request Generation Timing

This section describes the interrupt request generation timings in this module.

Legend: ST: Start condition AD6 to AD0: Slave address /W: Transfer direction bit: 0 (Write) R: Transfer direction bit: 1 (Read) /ACK: Acknowledge: 0 NACK: Acknowledge: 1 D7 to D0: Data RST: Restart condition

SP: Stop condition

# 6.2.1 Master Transmission

(1) Pattern 1

| ST | AD6 to<br>AD0 | /W | /ACK | D7 to D0 | /ACK | D7 to D0 | /ACK | SP |    |
|----|---------------|----|------|----------|------|----------|------|----|----|
|    | 1             |    |      | ▲2       |      | ▲3       |      | 4  | ▲5 |

▲ 1: STI (START) interrupt: Start condition detected

▲ 2: TXI interrupt: Address transmission completed (transfer direction bit: write) <sup>(1)</sup>

▲ 3: TXI interrupt: Data transmission completed (first data) <sup>(1)</sup>

- ▲ 4: TXI interrupt: Data transmission completed (second data) <sup>(1)</sup>
- ▲ 5: STI (STOP) interrupt: Stop condition detected
- (2) Pattern 2



▲ 1: STI (START) interrupt: Start condition detected

▲ 2: TXI interrupt: Address transmission completed (transfer direction bit: write) <sup>(1)</sup>

▲ 3: TXI interrupt: Data transmission completed (second data) <sup>(1)</sup>

▲ 4: STI (STOP) interrupt: Stop condition detected

Note:

1. An interrupt request is generated on the rising edge of the ninth clock.



(3) Pattern 3



▲ 1: STI (START) interrupt: Start condition detected

▲ 2: TXI interrupt: Address transmission completed (transfer direction bit: write) <sup>(1)</sup>

▲ 3: STI (STOP) interrupt: Stop condition detected

| ST |    | SP |
|----|----|----|
|    | ▲1 | ▲2 |

▲ 1: STI (START) interrupt: Start condition detected

▲ 2: STI (STOP) interrupt: Stop condition detected

Note:

1. An interrupt request is generated on the rising edge of the ninth clock.

# 6.2.2 Master Reception



▲ 1: STI (START) interrupt: Start condition detected

▲ 2: TXI interrupt: Address transmission completed (transfer direction bit: read) <sup>(1)</sup>

- ▲ 3: TXI interrupt: Reception for the last data 1 completed (second data) <sup>(1)</sup>
- ▲4: TXI interrupt: Reception for the last data completed (second data) <sup>(2)</sup>

▲ 5: STI (STOP) interrupt: Stop condition detected

Notes:

- 1. An interrupt request is generated on the rising edge of the ninth clock.
- 2. An interrupt request is generated on the rising edge of the eighth clock.

# 6.2.3 Master Transmit/Receive

| ST   | AD6 to<br>AD0 | /W   | /ACK     | D7 to D0 | /ACK | RST  | AD6 to<br>AD0 | R |
|------|---------------|------|----------|----------|------|------|---------------|---|
|      | <b>1</b>      |      |          | 2        | 4    | ▲3 ▲ | 4             |   |
| /ACK | D7 to D0      | /ACK | D7 to D0 | NACK     | SP   |      |               |   |
|      | ▲5            |      | 6        | 7        |      | 8    |               |   |

▲ 1: STI (START) interrupt: Start condition detected

▲ 2: TXI interrupt: Address transmission completed (transfer direction bit: write) <sup>(1)</sup>

▲ 3: TXI interrupt: Data transmission completed (first data) <sup>(1)</sup>

▲ 4: STI (START) interrupt: Restart condition detected

▲ 5: TXI interrupt: Address transmission completed (transfer direction bit: read) <sup>(1)</sup>

▲ 6: TXI interrupt: Reception for the last data - 1 completed (second data) <sup>(1)</sup>

▲ 7: TXI interrupt: Reception for the last data completed (second data) <sup>(2)</sup>

▲ 8: STI (STOP) interrupt: Stop condition detected

Notes:

- 1. An interrupt request is generated on the rising edge of the ninth clock.
- 2. An interrupt request is generated on the rising edge of the eighth clock.



# 6.3 Operating Test Environment

This section describes for detailed the operating test environments of this module.

| Item                   | Contents                                                                                                             |  |  |  |
|------------------------|----------------------------------------------------------------------------------------------------------------------|--|--|--|
| Integrated development | Renesas Electronics                                                                                                  |  |  |  |
| environment            | e <sup>2</sup> studio V3.1.2.09                                                                                      |  |  |  |
| C compiler             | Renesas Electronics                                                                                                  |  |  |  |
|                        | C/C++ compiler for RX Family V.2.02.00                                                                               |  |  |  |
|                        | Compiler options: The integrated development environment default settings are used, with the following option added. |  |  |  |
|                        | -lang = c99                                                                                                          |  |  |  |
| Endian order           | Big-endian/Little-endian                                                                                             |  |  |  |
| Module version         | Rev.1.60 and Rev.1.70                                                                                                |  |  |  |
| Board used             | Renesas Starter Kit for RX111 (product number. R0K505111SxxxBE)                                                      |  |  |  |
|                        | Renesas Starter Kit for RX113 (product number. R0K505113SxxxBE)                                                      |  |  |  |
|                        | Renesas Starter Kit for RX231 (product number. R0K505231SxxxBE)                                                      |  |  |  |
|                        | Renesas Starter Kit+ for RX63N (product number. R0K50563NSxxxBE)                                                     |  |  |  |
|                        | Renesas Starter Kit+ for RX64M (product number. R0K50564MSxxxBE)                                                     |  |  |  |
|                        | Renesas Starter Kit+ for RX71M (product number. R0K50571MSxxxBE)                                                     |  |  |  |

# Table 6.6 Operation Test Environment for Rev.1.60 and Rev.1.70.

# Table 6.7 Operation Test Environment for Rev.1.80.

| Item                   | Contents                                                                  |
|------------------------|---------------------------------------------------------------------------|
| Integrated development | Renesas Electronics                                                       |
| environment            | e <sup>2</sup> studio V4.0.2.008                                          |
| C compiler             | Renesas Electronics                                                       |
|                        | C/C++ compiler for RX Family V.2.03.00                                    |
|                        | Compiler options: The integrated development environment default settings |
|                        | are used, with the following option added.                                |
|                        | -lang = c99                                                               |
| Endian order           | Big-endian/Little-endian                                                  |
| Module version         | Rev.1.80                                                                  |
| Board used             | Renesas Starter Kit for RX130 (product number. R0K505113SxxxBE)           |
|                        | Renesas Starter Kit for RX23T (product number. RTK500523TSxxxxBE)         |

# Table 6.8 Operation Confirmation Environment for Rev.1.90.

| Item                   | Contents                                                                                                                            |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Integrated development | Renesas Electronics                                                                                                                 |
| environment            | e <sup>2</sup> studio V4.1.0.018                                                                                                    |
| C compiler             | Renesas Electronics                                                                                                                 |
|                        | C/C++ compiler for RX Family V.2.03.00                                                                                              |
|                        | Compiler options: The integrated development environment default settings are used, with the following option added.<br>-lang = c99 |
| Endian order           | Big-endian/Little-endian                                                                                                            |
| Module version         | Rev.1.90                                                                                                                            |
| Board used             | Renesas Starter Kit for RX111 (product number. R0K505111SxxxBE)                                                                     |
|                        | Renesas Starter Kit for RX113 (product number. R0K505113SxxxBE)                                                                     |
|                        | Renesas Starter Kit for RX130 (product number. RTK5005130SxxxxxBE)                                                                  |
|                        | Renesas Starter Kit for RX231 (product number. R0K505231SxxxBE)                                                                     |
|                        | Renesas Starter Kit for RX23T (product number. RTK500523TSxxxxxBE)                                                                  |
|                        | Renesas Starter Kit for RX24T (product number. RTK500524TSxxxxBE)                                                                   |
|                        | Renesas Starter Kit for RX63N (product number. R0K50563NSxxxBE)                                                                     |
|                        | Renesas Starter Kit for RX64M (product number. R0K50564MSxxxBE)                                                                     |
|                        | Renesas Starter Kit for RX71M (product number. R0K50571MSxxxBE)                                                                     |

## Table 6.9 Operation Confirmation Environment for Rev.2.00.

| Item                   | Contents                                                                  |
|------------------------|---------------------------------------------------------------------------|
| Integrated deveropment | Renesas Electronics                                                       |
| environment            | e <sup>2</sup> studio V5.0.1.005                                          |
| C compiler             | Renesas Electronics                                                       |
|                        | C/C++ compiler for RX Family V.2.05.00                                    |
|                        | Compiler options: The integrated development environment default settings |
|                        | are used, with the following option added.                                |
|                        | -lang = c99                                                               |
| Endian order           | Big-endian/Little-endian                                                  |
| Module version         | Rev.2.00                                                                  |
| Board used             | Renesas Starter Kit for RX231 (product number. R0K505231SxxxBE)           |
|                        | Renesas Starter Kit+ for RX65N (product number. RTK500565NSxxxxBE)        |
|                        | Renesas Starter Kit for RX111 (product number. R0K505111SxxxBE)           |
|                        | Renesas Starter Kit for RX130 (product number. RTK5005130SxxxxxBE)        |
|                        | Renesas Starter Kit for RX231 (product number. R0K505231SxxxBE)           |
|                        | Renesas Starter Kit for RX23T (product number. RTK500523TSxxxxBE)         |
|                        | Renesas Starter Kit for RX24T (product number. RTK500524TSxxxxBE)         |
|                        | Renesas Starter Kit+ for RX63N (product number. R0K50563NSxxxBE)          |
|                        | Renesas Starter Kit+ for RX64M (product number. R0K50564MSxxxBE)          |
|                        | Renesas Starter Kit+ for RX65N (product number. RTK500565NSxxxxBE)        |
|                        | Renesas Starter Kit+ for RX71M (product number. R0K50571MSxxxBE)          |



| ltem                   | Contents                                                                  |
|------------------------|---------------------------------------------------------------------------|
| Integrated deveropment | Renesas Electronics                                                       |
| environment            | e <sup>2</sup> studio V6.0.001                                            |
| C compiler             | Renesas Electronics                                                       |
|                        | C/C++ compiler for RX Family V.2.06.00                                    |
|                        | C/C++ compiler for RX Family V.2.07.00                                    |
|                        | Compiler options: The integrated development environment default settings |
|                        | are used, with the following option added.                                |
|                        | -lang = c99                                                               |
| Endian order           | Big-endian/Little-endian                                                  |
| Module version         | Rev.2.20                                                                  |
| Board used             | Renesas Starter Kit for RX24U (product number. RTK50524USxxxxBE)          |
|                        | Renesas Starter Kit for RX130-512KB                                       |
|                        | (product number. RTK5051308SxxxxBE)                                       |
|                        | Renesas Starter Kit+ for RX65N-2MB                                        |
|                        | (product number. RTK50565N2SxxxxBE)                                       |

# Table 6.10 Operation Confirmation Environment for Rev.2.20.

## Table 6.11 Operation Confirmation Environment for Rev.2.30.

| Item                   | Contents                                                                                                             |
|------------------------|----------------------------------------------------------------------------------------------------------------------|
| Integrated deveropment | Renesas Electronics                                                                                                  |
| environment            | e <sup>2</sup> studio V7.0.0                                                                                         |
| C compiler             | Renesas Electronics                                                                                                  |
|                        | C/C++ compiler for RX Family V.3.00.00                                                                               |
|                        | Compiler options: The integrated development environment default settings are used, with the following option added. |
|                        | -lang = c99                                                                                                          |
| Endian order           | Big-endian/Little-endian                                                                                             |
| Module version         | Rev.2.30                                                                                                             |
| Board used             | Renesas Starter Kit for RX66T (product number. RTK50566T0SxxxxxBE)                                                   |

## Table 6.12 Operation Confirmation Environment for Rev.2.31.

| ltem                                  | Contents                                                                                                                            |
|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Integrated deveropment<br>environment | Renesas Electronics<br>e <sup>2</sup> studio V7.1.0                                                                                 |
| C compiler                            | Renesas Electronics                                                                                                                 |
|                                       | C/C++ compiler for RX Family V.3.00.00                                                                                              |
|                                       | Compiler options: The integrated development environment default settings are used, with the following option added.<br>-lang = c99 |
| Endian order                          | Big-endian/Little-endian                                                                                                            |
| Module version                        | Rev.2.31                                                                                                                            |



# Table 6.13 Operation Confirmation Environment for Rev.2.40.

| ltem                   | Contents                                                                                                             |
|------------------------|----------------------------------------------------------------------------------------------------------------------|
| Integrated deveropment | Renesas Electronics                                                                                                  |
| environment            | e <sup>2</sup> studio V7.3.0                                                                                         |
| C compiler             | Renesas Electronics                                                                                                  |
|                        | C/C++ compiler for RX Family V.3.01.00                                                                               |
|                        | Compiler options: The integrated development environment default settings are used, with the following option added. |
|                        | -lang = c99                                                                                                          |
| Endian order           | Big-endian/Little-endian                                                                                             |
| Module version         | Rev.2.40                                                                                                             |
| Board used             | Renesas Starter Kit for RX72T (product number. RTK5572Txxxxxxxxx)                                                    |

## Table 6.14 Operation Confirmation Environment for Rev.2.41.

| ltem                   | Contents                                                                                                                                                                                   |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Integrated deveropment | Renesas Electronics e <sup>2</sup> studio V7.3.0                                                                                                                                           |
| environment            | IAR Embedded Workbench for Renesas RX 4.10.01                                                                                                                                              |
| C compiler             | Renesas Electronics C/C++ Compiler Package for RX Family V.3.01.00<br>Compiler option: The following option is added to the default settings of the<br>integrated development environment. |
|                        | -lang = c99                                                                                                                                                                                |
|                        | GCC for Renesas RX 4.08.04.201803                                                                                                                                                          |
|                        | Compiler option: The following option is added to the default settings of the integrated development environment.<br>-std=gnu99                                                            |
|                        | IAR C/C++ Compiler for Renesas RX version 4.10.01                                                                                                                                          |
|                        | Compiler option: The default settings of the integrated development environment.                                                                                                           |
| Endian order           | Big-endian/Little-endian                                                                                                                                                                   |
| Module version         | Rev.2.41                                                                                                                                                                                   |
| Board used             | Renesas Starter Kit+ for RX65N (product number. RTK500565Nxxxxx)                                                                                                                           |

## Table 6.15 Operation Confirmation Environment for Rev.2.42.

| Item                   | Contents                                                                                                             |
|------------------------|----------------------------------------------------------------------------------------------------------------------|
| Integrated deveropment | Renesas Electronics                                                                                                  |
| environment            | e <sup>2</sup> studio V7.2.0                                                                                         |
| C compiler             | Renesas Electronics                                                                                                  |
|                        | C/C++ compiler for RX Family V.3.01.00                                                                               |
|                        | Compiler options: The integrated development environment default settings are used, with the following option added. |
|                        | -lang = c99                                                                                                          |
| Endian order           | Big-endian/Little-endian                                                                                             |
| Module version         | Rev.2.42                                                                                                             |
| Board used             | Renesas Solution Starter Kit for RX23W (product No.: RTK5523Wxxxxxxxxx)                                              |

# Table 6.16 Operation Confirmation Environment for Rev.2.43.

| Item                   | Contents                                                                                                                                            |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Integrated deveropment | Renesas Electronics e <sup>2</sup> studio V7.4.0                                                                                                    |
| environment            | IAR Embedded Workbench for Renesas 4.12.01                                                                                                          |
| C compiler             | Renesas Electronics C/C++ Compiler Package for RX Family V.3.01.00<br>Compiler option: The following option is added to the default settings of the |
|                        | integrated development environment.                                                                                                                 |
|                        | -lang = c99                                                                                                                                         |
|                        | GCC for Renesas RX 4.08.04.201902                                                                                                                   |
|                        | Compiler option: The following option is added to the default settings of the integrated development environment.                                   |
|                        | -std=gnu99                                                                                                                                          |
|                        | IAR C/C++ Compiler for Renesas RX version 4.12.01                                                                                                   |
|                        | Compiler option: The default settings of the integrated development environment.                                                                    |
| Endian order           | Big-endian/Little-endian                                                                                                                            |
| Module version         | Rev.2.43                                                                                                                                            |
| Board used             | Renesas Starter Kit+ for RX72M                                                                                                                      |
|                        | (product number. RTK5572Mxxxxxxxx)                                                                                                                  |

### Table 6.17 Operation Confirmation Environment for Rev.2.44.

| Item                   | Contents                                                                                                                                                                                                  |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Integrated deveropment | Renesas Electronics e <sup>2</sup> studio V7.3.0                                                                                                                                                          |
| environment            | IAR Embedded Workbench for Renesas 4.12.01                                                                                                                                                                |
| C compiler             | Renesas Electronics C/C++ Compiler Package for RX Family V.3.01.00<br>Compiler option: The following option is added to the default settings of the<br>integrated development environment.<br>-lang = c99 |
|                        | GCC for Renesas RX 4.08.04.201902<br>Compiler option: The following option is added to the default settings of the<br>integrated development environment.<br>-std=gnu99                                   |
|                        | IAR C/C++ Compiler for Renesas RX version 4.12.01<br>Compiler option: The default settings of the integrated development<br>environment.                                                                  |
| Endian order           | Big-endian/Little-endian                                                                                                                                                                                  |
| Module version         | Rev.2.44                                                                                                                                                                                                  |
| Board used             | RX13T CPU Card (product number.RTK0EMXA10C00000BJ)                                                                                                                                                        |



| Item                   | Contents                                                                                                          |
|------------------------|-------------------------------------------------------------------------------------------------------------------|
| Integrated deveropment | Renesas Electronics e <sup>2</sup> studio 7.4.0                                                                   |
| environment            | IAR Embedded Workbench for Renesas 4.12.01                                                                        |
| C compiler             | Renesas Electronics C/C++ Compiler Package for RX Family V.3.01.00                                                |
|                        | Compiler option: The following option is added to the default settings of the integrated development environment. |
|                        | -lang = c99                                                                                                       |
|                        | GCC for Renesas RX 4.08.04.201902                                                                                 |
|                        | Compiler option: The following option is added to the default settings of the                                     |
|                        | integrated development environment.                                                                               |
|                        | -std=gnu99                                                                                                        |
|                        | IAR C/C++ Compiler for Renesas RX version 4.12.01                                                                 |
|                        | Compiler option: The default settings of the integrated development                                               |
|                        | environment.                                                                                                      |
| Endian order           | Big-endian/Little-endian                                                                                          |
| Module version         | Rev.2.45                                                                                                          |
| Board used             | Renesas Starter Kit+ for RX72N                                                                                    |
|                        | (product number. RTK5572Nxxxxxxxx)                                                                                |
|                        | Renesas Starter Kit+ for RX72M                                                                                    |
|                        | (product number. RTK5572Mxxxxxxxx)                                                                                |

# Table 6.18 Operation Confirmation Environment for Rev.2.45.

# Table 6.19 Operation Confirmation Environment for Rev.2.46.

| Item                   | Contents                                                                                                          |
|------------------------|-------------------------------------------------------------------------------------------------------------------|
| Integrated deveropment | Renesas Electronics e <sup>2</sup> studio 7.7.0                                                                   |
| environment            | IAR Embedded Workbench for Renesas 4.13.01                                                                        |
| C compiler             | Renesas Electronics C/C++ Compiler Package for RX Family V.3.02.00                                                |
|                        | Compiler option: The following option is added to the default settings of the integrated development environment. |
|                        | -lang = c99                                                                                                       |
|                        | GCC for Renesas RX 8.03.00.201904                                                                                 |
|                        | Compiler option: The following option is added to the default settings of the integrated development environment. |
|                        | -std=gnu99                                                                                                        |
|                        | IAR C/C++ Compiler for Renesas RX version 4.13.01                                                                 |
|                        | Compiler option: The default settings of the integrated development environment.                                  |
| Endian order           | Big-endian/Little-endian                                                                                          |
| Module version         | Rev.2.46                                                                                                          |
| Board used             | Renesas Solution Starter Kit for RX23E-A (RTK0ESXB10C00001BJ)                                                     |



### Table 6.20 Operation Confirmation Environment for Rev.2.47.

| Item                                  | Contents                                                                                                                         |  |
|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--|
| Integrated deveropment<br>environment | Renesas Electronics e <sup>2</sup> studio Version 2020-10 (20.10.0)                                                              |  |
| C compiler                            | Renesas Electronics C/C++ Compiler Package for RX Family V.3.02.00                                                               |  |
|                                       | Compiler option: The following option is added to the default settings of the integrated development environment.<br>-lang = c99 |  |
| Endian order                          | Big-endian/Little-endian                                                                                                         |  |
| Module version                        | Rev.2.47                                                                                                                         |  |
| Board used                            | Renesas Starter Kit for RX231 (product number. R0K505231SxxxBE)                                                                  |  |
|                                       | Renesas Starter Kit+ for RX64M (product number. R0K50564MSxxxBE)                                                                 |  |

### Table 6.21 Operation Confirmation Environment for Rev.2.48.

| ltem                   | Contents                                                                                                          |  |  |  |
|------------------------|-------------------------------------------------------------------------------------------------------------------|--|--|--|
| Integrated deveropment | Renesas Electronics e <sup>2</sup> studio Version 2021-01 (21.1.0)                                                |  |  |  |
| environment            | IAR Embedded Workbench for Renesas 4.14.01                                                                        |  |  |  |
| C compiler             | Renesas Electronics C/C++ Compiler Package for RX Family V.3.03.00                                                |  |  |  |
|                        | Compiler option: The following option is added to the default settings of the integrated development environment. |  |  |  |
|                        | -lang = c99                                                                                                       |  |  |  |
|                        | GCC for Renesas RX 8.03.00.202002                                                                                 |  |  |  |
|                        | Compiler option: The following option is added to the default settings of the                                     |  |  |  |
|                        | integrated development environment.                                                                               |  |  |  |
|                        | -std=gnu99                                                                                                        |  |  |  |
|                        | IAR C/C++ Compiler for Renesas RX version 4.14.01                                                                 |  |  |  |
|                        | Compiler option: The default settings of the integrated development                                               |  |  |  |
|                        | environment.                                                                                                      |  |  |  |
| Endian order           | Big-endian/Little-endian                                                                                          |  |  |  |
| Module version         | Rev.2.48                                                                                                          |  |  |  |
| Board used             | Renesas Starter Kit+ for RX671 (product number. RTK55671xxxxxxxxx)                                                |  |  |  |

### Table 6.22 Operation Confirmation Environment for Rev.2.49.

| ltem                   | Contents                                                                                                                                                                                                                               |  |  |  |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Integrated deveropment | Renesas Electronics e <sup>2</sup> studio Version 2021-07 (21.7.0)                                                                                                                                                                     |  |  |  |
| environment            | IAR Embedded Workbench for Renesas 4.20.01                                                                                                                                                                                             |  |  |  |
| C compiler             | Renesas Electronics C/C++ Compiler Package for RX Family V.3.03.00Compiler option: The following option is added to the default settings of the<br>integrated development environment.<br>-lang = c99GCC for Renesas RX 8.03.00.202102 |  |  |  |
|                        | Compiler option: The following option is added to the default settings of the integrated development environment.<br>-std=gnu99                                                                                                        |  |  |  |
|                        | IAR C/C++ Compiler for Renesas RX version 4.20.01<br>Compiler option: The default settings of the integrated development<br>environment.                                                                                               |  |  |  |
| Endian order           | Big-endian/Little-endian                                                                                                                                                                                                               |  |  |  |
| Module version         | Rev.2.49                                                                                                                                                                                                                               |  |  |  |
| Board used             | Target board for RX140 (product number. RTK5RX140xxxxxxxx)                                                                                                                                                                             |  |  |  |

## Table 6.23 Operation Confirmation Environment for Rev.2.50.

| Item                   | Contents                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Integrated development | Renesas Electronics e <sup>2</sup> studio Version 2022-04 (22.4.0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| environment            | IAR Embedded Workbench for Renesas 4.20.03                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| C compiler             | Renesas Electronics e² studio Version 2022-04 (22.4.0)IAR Embedded Workbench for Renesas 4.20.03Renesas Electronics C/C++ Compiler Package for RX Family V.3.04.00Compiler option: The following option is added to the default settings of the<br>integrated development environmentlang = c99GCC for Renesas RX 8.03.00.202104Compiler option: The following option is added to the default settings of the<br>integrated development environmentstd=gnu99Linker option: The following user defined option should be added to the default<br>settings of the integrated development environment, if "Optimize size (-Os)" is<br>used:-WI,no-gc-sectionsThis is to work around a GCC linker issue whereby the linker erroneously<br>discard interrupt functions declared in FIT peripheral moduleIAR C/C++ Compiler for Renesas RX version 4.20.03<br>Compiler option: The default settings of the integrated development<br>environment. |  |  |  |
| Endian order           | Big-endian/Little-endian                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| Module version         | Rev.2.50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| Board used             | Renesas Starter Kit for RX660 (product No.: RTK5056609HCxxxxxBJ)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |



## Table 6.24 Operation Confirmation Environment for Rev.2.60.

| ltem                   | Contents                                                                                                                                                                                                  |  |  |  |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Integrated development | Renesas Electronics e <sup>2</sup> studio Version 2022-10                                                                                                                                                 |  |  |  |
| environment            | IAR Embedded Workbench for Renesas 4.20.03                                                                                                                                                                |  |  |  |
| C compiler             | Renesas Electronics C/C++ Compiler Package for RX Family V.3.05.00<br>Compiler option: The following option is added to the default settings of the<br>integrated development environment.<br>-lang = c99 |  |  |  |
|                        | GCC for Renesas RX 8.03.00.202204                                                                                                                                                                         |  |  |  |
|                        | Compiler option: The following option is added to the default settings of the integrated development environment.<br>-std=gnu99                                                                           |  |  |  |
|                        | Linker option: The following user defined option should be added to the default settings of the integrated development environment, if "Optimize size (-Os)" is used:                                     |  |  |  |
|                        | -WI,no-gc-sections                                                                                                                                                                                        |  |  |  |
|                        | This is to work around a GCC linker issue whereby the linker erroneously<br>discard interrupt functions declared in FIT peripheral module                                                                 |  |  |  |
|                        | IAR C/C++ Compiler for Renesas RX version 4.20.03<br>Compiler option: The default settings of the integrated development<br>environment.                                                                  |  |  |  |
| Endian order           | Big-endian/Little-endian                                                                                                                                                                                  |  |  |  |
| Module version         | Rev.2.60                                                                                                                                                                                                  |  |  |  |
| Board used             | Renesas Flexible Motor Control Kit for RX26T (Part Number:<br>RTK0EMXE70S00020BJ)                                                                                                                         |  |  |  |
|                        | Renesas Starter Kit for RX64M (product No.: R0K50564Mxxxxx)                                                                                                                                               |  |  |  |
|                        | Renesas Starter Kit+ for RX72N (product No.: RTK5572NNDCxxxxx)                                                                                                                                            |  |  |  |
|                        | Renesas Starter Kit for RX231 (product No.: R0K505231SxxxBE)                                                                                                                                              |  |  |  |
|                        | Renesas Starter Kit+ for RX671 (product No.: RTK55671EDCxxxxxBJ)                                                                                                                                          |  |  |  |



## Table 6.25 Operation Confirmation Environment for Rev.2.70.

| ltem                   | Contents                                                                                                                                                                                                                                       |  |  |  |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Integrated development | Renesas Electronics e <sup>2</sup> studio Version 2023-04                                                                                                                                                                                      |  |  |  |
| environment            | IAR Embedded Workbench for Renesas 4.20.03                                                                                                                                                                                                     |  |  |  |
| C compiler             | Renesas Electronics C/C++ Compiler Package for RX Family V.3.05.00<br>Compiler option: The following option is added to the default settings of the<br>integrated development environment.<br>-lang = c99<br>GCC for Renesas RX 8.03.00.202204 |  |  |  |
|                        | Compiler option: The following option is added to the default settings of the integrated development environment.<br>-std=gnu99                                                                                                                |  |  |  |
|                        | Linker option: The following user defined option should be added to the default settings of the integrated development environment, if "Optimize size (-Os)" is used:                                                                          |  |  |  |
|                        | -WI,no-gc-sections                                                                                                                                                                                                                             |  |  |  |
|                        | This is to work around a GCC linker issue whereby the linker erroneously discard interrupt functions declared in FIT peripheral module                                                                                                         |  |  |  |
|                        | IAR C/C++ Compiler for Renesas RX version 4.20.03<br>Compiler option: The default settings of the integrated development<br>environment.                                                                                                       |  |  |  |
| Endian order           | Big-endian/Little-endian                                                                                                                                                                                                                       |  |  |  |
| Module version         | Rev.2.70                                                                                                                                                                                                                                       |  |  |  |
| Board used             | Renesas Solution Starter Kit for RX23E-B (product No.:<br>RTK0ES1001C00001BJ)                                                                                                                                                                  |  |  |  |

### Table 6.26 Operation Confirmation Environment for Rev.2.71.

| Item                   | Contents                                                                        |  |  |  |
|------------------------|---------------------------------------------------------------------------------|--|--|--|
| Integrated development | Renesas Electronics e <sup>2</sup> studio Version 2023-07                       |  |  |  |
| environment            | IAR Embedded Workbench for Renesas 4.20.03                                      |  |  |  |
| C compiler             | Renesas Electronics C/C++ Compiler Package for RX Family V.3.05.00              |  |  |  |
|                        | Compiler option: The following option is added to the default settings of the   |  |  |  |
|                        | integrated development environment.                                             |  |  |  |
|                        | -lang = c99                                                                     |  |  |  |
|                        | GCC for Renesas RX 8.03.00.202305                                               |  |  |  |
|                        | Compiler option: The following option is added to the default settings of the   |  |  |  |
|                        | integrated development environment.                                             |  |  |  |
|                        | -std=gnu99                                                                      |  |  |  |
|                        | Linker option: The following user defined option should be added to the default |  |  |  |
|                        | settings of the integrated development environment, if "Optimize size (-Os)" is |  |  |  |
|                        | used:                                                                           |  |  |  |
|                        | -WI,no-gc-sections                                                              |  |  |  |
|                        | This is to work around a GCC linker issue whereby the linker erroneously        |  |  |  |
|                        | discard interrupt functions declared in FIT peripheral module                   |  |  |  |
|                        | IAR C/C++ Compiler for Renesas RX version 4.20.03                               |  |  |  |
|                        | Compiler option: The default settings of the integrated development             |  |  |  |
|                        | environment.                                                                    |  |  |  |
| Endian order           | Big-endian/Little-endian                                                        |  |  |  |
| Module version         | Rev.2.71                                                                        |  |  |  |
| Board used             | Renesas Starter Kit+ for RX671 (product No.: RTK55671EDCxxxxxBJ)                |  |  |  |

## 6.4 Troubleshooting

- (1) Q: I have added the FIT module to the project and built it. Then I got the error: Could not open source file "platform.h".
  - A: The FIT module may not be added to the project properly. Check if the method for adding FIT modules is correct with the following documents:
  - When using CS+:

Application note "Adding Firmware Integration Technology Modules to CS+ Projects (R01AN1826)"

• When using e<sup>2</sup> studio:

Application note "Adding Firmware Integration Technology Modules to Projects (R01AN1723)"

When using a FIT module, the board support package FIT module (BSP module) must also be added to the project. For this, refer to the application note "Board Support Package Module Using Firmware Integration Technology (R01AN1685)".

(2) Q: I have added the FIT module to the project and built it. Then I got the error: This MCU is not supported by the current r\_sci\_iic\_rx module.

A: The FIT module you added may not support the target device chosen in the user project. Check if the FIT module supports the target device for the project used.

(3) Q: I have added the FIT module to the project and built it. Then I got an error for when the configuration setting is wrong.

A: The setting in the file "r\_sci\_iic\_rx\_config.h" may be wrong. Check the file "r\_sci\_iic\_rx\_config.h". If there is a wrong setting, set the correct value for that. Refer to 2.7 Configuration Overview for details.



## 7. Sample Code

## 7.1 Example when Accessing One Slave Device Continuously with One Channel

This section describes an example of using one SCI channel in simple  $I^2C$  mode to continuously write to one slave device.

The procedure is as follows:

- 1. Execute the R\_SCI\_IIC\_Open function to use SCI channel 1 in the SCI simple I<sup>2</sup>C mode FIT module.
- 2. Execute the R\_SCI\_IIC\_MasterSend function to write 3-byte data to device A.
- 3. Update the transmit data.
- 4. Execute the R\_SCI\_IIC\_MasterSend function to write 3-byte data to device A.
- 5. Execute the R\_SCI\_IIC\_Close function to release SCI channel 1 from the SCI simple I<sup>2</sup>C mode FIT module.

```
#include <stddef.h> // NULL definition
                                                                    The following abbreviations are used in
#include "platform.h"
                                                                    the program example:
#include "r_sci_iic_rx_if.h"
                                                                    - ST: Start condition
                                                                    - SP: Stop condition
/* Defines the number of retries when a NACK is detected. */
#define RETRY TMO
                         10
/* Defines the number of software loops to wait until next communication starts when retrying*/
#define RETRY WAIT TIME 1000
/* Transmit size */
#define SEND SIZE
/* Mode definitions in the sample code. */
typedef enum
{
   IDLE = OU,
BUSY,
INITIALIZE,
DEVICE_A_WRITE,
FINISH,
RETRY_WAIT_DEV_A_WR,
                                /* Being in idle state */
                                /* I2C communication being performed */
                                 /* Simple I2C mode FIT module initialization */
                                /* Writing device A */
                                 /* Communication completed */
                                 /* Waiting for retry writing device A */
                                /* Error occurred */
} sample mode t;
/* Variable for modes in the sample code */
volatile uint8_t sample_mode;
/* Variable for the number of retries */
uint32_t retry_cnt;
/* Variable for the number of transmissions */
uint8 t
                    send num = 0;
void main(void);
void Callback_deviceA(void);
void main (void)
{
                                /* For verifying the return value of the API function */
    sci iic return t ret;
   sci_iic_info_t iic_info_deviceA; /* Information structure for device A */
uint8_t slave_addr_deviceA[1] = {0x50}; /* Slave address of device A */
uint8_t access_addr_deviceA[1] = {0x00}; /* Address to be accessed in device A */
    uint8 t send data[6] = {0x81,0x82,0x83,0x84,0x85,0x86}; /* Transmit data */
```



RENESAS

```
/* Proceed to initialization processing */
sample mode = INITIALIZE;
while(1)
{
    switch(sample mode)
        /* Being in idle state */
                                                         A loop is performed with empty processing
        case IDLE:
                                                         during idle or I<sup>2</sup>C communication.
            /* No operation is performed. */
        break;
        /* I2C communication being performed */
        case BUSY:
                                                           The channel state can be verified with the
            /* No operation is performed. */
                                                           global variable "g sci iic ChStatus[]".
        break;
        /* Initializes the simple I2C mode FIT module.
        case INITIALIZE:
            /* Verifies if it is the first time to communicate with device A. */
            if (0 == send num)
            {
                 /* Verifies if channel 1 is currently communicating. */
                if (SCI_IIC_COMMUNICATION == g_sci_iic_ChStatus[1]
                 {
                     sample mode = ERROR;
                                                   /* Proceed to error processing */
                 }
                else
                 {
                   /* Configures the device A information structure (transmit pattern 1). */
                     iic info deviceA.p slv adr = slave addr deviceA;
                     iic info deviceA.p data1st = access addr deviceA;
                     iic_info_deviceA.p_data2nd = send data;
                     iic info deviceA.dev sts = SCI IIC NO INIT;
                     iic info deviceA.cnt1st = sizeof(access addr deviceA);
                     iic info deviceA.cnt2nd = SEND SIZE;
                     iic info deviceA.callbackfunc = &Callback deviceA;
                     iic_info_deviceA.ch_no = 1;
                 }
                retry cnt = 0;
                 /* SCI open processing */
                 ret = R SCI IIC Open(&iic info deviceA);
                 if (SCI IIC SUCCESS == ret)
                 {
                     sample_mode = DEVICE_A_WRITE; /* Proceed to write processing for
                                                          device A */
                 }
                else
                 {
                     /* Error processing at the R SCI IIC Open() function call */
                     sample mode = ERROR; /* Proceed to error processing */
                 }
             /* Verifies if it is the second or the subsequent continuous communication
               with device A. */
            else if (1 <= send num)
             {
                 /* Verifies if channel 1 is currently communicating. */
                 if (SCI_IIC_COMMUNICATION == g_sci_iic_ChStatus[1])
                 {
                                                   /* Proceed to error processing */
                     sample mode = ERROR;
                 }
                                                        Initializes the transmit counters and pointers for
                 else
                                                        the second transmission.
                    /* Information structure for device A (master transmission pattern 1) */
                     access addr deviceA[0] = (access addr deviceA[0] + SEND SIZE);
                     iic info deviceA.p data1st = access addr deviceA;
                     iic info deviceA.p data2nd = (send data + (SEND SIZE * send num));
                     iic_info_deviceA.cnt1st = sizeof(access_addr_deviceA);
iic_info_deviceA.cnt2nd = SEND_SIZE;
```

Figure 7.2 Example when Accessing One Slave Device Continuously with One Channel (2/4)







Figure 7.4 Example when Accessing One Slave Device Continuously with One Channel (4/4)

## 7.2 Example when Accessing Two Slave Devices with One Channel

This section describes an example of using one SCI channel in simple I<sup>2</sup>C mode to write to and read from two slave devices. In the sample code, I<sup>2</sup>C communication information structure is configured for each accessing device.

The procedure is as follows:

- 1. Execute the R\_SCI\_IIC\_Open function to use SCI channel 1 in the SCI simple I<sup>2</sup>C mode FIT module.
- 2. Execute the R\_SCI\_IIC\_MasterSend function to write 3-byte data to device A.
- 3. Execute the R\_SCI\_IIC\_MasterReceive function to read 3-byte data from device B.
- Execute the R\_SCI\_IIC\_Close function to release SCI channel 1 from the SCI simple I<sup>2</sup>C mode FIT module.



Figure 7.5 Example when Accessing Two Slave Devices with One Channel (1/5)





Figure 7.6 Example when Accessing Two Slave Devices with One Channel (2/5)

## Simple I<sup>2</sup>C Module Using Firmware Integration Technology

| case DE                                     | <pre>tes data to device A. */ EVICE_A_WRITE: cry_cnt = retry_cnt + 1;</pre>                                                                     | Processing from ST generation to SP generation is performed<br>by executing the R_SCI_IIC_MasterSend function in the FIT<br>module. After SP is output, the specified callback function<br>(Callback_deviceA()) is called. |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             | <pre>Starts master transmission. */</pre>                                                                                                       |                                                                                                                                                                                                                            |
| if<br>{                                     | ( <i>SCI_IIC_SUCCESS</i> == ret)                                                                                                                |                                                                                                                                                                                                                            |
| l                                           | <pre>sample_mode = BUSY;</pre>                                                                                                                  | <pre>/* Then the state becomes "I2C communication     being performed". */</pre>                                                                                                                                           |
| }<br>els                                    | se if (SCI_IIC_ERR_BUS_BUSY ==                                                                                                                  | ret)                                                                                                                                                                                                                       |
| t<br>}<br>els                               |                                                                                                                                                 | A_WR; /* Proceed to a wait for retry */                                                                                                                                                                                    |
| {                                           | /* Error processing at the R_                                                                                                                   | SCI_IIC_MasterSend() function call. */<br>/* Proceed to error processing */                                                                                                                                                |
| }<br>break;                                 |                                                                                                                                                 | Processing from ST generation to SP generation is performed                                                                                                                                                                |
| case DE                                     | ds data from device B. */<br>SVICE_B_READ:<br>cry_cnt = retry_cnt + 1;                                                                          | by executing the R_SCI_IIC_MasterReceive function in the FIT module. After SP is output, the specified callback function (Callback_deviceB()) is called.                                                                   |
|                                             | <pre>Starts master transmit/receive     = R_SCI_IIC_MasterReceive(ⅈ</pre>                                                                       |                                                                                                                                                                                                                            |
| if<br>{                                     | ( <i>SCI_IIC_SUCCESS</i> == ret)                                                                                                                |                                                                                                                                                                                                                            |
| t                                           | <pre>sample_mode = BUSY;</pre>                                                                                                                  | <pre>/* Then the state becomes "I2C communication     being performed". */</pre>                                                                                                                                           |
|                                             | se if (SCI_IIC_ERR_BUS_BUSY ==                                                                                                                  | ret)                                                                                                                                                                                                                       |
| {                                           | <pre>sample_mode = RETRY_WAIT_DEV_</pre>                                                                                                        | <u>B_RD;</u> /* Proceed to a wait for retry */                                                                                                                                                                             |
| }<br>els<br>{                               | se                                                                                                                                              |                                                                                                                                                                                                                            |
| }                                           | <pre>/* Error processing at the R_ sample_mode = ERROR;</pre>                                                                                   | <pre>SCI_IIC_MasterReceive() function call. */     /* Proceed to error processing */</pre>                                                                                                                                 |
| /* Wait<br>case <i>RE</i><br>case <i>RE</i> | ts for retry writing device A.<br>ts for retry reading device B.<br>TRY_WAIT_DEV_A_WR:<br>TRY_WAIT_DEV_B_RD:<br>try_wait_cnt = retry_wait_cnt + | <ul> <li>command, a NACK is returned until the write<br/>operation is completed.<br/>In the sample code, retry to start communication is</li> </ul>                                                                        |
| if<br>{                                     | (RETRY_TMO < retry_cnt)                                                                                                                         |                                                                                                                                                                                                                            |
| }                                           | <pre>retry_wait_cnt = 0;<br/>sample_mode = ERROR;</pre>                                                                                         | /* Proceed to error processing */                                                                                                                                                                                          |
|                                             | (RETRY_WAIT_TIME < retry_wait_                                                                                                                  | cnt)                                                                                                                                                                                                                       |
| {                                           | <pre>retry_wait_cnt = 0;</pre>                                                                                                                  |                                                                                                                                                                                                                            |
|                                             | <pre>switch (sample_mode)</pre>                                                                                                                 |                                                                                                                                                                                                                            |
|                                             | <pre>{     case RETRY_WAIT_DEV_A_WR:     sample_mode = DEVICE_A_WRI     break;</pre>                                                            | TTE; /* Proceed to write processing for device A */                                                                                                                                                                        |
|                                             | <pre>case RETRY_WAIT_DEV_B_RD:<br/>sample_mode = DEVICE_B_RE<br/>break;</pre>                                                                   | CAD; /* Proceed to read processing for device B */                                                                                                                                                                         |

Figure 7.7 Example when Accessing Two Slave Devices with One Channel (3/5)



Figure 7.8 Example when Accessing Two Slave Devices with One Channel (4/5)



Figure 7.9 Example when Accessing Two Slave Devices with One Channel (5/5)



## 7.3 Example when Accessing Two Slave Devices with Two Channels

This section describes an example of using two SCI channels in simple I<sup>2</sup>C mode to write and read two slave devices. Each channel writes to and reads from different slave device.

In the sample code, I<sup>2</sup>C communication information structure is configured for each accessing device.

The procedure is as follows:

- 1. Execute the R\_SCI\_IIC\_Open function to use SCI channel 1 in the SCI simple I<sup>2</sup>C mode FIT module. Also execute the R\_SCI\_IIC\_Open function to use SCI channel 5 in the SCI simple I<sup>2</sup>C mode FIT module.
- 2. Execute the R\_SCI\_IIC\_MasterSend function to write 3-byte data to device A using SCI channel 1.

Execute the R\_SCI\_IIC\_MasterReceive function to read 3-byte data from device B using SCI channel 5.

 Execute the R\_SCI\_IIC\_Close function to release SCI channel 1 from the SCI simple I<sup>2</sup>C mode FIT module.

Also execute the R\_SCI\_IIC\_Close function to release SCI channel 5 from the SCI simple I<sup>2</sup>C mode FIT module.

```
#include <stddef.h> /* NULL definition */
#include "platform.h"
                                                                                         The following abbreviations are used in
#include "r sci iic rx if.h"
                                                                                         the program example:
                                                                                         - ST: Start condition
/* Defines the number of retries when a NACK is detected. */
                                                                                         - SP: Stop condition
#define RETRY TMO
                               10
/* Defines the number of software loops to wait until next communication starts when retrying*/
#define RETRY WAIT TIME 1000
/* Transmit size */
#define SEND_SIZE
                                 3
/* Receive size */
#define RECEIVE SIZE
                                 3
/* Definitions for mode management in the sample code */
typedef enum
{
    IDLE = OU, /* Being in idle state */
BUSY, /* I2C communication being performed */
INITIALIZE, /* Simple I2C mode FIT module initialization */
DEVICE_A_WRITE, /* Writing device A */
DEVICE_B_READ, /* Reading device B */
FINISH, /* Communication completed */
RETRY_WAIT_DEV_A_WR, /* Waiting for retry writing device A */
RETRY_WAIT_DEV_B_RD, /* Waiting for retry reading device B */
ERROR /* Error occurred */
} sample mode t;
/* Variable for modes in the sample code */
volatile uint8_t sample_mode_ch1;
volatile uint8 t
                                          sample_mode_ch5;
/* Variable for the number of retries */
volatile uint32_t
                                           retry cnt ch1;
                                          retry_cnt_ch5;
volatile uint32<sup>t</sup>
void main(void);
void Callback deviceA(void);
void Callback_deviceB(void);
void main (void)
{
```

Figure 7.10 Example when Accessing Two Slave Devices with Two Channels (1/6)

volatile sci\_iic\_return\_t ret; /\* For verifying the return value of the API function \*/ volatile uint32 t retry wait cnt ch5 = 0; /\* Counter for adjusting the retry interval \*/ sci\_iic\_info\_t iic\_info\_deviceA; sci\_iic\_info\_t iic\_info\_deviceB; Information structure for device A /\* Information structure for device B \*/ /\* uint8\_t slave\_addr\_deviceA[1] = {0x50}; uint8\_t slave\_addr\_deviceB[1] = {0x50}; uint8\_t access\_addr\_deviceA[1] = {0x00}; Slave address of device A /\* Slave address of device B \*/ \* Address to be accessed in device A \*/ uint8\_t access\_addr\_deviceB[2] = {0x00,0x00}; / Address to be accessed in device B \*/ = {0x81,0x82,0x83,0x84,0x85}; /\* Transmit data \*/ uint8 t send data[5] = {0xFF,0xFF,0xFF,0xFF,0xFF}; /\* For receive data storage \*/ uint8 t store area[5] sample mode ch1 = INITIALIZE; Ch1: Proceed to initialization processing \*/ sample mode ch5 = INITIALIZE; /\* Ch5: Pro eed to initialization processing \*/ Declares information structures for each while(1) device to be accessed. { switch(sample mode ch1) Processing for different channels can be operated { \* Being in idle state \*/ simultaneously. Therefore mode is controlled for each channel. case IDLE: /\* No operation is performed. \*/ break; A loop is performed with empty processing during idle or I<sup>2</sup>C communication. /\* I2C Communication being performed \*/ case BUSY: /\* No operation is performed. \*/ The channel state can be verified with the break; global variable "g\_sci\_iic\_ChStatus[]". /\* Initializes the simple I2C mode FIT module. \*/ case INITIALIZE: /\* Verifies if channel 1 is currently communicating if (SCI IIC COMMUNICATION == g sci iic ChStatus[1]) { sample mode ch1 = ERROR; /\* Ch1: Proceed to error processing \*/ } else { /\* Configures the device A information structure (master transmit pattern 1). \*/ iic\_info\_deviceA.p\_slv\_adr = slave\_addr\_deviceA; iic\_info\_deviceA.p\_data1st = access\_addr\_deviceA; iic\_info\_deviceA.p\_data2nd = send\_data; iic\_info\_deviceA.dev\_sts = SCI\_IIC\_NO\_INIT; iic\_info\_deviceA.cnt1st = sizeof(access\_addr\_deviceA); iic\_info\_deviceA.cnt2nd = SEND\_SIZE; iic info deviceA.callbackfunc = &Callback deviceA; iic info deviceA.ch no = 1; } retry cnt ch1 = 0;/\* Resets the number of retries. \*/ /\* SCI open processing \*/ ret = R SCI IIC Open(&iic info deviceA); if (SCI IIC SUCCESS == ret) { sample\_mode\_ch1 = DEVICE\_A\_WRITE; /\* Ch1: Proceed to write processing for device A \*/ } else { /\* Error processing at the <code>R\_SCI\_IIC\_Open()</code> function call \*/ sample\_mode\_ch1 = ERROR; /\* Ch1: Proceed to error processing \*/ } break: /\* Writes data to device A. \*/ case DEVICE A WRITE: retry\_cnt\_ch1 = retry cnt ch1 + 1;

Figure 7.11 Example when Accessing Two Slave Devices with Two Channels (2/6)





Figure 7.12 Example when Accessing Two Slave Devices with Two Channels (3/6)





Figure 7.13 Example when Accessing Two Slave Devices with Two Channels (4/6)



Figure 7.14 Example when Accessing Two Slave Devices with Two Channels (5/6)

```
else
    {
        if (1 == iic status.BIT.NACK)
        {
            /* Processing when NACK is detected with the iic_status flag verification. */
            sample_mode_ch1 = RETRY_WAIT_DEV_A_WR; /* Ch1: Proceed to a wait for retry */
        }
        else
        {
            retry_cnt_ch1 = 0;
            sample_mode_ch1 = FINISH; /* Ch1: Proceed to communication end processing */
        }
    }
}
void Callback deviceB(void)
{
    volatile sci_iic_return_t ret;
    sci_iic_mcu_status_t iic_status;
    sci iic info t iic info ch;
   iic info ch.ch no = 5;
    /* Obtains the simple I2C status. */
    ret = R_SCI_IIC_GetStatus(&iic_info_ch, &iic_status);
    if (SCI IIC SUCCESS != ret)
    {
        /* Error processing at the <code>R_SCI_IIC_GetStatus()</code> function call. */
        sample mode ch5 = ERROR;
                                                    /* Ch5: Proceed to error processing */
    }
    else
    {
        if (1 == iic status.BIT.NACK)
        {
            /* Processing when NACK is detected with the iic status flag verification */
            sample_mode_ch5 = RETRY_WAIT_DEV_B_RD; /* Ch5: Proceed to a wait for retry */
        }
        else
        {
            retry_cnt_ch5 = 0;
            sample_mode_ch5 = FINISH; /* Ch5: Proceed to communication end processing */
        }
    }
}
```

Figure 7.15 Example when Accessing Two Slave Devices with Two Channels (6/6)



## 8. Reference Documents

User's Manual: Hardware

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

Technical Update/Technical News

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

User's Manual: Development Tools

RX Family C/C++ Compiler CC-RX User's Manual (R20UT3248)

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



# **Related Technical Updates**

This module reflects the content of the following technical updates.

None



# **Revision History**

| Rev. | Date          | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|------|---------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Rev. |               | Page        | Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| 1.60 | Feb. 27, 2015 | Program     | Modified the SCI simple I <sup>2</sup> C mode FIT module due to the software issue                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|      |               |             | [Description]<br>There are errors in the processing to set the clock source (CKS<br>bit in the SMR register) and the bit rate (BRR register) for the on-<br>chip baud rate generator, so the set values may differ from the<br>expected values.                                                                                                                                                                                                                    |  |  |
|      |               |             | <ul> <li>[Conditions]</li> <li>When rev.1.50 or an earlier version of the SCI simple I<sup>2</sup>C mode</li> <li>FIT module is used with RX64M or RX71M, either of the following conditions is met:</li> <li>Divided-by-3 is selected as the PLL input frequency division ratio (PLIDIV bit in the PLLCR register).</li> <li>The tenth place of the PLL frequency multiplication factor is 5 (STC bit in the PLLCR register).</li> </ul>                          |  |  |
|      |               |             | [Workaround]<br>Use rev.1.60 or a later version of the SCI simple I <sup>2</sup> C mode FIT<br>module.<br>Modified the SCI simple I <sup>2</sup> C mode FIT module due to the software<br>issue                                                                                                                                                                                                                                                                    |  |  |
|      |               |             | [Description]<br>When the bit rate is set to low, the program may go into an infinite<br>loop.                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|      |               |             | <ul> <li>[Conditions]</li> <li>The following two conditions are met: <ul> <li>Rev.1.50 or an earlier version of the SCI simple I<sup>2</sup>C mode FIT module is used.</li> <li>The BRR register value calculated by the sci_iic_set_frequency function is greater than 255.</li> <li>(The bit rate is extremely low compared to PCLKB.)</li> <li>Example: <ul> <li>When PCLKB is 60 MHz, the bit rate is set to 200 bps or less.</li> </ul> </li> </ul></li></ul> |  |  |
|      |               |             | When PCLKB is 300 kHz, the bit rate is set to 1 bps.<br>[Workaround]<br>Use rev.1.60 or a later version of the SCI simple I <sup>2</sup> C mode FIT<br>module                                                                                                                                                                                                                                                                                                      |  |  |
| 1.70 | May. 29, 2015 |             | Added support for the RX231 Group.                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 1.80 | Oct. 31, 2015 | -           | Added support for the RX130 Group, RX230 Group, RX23T Group.                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|      |               | 33          | Format of 3.5 R_SCI_IIC_GetStatus(), modified                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |



| David | Dete          |          | Description                                                                                                                                                                                                                                                                         |
|-------|---------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev.  | Date          | Page     | Summary                                                                                                                                                                                                                                                                             |
| 1.90  | Mar. 4, 2016  | -        | Added support for the RX24T Group.                                                                                                                                                                                                                                                  |
|       |               | 5        | Table 1.2 Required Memory Size, changed.                                                                                                                                                                                                                                            |
|       |               | 17, 18   | Added description of r_sci_iic_rx_pin_config.h to section 2.6,<br>Configuration Overview.                                                                                                                                                                                           |
|       |               | -        | Changed "master composite" to "master transmit/receive".                                                                                                                                                                                                                            |
|       |               | 45       | Modified the macro definition of the internal communication<br>information structure api_Mode, which is the I <sup>2</sup> C protocol<br>operating mode in the communication in progress (master<br>transmit/receive) state, in Table 4.5, States of Flags on State<br>Transitions. |
| 2.00  | Oct. 1, 2016  | -        | Added support for the RX65N Group.                                                                                                                                                                                                                                                  |
|       |               | 15       | 2.6 Configuration Overview:<br>Changed default value of<br>SCI_IIC_CFG_CHi_SSDA_DELAY_SELECT.                                                                                                                                                                                       |
|       |               | 19       | Changed code size description from "Table 1.2 Required Memory Size" to "2.7 Code Size."                                                                                                                                                                                             |
| 2.20  | Aug. 31, 2017 | -        | Added support for the RX24U Group.                                                                                                                                                                                                                                                  |
|       |               | -        | Added support for the RX65N-2MB edition.                                                                                                                                                                                                                                            |
|       |               | -        | Added support for the RX130-512KB edition.                                                                                                                                                                                                                                          |
|       |               | -        | Added support for the RX24T-512KB edition.                                                                                                                                                                                                                                          |
|       |               | 1        | Related Documents: Added the following document:<br>"Renesas e <sup>2</sup> studio Smart Configurator User Guide (R20AN0451)"                                                                                                                                                       |
|       |               | 16 to 18 | 2.4 Usage of Interrupt Vector: added.                                                                                                                                                                                                                                               |
|       |               | 20       | In "2.7 Configuration Overview ", SCI_IIC_CFG_CHi_INCLUDED describes the important points to be noted for using the compile time setting                                                                                                                                            |
|       |               |          | SCI_IIC_CFG_CHi_BITRATE_BPS describes the important points to be noted for bit rate setting.                                                                                                                                                                                        |
|       |               | 21       | A notice of bit setting about<br>SCI_IIC_CFG_PORT_SETTING_PROCESSING is added.                                                                                                                                                                                                      |
|       |               | 25       | 2.11 Adding the FIT Module to Your Project: Revised.                                                                                                                                                                                                                                |
|       |               | 45, 46   | 4. Pin Settings: added.                                                                                                                                                                                                                                                             |
|       |               | 59 to 61 | 5.3 Operating Test Environment: Added.                                                                                                                                                                                                                                              |
|       |               | 62       | 5.4 Troubleshooting: Added.                                                                                                                                                                                                                                                         |
|       |               | Program  | Changed default value of SCI_IIC_CFG_CH1_INCLUDED.                                                                                                                                                                                                                                  |
|       |               |          | Corrected the drive capacity control setting process by<br>r_sci_iic_io_open() function of RX63N, RX64M, RX65N and RX71M.                                                                                                                                                           |

| _    |                | Description |                                                                                        |
|------|----------------|-------------|----------------------------------------------------------------------------------------|
| Rev. | Date           | Page        | Summary                                                                                |
| 2.30 | Sep. 20, 2018  | -           | Added support for the RX66T Group.                                                     |
|      | •              | 15          | 2.3 Supported Toolchains                                                               |
|      |                |             | Added for Toolchain v.3.00.00                                                          |
|      |                | 19          | 2.4 Usage of Interrupt Vector: added.                                                  |
|      |                |             | Table 2.4 List of Usage of Interrupt Vectors - 4 -                                     |
|      |                | 23          | In "2.7 Configuration Overview ", Specify the value as an ASCII                        |
|      |                |             | code 'J' is changed to 'K'.                                                            |
|      |                | 25          | 2.8 Code Size: Changed code size for Rev2.30                                           |
|      |                | 28          | 2.12 "for", "while" and "do while" statements: added                                   |
|      |                | 49 to 50    | 5.Demo Projects: added                                                                 |
|      |                | -           | Change 5.Appendices to 6.Appendices                                                    |
|      |                |             | All file: Chapter 5 related number is changed to 6                                     |
|      |                | 64          | Operating Test Environment : added                                                     |
|      |                |             | Table 6-11Operation Confirmation Environment for Rev.2.30 isadded                      |
| 2.31 | Dec. 03, 2018  | 64          | 6.3 Operation Confirmation Environment:                                                |
|      |                |             | Corrected board used in Table 6.11 Confirmed Operation                                 |
|      |                |             | Environment (Rev. 2.30). Added Table 6.12 Confirmed Operation                          |
|      |                | Drogram     | Environment (Rev. 2.31).<br>Added document number of the application note accompanying |
|      |                | Program     | the sample program of the FIT module to xml file.                                      |
| 2.40 | Feb. 20, 2019  | _           | Added support for the RX72T Group.                                                     |
| 2.10 | 1 00. 20, 2010 | 1           | Related Documents: Changed the following documents' names                              |
|      |                |             | RX Family Board Support Package Module Using Firmware                                  |
|      |                |             | Integration Technology (R01AN1685)                                                     |
|      |                |             | RX Family Adding Firmware Integration Technology Modules to<br>Projects (R01AN1723)    |
|      |                |             | RX Family Adding Firmware Integration Technology Modules to CS+ Projects (R01AN1826)   |
|      |                | 15          | 2.3 Supported Toolchains                                                               |
|      |                |             | Added for Toolchain v.3.01.00                                                          |
|      |                | 19          | 2.4 Usage of Interrupt Vector: RX72T added.                                            |
|      |                |             | Table 2.4 List of Usage of Interrupt Vectors - 4 -                                     |
|      |                | 65          | Operating Test Environment : added                                                     |
|      |                |             | Table 6-13         Operation Confirmation Environment for Rev.2.40 is                  |
|      |                |             | added                                                                                  |
| 2.41 | May. 20, 2019  | -           | Update the following compilers                                                         |
|      |                |             | GCC for Renesas RX                                                                     |
|      |                | 4           | IAR C/C++ Compiler for Renesas RX.                                                     |
|      |                | 1           | Deleted Related Documents.                                                             |
|      |                | 1           | Added Target Compilers.                                                                |
|      |                | 15          | Added revision of dependent r_bsp module in 2.2 Software Requirements.                 |
|      |                |             | пециненнениз.                                                                          |

| Davi | Data          |          | Description                                                                                                  |
|------|---------------|----------|--------------------------------------------------------------------------------------------------------------|
| Rev. | Date          | Page     | Summary                                                                                                      |
| 2.41 | May. 20, 2019 | 25       | 2.8 Code Size, amended                                                                                       |
|      | -             | 47       | 3.7 R_SCI_IIC_GetVersion function, deleted special notes.                                                    |
|      |               | 66       | Operating Test Environment : added                                                                           |
|      |               |          | Table 6-14Operation Confirmation Environment for Rev.2.41 isadded                                            |
|      |               | Program  | RX63N is not supported in the following versions. Delete RX63N-<br>processes' related note:                  |
|      |               |          | Deleted RX63N from Target Devices.                                                                           |
| 2.42 | Jun. 20, 2019 | -        | Added support for the RX23W Group.                                                                           |
|      |               | 16       | 2.4 Usage of Interrupt Vector: RX23W added.                                                                  |
|      |               |          | Table 2.1 List of Usage of Interrupt Vectors - 1 -                                                           |
|      |               | 25       | 2.8 Code Size, amended                                                                                       |
|      |               | 65       | Operating Test Environment : added<br>Table 6-15 Operation Confirmation Environment for Rev.2.42 is<br>added |
| 2.43 | Jul. 30, 2019 | -        | Added support for the RX72M Group.                                                                           |
|      |               | 20       | 2.4 Usage of Interrupt Vector: RX72M added.<br>Table 2.5 List of Usage of Interrupt Vectors - 5 -            |
|      |               | 26       | 2.8 Code Size, amended                                                                                       |
|      |               | 30 to 47 | Delete "Reentrant" item on the API description page.                                                         |
|      |               | 67       | Operating Test Environment : added<br>Table 6-16 Operation Confirmation Environment for Rev.2.43 is<br>added |
| 2.44 | Oct. 30, 2019 | -        | Added support for the RX13T Group.                                                                           |
|      |               | 16       | 2.4 Usage of Interrupt Vector: RX13T added.<br>Table 2.1 List of Usage of Interrupt Vectors - 1 -            |
|      |               | 26       | 2.8 Code Size, amended                                                                                       |
|      |               | 67       | Operating Test Environment : added<br>Table 6-17 Operation Confirmation Environment for Rev.2.44 is<br>added |
| 2.45 | Nov. 22, 2019 | -        | Added support for the RX66N and RX72N Groups.                                                                |
|      |               | 16       | 2.4 Usage of Interrupt Vector: RX66N and RX72N added.<br>Table 2.5 List of Usage of Interrupt Vectors - 5 -  |
|      |               | 26       | 2.8 Code Size, amended                                                                                       |
|      |               | 68       | Operating Test Environment : added<br>Table 6-18 Operation Confirmation Environment for Rev.2.45 is<br>added |

| Rev. | Date          | Description |                                                                                                                                                                                                                                                              |
|------|---------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |               | Page        | Summary                                                                                                                                                                                                                                                      |
| 2.45 | Nov. 22, 2019 | Program     | Modified the SCI simple I <sup>2</sup> C mode FIT module due to the software issue                                                                                                                                                                           |
|      |               |             | [Description]<br>There are errors in the processing to set the clock source (CKS<br>bit in the SMR register) and the bit rate (BRR register) for the<br>onchip baud rate generator, so the set values may differ from the<br>expected values.                |
|      |               |             | [Conditions]<br>When rev.2.43 of the SCI simple I <sup>2</sup> C mode FIT module is used<br>with RX72M, and the following two conditions are met:<br>- SCI7, SCI8, or SCI9 of channel is used.<br>- The operating frequency of PCLKA and PCLKB is different. |
|      |               |             | [Workaround]<br>Use rev.2.45 or a later version of the SCI simple I <sup>2</sup> C mode FIT<br>module.                                                                                                                                                       |
| 2.46 | Mar. 10, 2020 | _           | Added support for the RX23E-A Group.                                                                                                                                                                                                                         |
| 2.10 |               | 17          | 2.4 Usage of Interrupt Vector: RX23E-A added.<br>Table 2.1 List of Usage of Interrupt Vectors - 1 -                                                                                                                                                          |
|      |               | 27          | 2.8 Code Size, amended                                                                                                                                                                                                                                       |
|      |               | 29          | Changed Section 2.11 Adding the FIT Module to Your Project.                                                                                                                                                                                                  |
|      |               | 69          | Operating Test Environment : added<br>Table 6-19 Operation Confirmation Environment for Rev.2.46 is<br>added                                                                                                                                                 |
| 2.47 | Oct. 30, 2020 | -           | Updated the sample code project due to the upgrade of the development environment.                                                                                                                                                                           |
| 2.48 | Jun 30, 2021  |             | Added support for the RX671 Group                                                                                                                                                                                                                            |
|      |               | 15          | 2.3 Supported Toolchains<br>Added for Toolchain v.3.03.00                                                                                                                                                                                                    |
|      |               | 19          | 2.4 Usage of Interrupt Vector: RX671 added.<br>Table 2.3 List of Usage of Interrupt Vectors - 3 -                                                                                                                                                            |
|      |               | 70          | Table 6-21 Operation Confirmation Environment for Rev.2.48 is Added.                                                                                                                                                                                         |
| 2.49 | Jul. 31, 2021 | -           | Added support for the RX140 Group.                                                                                                                                                                                                                           |
|      |               | 7 to 10     | The contents of Figure 1.3, Figure 1.4, Figure 1.5, Figure 1.6 and Figure 1.7 are modified.                                                                                                                                                                  |
|      |               | 16          | 2.4 Usage of Interrupt Vector: RX140 added.<br>Table 2.1 List of Usage of Interrupt Vectors - 1 -                                                                                                                                                            |
|      |               | 26          | 2.8 Code Size, amended                                                                                                                                                                                                                                       |
|      |               | 69          | Table 6-22 Operation Confirmation Environment for Rev.2.49 is added.                                                                                                                                                                                         |

| Rev. | Date          | Description |                                                                                                                     |
|------|---------------|-------------|---------------------------------------------------------------------------------------------------------------------|
|      |               | Page        | Summary                                                                                                             |
| 2.50 | Dec. 31, 2021 | -           | Added support for the RX660 Group.                                                                                  |
|      |               | 14          | 1.4 Using SCI Simple I2C Mode FIT Module added                                                                      |
|      |               | 15          | 2.3 Supported Toolchains                                                                                            |
|      |               |             | Added for Toolchain v.3.04.00                                                                                       |
|      |               | 18          | 2.4 Usage of Interrupt Vector: RX660 added.                                                                         |
|      |               |             | Table 2.3 List of Usage of Interrupt Vectors - 3 -                                                                  |
|      |               | 26          | 2.8 Code Size, amended                                                                                              |
|      |               | 71          | Table 6.23 Operation Confirmation Environment for Rev.2.50 isadded.                                                 |
| 2.60 | Jun. 15, 2022 | -           | Added support for the RX26T Group.                                                                                  |
|      |               | 15          | 2.3 Supported Toolchains, amended                                                                                   |
|      |               | 21          | 2.4 Usage of Interrupt Vector: RX26T added.                                                                         |
|      |               |             | Table 2.6 List of Usage of Interrupt Vectors - 6 -                                                                  |
|      |               | 28          | 2.8 Code Size, amended                                                                                              |
|      |               | 54          | Updated and added new demo project.                                                                                 |
|      |               |             | Added RSKRX671, RSKRX72N to "5. Demo Projects".                                                                     |
|      |               | 75          | Table 6.24 Operation Confirmation Environment for Rev.2.60 isadded.                                                 |
|      |               | Program     | Added support for RX26T Group.                                                                                      |
|      |               |             | Updated and added new demo projects.                                                                                |
| 2.70 | May. 29, 2023 | -           | Added support for the RX23E-B Group.                                                                                |
|      |               | 15          | 2.4 Usage of Interrupt Vector: RX23E-B added.                                                                       |
|      |               |             | Table 2.6 List of Usage of Interrupt Vectors - 6 -                                                                  |
|      |               | 27          | 2.8 Code Size, amended                                                                                              |
|      |               | 29, 49      | Deleted the description of FIT configurator from "2.11 Adding the FIT Module to Your Project" and "4. Pin Settings" |
|      |               | 75          | Table 6.25 Operation Confirmation Environment for Rev.2.70 isadded.                                                 |
|      |               | Program     | Added support for RX23E-B Group.                                                                                    |
| 2.71 | Oct. 05, 2023 | 36, 37      | 3.2 R_SCI_IIC_MasterSend():                                                                                         |
|      |               |             | Fixed a bug "the While loop would not exit" in the example code                                                     |
|      |               |             | when compiling option optimization level 2 (default).                                                               |
|      |               | 76          | Table 6.26 Operation Confirmation Environment for Rev.2.71 is added.                                                |

## 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. Precaution against Electrostatic Discharge (ESD)

A strong electrical field, when exposed to a CMOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop the generation of static electricity as much as possible, and quickly dissipate it when it occurs. Environmental control must be adequate. When it is dry, a humidifier should be used. This is recommended to avoid using insulators that can easily build up static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work benches and floors must be grounded. The operator must also be grounded using a wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions must be taken for printed circuit boards with mounted semiconductor devices.

2. Processing at power-on

The state of the product is undefined at the time 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 time 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 time 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 time when power is supplied until the power is supplied until the power is supplied until the power reaches the level at which resetting is specified.

3. Input of signal during power-off state

Do not input signals or an I/O pull-up power supply while the device is powered off. The current injection that results from input of such a signal or I/O pull-up power supply may cause malfunction and the abnormal current that passes in the device at this time may cause degradation of internal elements. Follow the guideline for input signal during power-off state as described in your product documentation.

4. 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 the 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.

5. Clock signals

After applying a reset, only release the reset line after the operating clock signal becomes stable. When switching the clock signal during program execution, wait until the target clock signal is 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. Additionally, 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.

6. Voltage application waveform at input pin

Waveform distortion due to input noise or a reflected wave may cause malfunction. If the input of the CMOS device stays in the area between  $V_{IL}$  (Max.) and  $V_{IH}$  (Min.) due to noise, for example, the device may malfunction. Take care to prevent chattering noise from entering the device when the input level is fixed, and also in the transition period when the input level passes through the area between  $V_{IL}$  (Max.) and  $V_{IH}$  (Min.).

7. Prohibition of access to reserved addresses

Access to reserved addresses is prohibited. The reserved addresses are provided for possible future expansion of functions. Do not access these addresses as the correct operation of the LSI is not guaranteed.

8. Differences between products

Before changing from one product to another, for example to a product with a different part number, confirm that the change will not lead to problems. The characteristics of a microprocessing unit or microcontroller unit products in the same group but having a different part number might differ in terms of 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

- 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 or any other use of the circuits, software, and information in the design of your product or system. Renesas Electronics disclaims any and all liability for any losses and damages incurred by you or third parties arising from the use of these circuits, software, or information.
- 2. Renesas Electronics hereby expressly disclaims any warranties against and liability for infringement or any other claims involving 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, including but not limited to, the product data, drawings, charts, programs, algorithms, and application examples.
- 3. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 4. You shall be responsible for determining what licenses are required from any third parties, and obtaining such licenses for the lawful import, export, manufacture, sales, utilization, distribution or other disposal of any products incorporating Renesas Electronics products, if required.
- 5. You shall not alter, modify, copy, or reverse engineer any Renesas Electronics product, whether in whole or in part. Renesas Electronics disclaims any and all liability for any losses or damages incurred by you or third parties arising from such alteration, modification, copying or reverse engineering.
- 6. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The intended 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; industrial robots; etc.

"High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control (traffic lights); large-scale communication equipment; key financial terminal systems; safety control equipment; etc.

Unless expressly designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not intended or 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 damage (space system; undersea repeaters; nuclear power control systems; aircraft control systems; key plant systems; military equipment; etc.). Renesas Electronics disclaims any and all liability for any damages or losses incurred by you or any third parties arising from the use of any Renesas Electronics product that is inconsistent with any Renesas Electronics data sheet, user's manual or other Renesas Electronics document.

- 7. No semiconductor product is absolutely secure. Notwithstanding any security measures or features that may be implemented in Renesas Electronics hardware or software products, Renesas Electronics shall have absolutely no liability arising out of any vulnerability or security breach, including but not limited to any unauthorized access to or use of a Renesas Electronics product or a system that uses a Renesas Electronics product. RENESAS ELECTRONICS DOES NOT WARRANT OR GUARANTEE THAT RENESAS ELECTRONICS PRODUCTS, OR ANY SYSTEMS CREATED USING RENESAS ELECTRONICS PRODUCTS WILL BE INVULNERABLE OR FREE FROM CORRUPTION, ATTACK, VIRUSES, INTERFERENCE, HACKING, DATA LOSS OR THEFT, OR OTHER SECURITY INTRUSION ("Vulnerability Issues"). RENESAS ELECTRONICS DISCLAIMS ANY AND ALL RESPONSIBILITY OR LIABILITY ARISING FROM OR RELATED TO ANY VULNERABILITY ISSUES. FURTHERMORE, TO THE EXTENT PERMITTED BY APPLICABLE LAW, RENESAS ELECTRONICS DISCLAIMS ANY AND ALL WARRANTIES, EXPRESS OR IMPLIED, WITH RESPECT TO THIS DOCUMENT AND ANY RELATED OR ACCOMPANYING SOFTWARE OR HARDWARE, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.
- 8. When using Renesas Electronics products, refer to the latest product information (data sheets, user's manuals, application notes, "General Notes for Handling and Using Semiconductor Devices" in the reliability handbook, etc.), and ensure that usage conditions are within the ranges specified by Renesas Electronics with respect to maximum ratings, operating power supply voltage range, heat dissipation characteristics, installation, etc. Renesas Electronics disclaims any and all liability for any malfunctions, failure or accident arising out of the use of Renesas Electronics products outside of such specified ranges.
- 9. Although Renesas Electronics endeavors to improve the quality and reliability of Renesas Electronics products, semiconductor products have specific characteristics, such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Unless designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not subject to radiation resistance design. You are responsible for implementing safety measures to guard against the possibility of bodily injury or damage caused by fire, and/or danger to the public in the event of a failure or malfunction of Renesas Electronics products, such as safety design for hardware and software, including but not limited to redundancy, fire control and malfunction, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult and impractical, you are responsible for evaluating the safety of the final products or systems manufactured by you.
- 10. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. You are responsible for carefully and sufficiently investigating applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive, and using Renesas Electronics products in compliance with all these applicable laws and regulations. Renesas Electronics disclaims any and all liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 11. Renesas Electronics products and technologies shall 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 shall comply with any applicable export control laws and regulations promulgated and administered by the governments of any countries asserting jurisdiction over the parties or transactions.
- 12. It is the responsibility of the buyer or distributor of Renesas Electronics products, or any other party who distributes, disposes of, or otherwise sells or transfers the product to a third party, to notify such third party in advance of the contents and conditions set forth in this document.
- 13. This document shall not be reprinted, reproduced or duplicated in any form, in whole or in part, without prior written consent of Renesas Electronics.
- 14. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products.
- (Note1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its directly or indirectly controlled subsidiaries.
- (Note2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.

(Rev.5.0-1 October 2020)

### **Corporate Headquarters**

TOYOSU FORESIA, 3-2-24 Toyosu, Koto-ku, Tokyo 135-0061, Japan www.renesas.com

#### Trademarks

Renesas and the Renesas logo are trademarks of Renesas Electronics Corporation. All trademarks and registered trademarks are the property of their respective owners.

## Contact information

For further information on a product, technology, the most up-to-date version of a document, or your nearest sales office, please visit: <u>www.renesas.com/contact/</u>.