

# RL78/G13

Low-power Consumption Operation (UART in SNOOZE Mode)

R01AN0742EJ0200 Rev. 2.00 Dec.1, 2013

# Introduction

This application note explains how to make low power consumption settings for UART reception in SNOOZE mode. The sample application covered in this application note uses the SNOOZE mode to receive data through the UART communication without starting the CPU. The application judges the receive data and displays the result on an LED.

# **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.   | Sp   | pecifications                                     |    |
|------|------|---------------------------------------------------|----|
| 2.   | Oj   | peration Check Conditions                         | 6  |
| 3.   | Re   | elated Application Notes                          | 6  |
| 4.   | De   | escription of the Hardware                        | 7  |
| 4.1  | Ha   | ardware Configuration Example                     | 7  |
| 4.2  | Li   | ist of Pins to be Used                            | 8  |
| 5.   |      | oftware Description                               |    |
| 5.1  | Ol   | peration Outline                                  | 9  |
| 5.2  | Li   | ist of Option Byte Settings                       | 10 |
| 5.3  | Li   | ist of Constants                                  | 10 |
| 5.4  | Li   | ist of Variables                                  | 11 |
| 5.5  | Li   | ist of Functions                                  | 11 |
| 5.6  | Fu   | unction Specifications                            | 12 |
| 5.7  |      | lowcharts                                         |    |
| 5.7. | 1    | Initialization Function                           | 15 |
| 5.7. | .2   | System Initialization function                    |    |
| 5.7. | 3    | I/O Port Setup                                    | 17 |
| 5.7. | .4   | CPU Clock Setup                                   | 19 |
| 5.7. | 5    | SAU0 Setup                                        |    |
| 5.7. | 6    | UART0 Setup                                       |    |
| 5.7. | .7   | Setting up Interrupts                             |    |
| 5.7. | .8   | Main Processing                                   | 40 |
| 5.7. | .9   | Enabling UART0 Operation in SNOOZE Mode           | 42 |
| 5.7. | 10   | Disabling UART0 Operation in SNOOZE Mode          |    |
| 5.7. | 11   | Starting UART0 Reception                          |    |
| 5.7. | 12   | Stopping UART Reception                           | 47 |
| 5.7. | .13  | Setting up UART0 Receive Buffer                   |    |
| 5.7. | 14   | Starting INTP0 Operation                          |    |
| 5.7. | .15  | Stopping INTP0                                    |    |
| 5.7. | .16  | Getting UART0 Receive Data                        |    |
| 6.   | Sa   | ample Code                                        |    |
| 7.   | Do   | ocuments for Reference                            |    |
| Revi | sio  | n Record                                          |    |
| Gene | eral | l Precautions in the Handling of MPU/MCU Products |    |



# 1. Specifications

Table 1.1

This application note explains how to make low power consumption settings for UART reception operation in SNOOZE mode. The sample application covered in this application note sets up the serial array unit (SAU) for UART reception and enables the SNOOZE mode. Subsequently, it executes the STOP instruction. When an input is detected at the RxDq pin in STOP mode, the application starts data reception in SNOOZE mode. It compares the data received via UART with the predefined data and turns on an LED if a match is found and off the LED otherwise.

Note: The SNOOZE mode can be enabled only when the high-speed on-chip oscillator clock is selected as the source of the CPU/peripheral hardware clock ( $f_{CLK}$ ).

Table 1.1 lists the peripheral functions to be used and their uses. Figure 1.1 shows the outline of the operation of the sample code.



Peripheral Functions to be Used and their Uses



Figure 1.1 Outline of Operation



Figure 1.2 shows the outline of UART reception in SNOOZE mode. The HALT mode is generally used to receive data via a UART. When a device which supports the SNOOZE mode is to be used, the STOP mode which supports lower operating current than the HALT mode is available in addition to the HALT mode. In UART reception in SNOOZE mode, the application switches from STOP mode to SNOOZE mode upon detection of the falling edge of the RxD0 signal and performs data reception via a UART0 without starting the CPU. If an error occurs during reception, the application returns to the STOP mode and waits for the next data. If the data reception is successful without an error, the application exits the SNOOZE mode and starts the CPU.

The actions that the application are to take when a receive error occurs can be configured using the SSECm bits. The sample code covered in this application note make settings so that it returns to the STOP mode when a receive error occurs as shown in figure 1.2. The SNOOZE mode can be configured only when the high-speed on-chip oscillator clock is selected as the source of the CPU/peripheral hardware clock ( $f_{CLK}$ ).



Figure 1.2 Outline of UART Receive Operation in SNOOZE Mode



Figure 1.3 shows the timing chart for the SNOOZE mode operation.



#### Figure 1.3 Timing Chart of SNOOZE Mode Operation



# 2. Operation Check Conditions

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

| Item                                  | Description                                                                                                               |  |
|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------|--|
| Microcontroller used                  | RL78/G13 (R5F100LEA)                                                                                                      |  |
| Operating frequency                   | <ul> <li>High-speed on-chip oscillator (HOCO) clock: 32 MHz</li> <li>CPU/peripheral hardware clock: 32 MHz</li> </ul>     |  |
| Operating voltage                     | 5.0V (can run on a voltage range of 2.9 V to 5.5 V.)<br>LVD operation ( $V_{LVI}$ ): Reset mode 2.81 V (2.76 V to 2.87 V) |  |
| Integrated development<br>environment | CubeSuite+ V1.00.01 from Renesas Electronics Corp.                                                                        |  |
| C compiler                            | CA78K0R V1.20 from Renesas Electronics Corp.                                                                              |  |

| Table 2.1 Operation Check Condition |
|-------------------------------------|
|-------------------------------------|

# 3. Related Application Notes

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

RL78/G13 Initialization (R01AN0451E) Application Note RL78/G13 Serial Array Unit (UART Communication) (R01AN0459E) Application Note



### 4. Description of the Hardware

### 4.1 Hardware Configuration Example

Figure 4.1 shows an example of the hardware configuration 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.

| Pin Name   | I/O    | Description                         |
|------------|--------|-------------------------------------|
| P11/RxD0   | Input  | UART0 receive input pin             |
| P137/INTP0 | Input  | UART0 reception start trigger input |
| P00        | Output | LED1 lighting control port          |
| P01        | Output | LED2 lighting control port          |

#### Table 4.1 Pins to be Used and their Functions



# 5. Software Description

# 5.1 Operation Outline

The sample application covered in this application note receives data via UART in SNOOZE mode, compares the receive data with the predefined data value, and turns on an LED when these data are matched.

The application turns on LED1 and waits for a switch input. If a switch input is present, the application turns off LED1 and LED2, sets UART reception and the SNOOZE mode, and then transitions to the STOP mode. When an input is detected at the RxD0 pin after switching to the STOP mode, the application starts UART reception in SNOOZE mode. The CPU returns to the normal operation mode if the reception is successful and returns to the STOP mode if a UART receive error is detected. After returning to the normal operation mode, the application turns on LED2 if the receive data is 0.

