

# RL78/G13

Serial Array Unit (SAU) (EEPROM Control Using Simplified IIC) [for CubeSuite+, IAR, and e2studio] R01AN1351EJ0201 Rev. 2.01 2014.5.16

## Introduction

This application note explains how to control EEPROM using the simplified IIC function of the serial array unit (SAU). The sample application covered in this application note carries out the read from and writes to EEPROM devices on an IIC bus using the simplified IIC function in an interrupt-driven mode.

## **Target Device**

RL78/G13

When applying the sample program covered in this application note to another microcomputer, modify the program according to the specifications for the target microcomputer and conduct an extensive evaluation of the modified program.

## Contents

| 1.    | Specifications                                          | 4  |
|-------|---------------------------------------------------------|----|
| 2.    | Operation Check Conditions                              | 10 |
| ۷.    | Operation Check Conditions                              | 12 |
| 3.    | Related Application Note                                | 12 |
| 4     | Description of the Hondryone                            | 10 |
|       | Description of the Hardware                             |    |
|       | Hardware Configuration Example  List of Pins to be Used |    |
| 4.2   | List of Fills to be Used                                | 13 |
| 5.    | Description of the Software                             | 14 |
| 5.1   | Operation Outline                                       | 14 |
| 5.2   | List of Option Byte Settings                            | 16 |
| 5.3   | List of Constants                                       | 19 |
| 5.4   | List of Variables                                       | 21 |
| 5.5   | List of Functions                                       | 23 |
| 5.6   | Function Specifications                                 | 25 |
| 5.7   | Flowcharts                                              | 34 |
| 5.7.1 | 1 Initialization Function                               | 34 |
| 5.7.2 | 2 System Function                                       | 35 |
| 5.7.3 | 3 CPU Clock Setup                                       | 35 |
| 5.7.4 | 4 Serial Array Unit Setup                               | 36 |
| 5.7.5 | 5 Main Function                                         | 46 |
| 5.7.6 | 6 EEPROM Selection                                      | 49 |
| 5.7.7 | 7 Stop Condition Issuing Processing                     | 50 |
| 5.7.8 | 8 Stop Condition Generation Function                    | 51 |
| 5.7.9 | 9 Bus Freeing Function                                  | 53 |
| 5.7.1 | 10 EEPROM Write Processing                              | 54 |
| 5.7.1 | 11 EEPROM Address Check Processing                      | 56 |
| 5.7.1 | 12 Slave Address Calculation                            | 57 |
| 5.7.1 | 13 Write Data Page Split Processing                     | 58 |
| 5.7.1 |                                                         |    |
| 5.7.1 | 15 EEPROM Write Completion Wait Processing              | 61 |
| 5.7.1 | 16 EEPROM Read Processing                               | 62 |
|       | 17 EEPROM Read Completion Wait Processing               |    |
| 5.7.1 |                                                         |    |
| 5.7.1 | · · · · · · · · · · · · · · · · · · ·                   |    |
|       | 20 Restart Processing                                   |    |
| 5.7.2 |                                                         |    |
| 5.7.2 |                                                         |    |
| 5.7.2 | 23 Last Data Receive Processing                         |    |
|       | 24 Data Transmission Start Processing                   |    |
| 5.7.2 | -                                                       |    |
|       | 26 Next Page Write Start Processing                     |    |
| 5.7.2 |                                                         |    |
| 5.7.2 |                                                         |    |
|       | 29 SCL Set Low Processing                               |    |
|       |                                                         |    |

| 5.7 | .30   | ACK Confirmation Processing                     | .72 |
|-----|-------|-------------------------------------------------|-----|
| 5.7 | .31   | SCL Low Level Period Wait Processing            | .73 |
| 5.7 | .32   | SCL High Level Period Wait Processing           | .73 |
| 5.7 | .33   | INTIICr Interrupt Processing                    | .74 |
| 5.7 | .34   | INTTM02 Interrupt Processing                    | .77 |
| 6.  | Sa    | mple Code                                       | .78 |
| 7.  | Do    | cuments for Reference                           | .78 |
| Rev | ision | Record                                          | .79 |
| Gen | eral  | Precautions in the Handling of MPU/MCU Products | .80 |

## 1. Specifications

The sample application covered in this application note carries out the read from and writes to EEPROM devices on an IIC bus using the simplified IIC function of the serial array unit.

- An access to an EEPROM is accomplished by specifying necessary parameters in a structure and calling a function.
- Control of EEPROM devices is done in an interrupt-driven mode whenever possible with due consideration to the function as an API.
- One EEPROM type can be selected as the target EEPROM from 2 to 512 kbits of EEPROM. (The 16 kbits of R1EX24016A is selected as the default EEPROM. The main function performs test processing that assumes this EEPROM.)
- The application exercises the access control that supports the selected EEPROM.
- When a reset occurs while the application is reading EEPROM and processing is subsequently resumed when the EEPROM sets the SDA signal low, the application provides the support of releasing the bus that is held in an occupied state.
- The standard simplified IIC channel to be used is channel 00. Provisions, however, are provided that this can easily be altered.

Table 1.1 lists the peripheral function to be used and its use. Figure 1.1 presents an overview of IIC communication.

Figures 1.2 through 1.8 show timing charts for explaining the IIC communication.

Table 1.1 Peripheral Function to be Used and Its Use

| Peripheral Function | Use                                                       |  |
|---------------------|-----------------------------------------------------------|--|
| Serial array unit   | Performs IIC master transmission and reception using the  |  |
|                     | simplified IIC function (using the SCL00 and SDA00 pins). |  |



Address transmission: Initial action taken by the master to identify the target of transfer (slave) in IIC communication. Address bits (7 bits) and a transfer direction bit (1 bit) is transmitted as 1 byte of data after a start condition is generated. Data transmission/reception: Sending/receiving of data to/from the destination slave after address transmission. After completion of data transmission/reception, the master generates a stop condition and releases the bus.

Remarks: The simplified IIC function supports only single master communication. It accepts no wait requests from slaves.

Figure 1.1 Outline of IIC Communication

#### (1) Master-to-slave communication 1 (start condition – address – data)



Figure 1.2 IIC Communication Timing Chart (Master-to-Slave Communication Example) (1/4)

- (1) After IICmn initialization (here the SCRmn register is set up such that TxEmn is 1 and RxEmn is 0) is completed, set the SDA signal low by setting the SOmn bit of the SOm register to 0 to issue a start condition.
- (2) After the lapse of the start condition hold time (4.0  $\mu$ s in standard mode and 0.6  $\mu$ s in fast mode), set the CKOmn bit of the SOm register to 0 to set the SCL signal low.
- (3) For communication, set the SOEmn bit of the SOEm register to 1 to enable output.
- (4) Set the SSmn bit of the SSm register to 1 to enable channel n.
- (5) Write the address of the slave into the SIOr register, and communication will start.
- (6) An INTIICr is generated when the transmission of the slave address is completed.
- (7) Check the ACK response from the slave by testing the PEF bit of the SSRmn register and load the SIOr register with the transmit data if the PEF bit is found to be 0. Abort the transmission is if the PEF bit is set to 1.

## (2) Master-to-slave communication 2 (address – data – data)



Figure 1.3 IIC Communication Timing Chart (Master-to-Slave Communication Example) (2/4)

- (6) An INTIICr is generated when the transmission of the slave address is completed.
- (7) Check the ACK response from the slave by testing the PEF bit of the SSRmn register and load the SIOr register with the transmit data if the PEF bit is found to be 0. Abort the transmission is if the PEF bit is set to 1.
- (8) An INTIICr is generated when the transmission of the data is completed.
- (9) Check the ACK response from the slave by testing the PEF bit of the SSRmn register and load the SIOr register with the transmit data if the PEF bit is found to be 0. Abort the transmission is if the PEF bit is set to 1.

### (3) Master-to-slave communication 3 (data – data – stop condition)



Figure 1.4 IIC Communication Timing Chart (Master-to-Slave Communication Example) (3/4)

- (8) An INTIICr is generated when the transmission of the data is completed.
- (9) Check the ACK response from the slave by testing the PEF bit of the SSRmn register and load the SIOr register with the transmit data if the PEF bit is found to be 0. Abort the transmission is if the PEF bit is set to 1.
- (10) An INTIICr is generated when the transmission of the data is completed.
- (11) Set the STmn bit of the STm register to 1 to disable channel n.
- (12) To issue a stop condition, set the SOEmn bit of the SOEm register to 0 to disable output.
- (13) To set SDA low in preparation for issuing a stop condition, set the SOmn bit of the SOm register to 0.
- (14) To set SCL high in preparation for issuing a stop condition, set the CKOmn bit of the SOm register to 1.
- (15) After the lapse of the stop condition setup time, set the SOmn bit of the SOm register to 1, and a stop condition will be issued.

#### (4) Master-to-slave communication 4 (data – restart condition – address)



Figure 1.5 IIC Communication Timing Chart (Master-to-Slave Communication Example) (4/4)

- (8) An INTIICr is generated when the transmission of the data is completed. Check the ACK response from the slave by testing the PEF bit of the SSRmn register.
- (9) Set the STmn bit of the STm register to 1 to disable channel n.
- (10) To issue a restart condition, set the SOEmn bit of the SOEm register to 0 to enable output.
- (11) To set SCL high following SDA in preparation for issuing a restart condition, set the CKOmn bit of the SOm register to 1.
- (12) Set the SOmn bit of the SOm register to 0, and a restart condition will be issued.
- (13) After the lapse of the start condition hold time, set the CKOmn bit of the SOm register to 0 to set the SCL signal low.
- (14) For communication, set the SOEmn bit of the SOEm register to 1 to enable output.
- (15) Set the SSmn bit of the SSm register to 1 to enable channel n.
- (16) Load the SIOr register with the address of the slave, and communication will start.

**Remarks:** This processing is used during EEPROM read processing, i.e., when specifying the cell address of the EEPROM and reading data from the specified address through master-to-slave communication.

#### (5) Slave-to-master communication 1 (start condition – address – data)



Figure 1.6 IIC Communication Timing Chart (Slave-to-Master Communication Example) (1/3)

- (1) After IICmn initialization (here the SCRmn register is set up such that TxEmn is 1 and RxEmn is 0) is completed, set the SDA signal low by setting the SOmn bit of the SOm register to 0 to issue a start condition.
- (2) After the lapse of the start condition hold time (4.0 µs in standard mode and 0.6 µs in fast mode), set the CKOmn bit of the SOm register to 0 to set the SCL signal low.
- (3) For communication, set the SOEmn bit of the SOEm register to 1 to enable output.
- (4) Set the SSmn bit of the SSm register to 1 to enable channel n.
- (5) Write the address of the slave into the SIOr register, and communication will start.
- (6) An INTIICr is generated when the transmission of the slave address is completed. Check the ACK response from the slave by testing the PEF bit of the SSRmn register.
- (7) Disable the IICmn to switch the direction of communication.
- (8) Set up the SCRmn register so that TxEmn is set to 0 and RxEmn to 1.
- (9) Enable the IICmn.
- (10) Write dummy data (0FFH) into the SIOr register to start receive processing.

#### (6) Slave-to-master communication 2 (address – data – data)



Figure 1.7 IIC Communication Timing Chart (Slave-to-Master Communication Example) (2/3)

- (6) An INTIICr is generated when the transmission of the slave address is completed. Check the ACK response from the slave by testing the PEF bit of the SSRmn register.
- (7) Disable the IICmn to switch the direction of communication.
- (8) Set up the SCRmn register so that TxEmn is set to 0 and RxEmn to 1.
- (9) Enable the IICmn.
- (10) Write dummy data (0FFH) into the SIOr register to start receive processing.
- (11) Since the SOEmn bit is set to 1, an ACK response is made on the 9th clock of SCL and an INTIICr is generated to signal the completion of receive processing.
- (12) To receive the next data (not the last data), write dummy data (0FFH) into the SIOr register to start receive processing.

#### (7) Slave-to-master communication 3 (data – data – stop condition)



Figure 1.8 IIC Communication Timing Chart (Slave-to-Master Communication Example) (3/3)

- (11) Since the SOEmn bit is set to 1, an ACK response is made on the 9th clock of SCL and an INTIICr is generated to signal the completion of receive processing.
- (12) To respond with NACK for the last receive data, set the SOEmn bit of the SOEm register to 0 and disable serial output.
- (13) Write dummy data (0FFH) into the SIOr register to start receive processing.
- (14) Since the SOEmn bit is set to 0, a NACK response is made on the 9th clock of SCL and an INTIICr is generated to signal the completion of receive processing.
- (15) Set the STmn bit of the STm register to 1 to disable channel n.
- (16) For the next communication operation, set up the SCRmn register into its initial state.
- (17) To set SDA low in preparation for issuing a stop condition, set the SOmn bit of the SOm register to 0.
- (18) To set SCL high in preparation for issuing a stop condition, set the CKOmn bit of the SOm register to 1.
- (19) After the lapse of the stop condition setup time, set the SOmn bit of the SOm register to 1, and a stop condition will be issued.

# 2. Operation Check Conditions

The sample code contained in this application note has been checked under the conditions listed in the table below.

**Table 2.1 Operation Check Conditions** 