(1) Initialize the SAU0.

<Conditions for setting>

- Use the SAU0 in UART mode, receive only.
- Use even parity as the parity setting.
- Set the data transfer order to LSB first.
- Set the transfer data size to 8 bits.
- Use one stop bit.
- Set the receive data level to standard.
- Set the transfer rate to 4800 bps.
- Set P11 to the RxD0 pin.
- Set the priority level of the INTSR0 and INTSRE0 interrupts to the lowest level.
- Use the UART reception transfer end interrupt (INTSR0) as the interrupt source.

#### (2) Set up I/O ports

<Conditions for setting>

- LED lighting control ports (LED1 and LED2): Set ports P00 and P01 to output ports.
- UARTO reception start switch: Set the P137/INTPO pin for INTPO interrupts in falling edge detection mode (using an external pull-up resistor).
- (3) Turn on LED1, transition to HALT mode, and wait for a switch input.
- (4) In the presence of a switch input, exit the HALT mode, turn off LED1 and LED2, and set up the UART and SNOOZE mode.
- Disable error interrupts and enable the startup of reception in STOP mode.
- Enable INTSR0 interrupts and transition to the communication wait status.
- (5) Transition to STOP mode and wait for the completion of the UART reception.

The UART reception is carried out by hardware in STOP mode. When a start bit (RxD0 pin input) is detected, a UART reception is started in SNOOZE mode. When the reception ends successfully, the application transitions to the normal operation mode and performs the step (6). If a receive error occurs, the application transitions to STOP mode and waits for a start bit again.

- (6) Read the receive data after switching into normal operation mode.
- (7) Stop the UART operation and disable the transition to SNOOZE mode.
- Disable INTSR0 interrupts and stop communication operation.
- Enable error interrupts and disable the startup of reception in STOP mode.

(8) Confirm the receive data and turn on LED2 if a 0 is received. Subsequently, repeats steps (3) through (8).

Caution: For information about the precautions in using the device, refer to RL78/G13 User's Manual: Hardware.



# 5.2 List of Option Byte Settings

Table 5.1 summarizes the settings of the option bytes.

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

### Table 5.1 Option Byte Settings

# 5.3 List of Constants

Table 5.2 list the constants that are used in this sample program.

| Constant                   | Setting | Description                                                                                 |
|----------------------------|---------|---------------------------------------------------------------------------------------------|
| _0002_SAU_CH1_START_TRG_ON | 0x0002  | Serial channel enable status register 0 (SE0) value for<br>enabling communication operation |
| _0002_SAU_CH1_STOP_TRG_ON  | 0x0002  | Serial channel stop register 0 (ST0) value for stopping communication operation             |
| MD_OK                      | 0x00    | Successful reception state                                                                  |
| MD_ARGERROR                | 0x81    | Error state                                                                                 |
| LED1_NOMAL                 | P0.0    | LED1 lighting control port                                                                  |
| LED2_RCV_0                 | P0.1    | LED2 lighting control port                                                                  |

 Table 5.2
 Constants for the Sample Program



# 5.4 List of Variables

Table 5.3 lists the global variable that is used by this sample program.

| Туре              | Variable Name      | Contents                            | Function Used             |
|-------------------|--------------------|-------------------------------------|---------------------------|
| volatile uint16_t | g_Uart0RxCnt       | Number of UART data bytes           | R_UART0_Receive           |
|                   |                    | received                            | R_UART0_Interrupt_Receive |
| volatile uint16_t | g_Uart0RxLen       | Number of UART data bytes to be     | R_UART0_Receive           |
|                   |                    | received                            | R_UART0_Interrupt_Receive |
| volatile uint8_t  | *gp_Uart0RxAddress | Address of location for storing the | R_UART0_Receive           |
|                   |                    | UART data to be received next       | R_UART0_Interrupt_Receive |
|                   |                    |                                     | R_UART0_Interrupt_Error   |
|                   |                    |                                     | R_UART0_GetRxData         |

Table 5.3Global Variable

# 5.5 List of Functions

Table 5.4 lists the functions that are used in this sample program.

| Function Name     | Outline                         |
|-------------------|---------------------------------|
| R_SAU0_SnoozeOn   | Enabling UART0 for SNOOZE mode  |
| R_SAU0_SnoozeOff  | Disabling UART0 for SNOOZE mode |
| R_UART0_Start     | Starting UART0 reception        |
| R_UART0_Stop      | Stopping UART0 reception        |
| R_UART0_Receive   | Setting UART0 receive buffer    |
| R_INTC0_Start     | Starting INTP0 operation        |
| R_INTC0_Stop      | Stopping INTP0 operation        |
| R_UART0_GetRxData | Getting UART0 receive data      |

Table 5.4 Functions



# 5.6 Function Specifications

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

#### [Function Name] R\_SAU0\_SnoozeOn

| Synopsis     | Enabling UART0 for SNOOZE mode                |
|--------------|-----------------------------------------------|
| Header       | r_cg_serial.h                                 |
| Declaration  | void R_SAU0_SnoozeOn(void)                    |
| Explanation  | This function enables SNOOZE mode (SWC0 = 1). |
| Arguments    | None                                          |
| Return value | None                                          |
| Remarks      | None                                          |

[Function Name] R\_SAU0\_SnoozeOff

| Synopsis     | Disabling UART0 for SNOOZE mode                |
|--------------|------------------------------------------------|
| Header       | r_cg_serial.h                                  |
| Declaration  | void R_SAU0_SnoozeOff(void)                    |
| Explanation  | This function disables SNOOZE mode (SWC0 = 0). |
| Arguments    | None                                           |
| Return value | None                                           |
| Remarks      | None                                           |
|              |                                                |

#### [Function Name] R\_UART0\_Start

| Synopsis     | Starting UART0 reception                                                       |
|--------------|--------------------------------------------------------------------------------|
| Header       | r_cg_serial.h                                                                  |
| Declaration  | void R_UART0_Start(void)                                                       |
| Explanation  | This function resets UART0 reception interrupt mask to enable UART0 reception. |
| Arguments    | None                                                                           |
| Return value | None                                                                           |
| Remarks      | None                                                                           |
|              |                                                                                |

#### [Function Name] R\_UART0\_Stop

|              | •                                                                             |
|--------------|-------------------------------------------------------------------------------|
| Synopsis     | Stopping UART0 reception                                                      |
| Header       | r_cg_serial.h                                                                 |
| Declaration  | void R_UART0_Stop(void)                                                       |
| Explanation  | This function sets UART0 reception interrupt mask to disable UART0 reception. |
| Arguments    | None                                                                          |
| Return value | None                                                                          |
| Remarks      | None                                                                          |
|              |                                                                               |



### RL78/G13

| Synopsis     | Setting UART0 receive buff  | er                                                                |
|--------------|-----------------------------|-------------------------------------------------------------------|
| Header       | r_cg_macrodriver.h          |                                                                   |
| Declaration  | MD_STATUS R_UART0_R         | eceive(uint8_t *rxbuf, uint16_t rxnum)                            |
| Explanation  | This function sets the UAR  | T receive buffer address and the number of data bytes to receive. |
|              | An argument error is return | ed if the receive data count is set to not more than 1.           |
| Arguments    | rxbuf                       | Address of receive data buffer                                    |
| Return value | rxnum                       | Number of data bytes to receive                                   |
| Remarks      | [MD_OK]: Setup completed    |                                                                   |
|              | [MD_ARGERROR]: Argum        | ent error                                                         |
| Synopsis     | None                        |                                                                   |
|              |                             |                                                                   |

#### [Function Name] R\_UART0\_Receive

#### [Function Name] R\_INTC0\_Start

| Synopsis     | Starting INTP0 operation                   |
|--------------|--------------------------------------------|
| Header       | None                                       |
| Declaration  | void R_INTC0_Start(void)                   |
| Explanation  | This function resets INTP0 interrupt mask. |
| Arguments    | None                                       |
| Return value | None                                       |
| Remarks      | None                                       |
|              |                                            |

#### [Function Name] R\_INTC0\_Stop

| - |              |                                          |
|---|--------------|------------------------------------------|
|   | Synopsis     | Stopping INTP0 operation                 |
|   | Header       | None                                     |
|   | Declaration  | void R_INTC0_Stop(void)                  |
|   | Explanation  | This function sets INTP0 interrupt mask. |
|   | Arguments    | None                                     |
|   | Return value | None                                     |
|   | Remarks      | None                                     |
|   |              |                                          |

#### [Function Name] R\_UART0\_GetRxData

|              | —                                                                                |
|--------------|----------------------------------------------------------------------------------|
| Synopsis     | Getting UART0 receive data                                                       |
| Header       | None                                                                             |
| Declaration  | void R_UART0_GetRxData(void)                                                     |
| Explanation  | This function stores the UART receive data in the buffer set by R_UART0_Receive. |
| Arguments    | None                                                                             |
| Return value | None                                                                             |
| Remarks      | None                                                                             |



# 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



# 5.7.2 System Initialization function

Figure 5.3 shows the flowchart for the system initialization function.



Figure 5.3 System Initialization Function



# 5.7.3 I/O Port Setup

Figure 5.4 shows the flowchart for setting up the I/O ports.



Figure 5.4 I/O Port Setup

- Note: Refer to the section entitled "Flowcharts" in RL78/G13 Initialization Application Note (R01AN0451E) for the configuration of the unused ports.
- Caution: Provide proper treatment for unused pins so that their electrical specifications are met. Connect each of any unused input-only ports to  $V_{DD}$  or  $V_{SS}$  via a separate resistor.



Setting to turn off LEDs

- Port register 0 (P0) Set up LED lighting control port for inactive output.
- Port mode register 1 (PM0)
   Select LED output mode of lighting control port

Symbol: P0

| 7   | 6 5 |     | 4       | 3 2 |     | 1   | 0   |  |
|-----|-----|-----|---------|-----|-----|-----|-----|--|
| P07 | P06 | P05 | P04 P03 |     | P02 | P01 | P00 |  |
| х   | х   | х   | х       | х   | х   | 1   | 1   |  |

Bits 1 and 0  $\,$ 

| P00, P01 | P00 and P01 output selection |
|----------|------------------------------|
| 0        | Output low level (LED on)    |
| 1        | Output high level (LED off)  |

#### Symbol: PM0

| 7    | 6 5       |   | 4    | 3    | 2    | 1    | 0    |
|------|-----------|---|------|------|------|------|------|
| PM07 | PM06 PM05 |   | PM04 | PM03 | PM02 | PM01 | PM00 |
| х    | х         | х | х    | х    | х    | 0    | 0    |

Bits 1 and 0

| PM00,<br>PM01 | PM00 and PM01 I/O mode selection |
|---------------|----------------------------------|
| 0             | Output mode (output buffer on)   |
| 1             | Input mode (output buffer off)   |



### 5.7.4 CPU Clock Setup

Figure 5.5 shows the flowchart for setting up the CPU clock



Caution: For details on the procedure for setting up the CPU clock (R\_CGC\_Create ()), refer to the section entitled "Flowcharts" in RL78/G13 Initialization Application Note (R01AN0451E).



### 5.7.5 SAU0 Setup

Figure 5.6 shows the flowchart for setting up the SAU0.



Caution: For details on the procedure for setting up the SAU0 (R\_SAU0\_Create ()), refer to the section entitled "Flowcharts" in RL78/G13 Serial Array Unit (UART Communication) Application Note (R01AN0459E).



Starting supplying clock to the SAU0

• Peripheral enable register 0 (PER0) Start supplying clock to SAU0.

Symbol: PER0

| 7     | 6       | 5     | 4             | 3 | 2             | 1 | 0      |  |
|-------|---------|-------|---------------|---|---------------|---|--------|--|
| RTCEN | IICA1EN | ADCEN | ADCEN IICA0EN |   | SAU1EN SAU0EN |   | TAU0EN |  |
| х     | х       | х     | х             | х | 1             | х | х      |  |

Bit 2

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



Setting serial clock

• Serial clock select register (SPS0) Operation clock (CK00 = 2 MHz).

Symbol: SPS0

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

Bits 3 to 0

|        |        |        |        |                         | Selection of operation clock (CK00) |                             |                              |                             |                              |  |  |
|--------|--------|--------|--------|-------------------------|-------------------------------------|-----------------------------|------------------------------|-----------------------------|------------------------------|--|--|
| PRS003 | PRS002 | PRS001 | PRS000 |                         | 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> =<br>2 MHz | f <sub>CLK</sub> =<br>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 <sub>CLK</sub> /2⁴    | 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_{CLK}/2^6$           | 31.3 kHz                            | 78.1 kHz                    | 156 kHz                      | 313 kHz                     | 500 kHz                      |  |  |
| 0      | 1      | 1      | 1      | $f_{CLK}/2^7$           | 15.6 kHz                            | 39.1 kHz                    | 78.1 kHz                     | 156 kHz                     | 250 kHz                      |  |  |
| 1      | 0      | 0      | 0      | $f_{CLK}/2^8$           | 7.81 kHz                            | 19.5 kHz                    | 39.1 kHz                     | 78.1 kHz                    | 125 kHz                      |  |  |
| 1      | 0      | 0      | 1      | $f_{CLK}/2^9$           | 3.91 kHz                            | 9.77 kHz                    | 19.5 kHz                     | 39.1 kHz                    | 62.5 kHz                     |  |  |
| 1      | 0      | 1      | 0      | $f_{CLK}/2^{10}$        | 1.95 kHz                            | 4.88 kHz                    | 9.77 kHz                     | 19.5 kHz                    | 31.3 kHz                     |  |  |
| 1      | 0      | 1      | 1      | $f_{CLK}/2^{11}$        | 977 Hz                              | 2.44 kHz                    | 4.88 kHz                     | 9.77 kHz                    | 15.6 kHz                     |  |  |
| 1      | 1      | 0      | 0      | $f_{\text{CLK}}/2^{12}$ | 488 Hz                              | 1.22 kHz                    | 2.44 kHz                     | 4.88 kHz                    | 7.81 kHz                     |  |  |
| 1      | 1      | 0      | 1      | $f_{\text{CLK}}/2^{13}$ | 244 Hz                              | 610 Hz                      | 1.22 kHz                     | 2.44 kHz                    | 3.91 kHz                     |  |  |
| 1      | 1      | 1      | 0      | $f_{\text{CLK}}/2^{14}$ | 122 Hz                              | 305 Hz                      | 610 Hz                       | 1.22 kHz                    | 1.95 kHz                     |  |  |
| 1      | 1      | 1      | 1      | $f_{\text{CLK}}/2^{15}$ | 61 Hz                               | 153 Hz                      | 305 Hz                       | 610 Hz                      | 977 Hz                       |  |  |