| Item                     | Description                                                           |
|--------------------------|-----------------------------------------------------------------------|
| Microcontroller used     | RL78/G13 (R5F100LE)                                                   |
| Operating frequency      | High-speed on-chip oscillator (HOCO) clock: 32 MHz                    |
|                          | CPU/peripheral hardware clock: 32 MHz                                 |
| Operating voltage        | 5.0 V (Operation is possible over a voltage range of 2.9 to 5.5 V.)   |
|                          | LVD operation (V <sub>LVI</sub> ): Reset mode 2.81 V (2.76 to 2.87 V) |
| Integrated development   | CubeSuite + V1.01.01                                                  |
| environment (CubeSuite+) |                                                                       |
| C compiler (CubeSuite+)  | CA78K0R V1.30                                                         |
| Integrated development   | e2studio V2.0.1.3                                                     |
| environment (e2studio)   |                                                                       |
| C compiler (e2studio)    | KPIT GNURL78-ELF Toolchain V13.02                                     |
| Integrated development   | IAR Embedded Workbench for Renesas RL78 V1.30.2                       |
| environment (IAR)        |                                                                       |
| C compiler (IAR)         | IAR C/C++ Compiler for Renesas RL78 V1.30.2.50607                     |
| Board used               | QB-R5F100LE-TB + EEPROM (R1EX24016, R1EX24032)                        |

Note: This sample code is compatible with the RL78/G13 devices with 64 pins.

# 3. Related Application Note

The application notes that are related to this application note are listed below for reference.

- RL78/G13 Initialization (R01AN0451E) Application Note
- RL78/G13 Timer Array Unit (Interval Timer) (R01AN0456E) Application Note

## 4. Description of the Hardware

## 4.1 Hardware Configuration Example

Figure 4.1 shows an example of hardware configuration that is used for this application note.



Figure 4.1 Hardware Configuration

- Cautions: 1. The purpose of this circuit is only to provide the connection outline and the circuit is simplified accordingly. When designing and implementing an actual circuit, provide proper pin treatment and make sure that the hardware's electrical specifications are met (connect the input-only ports separately to  $V_{DD}$  or  $V_{SS}$  via a resistor).
  - 2. Connect any pins whose name begins with  $EV_{SS}$  to  $V_{SS}$  and any pins whose name begins with  $EV_{DD}$  to  $V_{DD}$ , respectively.
  - 3.  $V_{DD}$  must be held at not lower than the reset release voltage  $(V_{LVI})$  that is specified as LVD.

## 4.2 List of Pins to be Used

Table 4.1 lists the pins to be used and their functions.

Table 4.2 Pins to be Used and their Functions

| Pin Name  | I/O          | Description                            |
|-----------|--------------|----------------------------------------|
| P10/SCL00 | Input/Output | IIC00 serial clock output pin          |
| P11/SDA00 | Input/Output | IIC00 serial data transmit/receive pin |

## 5. Description of the Software

## 5.1 Operation Outline

The sample application covered in this application note controls operations (read and write) on EEPROM devices using the IIC master transmit/receive functions of the IIC00 serial interface. Control of EEPROM devices is done in an interrupt-driven mode whenever possible with due consideration to the function as an API.

(1) Initializes channel 0 of the serial array unit 0 through simplified IIC. <Setting conditions>

- Sets the operating clock to CK00 (32 MHz).
- Sets the operating mode to "simplified IIC."
- Enables transfer end interrupts.
- Sets the phase of data and clock to type 1.
- Sets the data length to 8 bits, the stop bit length to 1 bit, no parity, and MSB first transfer.
- Sets the transfer clock to 381 kHz of fast mode.
- Sets SO00 and CKO00 to 1.
- Sets the P10/SCL00 pin for transfer clock output and the P11/SDA00 pin for data transmit/receive.
- (2) Sets channel 2 of the timer array unit as a 100-us interval timer for checking the completion of write processing.
- (3) Copies the parameters for the EEPROM (16 kbits) to be used into the processing parameter structure.
- (4) Issues a stop condition to set the bus free.
- (5) Creates 256 bytes of write data (increment pattern).
- (6) Sets up the access parameters (structure g\_PARAI).
- (7) Writes 256 bytes of data to the EEPROM starting at address 0x400.
- (8) Reads out the written data with the leading and tailing padding bytes.
- (9) Prepares 16 bytes of data of the same pattern (0xkk) (kk = 00, 11, 22, ..., 77).
- (10) Writes that data to the EEPROM starting at address 0xk00.
- (11) Repeats steps (9) and (10) while changing the value of k from 0 to 7.
- (12) Reads out the data that is written in steps (9) and (10) including 8 bytes each of the leading and trailing padding data, a total of 32 bytes.

Note: This sample code is available to illustrate the example of controlling the EEPROM (R1EX24016 or R1EX24032) on an IIC bus using the simplified IIC00 function of the RL78/G13 series. When the channel or EEPROM to be used with this sample code is changed, conduct extensive evaluation of the modified code.

Remarks: In the project that is used, the simplified IIC channel and device's pin count are specified using the [Macro definition] function of the [Compile option]. The following illustration is for CubeSuite+ environment.

The Macro definition[0] selects IIC00 as the simplified IIC channel to be used. When using channel 20, for

The Macro definition [0] selects IIC00 as the simplified IIC channel to be used. When using channel 20, for example, modify there to "IIC20 = 1."

The Macro definition[1] specifies the number of pins of the product to be used. It is used to check whether the channel specified in the Macro definition[0] is available for the target product.

To change these, click the button at the right-most end of [Macro definition] to open the text edit window, then edit the definitions in that window.



The IAR environment has a similar interface for this definition. Right click on the project name, and choose "Options". Choose the tab "C/C++ Compiler", and "Preprocessor" in the diarog shown below. In the last place, input your necessary define symbols in the field of "Defined symbols: (one per line)".



In the e2studio environment, please follow the following procedure. First, click "Rnesas Tool Settings".



Next, choose "Setting" in "C/C++ Build", "Tool Settings" tab, and "Source" in "Compiler". Then write in the field of "Macro Defines" the definition macros which you used in Macro definition in CubeSuite+ environment. In the last place, click "Add" button and you can add the setting to the system.



# 5.2 List of Option Byte Settings

Table 5.1 summarizes the settings of the option bytes.

Table 5.1 Option Byte Settings

| Address       | Value     | Description                                              |  |
|---------------|-----------|----------------------------------------------------------|--|
| 000C0H/010C0H | 01101110B | Disables the watchdog timer.                             |  |
|               |           | (Stops counting after the release from the reset state.) |  |
| 000C1H/010C1H | 01111111B | LVD reset mode, 2.81 V (2.76 to 2.87 V)                  |  |
| 000C2H/010C2H | 11101000B | HS mode, HOCO: 32 MHz                                    |  |
| 000C3H/010C3H | 10000100B | Enables the on-chip debugger.                            |  |

## 5.3 List of Constants

Constants for the Sample Program (Table 5.2 and Table 5.3) list the constants that are used in this sample program.

Table 5.4 shows a list of names of macros specifying the channel numbers to be used in the sample program.

Table 5.2 Constants for the Sample Program (1/2)

| Constant    | Setting    | Description                                               |
|-------------|------------|-----------------------------------------------------------|
| PAGE_16     | 0x000F     | Number of data bytes per page of 2 to 16 kbits of EEPROM  |
| PAGE_32     | 0x001F     | Number of data bytes per page of 32 or 64 kbits of EEPROM |
| PAGE_64     | 0x003F     | Number of data bytes per page of 128 or 256 kbits EEPROM  |
| PAGE_128    | 0x007F     | Number of data bytes per page of 512 kbits of EEPROM      |
| MEMORY_2K   | 0x0001     | 2 kbits of EEPROM capacity (unit of 256 bytes)            |
| MEMORY_4K   | 0x0002     | 4 kbits of EEPROM capacity (unit of 256 bytes)            |
| MEMORY_8K   | 0x0004     | 8 kbits of EEPROM capacity (unit of 256 bytes)            |
| MEMORY_16K  | 8000x0     | 16 kbits of EEPROM capacity (unit of 256 bytes)           |
| MEMORY_32K  | 0x0010     | 32 kbits of EEPROM capacity (unit of 256 bytes)           |
| MEMORY_64K  | 0x0020     | 64 kbits of EEPROM capacity (unit of 256 bytes)           |
| MEMORY_128K | 0x0040     | 128 kbits of EEPROM capacity (unit of 256 bytes)          |
| MEMORY_256K | 0x0080     | 256 kbits of EEPROM capacity (unit of 256 bytes)          |
| MEMORY_512K | 0x0100     | 512 kbits of EEPROM capacity (unit of 256 bytes)          |
| ADDR0BIT    | 0b00000000 | Do not use the slave address for cell addresses.          |
| ADDR1BIT    | 0b00000001 | Specify A8 with bit 1 of the slave address.               |
| ADDR2BIT    | 0b00000011 | Specify A9 and 8 with bits 2 and 1 of the slave address.  |
| ADDR3BIT    | 0b00000111 | Specify A10 to A8 with bits 3 to 1 of the salve address.  |
| I2C_OK      | 0x00       | Normal termination                                        |
| PARA_ERR    | 0x20       | Parameter error                                           |
| NO_ACK1     | 0x40       | No ACK response to slave address                          |
| NO_ACK2     | 0x41       | No ACK response to EEPROM address                         |
| NO_ACK3     | 0x42       | No ACK response to transmit data                          |
| BUS_ERR     | 0x60       | Bus is not free (SDA is not high).                        |
| SVAMSK      | 0b11111110 | Mask data for bit 0 of the slave address                  |
| SCLLOWW     | 0x05       | SCL low level time measurement data                       |
| SCLHIGHW    | 0x02       | SCL high level time measurement data                      |
| RETRYCNT    | 0x09       | Number of SCL dummy clock pulses                          |

Table 5.3 **Constants for the Sample Program (2/2)** 

| Constant   | Setting | Description                                           |
|------------|---------|-------------------------------------------------------|
| R1EX24002A | 0x00    | Constants for specifying the EEPROM to be used.       |
| R1EX24004A | 0x01    | Defined by the enumeration type constant eeprom_name. |
| R1EX24008A | 0x02    | Used to reference the EEPROM parameters through the   |
| R1EX24016A | 0x03    | eeprom_info type structure EEPROM_ADDRESS.            |
| R1EX24032A | 0x04    |                                                       |
| R1EX24064A | 0x05    |                                                       |
| R1EX24128B | 0x06    |                                                       |
| R1EX24256B | 0x07    |                                                       |
| R1EX24512B | 0x08    |                                                       |

Table 5.4 **Macro Names Used in the Sample Program** 

| Macro Name | Setting (Channel 0)    | Description                                            |
|------------|------------------------|--------------------------------------------------------|
| SAUmEN     | SAU0EN                 | Peripheral enable register                             |
| SPSm       | SPS0                   | Serial clock selection register                        |
| SMRmn      | SMR00                  | Serial mode register                                   |
| SCRmn      | SCR00                  | Serial communication register                          |
| SDRmn      | SDR00                  | Serial data register                                   |
| SIOr       | SIO00                  | Serial data register (for data transmission/reception) |
| SSRmn      | SSR00                  | Serial status register                                 |
| SIRmn      | SIR00                  | Serial flag clear trigger register                     |
| SSmL       | SS0L                   | Serial channel start register                          |
| STmL       | ST0L                   | Serial channel stop register                           |
| TRGONn     | 0b00000001             | Trigger bit                                            |
| SOEmL      | SOE0L                  | Serial output enable register                          |
| SOEON      | TRGONn                 | Serial output enable register setting bit              |
| SOEOFF     | (uint8_t)(~SOEON)      | Bits for clearing the serial output enable register    |
| SOm        | SO0                    | Serial output register                                 |
| SDAHIGH    | TRGONn                 | Bit for setting SDA high                               |
| SDALOW     | ~SDAHIGH               | Bit for setting SDA low                                |
| SCLHIGH    | TRGONn × 0x100         | Bit for setting SCL high                               |
| SCLLOW     | ~SCLHIGH               | Bit for setting SCL low                                |
| IICIFr     | IICIF00                | Interrupt request flag register                        |
| IICMKr     | IICMK00                | Interrupt request mask register                        |
| PM_IICr    | PM1                    | IICr port mode register (specifying SDA signal)        |
| PM_SDAr    | PM1.1                  | SDA port mode register bits                            |
| PM_SCLr    | PM1.0                  | SCL port mode register bits                            |
| POM_IICr   | POM1                   | Port output mode register                              |
| P_IICr     | P1                     | IICr port                                              |
| P_SDAr     | P1.1                   | SDA port                                               |
| P_SCLr     | P1.0                   | SCL port                                               |
| SDAINMODE  | 0b00000010             | Bits for specifying port mode register input           |
| SDAOUTMODE | 0b11111100             | Bits for port mode register output                     |
| SDASCLON   | (uint8_t)(~SDAOUTMODE) | Port setting bits                                      |
| IICPR0r    | IICPR000               | Interrupt priority setting registers                   |
| IICPR1r    | IICPR100               |                                                        |

## 5.4 List of Variables

Table 5.5 lists the global variables that are used in this sample program.

g\_eeprom\_type and the subsequent entries contain global variables that are valid within the module.

Table 5.5 Global Variables for the Sample Program

| Туре                     | Variable Name   | Contents                          | Function Used         |
|--------------------------|-----------------|-----------------------------------|-----------------------|
| Structure eeprom_paraA16 | g_PARAI         | Parameters for specifying         | main()                |
|                          |                 | EEPROM access                     | check_EEPROM_Addr()   |
| uint8_t                  | g_comstatus     | Operation information/result flag | main()                |
|                          |                 |                                   | check_EEPROM_Addr()   |
|                          |                 |                                   | R_EEPROM_R()          |
|                          |                 |                                   | R_EEPROM_wait_read()  |
|                          |                 |                                   | R_IICr_Tx_addr1()     |
|                          |                 |                                   | R_IICr_Tx_addr2()     |
|                          |                 |                                   | R_IICr_Rx_RST()       |
|                          |                 |                                   | R_IICr_RxData_ST()    |
|                          |                 |                                   | R_IICr_RxData()       |
|                          |                 |                                   | R_IICr_Rx_LastData()  |
|                          |                 |                                   | R_EEPROM_W()          |
|                          |                 |                                   | R_EEPROM_wait_write() |
|                          |                 |                                   | R_IICr_TxDataST()     |
|                          |                 |                                   | R_IICr_TxData()       |
|                          |                 |                                   | R_EEPROM_next_page()  |
|                          |                 |                                   | IINTIICr()            |
| uint8_t array (256)      | g_data_bufferW1 | Write data buffer                 | main()                |
| uint8_t array (256)      | g_data_bufferW2 | Write data buffer                 | main()                |
| uint8_t array (512)      | g_data_bufferR1 | Read data buffer                  | main()                |

| Туре                                                                                                    | Variable Name | Contents                                                                | Function Used                                                                                                                                                                                                                          |
|---------------------------------------------------------------------------------------------------------|---------------|-------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| uint8_t                                                                                                 | g_eeprom_type | No. of EEPROM to be used                                                | R_device_select()                                                                                                                                                                                                                      |
| Structures eeprom_paraA16 uint8_t slaveaddr; uint16_t eepromaddr; uint8_t *bufferaddr; uint16_t number; | g_PARAA       | Parameters for accessing EEPROM                                         | R_EEPROM_R()  R_IICr_Tx_addr1()  R_IICr_Tx_addr2()  R_IICr_Rx_RST()  R_IICr_RxData_ST()  R_IICr_RxData()  R_IICr_Rx_LastData()  R_EEPROM_W()  R_IICr_TxDataST()  R_IICr_TxData()  R_EEPROM_Devide()  SINTTM02()  R_EEPROM_wait_write() |
| Structure eeprom_paraA16                                                                                | g_PARAC       | Copy of parameters for specifying access to EEPROM                      | check_EEPROM_Addr() R_EEPROM_R() R_EEPROM_W() R_IICr_TxData() get_slave_Addr() R_EEPROM_Devide()                                                                                                                                       |
| Structure eeprom_info uint16_t page_size; uint16_t rom_size; uint8_t addr_mask; uint8_t mask2;          | EEPROM_Info   | For holding parameters for<br>the EEPROM to be used (for<br>processing) | R_device_select() R_IICr_Tx_addr1() get_slave_Addr() R_EEPROM_Devide()                                                                                                                                                                 |

## 5.5 List of Functions

Table 5.6 summarizes the functions that are used in this sample program.

Table 5.6 Functions

| Function Name       | Outline                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R_device_select     | Specifies the EEPROM to be used.                                                                                                                                                                                                                                                                                                                                                 |
| R_EEPROM_R          | Reads data from the EEPROM according to the accessing parameters in                                                                                                                                                                                                                                                                                                              |
|                     | the structure that is pointed to by the argument pointer.                                                                                                                                                                                                                                                                                                                        |
| R_EEPROM_wait_read  | Waits for the completion of the read from EEPROM.                                                                                                                                                                                                                                                                                                                                |
| R_EEPROM_W          | Writes data into the EEPROM according to the accessing parameters in                                                                                                                                                                                                                                                                                                             |
|                     | the structure that is pointed to by the argument pointer.                                                                                                                                                                                                                                                                                                                        |
| R_EEPROM_wait_write | Waits for the completion of the write to EEPROM.                                                                                                                                                                                                                                                                                                                                 |
| check_EEPROM_Addr   | Checks if the specified parameter exceeds the EEPROM capacity.  Copies the accessing parameter if the parameter falls within the specified capacity.                                                                                                                                                                                                                             |
| get_slave_Addr      | Includes the upper bits of the cell address into the slave address when the EEPROM capacity is 4 to 16 kbits.                                                                                                                                                                                                                                                                    |
| R_EEPROM_Devide     | Corrects the 1-write parameter so that the write data falls within 1 page in write mode.                                                                                                                                                                                                                                                                                         |
| R_IICr_Tx_addr1     | Performs slave address transmission completion processing and sends the cell address of the EEPROM.                                                                                                                                                                                                                                                                              |
| R_IICr_Tx_addr2     | Sends the lower bit address when the cell address of the EEPROM is 2 bytes long.                                                                                                                                                                                                                                                                                                 |
| R_IICr_Rx_RST       | Restarts processing in receive mode to read data following the completion of the transmission of the EEPROM cell address.                                                                                                                                                                                                                                                        |
| R_IICr_RxData_ST    | Starts the data receive processing for receiving data with TxE set to 0 and RxE set to 1. If the data to read is 1 byte long, start the receive processing after setting up a NACK response.                                                                                                                                                                                     |
| R_IICr_RxData       | Stores the received data in the buffer and starts the next data reception processing.                                                                                                                                                                                                                                                                                            |
| R_IICr_Rx_LastData  | Stores the last received data in the buffer, sets TxE to 1 and RxE to 0, and terminates processing after issuing a stop condition in preparation for the next communication.                                                                                                                                                                                                     |
| R_IICr_TxDataST     | Starts transmission of write data to the EEPROM.                                                                                                                                                                                                                                                                                                                                 |
| R_IICr_TxData       | After data transmission is completed and the transmission of all data to the current page is ended, issues a stop condition and specifies the write to the EEPROM. Terminates processing if processing of all data is completed. If there is remaining data, makes preparation for the next page write and starts the timer for awaiting the completion of the write processing. |
| R_EEPROM_next_page  | Upon completion of the write to EEPROM, stops the timer and sends the cell address for the next EEPROM page.                                                                                                                                                                                                                                                                     |

| Function Name       | Outline                                                                                                                                  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| R_IICr_StartCond    | Manipulates the SOm register, issues a start condition, and enable the IICr.                                                             |
| R_IICr_StopCond     | Issues a stop condition and checks if the bus is freed. If the bus is not free, sends dummy clocks to SCL and reissues a stop condition. |
| R_IICr_send_Stop    | Disables the IICr and manipulates the SOm register to issue a stop condition.                                                            |
| R_IICr_wait_bus     | Sends 9 dummy clock pulses on the SCL signal line and checks if the SDA signal is becomes free (goes high).                              |
| R_IICr_SCL_pulse    | Sends dummy clock pulses to the SCL signal.                                                                                              |
| R_IICr_SCL_high     | Sets the SCL signal high and waits for the duration equal to the high level width.                                                       |
| R_IICr_SCL_low      | Sets the SCL signal low and waits for the duration equal to the low level width.                                                         |
| R_IICr_NACK         | Checks for an ACK/NACK response from the slave.                                                                                          |
| R_IICr_SCL_Time     | Waits for the duration equal to the low period of the SCL signal.                                                                        |
| R_IICr_SCL_highTime | Waits for the duration equal to the high period of the SCL signal.                                                                       |
| IINTIICr            | Checks the ACK response from the slave on an IICr transfer completion                                                                    |
|                     | interrupt and allocates program control to the next processing.                                                                          |
| IINTTM02            | Sends the slave address that is used to confirm the completion of write                                                                  |
|                     | processing during the TM02 interval interrupt processing.                                                                                |
| R_IICr_Init         | Initializes the IICr and TM02.                                                                                                           |

## 5.6 Function Specifications

This section describes the specifications for the functions that are used in this sample program

### [Function Name] R\_device\_select

Synopsis Specify EEPROM to be used.

Header r\_cg\_macrodriver.h

r\_cg\_userdefine.h

Declaration MD\_STATUS R\_device\_select(enum eeprom\_name);

Explanation This function copies the EEPROM parameter specified in the argument into the structure

EEPROM\_Info.