### 5.7.6 UART0 Setup

Figure 5.7 shows the flowcharts for setting up the UARTO.



Figure 5.7 UART0 Setup

Caution: For details on the procedure for setting up the UART0 (R\_UART0\_Create ()), refer to the section entitled "Flowcharts" in RL78/G13 Serial Array Unit (UART Communication) Application Note (R01AN0459E).



Stopping serial channel 0

• Serial channel stop register 0 (ST0) Stop serial channel 1 communication.

Symbol: ST0

| 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 | ST03 | ST02 | ST01 | ST00 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    | 1    | 0    |

#### Bits 3 to 0

| ST01 | Operation stop trigger of channel                     |
|------|-------------------------------------------------------|
| 0    | No trigger operation                                  |
| 1    | Clears the SE01 bit to 0 and stops the communication. |



Initializing UART interrupt control

- Interrupt request flag register (IF0H) Clear interrupt request flag.
- Interrupt mask flag register (MK0H) Clear interrupt mask.

Symbol: IF0H

| 7                 | 6                           | 5                           | 4      | 3      | 2                 | 1                           | 0                           |
|-------------------|-----------------------------|-----------------------------|--------|--------|-------------------|-----------------------------|-----------------------------|
| SREIF0<br>TMIF01H | SRIF0<br>CSIIF01<br>IICIF01 | STIF0<br>CSIIF00<br>IICIF00 | DMAIF1 | DMAIF0 | SREIF2<br>TMIF11H | SRIF2<br>CSIIF21<br>IICIF21 | STIF2<br>CSIIF20<br>IICIF20 |
| 0                 | 0                           | 0                           | х      | х      | х                 | х                           | х                           |

Bit 5

| STIF0                                      | Interrupt request flag                                   |  |  |  |  |  |
|--------------------------------------------|----------------------------------------------------------|--|--|--|--|--|
| 0 No interrupt request signal is generated |                                                          |  |  |  |  |  |
| 1                                          | Interrupt request is generated, interrupt request status |  |  |  |  |  |

Bit 6

| SRIF0 | Interrupt request flag                                   |  |  |  |  |  |
|-------|----------------------------------------------------------|--|--|--|--|--|
| 0     | 0 No interrupt request signal is generated               |  |  |  |  |  |
| 1     | Interrupt request is generated, interrupt request status |  |  |  |  |  |

Bit 7

| SREIF0 | Interrupt request flag                                   |  |  |  |  |  |
|--------|----------------------------------------------------------|--|--|--|--|--|
| 0      | No interrupt request signal is generated                 |  |  |  |  |  |
| 1      | Interrupt request is generated, interrupt request status |  |  |  |  |  |



Symbol: MKH

| 7                 | 6                           | 5                           | 4      | 3      | 2                 | 1                           | 0                           |
|-------------------|-----------------------------|-----------------------------|--------|--------|-------------------|-----------------------------|-----------------------------|
| SREMK0<br>TMMK01H | SRMK0<br>CSIMK01<br>IICMK01 | STMK0<br>CSIMK00<br>IICMK00 | DMAMK1 | DMAMK0 | SREMK2<br>TMMK11H | SRMK2<br>CSIMK21<br>IICMK21 | STMK2<br>CSIMK20<br>IICMK20 |
| 1                 | 1                           | 1                           | х      | х      | х                 | x                           | х                           |

Bit 5

| STMK0 | Interrupt processing control  |
|-------|-------------------------------|
| 0     | Interrupt processing enabled  |
| 1     | Interrupt processing disabled |

Bit 6

| SRMK0 | Interrupt processing control  |
|-------|-------------------------------|
| 0     | Interrupt processing enabled  |
| 1     | Interrupt processing disabled |

Bit 7

| SREMK0 | Interrupt processing control  |
|--------|-------------------------------|
| 0      | Interrupt processing enabled  |
| 1      | Interrupt processing disabled |



Setting interrupt priorities

• Priority specification flag registers (PR00H, PR10H) Clear interrupt request flags.

Symbol: PR00H

| 7                   | 6                              | 5                              | 4       | 3       | 2                   | 1                              | 0                              |
|---------------------|--------------------------------|--------------------------------|---------|---------|---------------------|--------------------------------|--------------------------------|
| SREPR00<br>TMPR001H | SRPR00<br>CSIPR001<br>IICPR001 | STPR00<br>CSIPR000<br>IICPR000 | DMAPR01 | DMAPR00 | SREPR02<br>TMPR011H | SRPR02<br>CSIPR021<br>IICPR021 | STPR02<br>CSIPR020<br>IICPR020 |
| 1                   | 1                              | х                              | х       | х       | х                   | х                              | х                              |

Symbol: PR10H

| 7                   | 6        | 5                              | 4       | 3       | 2                   | 1                              | 0                              |
|---------------------|----------|--------------------------------|---------|---------|---------------------|--------------------------------|--------------------------------|
| SREPR10<br>TMPR101H | CSIPR101 | STPR10<br>CSIPR100<br>IICPR100 | DMAPR11 | DMAPR10 | SREPR12<br>TMPR111H | SRPR12<br>CSIPR121<br>IICPR121 | STPR12<br>CSIPR120<br>IICPR120 |
| 1                   | 1        | х                              | х       | х       | х                   | х                              | х                              |

Bit 6

| SRPR10 | SRPR00 | Priority level selection        |
|--------|--------|---------------------------------|
| 0      | 0      | Specify level 0 (highest level) |
| 0      | 1      | Specify level 1                 |
| 1      | 0      | Specify level 2                 |
| 1      | 1      | Specify level 3 (lowest level)  |

Bit 7