Arguments [EEPROM's name] Name defined in the Enum type constant

eeprom\_name

Return value When [I2C\_OK]: Normal termination

When [PARA\_ERR]: Wrong name specified

Remarks None

### [Function Name] R\_EEPROM\_R

Synopsis Process request to start read from EEPROM.

Header r\_cg\_macrodriver.h

r\_cg\_userdefine.h

Declaration void R\_EEPROM\_R(struct eeprom\_paraA16 \*PARA);

Explanation This function performs a read from EEPROM according to the parameters specified in the

structure that is pointed to by the pointer in the argument.

Arguments \*PARA Pointer to the eeprom paraA16 type structure

Return value None

Remarks The processes of awaiting the completion of the read and getting the result must be done by

R\_EEPROM\_wait\_read.

#### [Function Name] R\_EEPROM\_wait\_read

Synopsis Wait for completion of read from EEPROM.

Header r\_cg\_macrodriver.h

r\_cg\_userdefine.h

Declaration MD\_STATUS R\_EEPROM\_wait\_read (void);

Explanation This function waits for the completion of the read processing started by R\_EEPROM\_R.

Arguments None

Return value When [I2C\_OK] : Read terminates normally.

When [PARA\_ERR] : Specified parameter out of valid EEPROM address range.

When [NO\_ACK1] : No ACK response to slave address
When [NO\_ACK2] : No ACK response to EEPROM address

Remarks

#### [Function Name] R EEPROM W

Synopsis Start write to EEPROM.

Header r\_cg\_macrodriver.h

r\_cg\_userdefine.h

Declaration void R EEPROM W(struct eeprom paraA16 \*PARA);

Explanation This function performs a write to EEPROM according to the parameters specified in the

structure that is pointed to by the pointer in the argument.

Arguments \*PARA Pointer to the eeprom\_paraA16 type structure

Return value None

Remarks The processes of awaiting the completion of the write and getting the result must be done by

R\_EEPROM\_wait\_write.

#### [Function Name] R\_EEPROM\_wait\_write

Synopsis Wait for completion of write to EEPROM.

Header r\_cg\_macrodriver.h

r\_cg\_userdefine.h

Declaration MD\_STATUS R\_EEPROM\_wait\_write(void);

Explanation This function waits for the completion of the write processing started by R\_EEPROM\_W.

Arguments None

Return value When [I2C OK] : Writer terminates normally.

When [PARA ERR] : Specified parameter out of valid EEPROM address range.

When [NO\_ACK1] : No ACK response to slave address
When [NO\_ACK2] : No ACK response to EEPROM address
When [NO\_ACK3] : No ACK response to transmit data

Remarks None

#### [Function Name] check\_EEPROM\_Addr

Synopsis Check access area in EEPROM.

Header r\_cg\_macrodriver.h

r\_cg\_userdefine.h

Declaration static MD\_STATUS check\_EEPROM\_Addr(struct eeprom\_paraA16 \*PARA);

Explanation This function checks the paramers for accessing the EEPROM to determine whether

the area to be read or written falls within the valid EEPROM address range.

Arguments \*PARA Pointer to the eeprom\_paraA16 type structure

Return value When [I2C OK]: Accessing area falls within valid EEPROM address range.

When [PARA\_ERR]: Accessing area not falls within valid EEPROM address range.

Remarks None

#### [Function Name] get slave Addr

Synopsis Compute slave address of EEPROM

Header r\_cg\_userdefine.h

Declaration static void get\_slave\_Addr(void);

Explanation This function qualifies the slave address of 4 to 16 kbits of EEPROM with the upper 1 to 3 bits

of the cell address.

Arguments None

Return value None

Remarks The function qualifies the member slaveaddr with the value of the member eepromaddr of the

structure g PARAC.

#### [Function Name] R\_EEPROM\_Devide

Synopsis Split into pages in EEPROM write mode.

Header r\_cg\_userdefine.h

Declaration static void R EEPROM Devide(void);

Explanation This function splits the write data according to the page size of the EEPROM. It stores the

parameters to be written during the current operation in the structure g\_PARAA and the

remaining data in the structure g PARAC.

Arguments None

Return value None

Remarks The members eepromaddr and bufferaddr of the structure g\_PARAC contains the current write

parameters and the member number contains the data count for the next and subsequent

write operations.

### [Function Name] R\_IICr\_Tx\_addr1

Synopsis Transmit EEPROM address.

Header r\_cg\_userdefine.h

Declaration static void R IICr Tx addr1(void);

Explanation This function transmits the upper byte of the address of 32 kbits or more of EEPROM. For 16

kbits or less of EEPROM, the function transmits the 1 byte of cell address.

Arguments None -

Return value None

Remarks Used by the INTIICmn processing (function name: IINTIICr).

#### [Function Name] R\_IICr\_Tx\_addr2

Synopsis Transmit lower address of EEPROM cell.

Header r\_cg\_userdefine.h

Declaration static void R IICr Tx addr2(void);

Explanation This function transmits the lower byte of the address of 32 kbits or more of EEPROM.

Arguments None -

Return value None

Remarks Used by the INTIICmn processing (function name: IINTIICr).

#### [Function Name] R\_IICr\_Rx\_RST

Synopsis Restart processing in receive mode

Header r\_cg\_userdefine.h

Declaration static void R\_IICr\_Rx\_RST(void);

Explanation Restarts processing in receive mode to read data following the completion of the transmission

of the EEPROM cell address.

Arguments None -

Return value None

Remarks Used by the INTIICmn processing (function name: IINTIICr).

### [Function Name] R\_IICr\_RxData\_ST

Synopsis Start data read processing.

Header r cg userdefine.h

Declaration static void R\_IICr\_RxData\_ST(void);

Explanation This function switches the state of the IICr from transmit (TxE = 1, RxE = 0) to receive (TxE =

0, RxE = 1) upon completion of the transmission of the slave address in read mode and starts the receive processing (writing dummy data into SIOr). If the size of the data to be read is 1 byte long, the function sets up a NACK response before starting the receive processing.

Arguments None -

Return value None

Remarks Used by the INTIICmn processing (function name: IINTIICr).

#### [Function Name] R IICr RxData

Synopsis Data receive processing.

Header r cg userdefine.h

Declaration static void R\_IICr\_RxData (void);

Explanation This function stores the received data in the buffer and starts the next data receive processing.

If the data to be read out is 1 byte long, the function sets up a NACK response before starting

the receive processing.

Arguments None -

Return value None

Remarks Used by the INTIICmn processing (function name: IINTIICr).

#### [Function Name] R IICr Rx LastData

Synopsis Complete the reception of last data.

Header r\_cg\_userdefine.h

Declaration static void R\_IICr\_Rx\_LastData (void);

Explanation This function stores the received data in the buffer and stops the IICr. In preparation for the

next communication, the function sets TxE to 1 and RxE to 0 and issues a stop condition

before exiting.

Arguments None

Return value None

Remarks Used by the INTIICmn processing (function name: IINTIICr).

#### [Function Name] R IICr TxDataST

Synopsis Start data transmission.

Header r cg userdefine.h

Declaration static void R IICr TxDataST (void);

Explanation This function starts the data transmit processing when the transmission of the EEPROM

address is completed.

Arguments None -

Return value None

Remarks Used by the INTIICmn processing (function name: IINTIICr).

## [Function Name] R\_IICr\_TxData

Synopsis Data transmission processing

Header r cg userdefine.h

Declaration static void R IICr TxData (void);

Explanation This function transmits the next data after the transmission of 1 byte of data is completed.

When the transmission of all data to be written into one page is completed, the function issues a stop condition and specifies the write into the EEPROM. The function terminates processing

if the transmission of all data has been completed.

If there is remaining data, the function makes preparation for writing into the next page, and

invokes the timer for awaiting the completion of write processing.

Arguments None -

Return value None

Remarks Used by the INTIICmn processing (function name: IINTIICr).

### [Function Name] R\_EEPROM\_next\_page

Synopsis Specify address of next page following completion of wait for write.

Header r\_cg\_userdefine.h

Declaration static void R\_EEPROM\_next\_page(void);

Explanation This function stops the waiting timer for writing upon completion of the write into one page and

transmits the cell address of the next page in the EEPROM.

Arguments None -

Return value None

Remarks Used by the INTIICmn processing (function name: IINTIICr). This function is invoked on an

ACK response to the slave address transmission received during the write completion check.



### [Function Name] R\_IICr\_StartCond

Synopsis Issue start condition. Header r\_cg\_userdefine.h

Declaration static void R\_IICr\_StartCond(void);

Explanation This function temporarily disables the IICr and issues a start condition to enable the IICr.

Arguments None -

Return value None

Remarks Used by the INTIICmn processing (function name: IINTIICr).

### [Function Name] R\_IICr\_StopCond

Synopsis Perform bus freeing processing.

 $Header \qquad \qquad r\_cg\_macrodriver.h$ 

r\_cg\_userdefine.h

Declaration MD\_STATUS R\_IICr\_StopCond(void);

Explanation This function generates a stop condition for the IICr. If the bus cannot be freed, the function

generates 9 dummy clocks on the SCL line and, when SDA is found high, reissues a stop

condition.

Arguments None

Return value When [I2C\_OK]: Bus freeing complete

When [BUS ERR]: Could not free the bus.

Remarks None

#### [Function Name] R IICr send Stop

Synopsis Issues stop condition. Header r\_cg\_userdefine.h

Declaration static void R\_IICr\_send\_Stop (void);

Explanation This function disables the IICr and manipulates the SOm register to issue a stop condition.

Arguments None

Return value None

Remarks This function is used to issue a stop condition internally.

#### [Function Name] R\_IICr\_wait\_bus

Synopsis Check bus free state.

Header r\_cg\_macrodriver.h

r cg userdefine.h

Declaration static MD\_STATUS R\_IICr\_wait\_bus(void);

Explanation This function places 9 dummy pulses on the SCL line with the IICr stopped and tests the SDA

signal.

Arguments None - Return value When [I2C\_OK]: Successful in freeing the bus.

When [BUS\_ERR]: Could not free the bus (SDA signal did not go high.)

Remarks

### [Function Name] R\_IICr\_SCL\_pulse

Synopsis Output dummy clocks to SCL signal

Header r\_cg\_userdefine.h

Declaration static void R IICr SCL pulse(void);

Explanation This function manipulates the SOm register to output low pulses to SCL.

Arguments None -

Return value None Remarks None

#### [Function Name] R\_IICr\_SCL\_high

Synopsis Set SCL high.

Header r\_cg\_userdefine.h

Declaration static void R\_IICr\_SCL\_high(void);

Explanation This function manipulates the SOm register to set and hold the SCL signal high for the SCL

high level period.

Arguments None -

Return value None Remarks None

### [Function Name] R\_IICr\_SCL\_low

Synopsis Set SCL low. Header r cg userdefine.h

Declaration static void R\_IICr\_SCL\_low(void);

Explanation This function manipulates the SOm register to set and hold the SCL signal low for the SCL low

level period.

Arguments None -

Return value None Remarks None

### [Function Name] R\_IICr\_NACK

Synopsis Check ACK/NACK response from slave.

Header r\_cg\_userdefine.h

Declaration static MD\_STATUS R\_IICr\_NACK(void);

Explanation This function returns the value of bit 1 (PEF bit = NACK) of the SSRMn register.

Arguments None -

Return value When [0x00]: ACK response present

When [0x02]: No ACK response

Remarks This status flag should only be checked and not cleared.

#### [Function Name] R\_IICr\_SCL\_Time

Synopsis Wait for SCL signal low period.

Header r\_cg\_userdefine.h

Declaration static void R\_IICr\_SCL\_Time(void);

Explanation This function waits for the SCL signal low period.

Arguments None
Return value None

Remarks

### [Function Name] R\_IICr\_SCL\_highTime

Synopsis Wait for SCL signal high period.

Header r cg userdefine.h

Declaration static void R\_IICr\_SCL\_highTime(void);

Explanation This function waits for the SCL signal high period.

Arguments None

Return value None

Remarks

### [Function Name] IINTIICr

Synopsis Process IICr transfer completion interrupt.

Header r\_cg\_userdefine.h

Declaration \_\_interrupt void IINTIICr(void);

Explanation This function is invoked on an INTIICr and calls the necessary processing according to the

state of communication. When processing other than EEPROM write completion wait is in progress and a NACK response from the slave is detected, the function sets an error flag in

g\_comstatus in according to the condition of processing.

Arguments None

Return value None

Remarks

#### [Function Name] IINTTM02

Synopsis Process 100-μs interval timer completion interrupt.

Header r cg userdefine.h

Declaration interrupt void IINTTM02 (void);

Explanation This function sends a start condition and a slave address to check for the completion of write

processing.

Arguments None -

Return value None

Remarks The evaluation of the result is done by IINTIICr.

### [Function Name] R\_IICr\_Init

 $\begin{array}{ll} \text{Synopsis} & \text{Perform IICr initialization.} \\ \text{Header} & \text{r\_cg\_userdefine.h} \\ \end{array}$ 

Declaration void R\_IICr\_Init (void);

Explanation This function makes settings according to the IIC channel to be used. After completing the

setup of the IICr, the function configures timer 02 as an interval timer for checking for the completion of write processing. After completing all settings, the function sets the initial value

of the EEPROM to be used to 16 kbits.

Arguments Return value None None

Remarks

## 5.7 Flowcharts

Figure 5.1 shows the overall flow of the sample program described in this application note.



Figure 5.1 Overall Flow

## 5.7.1 Initialization Function

Figure 5.2 shows the flowchart for the initialization function



Figure 5.2 Initialization Function

Note: This function is used in the Renesas CubeSuite+ sample code. The function \_\_low\_level\_init initializes the system in the IAR Workbench IDE-based sample code insted.

## 5.7.2 System Function

Figure 5.3 shows the flowchart for the system function.



Figure 5.3 System Function

Note: Since the pins to be used differ depending on the IIC channel to be used, no settings are made for unused ports.

## 5.7.3 CPU Clock Setup

Figure 5.4 shows the flowchart for CPU clock setup.



Figure 5.4 CPU Clock Setup

## 5.7.4 Serial Array Unit Setup

Figures 5.5 and 5.6 show the flowcharts for setting up the serial interface.



Figure 5.5 SAU Setup (1/2)



Figure 5.6 SAU Setup (2/2)

Starting the supply of clock to the serial array unit SAUm
• Peripheral enable register 0 (PER0)

Manipulate SAUmEN to start the supply of clock to the SAUm.

Symbol: PER0

|   | 7     | 6 | 5     | 4       | 3              | 2      | 1 | 0      |
|---|-------|---|-------|---------|----------------|--------|---|--------|
| ı | RTCEN | 0 | ADCEN | IICA0EN | SAU1EN<br>Note | SAU0EN | 0 | TAU0EN |
| 1 | х     | 0 | Х     | Х       | 1 Note         | 1      | 0 | Х      |

Bits 3 Note and 2

| SAUmEN | Control of serial array unit m input clock supply |  |  |  |  |  |  |
|--------|---------------------------------------------------|--|--|--|--|--|--|
| 0      | Stops input clock supply.                         |  |  |  |  |  |  |
| 1      | Enables input clock supply.                       |  |  |  |  |  |  |

Note: This is not provided in the 20, 24 and 25-pin products.

Selecting the clock to the serial array unit SAUm

Serial clock selection register m (SPSm) Operation clock: CK00 = 32 MHz, CK01 = 32 MHz

Symbol: SPSm

| _ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|---|----|----|----|----|----|----|---|---|-----|-----|-----|-----|-----|-----|-----|-----|
|   | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | PRS |
|   | U  | U  | U  | U  | U  | U  | U | U | 013 | 012 | 011 | 010 | 003 | 002 | 001 | 000 |
|   | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Bits 3 to 0

| 222        | 550        | 550        | DDC        |                                   | Se                          | election of                 | operation o                  | clock (CK0                | 0)                        |
|------------|------------|------------|------------|-----------------------------------|-----------------------------|-----------------------------|------------------------------|---------------------------|---------------------------|
| PRSm<br>03 | PRSm<br>02 | PRSm<br>01 | PRSm<br>00 |                                   | f <sub>CLK</sub> =<br>2 MHz | f <sub>CLK</sub> =<br>5 MHz | f <sub>CLK</sub> =<br>10 MHz | f <sub>CLK</sub> = 20 MHz | f <sub>CLK</sub> = 32 MHz |
| 0          | 0          | 0          | 0          | f <sub>CLK</sub>                  | 2 MHz                       | 5 MHz                       | 10 MHz                       | 20 MHz                    | 32 MHz                    |
| 0          | 0          | 0          | 1          | f <sub>CLK</sub> /2               | 1 MHz                       | 2.5 MHz                     | 5 MHz                        | 10 MHz                    | 16 MHz                    |
| 0          | 0          | 1          | 0          | $f_{CLK}/2^2$                     | 500 kHz                     | 1.25 MHz                    | 2.5 MHz                      | 5 MHz                     | 8 MHz                     |
| 0          | 0          | 1          | 1          | $f_{CLK}/2^3$                     | 250 kHz                     | 625 kHz                     | 1.25 MHz                     | 2.5 MHz                   | 4 MHz                     |
| 0          | 1          | 0          | 0          | $f_{CLK}/2^4$                     | 125 kHz                     | 313 kHz                     | 625 kHz                      | 1.25 MHz                  | 2 MHz                     |
| 0          | 1          | 0          | 1          | $f_{CLK}/2^5$                     | 62.5 kHz                    | 156 kHz                     | 313 kHz                      | 625 kHz                   | 1 MHz                     |
| 0          | 1          | 1          | 0          | f <sub>CLK</sub> /2 <sup>6</sup>  | 31.3 kHz                    | 78.1 kHz                    | 156 kHz                      | 313 kHz                   | 500 kHz                   |
| 0          | 1          | 1          | 1          | f <sub>CLK</sub> /2 <sup>7</sup>  | 15.6 kHz                    | 39.1 kHz                    | 78.1 kHz                     | 156 kHz                   | 250 kHz                   |
| 1          | 0          | 0          | 0          | f <sub>CLK</sub> /2 <sup>8</sup>  | 7.81 kHz                    | 19.5 kHz                    | 39.1 kHz                     | 78.1 kHz                  | 125 kHz                   |
| 1          | 0          | 0          | 1          | f <sub>CLK</sub> /2 <sup>9</sup>  | 3.91 kHz                    | 9.77 kHz                    | 19.5 kHz                     | 39.1 kHz                  | 62.5 kHz                  |
| 1          | 0          | 1          | 0          | f <sub>CLK</sub> /2 <sup>10</sup> | 1.95 kHz                    | 4.88 kHz                    | 9.77 kHz                     | 19.5 kHz                  | 31.3 kHz                  |
| 1          | 0          | 1          | 1          | f <sub>CLK</sub> /2 <sup>11</sup> | 977 Hz                      | 2.44 kHz                    | 4.88 kHz                     | 9.77 kHz                  | 15.6 kHz                  |
| 1          | 1          | 0          | 0          | f <sub>CLK</sub> /2 <sup>12</sup> | 488 Hz                      | 1.22 kHz                    | 2.44 kHz                     | 4.88 kHz                  | 7.81 kHz                  |
| 1          | 1          | 0          | 1          | $f_{CLK}/2^{13}$                  | 244 Hz                      | 610 Hz                      | 1.22 kHz                     | 2.44 kHz                  | 3.91 kHz                  |
| 1          | 1          | 1          | 0          | f <sub>CLK</sub> /2 <sup>14</sup> | 122 Hz                      | 305 Hz                      | 610 Hz                       | 1.22 kHz                  | 1.95 kHz                  |
| 1          | 1          | 1          | 1          | f <sub>CLK</sub> /2 <sup>15</sup> | 61 Hz                       | 153 Hz                      | 305 Hz                       | 610 Hz                    | 977 Hz                    |

## Clearing the error flags

• Serial flag clear trigger register mn (SIRmn) Clear channel mn error flags.

## Symbol: SIRmn

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2          | 1          | 0          |
|----|----|----|----|----|----|---|---|---|---|---|---|---|------------|------------|------------|
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | FECT<br>01 | PECT<br>01 | OVCT<br>01 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1          | 1          | 1          |

### Bit 1

| PECTmn | Clear trigger of parity error flag of channel mn (no ACK response) |  |  |  |  |  |  |  |
|--------|--------------------------------------------------------------------|--|--|--|--|--|--|--|
| 0      | ot cleared.                                                        |  |  |  |  |  |  |  |
| 1      | Clears the PEFmn bit of the SSRmn register to 0.                   |  |  |  |  |  |  |  |

Setting up channel mn operation mode

Serial mode register mn (SMRmn)
 Select an operation clock: CK00
 Set the start trigger: Soft trigger only
 Set the operation mode: Simplified I<sup>2</sup>C

Select an interrupt factor: Transfer end interrupt

## Symbol: SMRmn

| 15        | 14        | 13 | 12 | 11 | 10 | 9 | 8              | 7 | 6                             | 5 | 4 | 3 | 2         | 1         | 0         |
|-----------|-----------|----|----|----|----|---|----------------|---|-------------------------------|---|---|---|-----------|-----------|-----------|
| CKS<br>mn | CCS<br>mn | 0  | 0  | 0  | 0  | 0 | STS<br>mn Note | 0 | SIS<br>mn0<br><sub>Note</sub> | 1 | 0 | 0 | MD<br>mn2 | MD<br>mn1 | MD<br>mn0 |
| 0         | 0         | 0  | 0  | 0  | 0  | 0 | 0              | 0 | 0                             | 1 | 0 | 0 | 1         | 0         | 0         |

#### Bit 15

| CKSmn Selection of operation clock (f <sub>MCK</sub> ) of channel mn |                                               |  |  |  |  |  |
|----------------------------------------------------------------------|-----------------------------------------------|--|--|--|--|--|
| 0 Operation clock CK00 set by the SPS0 register                      |                                               |  |  |  |  |  |
| 1                                                                    | Operation clock CK01 set by the SPS0 register |  |  |  |  |  |

#### Bit 14

| CCSmn | Selection of transfer clock (f <sub>TCLK</sub> ) of channel mn               |
|-------|------------------------------------------------------------------------------|
| 0     | Divided operation clock f <sub>MCK</sub> specified by the CKSmn bit          |
| 1     | Clock input f <sub>SCK</sub> from the SCK00 pin (slave transfer in CSI mode) |

#### Bit 8

| STSmn Note | Selection of start trigger source                                                                      |
|------------|--------------------------------------------------------------------------------------------------------|
|            | Only software trigger is valid (selected for CSI, UART transmission, and simplified I <sup>2</sup> C). |
| 1          | Valid edge of the RXD0 pin (selected for UART reception)                                               |

### Bits 2 and 1

| MDmn2 | MDmn1 | Setting of operation mode of channel mn |  |  |  |  |  |
|-------|-------|-----------------------------------------|--|--|--|--|--|
| 0     | 0     | CSI mode                                |  |  |  |  |  |
| 0     | 1     | UART mode                               |  |  |  |  |  |
| 1     | 0     | Simplified I <sup>2</sup> C mode        |  |  |  |  |  |
| 1     | 1     | Setting prohibited                      |  |  |  |  |  |

#### Bit 0

| MDmn0 Selection of interrupt source of channel mn <b>Transfer end interrupt</b> |                  |  |  |  |  |
|---------------------------------------------------------------------------------|------------------|--|--|--|--|
|                                                                                 |                  |  |  |  |  |
|                                                                                 | shift register.) |  |  |  |  |

Note: Odd channels only

## Setting up the communication format

Serial communication operation setting register mn (SCRmn)

Operation mode: Transmission only Parity bit setting: No parity

Data transfer order: MSB first

Stop bit length: 1 bit Data length: 8 bits

### Symbol: SCRmn

| 15  | 14  | 13  | 12  | 11 | 10  | 9   | 8   | 7   | 6 | 5   | 4   | 3 | 2 | 1   | 0   |
|-----|-----|-----|-----|----|-----|-----|-----|-----|---|-----|-----|---|---|-----|-----|
| TXE | RXE | DAP | CKP | 0  | EOC | PTC | PTC | DIR | 0 | SLC | SLC | 0 | 1 | DLS | DLS |
| mn  | mn  | mn  | mn  | O  | mn  | mn1 | mn0 | mn  | U | mn1 | mn0 | O | ı | mn1 | mn0 |
| 1   | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0   | 0 | 0   | 1   | 0 | 1 | 1   | 1   |

#### Bits 15 and 14

| TXEmn | RXEmn | Setting of operation mode of channel mn |
|-------|-------|-----------------------------------------|
| 0     | 0     | Disable communication.                  |
| 0     | 1     | Reception only                          |
| 1     | 0     | Transmission only                       |
| 1     | 1     | Transmission/reception                  |

### Bits 13 and 12

| DAPmn | CKPmn | Selection of data and clock phase in CSI mode |
|-------|-------|-----------------------------------------------|
| 0     | 0     | Type 1                                        |
| 0     | 1     | Type 2                                        |
| 1     | 0     | Type 3                                        |
| 1     | 1     | Type 4                                        |

Be sure to set DAP01 and CKP01 to 0 in the UART mode and simplified I<sup>2</sup>C mode.

### Bit 10

| EOCmn | Selection of masking of error interrupt signal (INTSREx (x = 0 to 3))                |
|-------|--------------------------------------------------------------------------------------|
| 0     | Masks error interrupt INTSREx (INTSRx is not masked).                                |
| 1     | Enables generation of error interrupt INTSREx (INTSRx is masked if an error occurs). |

Set EOC01 to 0 during UART reception.

### Bits 9 and 8

| PTCmn1   | DTCmn0   | Setting of parity bit in UART mode |                         |  |  |  |  |  |  |  |
|----------|----------|------------------------------------|-------------------------|--|--|--|--|--|--|--|
| PICIIIII | PTCIIIIO | Transmission                       | Reception               |  |  |  |  |  |  |  |
| 0        | 0        | Does not output the parity bit.    | Receives without parity |  |  |  |  |  |  |  |
| 0        | 1        | Outputs 0 parity.                  | No parity judgment      |  |  |  |  |  |  |  |
| 1        | 0        | Outputs even parity.               | Judges as even parity.  |  |  |  |  |  |  |  |
| 1        | 1        | Outputs odd parity.                | Judges as odd parity.   |  |  |  |  |  |  |  |

### Bit 7

| DIRmn | Selection of data transfer sequence in CSI and UART modes |
|-------|-----------------------------------------------------------|
| 0     | Inputs/outputs data with MSB first.                       |
| 1     | Inputs/outputs data with LSB first.                       |

### Bits 5 and 4

| SLCmn1 | SLCmn0 | Setting of stop bit in UART mode                    |
|--------|--------|-----------------------------------------------------|
| 0      | 0      | No stop bit                                         |
| 0      | 1      | Stop bit length = 1 bit                             |
| 1      | 0      | Stop bit length = 2 bits (mn = 00, 02, 10, 12 only) |
| 1      | 1      | Setting prohibited                                  |

Set 1 bit (SLCmn1, SLCmn0 = 0, 1) during UART reception and in the simplified  $I^2C$  mode.

## Bits 1 and 0

| DLSmn1    | DLSmn0   | Setting of data length in CSI and UART modes                                                   |
|-----------|----------|------------------------------------------------------------------------------------------------|
| 0         |          | 9-bit data length (stored in bits 0 to 8 of the SDRmn register) (can be set in UART mode only) |
| 1         | 0        | 7-bit data length (stored in bits 0 to 6 of the SDRmn register)                                |
| 1         | 1        | 8-bit data length (stored in bits 0 to 7 of the SDRmn register)                                |
| Other tha | ın above | Setting prohibited                                                                             |

Selecting an operation clock ( $f_{\text{MCK}}$ ) frequency division

Serial data register mn (SDRmn)
 Transfer clock: f<sub>MCK</sub>/84 (381 kbps)

## Symbol: SDRmn

| 15                                                    | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5      | 4         | 3        | 2 | 1 | 0 |
|-------------------------------------------------------|----|----|----|----|----|---|---|---|---|--------|-----------|----------|---|---|---|
| Division ratio of operation clock (f <sub>MCK</sub> ) |    |    |    |    |    |   |   |   |   | Transm | it/receiv | e buffer |   |   |   |
| 0                                                     | 1  | 0  | 1  | 0  | 0  | 1 | Х | Х | Х | Х      | Х         | Х        | х | Х | Х |

Bits 15 to 9

| b15 | b14 | b13 | b12 | b11 | b10 | b9 | Transfer clock setting by dividing the operating clock ( $f_{MCK}$ ) |  |  |  |  |  |
|-----|-----|-----|-----|-----|-----|----|----------------------------------------------------------------------|--|--|--|--|--|
| 0   | 0   | 0   | 0   | 0   | 0   | 0  | f <sub>MCK</sub> /2                                                  |  |  |  |  |  |
| 0   | 0   | 0   | 0   | 0   | 0   | 1  | f <sub>MCK</sub> /4                                                  |  |  |  |  |  |
| 0   | 0   | 0   | 0   | 0   | 1   | 0  | f <sub>MCK</sub> /6                                                  |  |  |  |  |  |
| 0   | 0   | 0   | 0   | 0   | 1   | 1  | f <sub>MCK</sub> /8                                                  |  |  |  |  |  |
| •   | •   | •   | •   | •   | •   | •  | •                                                                    |  |  |  |  |  |
| •   | •   | •   | •   | •   | •   | •  | •                                                                    |  |  |  |  |  |
| •   | •   | •   | •   | •   | •   | •  | •                                                                    |  |  |  |  |  |
| 0   | 1   | 0   | 1   | 0   | 0   | 1  | f <sub>MCK</sub> /84                                                 |  |  |  |  |  |
| •   | •   | •   | •   | •   | •   | •  | •                                                                    |  |  |  |  |  |
| •   | •   | •   | •   | •   | •   | •  | •                                                                    |  |  |  |  |  |
| •   | •   | •   | •   | •   | •   | •  | •                                                                    |  |  |  |  |  |
| 1   | 1   | 1   | 1   | 1   | 1   | 0  | f <sub>MCK</sub> /254                                                |  |  |  |  |  |
| 1   | 1   | 1   | 1   | 1   | 1   | 1  | f <sub>MCK</sub> /256                                                |  |  |  |  |  |

Enabling/disabling target channel for serial data output

• Serial output enable register m (SOEm) Stop output

## Symbol: SOEm

|   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2   | 1   | 0   |
|---|----|----|----|----|----|----|---|---|---|---|---|---|-----|-----|-----|-----|
| I | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | SOE | SOE | SOE | SOE |
| L |    | U  | U  | U  | O  | U  | O | O | O | U | U | U | m3  | m2  | m1  | m0  |
| I | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0   | 0   | 0   | 0   |

| SOEmn | Serial output enable/stop of channel mn           |  |  |  |  |  |  |  |
|-------|---------------------------------------------------|--|--|--|--|--|--|--|
| 0     | Stops output by serial communication operation    |  |  |  |  |  |  |  |
| 1     | Enables output by serial communication operation. |  |  |  |  |  |  |  |

Setting SDA and SCL initial output level

• Serial output register m (SOm) Output level: 1

### Symbol: SOm

| 15 | 14                  | 13 | 12 | 11        | 10        | 9         | 8                  | 7 | 6 | 5 | 4 | 3        | 2        | 1        | 0        |
|----|---------------------|----|----|-----------|-----------|-----------|--------------------|---|---|---|---|----------|----------|----------|----------|
|    | Serial clock Output |    |    |           |           |           | Serial data output |   |   |   |   |          |          |          |          |
| 0  | 0                   | 0  | 0  | CKO<br>m3 | CKO<br>m2 | CKO<br>m1 | CKO<br>m0          | 0 | 0 | 0 | 0 | SO<br>m3 | SO<br>m2 | SO<br>m1 | SO<br>m0 |
| 0  | 0                   | 0  | 0  | 1         | 1         | 1         | 1                  | 0 | 0 | 0 | 0 | 1        | 1        | 1        | 1        |

### Bits 11 to 8

| CKOmn                               | Serial clock output of channel mn |  |  |  |  |
|-------------------------------------|-----------------------------------|--|--|--|--|
| 0 Serial clock output value is "0". |                                   |  |  |  |  |
| 1                                   | Serial clock output value is "0". |  |  |  |  |

Bits 3 to 0