| SREPR10 | SREPR00 | Priority level selection        |
|---------|---------|---------------------------------|
| 0       | 0       | Specify level 0 (highest level) |
| 0       | 1       | Specify level 1                 |
| 1       | 0       | Specify level 2                 |
| 1       | 1       | Specify level 3 (lowest level)  |



Clearing error flags

• Serial flag clear trigger register 01 (SIR01) Clear error information of channel 1.

Symbol: SIR01

| 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 0

| FECT01 | Clear trigger of framing error of channel 1      |
|--------|--------------------------------------------------|
| 0      | Not cleared                                      |
| 1      | Clears the FEF01 bit of the SSR01 register to 0. |

Bit 1

| PECT01 | Clear trigger of parity error of channel 1       |
|--------|--------------------------------------------------|
| 0      | Not cleared                                      |
| 1      | Clears the PEF01 bit of the SSR01 register to 0. |

Bit 2

| OVCT01 | Clear trigger of overrun error of channel 1      |
|--------|--------------------------------------------------|
| 0      | Not cleared                                      |
| 1      | Clears the OVF01 bit of the SSR01 register to 0. |



Setting up noise filter for RxD0 pin

• Noise filter enable register 0 (NFEN0) Turn on channel 0 noise filter.

Symbol: NFEN0

| 7 | 6       | 5 | 4       | 3 | 2       | 1 | 0       |
|---|---------|---|---------|---|---------|---|---------|
| 0 | SNFEN30 | 0 | SNFEN20 | 0 | SNFEN10 | 0 | SNFEN00 |
| 0 | x       | 0 | х       | 0 | х       | 0 | 1       |

Bit 0

| 0 | Use of noise filter of RxD0 pin<br>Noise filter OFF |
|---|-----------------------------------------------------|
| 1 | Noise filter ON                                     |



Setting up operation mode

Serial mode register 00 (SMR00)
 Operation clock (f<sub>MCK</sub>): Operation clock CK00 set by SPS0 register
 Transfer clock (f<sub>TCLK</sub>): Divided operation clock f<sub>MCK</sub> specified by CKS00 bit
 Operation mode: Select UART.
 Interrupt source: Select transfer end interrupt.

#### Symbol: SMR00

| 15       | 14    |    | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2         | 1         | 0         |
|----------|-------|----|----|----|----|----|---|---|---|---|---|---|---|-----------|-----------|-----------|
| CK5<br>0 | 0 CCS | 60 | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 1 | 0 | 0 | MD00<br>2 | MD00<br>1 | MD00<br>0 |
| 0        | 0     |    | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0         | 1         | 0         |

Bit 15

| CKS00 | Selection of operation clock $(f_{MCK})$ of channel 0 |
|-------|-------------------------------------------------------|
| 0     | Operation clock CK00 set by the SPS0 register         |
| 1     | Operation clock CK01 set by the SPS0 register         |

Bit 14

| CCS00 | Selection of transfer clock ( $f_{TCLK}$ ) of channel 0               |
|-------|-----------------------------------------------------------------------|
| 0     | Divided operation clock f <sub>MCK</sub> specified by the CKS00 bit   |
| 1     | Clock input $f_{SCK}$ from the SCK00 pin (slave transfer in CSI mode) |

Bits 2 and 1

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

Bit 0

| MD000 | Selection of interrupt source of channel 0                            |
|-------|-----------------------------------------------------------------------|
| 0     | Transfer end interrupt                                                |
|       | Buffer empty interrupt                                                |
| 1     | (Occurs when data is transferred from the SDR00 register to the shift |
|       | register.)                                                            |



Setting up operation mode

Serial mode register 01 (SMR01)
 Operation clock (f<sub>MCK</sub>): Operation clock CK00 set by SPS0 register
 Transfer clock (f<sub>TCLK</sub>): Divided operation clock f<sub>MCK</sub> specified by CKS00 bit
 Start trigger source: Select valid edge of the RxD0 pin.
 Start bit detection and data inversion: Select start bit on detection of a falling edge
 Capture the input communication data as is.
 Operation mode: Select UART.

Interrupt source: Select transfer end interrupt.

Symbol: SMR01

| - | 15        | 14        | 13 | 12 | 11 | 10 | 9 | 8     | 7 | 6          | 5 | 4 | 3 | 2         | 1         | 0         |
|---|-----------|-----------|----|----|----|----|---|-------|---|------------|---|---|---|-----------|-----------|-----------|
|   | CKS0<br>1 | CCS0<br>1 | 0  | 0  | 0  | 0  | 0 | STS01 | 0 | SIS01<br>0 | 1 | 0 | 0 | MD01<br>2 | MD01<br>1 | MD01<br>0 |
|   | 0         | 0         | 0  | 0  | 0  | 0  | 0 | 1     | 0 | 0          | 1 | 0 | 0 | 0         | 1         | 0         |

Bit 15

| CKS01 | Selection of operation clock ( $f_{MCK}$ ) of channel 1 |  |  |  |  |  |  |
|-------|---------------------------------------------------------|--|--|--|--|--|--|
| 0     | Operation clock CK00 set by the SPS0 register           |  |  |  |  |  |  |
| 1     | Operation clock CK01 set by the SPS0 register           |  |  |  |  |  |  |

#### Bit 14

| CCS01 | Selection of transfer clock ( $f_{TCLK}$ ) of channel 1               |  |  |  |  |  |  |
|-------|-----------------------------------------------------------------------|--|--|--|--|--|--|
| 0     | Divided operation clock f <sub>MCK</sub> specified by the CKS01 bit   |  |  |  |  |  |  |
| 1     | Clock input $f_{SCK}$ from the SCK00 pin (slave transfer in CSI mode) |  |  |  |  |  |  |

Bit 8

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

Bit 6

| SIS00 | Controls inversion of level of receive data of channel 0 in UART mode |
|-------|-----------------------------------------------------------------------|
|       | Falling edge is detected as the start bit.                            |
| U     | The input communication data is captured as is.                       |
| 1     | Rising edge is detected as the start bit.                             |
| Ι     | The Input communication data is inverted and captured.                |



Bits 2 and 1

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

Bit 0

| MD000 | Channel 0 interrupt source select                           |  |  |  |  |  |  |  |
|-------|-------------------------------------------------------------|--|--|--|--|--|--|--|
| 0     | Transfer end interrupt                                      |  |  |  |  |  |  |  |
|       | Buffer empty interrupt                                      |  |  |  |  |  |  |  |
| 1     | (Occurs when data is transferred from the SDR00 register to |  |  |  |  |  |  |  |
|       | the shift register.)                                        |  |  |  |  |  |  |  |



Setting up communication format

 Serial communication operation setting register 01 (SCR01) Operation mode: Reception only Parity bit setting: Even parity Data transfer sequence: LSB first Stop bit length: 1 bit Data length: 8 bits

Symbol: SCR01