| SOmn | Serial data output of channel mn |  |  |  |  |  |
|------|----------------------------------|--|--|--|--|--|
| 0    | Serial data output value is "0". |  |  |  |  |  |
| 1    | Serial data output value is "0". |  |  |  |  |  |

### Setting up the IICr pins

- Port register (Px)
- Port mode register (PMx)
- Port output mode register (POMx)

Set up the SDA pin for open drain output.

The pins that are to be used as SCL and SDA in output mode are listed below.

### Products with 20 pins

| Simplified I <sup>2</sup> C channel | IIC00 | IIC01 | IIC10 | IIC11 | IIC20 | IIC21 |
|-------------------------------------|-------|-------|-------|-------|-------|-------|
| SCL pin                             | P10   | _     | _     | P30   | _     | _     |
| SDA pin                             | P11   | _     | _     | P17   | _     | _     |

#### Products with 24 to 64 pins

| Simplified I <sup>2</sup> C channel | IIC00 | IIC01 Note | IIC10 Note | IIC11 | IIC20 Note | IIC21 Note |
|-------------------------------------|-------|------------|------------|-------|------------|------------|
| SCL pin                             | P10   | P75        | P04        | P30   | P15        | P70        |
| SDA pin                             | P11   | P74        | P03        | P50   | P14        | P71        |

Notes 1. Products with 30 or more pins

- 2. Products with 36 or more pins
- 3. Products with 48 or more pins
- 4. Products with 64 pins only

#### Products with 80 or more pins

| Simplified I <sup>2</sup> C channel | IIC00 | IIC01 | IIC10 | IIC11 | IIC20 | IIC21 | IIC30 | IIC31 |
|-------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| SCL pin                             | P10   | P43   | P04   | P30   | P15   | P70   | P142  | P54   |
| SDA pin                             | P11   | P44   | P03   | P50   | P14   | P71   | P143  | P53   |

### Symbol: Pxn

| Pxn | Output data control |
|-----|---------------------|
| 0   | Output 0            |
| 1   | Output 1            |

### Symbol: PMxn

| PMxn                             | Pxn pin I/O mode selection     |  |  |  |  |  |
|----------------------------------|--------------------------------|--|--|--|--|--|
| 0 Output mode (output buffer on) |                                |  |  |  |  |  |
| 1                                | Input mode (output buffer off) |  |  |  |  |  |

### Symbol: POMxn

| POMxn | Pxn pin output mode selection |
|-------|-------------------------------|
| 0     | CMOS output mode              |
| 1     | N-ch open drain output mode   |

Note: Only the pins that can be used as SDA pins are set up.

Caution: For details on the register setup procedures, refer to RL78/G13 User's Manual: Hardware.

Setting up timer 02 (interval timer)

• See the following application note for details on the timer settings: RL78/G13 Timer Array Unit (Interval Timer) (R01AN0456E) Application Note



### 5.7.5 Main Function

Figures 5.7 through 5.9 show the flowchart for the main function.

The main function performs read/write tests on 16 kbits of EEPROM to illustrate the use of API.



Figure 5.7 Main Function (1/3)



Figure 5.8 Main Function (2/3)



Figure 5.9 Main Function (3/3)

### 5.7.6 EEPROM Selection

Figure 5.10 shows the flowchart for selecting the EEPROM.



Figure 5.10 EEPROM Selection

## 5.7.7 Bus freeing Processing

Figure 5.11 shows the flowchart for the function to free the bus.



Figure 5.11 Bus freeing Processing

### 5.7.8 Stop Condition Generation Function

Figure 5.12 shows the flowchart for the function to generate a stop condition.



Figure 5.12 Stop Condition Generation Function

### Stopping serial channel

• Serial channel stop register m (STm/STmL) Stops a given serial channel.

Symbol: STmL

| 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|---|---|---|---|------|------|------|------|
| 0 | 0 | 0 | 0 | STm3 | STm2 | STm1 | STm0 |
| 0 | 0 | 0 | 0 | 0/1  | 0/1  | 0/1  | 0/1  |

### Bits 3 to 0

| Operation stop trigger of channel mn                          |  |  |  |  |  |  |
|---------------------------------------------------------------|--|--|--|--|--|--|
| o trigger operation                                           |  |  |  |  |  |  |
| lears the SEmn bit to 0 and stops the ommunication operation. |  |  |  |  |  |  |
| :                                                             |  |  |  |  |  |  |

### Disabling serial output

• Serial output enable register m (SOEm/SOEmL) Disables the serial channel for output.

Symbol: SOEmL

| 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     |
|---|---|---|---|-------|-------|-------|-------|
| 0 | 0 | 0 | 0 | SOEm3 | SOEm2 | SOEm1 | SOEm0 |
| 0 | 0 | 0 | 0 | 0/1   | 0/1   | 0/1   | 0/1   |

### Bits 3 to 0

| SOEmn | Serial output enable/stop of channel mn           |  |  |  |  |  |
|-------|---------------------------------------------------|--|--|--|--|--|
| 0     | Stops output by serial communication operation.   |  |  |  |  |  |
| 1     | Enables output by serial communication operation. |  |  |  |  |  |

## Serial output manipulation

• Serial output register m (SOm)
Manipulates serial output s (SCL and SDA).

Symbol: SOm

| _ | 15 | 14 | 13 | 12 | 11        | 10        | 9         | 8         | 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|---|----|----|----|----|-----------|-----------|-----------|-----------|---|---|---|---|------|------|------|------|
|   | 0  | 0  | 0  | 0  | CKO<br>m3 | CKO<br>m2 | CKO<br>m1 | CKO<br>m0 | 0 | 0 | 0 | 0 | SOm3 | SOm2 | SOm1 | SOm0 |
| I | 0  | 0  | 0  | 0  | 0/1       | 0/1       | 0/1       | 0/1       | 0 | 0 | 0 | 0 | 0/1  | 0/1  | 0/1  | 0/1  |

Bits 11 to 8

| CKOmn | Serial clock output of channel mn |  |  |  |
|-------|-----------------------------------|--|--|--|
| 0     | Serial clock output value is "0". |  |  |  |
| 1     | Serial clock output value is "1". |  |  |  |

Bits 3 to 0

| SOmn | Serial data output of channel mn |
|------|----------------------------------|
| 0    | Serial data output value is "0". |
| 1    | Serial data output value is "1". |

## 5.7.9 Bus Freeing Function

Figure 5.13 shows the flowchart for the bus freeing function.



Figure 5.13 Bus Freeing Function

### 5.7.10 EEPROM Write Processing

Figure 5.14 shows the state transition diagram of EEPROM write processing and figure 5.15 shows its flow chart.



Figure 5.14 EEPROM Write Processing State Transition Diagram



Figure 5.15 EEPROM Write Processing

## 5.7.11 EEPROM Address Check Processing

Figure 5.16 shows the flowchart for the EEPROM address check processing.



Figure 5.16 EEPROM Address Check Processing

### 5.7.12 Slave Address Calculation

Figure 5.17 shows the flowchart for the slave address calculation processing.



Figure 5.17 Slave Address Calculation Processing

## 5.7.13 Write Data Page Split Processing

Figure 5.18 shows the flowchart for the write data page split processing.



Figure 5.18 Write Data Page Split Processing

## 5.7.14 Start Condition Issuing Processing

Figure 5.19 shows the flowchart for the function to issue a start condition.



Figure 5.19 Start Condition Issuing Processing

## Starting serial channel

• Serial channel start register m (SSm/SSmL) Starts a given serial channel.

Symbol: SSmL

| 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|---|---|---|---|------|------|------|------|
| 0 | 0 | 0 | 0 | SSm3 | SSm2 | SSm1 | SSm0 |
| 0 | 0 | 0 | 0 | 0/1  | 0/1  | 0/1  | 0/1  |

### Bits 3 to 0

| SSmn | Operation start trigger of channel mn                            |
|------|------------------------------------------------------------------|
| 0    | No trigger operation                                             |
| 1    | Sets the SEmn bit to 1 and enters the communication wait status. |

### 5.7.15 EEPROM Write Completion Wait Processing

Figure 5.20 shows the flowchart for the EEPROM write completion wait processing.



Figure 5.20 EEPROM Write Completion Wait Processing

# 5.7.16 EEPROM Read Processing

Figure 5.21 shows the state transition diagram of EEPROM read processing and figure 5.22 shows its flow chart.



Figure 5.21 EEPROM Read Processing State Transition Diagram



Figure 5.22 EEPROM Read Processing

### 5.7.17 EEPROM Read Completion Wait Processing

Figure 5.23 shows the flowchart for the EEPROM read completion wait processing.



Figure 5.23 EEPROM Read Completion Wait Processing

### 5.7.18 Slave Address Transmission Completion Processing

Figure 5.24 shows the flowchart for the slave address transmission completion processing.



Figure 5.24 Slave Address Transmission Completion Processing

# 5.7.19 Upper Address Transmission Completion Processing

Figure 5.25 shows the flowchart for the upper address transmission completion processing.



Figure 5.25 Upper Address Transmission Completion Processing

### 5.7.20 Restart Processing

Figure 5.26 shows the flowchart for the restart processing.



Figure 5.26 Restart Processing

## 5.7.21 Data Reception Start Processing

Figure 5.27 shows the flowchart for the data reception start processing.



Figure 5.27 Data Reception Start Processing

# 5.7.22 Data Receive Processing

Figure 5.28 shows the flowchart for the data receive processing.



Figure 5.28 Data Receive Processing

### 5.7.23 Last Data Receive Processing

Figure 5.29 shows the flowchart for the last data receive processing.



Figure 5.29 Last Data Receive Processing

## 5.7.24 Data Transmission Start Processing

Figure 5.30 shows the flowchart for the data transmission start processing.



Figure 5.30 Data Transmission Start Processing

### 5.7.25 Data Transmit Processing

Figure 5.31 shows the flowchart for the data transmit processing.



Figure 5.31 Data Transmit Processing

# 5.7.26 Next Page Write Start Processing

Figure 5.32 shows the flowchart for the next page write start processing.



Figure 5.32 Next Page Write Start Processing

## 5.7.27 SCL Dummy Clock Output Processing

Figure 5.33 shows the flowchart for the SCL dummy clock output processing.



Figure 5.33 SCL Dummy Clock Output Processing

## 5.7.28 SCL Set High Processing

Figure 5.34 shows the flowchart for setting SCL high.



Figure 5.34 SCL Set High Processing

## 5.7.29 SCL Set Low Processing

Figure 5.35 shows the flowchart for setting SCL low.



Figure 5.35 SCL Set Low Processing

## 5.7.30 ACK Confirmation Processing

Figure 5.36 shows the flowchart for checking the ACK response.



Figure 5.36 ACK Response Check Processing

## 5.7.31 SCL Low Level Period Wait Processing

Figure 5.37 shows the flowchart for the SCL low level period wait processing.



Figure 5.37 SCL Low Level Period Wait Processing

## 5.7.32 SCL High Level Period Wait Processing

Figure 5.38 shows the flowchart for the SCL high level period wait processing.



Figure 5.38 SCL High Level Period Wait Processing

### 5.7.33 INTIICr Interrupt Processing

Figures 5.39 to 5.41 show the flowcharts for the INTIICr interrupt processing.



Figure 5.39 INTIICr Interrupt Processing (1/3)



Figure 5.40 INTIICr Interrupt Processing (2/3)



Figure 5.41 INTIICr Interrupt Processing (3/3)

## 5.7.34 INTTM02 Interrupt Processing

Figure 5.42 shows the flowchart for the INTTM02 interrupt processing.



Figure 5.42 INTTM02 Interrupt Processing

# 6. Sample Code

The sample code is available on the Renesas Electronics Website.

### 7. Documents for Reference

RL78/G13 User's Manual: Hardware (R01UH0146E) RL78 Family User's Manual: Software (R01US0015E)

(The latest versions of the documents are available on the Renesas Electronics Website.)

Technical Updates/Technical Brochures

(The latest versions of the documents are available on the Renesas Electronics Website.)

# **Website and Support**

Renesas Electronics Website

http://www.renesas.com/index.jsp

### Inquiries

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

| Revision Record | RL78/G13                                                               |
|-----------------|------------------------------------------------------------------------|
|                 | RL78/G13 Serial Array Unit (SAU) (EEPROM Control Using Simplified IIC) |

| Rev.   Date   Page   Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Description |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--|--|--|--|--|--|
| 2.00   2014.3.24   12   Table 2.1: Added e2studio and IAR version information   34   Fibure 5.1, Figure 5.2: Added note   37   Figure 5.6: Updated   2.01   2014.5.16-1   19   Table 5.2: Corrected   38   Notes for Bit3-2: Added   43   The setteing of f <sub>MCK</sub> Modified   2014.5.16-2   5-11   Correction (SCKmn bit -> CKOmn bit)   7.8   Correction (P.7 (12) and P.8 (10))   24   Correction (Declaration of R_device_select function)   25   Correction (Declaration of R_device_select function)   27-30   "Function Name: IINTIICr": Added   28   Synopsis of R_IICr_Rx_RST function: Added   28   Explanation of R_IICr_Rx_RST function: Added   28   Synopsis of R_IICr_TxData function: Added   29   Name of function "R_IICr_TxDataST": Corrected   30   Name of R_IICr_TxData function: Corrected   30   Name of R_IICr_TxData function: Corrected   30   Name of R_IICr_TxData function: Corrected   30   Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait_bus function   32   Name of IINTIICr function: Modified (mn -> r)   32   Declaration of R_IICr_Init function: Corrected   33   Declaration of R_IICr_Init function: Corrected   25   Spnopsis of R_IICr_Init function: Corrected   26   Explanation of B_IICr_Init function: Corrected   27   Spnopsis of R_IICr_Init function: Modified   28   Spnopsis of R_IICr_Init function: Corrected   39   Spnopsis of R_IICr_Init function: Modified   30   Spnopsis of R_IICr_Init function: Corrected   30   Spnopsis of R_IICr_Init function: Corrected   31   Spnopsis of R_IICr_Init function: Corrected   32   Spnopsis of R_IICr_Init function: Corrected   33   Spnopsis of R_IICr_Init function: Corrected   34   Spnopsis of R_IICr_Init function: Corrected   35   Spnopsis of R_IICr_Init function: Corrected   36   Spnopsis of R_IICr_Init function: Corrected   37   Spnopsis of R_IICr_Init function: Corrected   38   Spnopsis of R_IICr_Init function: Corrected   39   Spnopsis of R_IICr_Init function: Corrected   39   Spnopsis of R_IICr_Init function: Corrected   39   Spnopsis of R_IICr_Init function:    |             |  |  |  |  |  |  |
| 34 Fibure 5.1, Figure 5.2: Added note 37 Figure 5.6: Updated 38 Figure 5.6: Updated 38 Notes for Bit3-2: Added 43 The setteing of f <sub>MCK</sub> . Modified 2014.5.16 -2 5-11 Correction (SCKmn bit -> CKOmn bit) 7,8 Correction (P.7 (12) and P.8 (10)) 24 Correction (Outline of R_IICr_send_Stop function) 25 Correction (Declaration of R_device_select function) 27-30 "Function Name: IINTIICr": Added 28 Synopsis of R_IICr_Rx_RST function: Modified 28 Synopsis of R_IICr_Rx_RST function: Added 28 Explanation of R_IICr_Rx_RST function: Added 29 Name of function "R_IICr_TxData function: Added 29 Name of R_IICr_TxData function: Modified 29 Name of R_IICr_TxData function: Corrected 30 Name of R_IICr_TxData function: Corrected 30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait function 31 Name of IINTIICr function: Modified (mn -> r) 32 Declaration of R_IICr_Init function: Corrected 33 Declaration of R_IICr_Init function: Corrected 34 Declaration of B_IICr_Init function: Corrected 35 Name of R_device_select function: Corrected 46 Explanation of bits 5 and 4: Modified 47 Serial output enable register m (SOEm): Register name was Modified 48 Name of Fig. 5.7: Modified 49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |             |  |  |  |  |  |  |
| 2.01 2014.5.16 -1 19 Table 5.2: Corrected 38 Notes for Bit3-2: Added 43 The setteing of f <sub>McK</sub> . Modified 2014.5.16 -2 5-11 Correction (SCKmn bit > CKOmn bit) 7.8 Correction (P.7 (12) and P.8 (10)) 24 Correction (Outline of R_IICr_send_Stop function) 25 Correction (Declaration of R_device_select function) 27-30 "Function Name: IINTIICr": Added 28 Synopsis of R_IICr_Rx_RST function: Modified 28 Synopsis of R_IICr_Rx_RST function: Added 28 Explanation of R_IICr_TxData function: Added 29 Name of function "R_IICr_TxDataST": Corrected 29 Synopsis of R_IICr_TxData function: Corrected 30 Name of R_IICr_TxData function: Corrected 31 Name of R_IICr_TxData function: Corrected 32 Name of R_IICr_TxData function: Corrected 33 Name of R_IICr_TxData function: Corrected 34 Synopsis of R_IICr_TxData function: Corrected 35 Name of R_IICr_TxData function: Corrected 36 Name of R_IICr_TxData function: Corrected 37 Name of R_IICr_TxData function: Corrected 38 Name of R_IICr_ScL_Time function and R_IICr_wait function 39 Declaration of R_IICr_ScL_Time function and R_IICr_ScL_highTime function function of R_IICr_ScL_highTime function: Corrected 30 Declaration of R_IICr_ScL_Time function: Corrected 31 Declaration of R_IICr_ScL_Time function: Corrected 32 Sproprious for the function: Corrected 33 Declaration of R_IICr_ScL_Time function: Corrected 34 Explanation of bits 5 and 4: Modified 45 Explanation of bits 5 and 4: Modified 46 Explanation of R_IICr_StopCond function function: Modified 46 Explanation of R_IICr_StopCond function function: Modified 47 Buffer name was changed to g_data_bufferW2 49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                          |             |  |  |  |  |  |  |
| 2.01   2014.5.16 -1   19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |             |  |  |  |  |  |  |
| 38 Notes for Bit3-2: Added  43 The setteing of f <sub>MCK</sub> : Modified  2014.5.16 -2  5-11 Correction (SCKmn bit -> CKOmn bit)  7,8 Correction (P.7 (12) and P.8 (10))  24 Correction (Outline of R_IICr_send_Stop function)  25 Correction (Declaration of R_device_select function)  27-30 "Function Name: IINTIICr": Added  28 Synopsis of R_IICr_Rx_RST function: Modified  28 Synopsis of R_IICr_Rx_RST function: Added  28 Explanation of R_IICr_Rx_RST function: Added  29 Name of function "R_IICr_TxDataST": Corrected  29 Synopsis of R_IICr_TxData function: Modified  29 Name of R_IICr_TxData function: Corrected  30 Name of R_IICr_wait_bus function: Corrected  30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait_function  31 Name of IIINTIICr function: Modified (mn -> r)  32 Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function for R_IICr_sclaration of R_IICr_sclaration in R_IICr_sc |             |  |  |  |  |  |  |
| The setteing of f <sub>McK</sub> : Modified  2014.5.16 -2  5-11 Correction (SCKmn bit -> CKOmn bit)  7,8 Correction (P.7 (12) and P.8 (10))  24 Correction (Outline of R_IICr_send_Stop function)  25 Correction (Declaration of R_device_select function)  27-30 "Function Name: IINTIICr": Added  28 Synopsis of R_IICr_Rx_RST function: Modified  28 Synopsis of R_IICr_Rx_RST function: Added  28 Explanation of R_IICr_Rx_RST function: Added  29 Name of function "R_IICr_TxData function: Modified  29 Name of R_IICr_TxData function: Corrected  30 Name of R_IICr_txData function: Corrected  30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_waif function  32 Name of IINTIICr function: Modified (mn -> r)  32 Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function for R_device_select function: Corrected  33 Declaration of R_IICr_Init function: Corrected  34 Name of R_device_select function: Corrected  45 Explanation of bits 5 and 4: Modified  46 Explanation of bits 5 and 4: Modified  47 Serial output enable register m (SOEm): Register name was Modified  48 Explanation of R_IICr_StopCond function function: Modified  49 Name of F.I. StopCond function function: Modified  40 Name of F.I. StopCond function function: Modified  41 Buffer name was changed to g_data_bufferW2  42 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             |  |  |  |  |  |  |
| 2014.5.16 -2  5-11 Correction (SCKmn bit -> CKOmn bit)  7,8 Correction (P.7 (12) and P.8 (10))  24 Correction (Outline of R_IICr_send_Stop function)  25 Correction (Declaration of R_device_select function)  27-30 "Function Name: IIINTIICr": Added  28 Synopsis of R_IICr_Rx_RST function: Modified  28 Synopsis of R_IICr_Rx_Data function: Added  28 Explanation of R_IICr_Rx_RST function: Added  29 Name of function "R_IICr_TxDataST": Corrected  29 Synopsis of R_IICr_TxData function: Modified  29 Name of R_IICr_TxData function: Corrected  30 Name of R_IICr_TxData function: Corrected  30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait function  32 Name of IINTIICr function: Modified (mn -> r)  32 Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime functor Corrected  33 Declaration of R_IICr_Init function: Corrected  34 Name of R_device_select function: Corrected  42 Explanation of bits 5 and 4: Modified  44 Serial output enable register m (SOEm): Register name was Modified  45 Explanation of R_IICr_StopCond function function: Modified  46 Name of Fig. 5.7: Modified  47 Buffer name was changed to g_data_bufferW2  49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |  |  |  |  |  |  |
| 7,8 Correction (P.7 (12) and P.8 (10))  24 Correction (Outline of R_IICr_send_Stop function)  25 Correction (Declaration of R_device_select function)  27-30 "Function Name: IINTIICr": Added  28 Synopsis of R_IICr_Rx_RST function: Modified  28 Synopsis of R_IICr_Rx_RST function: Added  28 Explanation of R_IICr_Rx_RST function: Added  29 Name of function "R_IICr_TxDataST": Corrected  29 Synopsis of R_IICr_TxData function: Modified  29 Name of R_IICr_TxData function: Corrected  30 Name of R_IICr_wait_bus function: Corrected  30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait function  31 Name of IINTIICr function: Modified (mn -> r)  32 Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function of R_IICr_Init function: Corrected  33 Declaration of R_IICr_Init function: Corrected  34 Name of R_ICr_Init function: Corrected  35 Declaration of R_IICr_Init function: Corrected  36 Explanation of bits 5 and 4: Modified  47 Serial output enable register m (SOEm): Register name was Modified  48 Explanation of R_IICr_StopCond function function: Modified  49 Name of Fig. 5.7: Modified  40 Name of Fig. 5.7: Modified  41 Buffer name was changed to g_data_bufferW2  42 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |             |  |  |  |  |  |  |
| 24 Correction (Outline of R_IICr_send_Stop function) 25 Correction (Declaration of R_device_select function) 27-30 "Function Name: IINTIICr": Added 28 Synopsis of R_IICr_Rx_RST function: Modified 28 Synopsis of R_IICr_Rx_RST function: Added 28 Explanation of R_IICr_Rx_RST function: Added 29 Name of function "R_IICr_TxDatasTr": Corrected 29 Synopsis of R_IICr_TxData function: Modified 29 Name of R_IICr_TxData function: Corrected 30 Name of R_IICr_TxData function: Corrected 30 Name of R_IICr_wait_bus function: Corrected 30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait function 31 Name of IINTIICr function: Modifed (mn -> r) 32 Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function for R_IICr_SCL_bighTime function: Corrected 31 Declaration of R_IICr_Init function: Corrected 32 Declaration of R_IICr_Scleded (mn -> r) 33 Declaration of R_IICr_Scleded (mn -> r) 34 Declaration of R_IICr_Scleded (mn -> r) 35 Declaration of R_IICr_Scleded (mn -> r) 36 Declaration of R_IICr_Scleded (mn -> r) 37 Name of R_device_select function: Corrected (mn -> r) 38 Declaration of R_IICr_Scleded (mn -> r) 49 Serial output enable register m (solem): Register name was Modified (mn -> r) 40 Serial output enable register m (solem): Register name was Modified (mn -> r) 41 Serial output enable register m (solem): Register name was Modified (mn -> r) 42 Serial output enable register m (solem): Register name was Modified (mn -> r) 44 Serial output enable register m (solem): Register name was Modified (mn -> r) 45 Serial output enable register m (solem): Register name was Modified (mn -> r) 46 Name of Fig. 5.7: Modified (mn -> r)                                                                                                                                                                                                                                                                                                                                                                                                      |             |  |  |  |  |  |  |
| 25 Correction (Declaration of R_device_select function) 27-30 "Function Name: IINTIICr": Added 28 Synopsis of R_IICr_Rx_RST function: Modified 28 Synopsis of R_IICr_Rx_RST function: Added 28 Explanation of R_IICr_Rx_RST function: Added 29 Name of function "R_IICr_TxData function: Added 29 Name of function "R_IICr_TxData function: Modified 29 Name of R_IICr_TxData function: Corrected 30 Name of R_IICr_TxData function: Corrected 30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait function 31 Name of IINTIICr function: Modifed (mn -> r) 32 Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function 33 Declaration of R_IICr_Init function: Corrected 34 Declaration of B_IICr_Init function: Corrected 35 Name of R_device_select function: Corrected 46 Explanation of bits 5 and 4: Modified 47 Serial output enable register m (SOEm): Register name was Modified 48 Name of Fig. 5.7: Modified 49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |             |  |  |  |  |  |  |
| 27-30 "Function Name: IINTIICr": Added 28 Synopsis of R_IICr_Rx_RST function: Modified 28 Synopsis of R_IICr_Rx_RST function: Added 28 Explanation of R_IICr_Rx_RST function: Added 29 Name of function "R_IICr_TxDataST": Corrected 29 Synopsis of R_IICr_TxData function: Modified 29 Name of R_IICr_TxData function: Corrected 30 Name of R_IICr_TxData function: Corrected 30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait function 31 Name of INTIICr function: Modifed (mn -> r) 32 Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function 33 Declaration of R_IICr_Init function: Corrected 36 Name of R_IICr_Init function: Corrected 37 Name of R_device_select function: Corrected 48 Explanation of bits 5 and 4: Modified 49 "SDR01" was changed into "SDRmn" 40 Serial output enable register m (SOEm): Register name was Modified 40 Rame of Fig. 5.7: Modified 41 Buffer name was changed to g_data_bufferW2 42 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |  |  |  |  |  |  |
| Synopsis of R_IICr_Rx_RST function: Modified  28  Synopsis of R_IICr_RxData function: Added  28  Explanation of R_IICr_Rx_RST function: Added  29  Name of function "R_IICr_TxDataST": Corrected  29  Synopsis of R_IICr_TxData function: Modified  29  Name of R_IICr_TxData function: Corrected  30  Name of R_IICr_wait_bus function: Corrected  30  Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait_function  31  Name of IINTIICr function: Modifed (mn -> r)  32  Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function function of R_IICr_SCL_time function: Corrected  33  Declaration of R_IICr_Init function: Corrected  34  Name of R_device_select function: Corrected  45  Explanation of bits 5 and 4: Modified  46  Explanation of R_IICr_StopCond function function: Modifeid  46  Explanation of R_IICr_StopCond function function: Modifeid  47  Buffer name was changed to g_data_bufferW2  49  Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             |  |  |  |  |  |  |
| 28 Synopsis of R_IICr_RxData function: Added 28 Explanation of R_IICr_Rx_RST function: Added 29 Name of function "R_IICr_TxDataST": Corrected 29 Synopsis of R_IICr_TxData function: Modified 29 Name of R_IICr_TxData function: Corrected 30 Name of R_IICr_wait_bus function: Corrected 30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait function 31 Name of IINTIICr function: Modified (mn -> r) 32 Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function function for R_IICr_Init function: Corrected 33 Declaration of R_IICr_Init function: Corrected 34 Name of R_device_select function: Corrected 35 Name of R_device_select function: Corrected 46 Explanation of bits 5 and 4: Modified 47 Serial output enable register m (SOEm): Register name was Modified 48 Explanation of R_IICr_StopCond function function: Modified 49 Name of Fig. 5.7: Modified 40 Name of Fig. 5.7: Modified 41 Buffer name was changed to g_data_bufferW2 42 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |             |  |  |  |  |  |  |
| 28 Explanation of R_IICr_Rx_RST function: Added 29 Name of function "R_IICr_TxDataST": Corrected 29 Synopsis of R_IICr_TxData function: Modified 29 Name of R_IICr_TxData function: Corrected 30 Name of R_IICr_wait_bus function: Corrected 30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait_function 31 Name of IINTIICr function: Modified (mn -> r) 32 Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function of R_IICr_Init function: Corrected 33 Declaration of R_IICr_Init function: Corrected 43 Name of R_device_select function: Corrected 44 Explanation of bits 5 and 4: Modified 45 WSDR01" was changed into "SDRmn" 46 Serial output enable register m (SOEm): Register name was Modified 46 Name of Fig. 5.7: Modified 47 Buffer name was changed to g_data_bufferW2 49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |  |  |  |  |  |  |
| 29 Name of function "R_IICr_TxDataST": Corrected 29 Synopsis of R_IICr_TxData function: Modified 29 Name of R_IICr_TxData function: Corrected 30 Name of R_IICr_wait_bus function: Corrected 30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait function 31  Name of IINTIICr function: Modifed (mn -> r) 32  Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function: Corrected 33  Declaration of R_IICr_Init function: Corrected 34  Declaration of B_IICr_Init function: Corrected 35  Name of R_device_select function: Corrected 46  Explanation of bits 5 and 4: Modified 47  Serial output enable register m (SOEm): Register name was Modified 48  Explanation of R_IICr_StopCond function function: Modified 49  Name of Fig. 5.7: Modified 40  Name of Fig. 5.7: Modified 41  Buffer name was changed to g_data_bufferW2 42  Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |  |  |  |  |  |  |
| 29 Synopsis of R_IICr_TxData function: Modified 29 Name of R_IICr_TxData function: Corrected 30 Name of R_IICr_wait_bus function: Corrected 30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait_function 31 Name of IINTIICr function: Modified (mn -> r) 32 Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function: Corrected 33 Declaration of R_IICr_Init function: Corrected 34 Name of R_device_select function: Corrected 35 Variable register m (SOEm): Register name was Modified 46 Explanation of R_IICr_StopCond function function: Modified 47 Buffer name was changed to g_data_bufferW2 48 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |             |  |  |  |  |  |  |
| Name of R_IICr_TxData function: Corrected  Name of R_IICr_wait_bus function: Corrected  The solution of R_IICr_wait_bus function: Corrected  Name of R_IICr_wait_bus function: Corrected  In solution of R_IICr_StartCond function, and R_IICr_wait function  Resolution of R_IICr_StartCond function, and R_IICr_wait function: Modified (mn -> r)  Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function: Corrected  Name of R_device_select function: Corrected  Explanation of bits 5 and 4: Modified  Explanation of bits 5 and 4: Modified  Serial output enable register m (SOEm): Register name was Modified  Explanation of R_IICr_StopCond function function: Modified  Rame of Fig. 5.7: Modified  Name of Fig. 5.7: Modified  Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |             |  |  |  |  |  |  |
| 30 Name of R_IICr_wait_bus function: Corrected 30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wait function 32 Name of IINTIICr function: Modifed (mn -> r) 32 Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime funct Corrected 33 Declaration of R_IICr_Init function: Corrected 34 Name of R_device_select function: Corrected 45 Explanation of bits 5 and 4: Modified 46 Explanation of R_IICr_StopCond function function: Modified 47 Buffer name was changed to g_data_bufferW2 48 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |             |  |  |  |  |  |  |
| 30 Fonts Modified: Explanation in R_IICr_StartCond function, and R_IICr_wai function  32 Name of IINTIICr function: Modifed (mn -> r)  32 Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function corrected  33 Declaration of R_IICr_Init function: Corrected  37 Name of R_device_select function: Corrected  42 Explanation of bits 5 and 4: Modified  42 "SDR01" was changed into "SDRmn"  44 Serial output enable register m (SOEm): Register name was Modified  46 Explanation of R_IICr_StopCond function function: Modifeid  46 Name of Fig. 5.7: Modified  47 Buffer name was changed to g_data_bufferW2  49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |             |  |  |  |  |  |  |
| function  32 Name of IINTIICr function: Modifed (mn -> r)  32 Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function corrected  33 Declaration of R_IICr_Init function: Corrected  37 Name of R_device_select function: Corrected  42 Explanation of bits 5 and 4: Modified  42 "SDR01" was changed into "SDRmn"  44 Serial output enable register m (SOEm): Register name was Modified  46 Explanation of R_IICr_StopCond function function: Modifeid  46 Name of Fig. 5.7: Modified  47 Buffer name was changed to g_data_bufferW2  49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |  |  |  |  |  |  |
| Name of IINTIICr function: Modifed (mn -> r)  Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function: Corrected  33 Declaration of R_IICr_Init function: Corrected  Name of R_device_select function: Corrected  Explanation of bits 5 and 4: Modified  22 "SDR01" was changed into "SDRmn"  44 Serial output enable register m (SOEm): Register name was Modified  46 Explanation of R_IICr_StopCond function function: Modifeid  46 Name of Fig. 5.7: Modified  47 Buffer name was changed to g_data_bufferW2  49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | _bus        |  |  |  |  |  |  |
| Declaration of R_IICr_SCL_Time function and R_IICr_SCL_highTime function:  Corrected  33 Declaration of R_IICr_Init function: Corrected  37 Name of R_device_select function: Corrected  42 Explanation of bits 5 and 4: Modified  42 "SDR01" was changed into "SDRmn"  44 Serial output enable register m (SOEm): Register name was Modified  46 Explanation of R_IICr_StopCond function function: Modifeid  46 Name of Fig. 5.7: Modified  47 Buffer name was changed to g_data_bufferW2  49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |             |  |  |  |  |  |  |
| 33 Declaration of R_IICr_Init function: Corrected  37 Name of R_device_select function: Corrected  42 Explanation of bits 5 and 4: Modified  42 "SDR01" was changed into "SDRmn"  44 Serial output enable register m (SOEm): Register name was Modified  46 Explanation of R_IICr_StopCond function function: Modifeid  46 Name of Fig. 5.7: Modified  47 Buffer name was changed to g_data_bufferW2  49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | on:         |  |  |  |  |  |  |
| 37 Name of R_device_select function: Corrected  42 Explanation of bits 5 and 4: Modified  42 "SDR01" was changed into "SDRmn"  44 Serial output enable register m (SOEm): Register name was Modified  46 Explanation of R_IICr_StopCond function function: Modifeid  46 Name of Fig. 5.7: Modified  47 Buffer name was changed to g_data_bufferW2  49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |  |  |  |  |  |  |
| 42 Explanation of bits 5 and 4: Modified 42 "SDR01" was changed into "SDRmn" 44 Serial output enable register m (SOEm): Register name was Modified 46 Explanation of R_IICr_StopCond function function: Modifeid 46 Name of Fig. 5.7: Modified 47 Buffer name was changed to g_data_bufferW2 49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             |  |  |  |  |  |  |
| 42 "SDR01" was changed into "SDRmn"  44 Serial output enable register m (SOEm): Register name was Modified  46 Explanation of R_IICr_StopCond function function: Modifeid  46 Name of Fig. 5.7: Modified  47 Buffer name was changed to g_data_bufferW2  49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |             |  |  |  |  |  |  |
| 44 Serial output enable register m (SOEm): Register name was Modified 46 Explanation of R_IICr_StopCond function function: Modified 46 Name of Fig. 5.7: Modified 47 Buffer name was changed to g_data_bufferW2 49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |  |  |  |  |  |  |
| 46 Explanation of R_IICr_StopCond function function: Modifeid 46 Name of Fig. 5.7: Modified 47 Buffer name was changed to g_data_bufferW2 49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |             |  |  |  |  |  |  |
| 47 Buffer name was changed to g_data_bufferW2 49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |             |  |  |  |  |  |  |
| 49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |  |  |  |  |  |  |
| 49 Variable name: Corrected to g_eeprom_type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |  |  |  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             |  |  |  |  |  |  |
| 52,53 Bits 11 to 8: Modified                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |  |  |  |  |  |  |
| 53 Fig. 5.13: Correction (Flow chart part)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |             |  |  |  |  |  |  |
| 53 Fig. 5.13: Correction (Explanation part)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |             |  |  |  |  |  |  |
| 56 Explanation of return: Modified                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |             |  |  |  |  |  |  |
| 63 Fig 5.22: Corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |             |  |  |  |  |  |  |
| 69 Function name was modified to R_IICr_TxData                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |             |  |  |  |  |  |  |
| 2014.5.16 -3 22 R_EEPROM_wait_write function: Added to variable g_PARAA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |  |  |  |  |  |  |
| 24 Outlline of IINTTM02 function: Modified                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ·           |  |  |  |  |  |  |
| 25,30 Function Specifications of R_IICr_StopCond function were redundant, so needless one was deleted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |             |  |  |  |  |  |  |
| 67 Modification of Fig. 5.28 (Addition of a process)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |  |  |  |  |  |  |
| 69 Modification of Fig. 5.31 (Sequence of processes)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             |  |  |  |  |  |  |

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