| 15    | 14        | 13        | 12        | 11 | 10        | 9          | 8          | 7     | 6 | 5          | 4          | 3 | 2 | 1          | 0          |
|-------|-----------|-----------|-----------|----|-----------|------------|------------|-------|---|------------|------------|---|---|------------|------------|
| TXE01 | RXE0<br>1 | DAP0<br>1 | CKP0<br>1 | 0  | EOC0<br>1 | PTC0<br>11 | PTC0<br>10 | DIR01 | 0 | SLC01<br>1 | SLC01<br>0 | 0 | 1 | DLS01<br>1 | DLS01<br>0 |
| 0     | 1         | 0         | 0         | 0  | 1         | 1          | 0          | 1     | 0 | 0          | 1          | 0 | 1 | 1          | 1          |

Bits 15 and 14

| TXE01 | RXE01 | Setting of operation mode of channel 1 |
|-------|-------|----------------------------------------|
| 0     | 0     | Disable communication.                 |
| 0     | 1     | Reception only                         |
| 1     | 0     | Transmission only                      |
| 1     | 1     | Transmission/reception                 |

#### Bits 13 and 12

| DAP01 | CKP01 | Selection of data and clock in CSI mode |
|-------|-------|-----------------------------------------|
| 0     | 0     | Type 1                                  |
| 0     | 1     | Туре 2                                  |
| 1     | 0     | Туре 3                                  |
| 1     | 1     | Туре 4                                  |

Set DAP01, CKP01 = 0, 0 in the UART mode and simplified  $I^2C$  mode.

#### Bit 10

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

Set EOC01 = 1 during UART reception.



### Bits 9 and 8

| DTCO44 | DTCO40 | Setting of parity bit in UART mode |                         |  |  |  |  |  |  |
|--------|--------|------------------------------------|-------------------------|--|--|--|--|--|--|
| PTC011 | PTC010 | Transmission                       | Reception               |  |  |  |  |  |  |
| 0      | 0      | Does not output the parity bit.    | Receives without parity |  |  |  |  |  |  |
| 0      | 1      | Outputs 0 parity Note 3            | No parity judgment      |  |  |  |  |  |  |
| 1      | 0      | Outputs even parity.               | Judges as even parity.  |  |  |  |  |  |  |
| 1      | 1      | Outputs odd parity.                | Judges as odd parity.   |  |  |  |  |  |  |

#### Bit 7

| DIR01 | 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

| SLC011 | SLC010 | Setting of stop bit in UART mode |
|--------|--------|----------------------------------|
| 0      | 0      | No stop bit                      |
| 0      | 1      | Stop bit length = 1 bit          |
| 1      | 0      | Setting prohibited               |
| 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

| DLS011           | DLS010 | CSI/UART mode data length setting                               |  |  |  |  |  |
|------------------|--------|-----------------------------------------------------------------|--|--|--|--|--|
| 0                | 1      | 9-bit data length (stored in bits 0 to 8 of the SDR01 register) |  |  |  |  |  |
| 0                |        | (settable in UART mode only)                                    |  |  |  |  |  |
| 1                | 0      | 8-bit data length (stored in bits 0 to 6 of the SDR01 register) |  |  |  |  |  |
| 1                | 1      | 8-bit data length (stored in bits 0 to 7 of the SDR01 register) |  |  |  |  |  |
| Other than above |        | Setting prohibited                                              |  |  |  |  |  |



Setting up frequency division ratio of operation clock  $\left(f_{MCK}\right)$ 

• Serial data register 01 (SDR01) Transfer clock: f<sub>MCK</sub>/208

Symbol: SDR01

| 15   | 14                                                        | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5      | 4         | 3        | 2 | 1 | 0 |
|------|-----------------------------------------------------------|----|----|----|----|---|---|---|---|--------|-----------|----------|---|---|---|
| Frec | Frequency division ratio of operation clock ( $f_{MCK}$ ) |    |    |    |    |   |   |   |   | Transm | it/receiv | e buffer |   |   |   |
| 1    | 1                                                         | 0  | 0  | 1  | 1  | 1 | х | х | х | х      | х         | х        | х | х | х |

Bits 15 to 9

| b15 | b14 | b13 | b12 | b11 | b10 | b9 | Transfer clock setting by dividing the operating clock $(f_{\mbox{\scriptsize 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                                                                                     |
| •   | •   | ٠   | •   | •   | ٠   | ٠  | 0                                                                                     |
|     | •   | •   | •   | •   | ٠   | ٠  | 0                                                                                     |
| 1   | 1   | 0   | 0   | 1   | 1   | 1  | f <sub>мск</sub> /208                                                                 |
| ٠   | ٠   | ٠   | ٠   | ٠   | ٠   | ٠  | 0                                                                                     |
| •   | •   | ٠   | •   | •   | ٠   | ٠  | 0                                                                                     |
| •   | •   | ٠   | •   | •   | ٠   | ٠  | 0                                                                                     |
| 1   | 1   | 1   | 1   | 1   | 1   | 0  | f <sub>мск</sub> /254                                                                 |
| 1   | 1   | 1   | 1   | 1   | 1   | 1  | f <sub>мск</sub> /256                                                                 |

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

Enabling/disabling data output through target channel

• Serial output enable register 0 (SOE0) Disable output.

Symbol: SOE0

| 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 | SOE | SOE | SOE | SOE |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 03  | 02  | 01  | 00  |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | х   | х   | 0   | х   |

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



Setting up UART RxD0 pin

• Port mode register 1 (PM1) Select I/O mode of serial input port.

Symbol: PM1

| 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|------|------|------|------|------|------|------|------|
| PM17 | PM16 | PM15 | PM14 | PM13 | PM12 | PM11 | PM10 |
| х    | х    | х    | х    | х    | х    | 1    | х    |

Bit 1

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



## 5.7.7 Setting up Interrupts

The sample code covered in this application note uses the external interrupt INTPO.

Figure 5.8 shows the flowchart for setting this type of interrupts.



Figure 5.8 Setting up Interrupts



Setting up the INTP0 interrupt

- Interrupt request flag register (IF0L) Clear the interrupt request flag.
- Interrupt mask flag register (MK0L) Clear the interrupt mask.

Symbol: IF0L

| 7    | 6    | 5         | 4 | 3         | 2 | 1     | 0      |  |
|------|------|-----------|---|-----------|---|-------|--------|--|
| PIF5 | PIF4 | PIF4 PIF3 |   | PIF2 PIF1 |   | LVIIF | WDTIIF |  |
| х    | x x  |           | х | х         | 0 | х     | х      |  |

Bit 7

| PIF0 | Interrupt request flag                                   |
|------|----------------------------------------------------------|
| 0    | No interrupt request signal is generated                 |
| 1    | Interrupt request is generated, interrupt request status |

Symbol: MK0L

| 7    | 6           | 5 | 5 4  |      | 2    | 1     | 0      |  |
|------|-------------|---|------|------|------|-------|--------|--|
| PMK5 | 5 PMK4 PMK3 |   | PMK2 | PMK1 | PMK0 | LVIMK | WDTIMK |  |
| х    | x x         |   | х    | х    | 1    | х     | х      |  |

Bit 7

| PMK0 | Interrupt processing control  |
|------|-------------------------------|
| 0    | Interrupt processing enabled  |
| 1    | Interrupt processing disabled |



#### Setting up the INTP0 interrupt priority

• Priority specification flag registers (PR00L, PR10L) Interrupt priority level: Level 3 (lowest level)

Symbol: PR00L

| 7     | 6          | 6 5 |       | 3     | 2     | 1      | 0       |  |
|-------|------------|-----|-------|-------|-------|--------|---------|--|
| PPR05 | PPR04 PPR0 |     | PPR02 | PPR01 | PPR00 | LVIPR0 | WDTIPR0 |  |
| х     | x x        |     | х     | х     | 1     | х      | х       |  |

; Symbol: PR10L

| 7     | 6 5   |       | 4     | 3     | 2     | 1      | 0       |  |
|-------|-------|-------|-------|-------|-------|--------|---------|--|
| PPR15 | PPR14 | PPR13 | PPR12 | PPR11 | PPR10 | LVIPR1 | WDTIPR1 |  |
| х     | x x   |       | х     | х     | 1     | х      | х       |  |

Bit 2

| PPR00 | PPR10 | Priority level selection        |
|-------|-------|---------------------------------|
| 0     | 0     | Specify level 0 (highest level) |
| 0     | 1     | Specify level 1                 |
| 1     | 0     | Specify level 2                 |
| 1     | 1     | Specify level 3 (lowest level)  |

Setting up INTP0 pin edge sense mode

- External interrupt rising edge enable register (EGP0)
- External interrupt falling edge enable register (EGN0) INTP0 pin edge detection mode: Falling edge

Symbol: EGP0

| 7    | 6    | 5    | 4    | 3    | 2         | 1 | 0    |  |
|------|------|------|------|------|-----------|---|------|--|
| EGP7 | EGP6 | EGP5 | EGP4 | EGP3 | EGP3 EGP2 |   | EGP0 |  |
| х    | х    | x x  |      | х    | х         | х | 0    |  |

Symbol: EGN0

| 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|------|------|------|------|------|------|------|------|
| EGN7 | EGN6 | EGN5 | EGN4 | EGN3 | EGN2 | EGN1 | EGN0 |
| х    | x x  |      | х    | х    | х    | х    | 1    |

Bit 0

| EGP0 | EGN0 | INTP0 pin valid edge selection |
|------|------|--------------------------------|
| 0    | 0    | Edge detection disabled        |
| 0    | 1    | Falling edge                   |
| 1    | 0    | Rising edge                    |
| 1    | 1    | Both rising and falling edges  |



### 5.7.8 Main Processing

Figures 5.9 shows the flowcharts for the main processing.



Figure 5.9 Main Processing (1/2)





Figure 5.9 Main Processing (2/2)



# 5.7.9 Enabling UART0 Operation in SNOOZE Mode

Figure 5.10 shows the flowchart for enabling the UART0 operation in SNOOZE mode.



Figure 5.10 Enabling UART0 Operation in SNOOZE Mode



Controlling the SNOOZE mode

• Serial standby control register 0 (SSC0) Disable error interrupts (INTSRE0/INTSRE2). Enable the startup of reception in STOP mode.

Symbol: SSC0

|   | 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 | 0 | SSEC<br>0 | SWC0 |
| ĺ | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1         | 1    |

#### Bit 1

| SSEC0 | Selection of whether to enable or stop the generation of transfer end interrupts   |  |  |  |  |  |  |  |
|-------|------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|       | Enable the generation of error interrupts (INTSRE0/INTSRE2).                       |  |  |  |  |  |  |  |
|       | In the following cases, the clock request signal (an internal signal) to the clock |  |  |  |  |  |  |  |
| 0     | generator is also cleared:                                                         |  |  |  |  |  |  |  |
|       | When the SWC0 bit is cleared to 0                                                  |  |  |  |  |  |  |  |
|       | • When the UART reception start bit is mistakenly detected                         |  |  |  |  |  |  |  |
|       | Stop the generation of error interrupts (INTSRE0/INTSRE2).                         |  |  |  |  |  |  |  |
|       | In the following cases, the clock request signal (an internal signal) to the clock |  |  |  |  |  |  |  |
|       | generator is also cleared:                                                         |  |  |  |  |  |  |  |
| 1     | When the SWC0 bit is cleared to 0                                                  |  |  |  |  |  |  |  |
|       | When the UART reception start bit is mistakenly detected                           |  |  |  |  |  |  |  |
|       | • When the transfer end interrupt generation timing is based on a parity error     |  |  |  |  |  |  |  |
|       | or framing error                                                                   |  |  |  |  |  |  |  |

#### Bit 0

| SWC0 | Selection of whether to enable or stop the startup of CSI00 or UART0 reception while in the STOP mode                                                                             |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | Stop the startup of reception while in the STOP mode.                                                                                                                             |
| 1    | Enable the startup of reception while in the STOP mode.<br>(During asynchronous CSI00/CSI20 reception or UART0/UART2 reception, the<br>baud rate adjustment function is enabled.) |



# 5.7.10 Disabling UART0 Operation in SNOOZE Mode

Figure 5.11 shows the flowchart for disabling the UART0 operation in SNOOZE mode.



Figure 5.11 Disabling UART0 Operation in SNOOZE Mode



Controlling the SNOOZE mode

• Serial standby control register (SSC0) Enable error interrupts (INTSRE0/INTSRE2). Disable startup of reception in STOP mode.

Symbol: SSC0

| 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 | 0 | SSEC0 | SWC0 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0     | 0    |

#### Bit 1

| SSEC0 | Selection of whether to enable or stop the generation of transfer end interrupts                                                                                                                                                                                                                                                                                                                                          |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | <ul> <li>Enable the generation of error interrupts (INTSRE0/INTSRE2).</li> <li>In the following cases, the clock request signal (an internal signal) to the clock generator is also cleared:</li> <li>When the SWC0 bit is cleared to 0</li> <li>When the UART reception start bit is mistakenly detected</li> </ul>                                                                                                      |
| 1     | <ul> <li>Stop the generation of error interrupts (INTSRE0/INTSRE2).</li> <li>In the following cases, the clock request signal (an internal signal) to the clock generator is also cleared:</li> <li>When the SWC0 bit is cleared to 0</li> <li>When the UART reception start bit is mistakenly detected</li> <li>When the transfer end interrupt generation timing is based on a parity error or framing error</li> </ul> |

#### Bit 0

| SWC0 | Selection of whether to enable or stop the startup of CSI00 or UART0 reception while in the STOP mode |
|------|-------------------------------------------------------------------------------------------------------|
| 0    | Stop the startup of reception while in the STOP mode.                                                 |
|      | Enable the startup of reception while in the STOP mode.                                               |
| 1    | (During asynchronous CSI00/CSI20 reception or UART0/UART2 reception, the baud rate adjustment         |
|      | function is enabled.)                                                                                 |



# 5.7.11 Starting UART0 Reception

Figure 5.12 shows the flowchart for starting UART0 reception.



Figure 5.12 Starting UART0 Reception

Setting the startup standby of UART0 reception

• Serial channel start register 0 (SS0) Switch channel 1 to communication wait status.

Symbol: SS0

| <br>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 | SS03 | SS02 | SS01 | SS00 |
| 0      | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    | 1    | 0    |

Bits 3 to 0

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



# 5.7.12 Stopping UART Reception

Figure 5.13 shows the flowchart for stopping UART reception.



Figure 5.13 Stopping UART Reception

Setting the startup standby of UART0 reception

• Serial channel stop register 0 (ST0) Enable stopping channel 1 communication.

Symbol: ST0

| 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 | ST03 | ST02 | ST01 | ST00 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    | 1    | 0    |

Bits 3 to 0

| ST01 | Operation start trigger of channel 1                                              |
|------|-----------------------------------------------------------------------------------|
| 0    | No trigger operation                                                              |
| 1 1  | Sets the SE01 bit to 1 and enters the communication wait status <sup>Note</sup> . |

Note: Communication stops while holding the value of the control register and shift register, and the status of the serial clock I/O pin, serial data output pin, and each error flag (FEFmn: framing error flag, PEFmn: parity error flag, and OVFmn: overrun error flag).



#### 5.7.13 Setting up UART0 Receive Buffer

Figure 5.14 shows the flowchart for setting up the UART0 receive buffer.



Figure 5.14 Setting up UART0 Receive Buffer



#### 5.7.14 Starting INTP0 Operation

Figure 5.15 shows the flowchart for starting INTP0 operation.





Setting up the INTP0 interrupt

- Interrupt request flag register (IF0L) Clear interrupt request flag.
- Interrupt mask flag register (MK0L) Clear interrupt mask.

Symbol: IF0L

| 7    | 6    | 5    | 4    | 3    | 2    | 1     | 0      |
|------|------|------|------|------|------|-------|--------|
| PIF5 | PIF4 | PIF3 | PIF2 | PIF1 | PIF0 | LVIIF | WDTIIF |
| х    | х    | х    | х    | х    | 0    | х     | х      |

Bit 2

| PIF0 | Interrupt request flag                                   |  |  |  |  |  |  |  |
|------|----------------------------------------------------------|--|--|--|--|--|--|--|
| 0    | No interrupt request signal is generated                 |  |  |  |  |  |  |  |
| 1    | Interrupt request is generated, interrupt request status |  |  |  |  |  |  |  |

Symbol: MK0L

| 7    | 6    | 5    | 4    | 3    | 2    | 1     | 0      |
|------|------|------|------|------|------|-------|--------|
| PMK5 | PMK4 | PMK3 | PMK2 | PMK1 | PMK0 | LVIMK | WDTIMK |
| х    | х    | х    | х    | х    | 0    | х     | х      |

Bit 0

| PMK0                           | Interrupt processing control  |  |  |  |  |  |  |
|--------------------------------|-------------------------------|--|--|--|--|--|--|
| 0 Interrupt processing enabled |                               |  |  |  |  |  |  |
| 1                              | Interrupt processing disabled |  |  |  |  |  |  |



# 5.7.15 Stopping INTP0

Figure 5.16 shows the flowchart for stopping INTPO.



Figure 5.16 Stopping INTP0 Operation

#### 5.7.16 Getting UART0 Receive Data

Figure 5.17 shows the flowchart for getting UART0 receive data.



Figure 5.17 Getting UART0 Receive Data

Getting UART0 receive data

• Serial data register 01 (SDR01) Receive buffer RXD0

Symbol: SDR01



UART0 receive data register (RXD0)

The receive data is written to the lower 8 bits of SDR01.

The lower 8 bits are accessed as the RXD0 register.



#### 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 Low-power Consumption Operation (UART in SNOOZE Mode) |
|-----------------|----------------------------------------------------------------|
|-----------------|----------------------------------------------------------------|

| Rev. | Date          | Description |                                            |  |
|------|---------------|-------------|--------------------------------------------|--|
|      |               | Page        | Summary                                    |  |
| 1.00 | Feb. 15, 2012 |             | First edition issued                       |  |
| 1.01 | Apr. 20, 2012 | 4           | Outline missing of Figure 1.2 is repaired. |  |
| 2.00 | Dec. 1, 2013  | 9           | UART baud rate is changed.                 |  |

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

- 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.
- 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.
- Renesas Electronics does not assume any liability for infringement of patents, copyrights, or other intellectual property rights of third parties by or arising from the use of Renesas Electronics products or technical information described in this document. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 4. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from such alteration, modification, copy or otherwise misappropriation of Renesas Electronics product.
- 5. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below.
- \*Standard\*: Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; and industrial robots etc.

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

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

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

(Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.

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



#### SALES OFFICES

#### **Renesas Electronics Corporation**

http://www.renesas.com

Renesas Electronics America Inc. 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-408-588-5441, Fax: +1-409-588-3220 Renesas Electronics Europe Limited Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K Tel: +44-1628-651-700, Fax: +449-211-6503 Renesas Electronics Europe GmbH Arcadiastrasse 10, 40472 Düsseldorf, Germany Tel: +49-211-65030, Fax: +49-211-6503-1327 Renesas Electronics (China) Co., Ltd. Th Filoor, Quantum Plaza, No.27 ZhiChunLu Haidian District, Beijing 100083, P.R.China Tel: +49-211-6503, Fax: +49-211-6503-1327 Renesas Electronics (Shanghai) Co., Ltd. Unit 204, 205, ZJAC Center, No.1233 Lujiazui Ring Rd., Pudong District, Shanghai 200120, China Tel: +48-10-8235-1155, Fax: +86-10-8235-7679 Renesas Electronics (Shanghai) Co., Ltd. Unit 204, 205, ZJAC Center, No.1233 Lujiazui Ring Rd., Pudong District, Shanghai 200120, China Tel: +48-21-5877-1818, Fax: +86-21-6887-7898 Renesas Electronics Hong Kong Limited Unit 101-1613, 16/F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong Tel: +48-2-2175-9600, Fax: +488-29175-9670 Renesas Electronics Toing Angele, Tui 80 Bendemeer Road, Unit #06-02 Hyllux Innovation Centre Singapore 339949 Tel: +65-6213-0200, Fax: +605-2132-95-9510 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: +805-258-9307, Fax: +605-2795-9510

> © 2013 Renesas Electronics Corporation. All rights reserved. Colophon 2.2