## **General Precautions in the Handling of MPU/MCU Products**

The following usage notes are applicable to all MPU/MCU products from Renesas. For detailed usage notes on the products covered by this manual, refer to the relevant sections of the manual. If the descriptions under General Precautions in the Handling of MPU/MCU Products and in the body of the manual differ from each other, the description in the body of the manual takes precedence.

### 1. Handling of Unused Pins

- Handle unused pins in accord 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 unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of LSI, an associated shoot-through current flows internally, and malfunctions occur due to the false recognition of the pin state as an input signal become possible. Unused pins should be handled as described under Handling of Unused Pins in the manual.

### 2. Processing at Power-on

- The state of the product is undefined at the moment when power is supplied.
  - The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the moment when power is supplied.
     In a finished product where the reset signal is applied to the external reset pin, the states of pins are not guaranteed from the moment when power is supplied until the reset process is completed.
     In a similar way, the states of pins in a product that is reset by an on-chip power-on reset function are not guaranteed from the moment when power is supplied until the power reaches the level at which resetting has been specified.
- 3. Prohibition of Access to Reserved Addresses
- Access to reserved addresses is prohibited.
  - The reserved addresses are provided for the possible future expansion of functions. Do not access these addresses; the correct operation of LSI is not guaranteed if they are accessed.
- 4. Clock Signals
- After applying a reset, only release the reset line after the operating clock signal has become stable.
   When switching the clock signal during program execution, wait until the target clock signal has stabilized.
  - When the clock signal is generated with an external resonator (or from an external oscillator) during a reset, ensure that the reset line is only released after full stabilization of the clock signal. Moreover, when switching to a clock signal produced with an external resonator (or by an external oscillator) while program execution is in progress, wait until the target clock signal is stable.
- 5. Differences between Products
- Before changing from one product to another, i.e. to one with a different part number, confirm that the change will not lead to problems.
  - The characteristics of MPU/MCU in the same group but having different part numbers may differ because of the differences in internal memory capacity and layout pattern. When changing to products of different part numbers, implement a system-evaluation test for each of the products.

#### Notice

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

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

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



### **SALES OFFICES**

Renesas Electronics Corporation

http://www.renesas.com

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

Renesas Electronics America Inc.
2880 Scott Boulevard Santa Clara, CA 95050-2554, U.S.A.
Tel: +1-408-588-6000, Fax: +1-408-588-6130
Renesas Electronics Canada Limited
1101 Nicholson Road, Newmarket, Ontario L3Y 9C3, Canada
Tel: +1-905-898-5441, Fax: +1-905-898-3220

Renesas Electronics Europe Limited Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K Tei: +44-1628-651-700, Fax: +44-1628-651-804

Renesas Electronics Europe GmbH

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

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

Renesas Electronics (Shanghai) Co., Ltd. Unit 301, Tower A, Central Towers, 555 LanGao Rd., Putuo District, Shanghai, China Tei: +86-21-2226-0888, Fax: +86-21-2226-0999

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

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

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

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

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

© 2014 Renesas Electronics Corporation. All rights reserved.