

Migration Guide from R8C to RL78:

Timer RF to Timer Array Unit

## Introduction

This document describes how to migrate from timer RF in R8C/36M group to the timer array unit (TAU) in RL78/G14 (This document is described in 64-pin package as an example.).

## **Target Device**

RL78/G14, R8C/36M Group

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

R01AN3710EC0100 Rev.1.00 Aug. 1, 2017



## Contents

| 1. Migration Method from R8C Family to RL78 Family | 4 |
|----------------------------------------------------|---|
| 2. Differences between RL78/G14 and R8C/36M Group  | 6 |
| 2.1 Differences in Function Overview               | 6 |
| 2.2 Differences in Input Capture Mode              | 7 |
| 2.3 Differences in Output Compare Mode             | 8 |
| 2.4 Assigned I/O Pins                              | 9 |
| 2.5 Register Compatibility1                        | 0 |
| 3. How to migrate Timer RF in this sample code1    | 2 |
| 4. Example of Migration from Input Capture Mode1   |   |
| 4.1 Specifications1                                | 3 |
| 4.2 Operation Check Conditions1                    |   |
| 4.3 Description of Hardware1                       |   |
| 4.3.1 Hardware Configuration Example1              |   |
| 4.3.2 List of Pins to be used1                     | - |
| 4.4 Description of Software1                       |   |
| 4.4.1 Operation Outline1                           |   |
| 4.4.2 List of Option Byte Setting1                 |   |
| 4.4.3 List of Constant1                            |   |
| 4.4.4 List of Variables1                           | 7 |
| 4.4.5 List of Functions1                           |   |
| 4.4.6 Function Specification1                      |   |
| 4.4.7 Flow Chart1                                  | 9 |
| 5. Example of Migration from Output Compare Mode   | 2 |
| 5.1 Specifications                                 | 2 |
| 5.2 Operation Check Conditions3                    | 3 |
| 5.3 Description of Hardware                        | 3 |
| 5.3.1 Hardware Configuration Example               | 3 |
| 5.3.2 List of Pins to be used                      | 4 |
| 5.4 Description of Software                        |   |
| 5.4.1 Operation Outline                            | 4 |
| 5.4.2 List of Option Byte Setting                  | 6 |
| 5.4.3 List of Functions                            |   |
| 5.4.4 Function Specification                       | 6 |
| 5.4.5 Flow Chart                                   | 7 |
| 6. Sample Code5                                    | 5 |
| 7. Reference Application Note5                     | 5 |

RENESAS

| RL78/G1 | 14, R8C/36M Group  | Migration Guide from R8C to RL78: Timer RF to Timer Array Unit |
|---------|--------------------|----------------------------------------------------------------|
| 8.      | Reference Document | ts                                                             |



## 1. Migration Method from R8C Family to RL78 Family

This application note explains how to achieve each mode (input capture mode and output compare mode) in timer RF of R8C/36M using RL78/G14.

Table 1.1 shows the mode in timer RF of R8C/36M group, and Table 1.2 shows the mode in timer array unit of RL78/G14.

In R8C/36M group, timer RF is a 16-bit timer. Timer RF has two modes: input capture mode and output compare mode. In input capture mode, the edge of the TRFI pin input signal is used as a trigger to latch the timer value and the width or the period of external signal is measured. The TRFI input is equipped with a digital filter, and this prevents errors caused by noise or the like from occurring. In output compare mode, when the value of the TRF register matches the value of the TRFM0 (compare 0 match) or TRFM1 (compare 1 match) register, a user-set level is output from the output-compare output pin.

In RL78/G14, the timer array unit has four 16-bit timers. Each 16-bit timer is called a channel and can be used as an independent timer. In addition, two or more "channels" can be used to create a high-accuracy timer. A count clock is counted by the TCRmn register. Set the count value in the TDRmn register.

The same operation as that in input capture mode of R8C/36M can be realized by using input pulse interval measurement function in TAU of RL78/G14. The count value can be captured at the TImn valid edge and the interval of the pulse input to TImn can be measured. In addition, the count value can be captured by using software operation (TSmn = 1) as a capture trigger while the TEmn bit is set to 1.

The same operation as that in output compare mode of R8C/36M can be realized by using PWM output function in TAU of RL78/G14. Two channels can be used as a set to generate a pulse of any period and duty factor.

Remark m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3)

#### Table 1.1 Operation Mode of Timer RF in R8C/36M

| Timer RF in R8C/36M |                                                                                          |  |
|---------------------|------------------------------------------------------------------------------------------|--|
| Mode Function       |                                                                                          |  |
| Input capture mode  | Transfer the counter value to a register as a trigger of the external signal.            |  |
| Output compare mode | Detect the register value match with a counter (Pin output can be changed at detection). |  |



 Table 1.2 Operation Mode of TAU in RL78/G14

| TAU in RL78/G14                                      |                                                                                                                                                                                                       |  |
|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Mode                                                 | Function                                                                                                                                                                                              |  |
| Interval timer                                       | The timer array unit can be used as a reference<br>timer that generates INTTMmn (timer interrupt) at<br>fixed intervals.                                                                              |  |
| Square wave output                                   | TOmn performs a toggle operation as soon as<br>INTTMmn has been generated, and outputs a<br>square wave with a duty factor of 50%.                                                                    |  |
| External event counter                               | The timer array unit can be used as an external<br>event counter that counts the number of times the<br>valid input edge (external event) is detected in the<br>TImn pin.                             |  |
| Divider                                              | A clock input from a timer input pin (TI00) is divided and output from an output pin (TOm0).                                                                                                          |  |
| Input pulse interval measurement                     | The count value can be captured at the TImn<br>valid edge and the interval of the pulse input to<br>TImn can be measured.                                                                             |  |
| Measurement of high-/low-level width of input signal | By starting counting at one edge of the TImn pin<br>input and capturing the number of counts at<br>another edge, the signal width (high-level<br>width/low-level width) of TImn can be measured.      |  |
| Delay counter                                        | It is possible to start counting down when the valid<br>edge of the TImn pin input is detected (an external<br>event), and then generate INTTMmn (a timer<br>interrupt) after any specified interval. |  |
| One-shot pulse output                                | By using two channels as a set, a one-shot pulse<br>having any delay pulse width can be generated<br>from the signal input to the TImn pin.                                                           |  |
| PWM output                                           | Two channels can be used as a set to generate a pulse of any period and duty factor.                                                                                                                  |  |
| Multiple PWM output                                  | By extending the PWM function and using multiple slave channels, many PWM waveforms with different duty values can be output.                                                                         |  |



## 2. Differences between RL78/G14 and R8C/36M Group

## 2.1 Differences in Function Overview

Table 2.1 lists the differences between timer RF in R8C/36M group and the TAU in RL78/G14.

#### Table 2.1 Differences

| ltem                                                | R8C/36M Group Timer RF                                              | RL78/G14 TAU                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------------------------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Configuration                                       | 16-bit timer                                                        | 16-bit timer Note 1                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Count sources                                       | f1, f2, f32                                                         | fтськ (between fcьк to fcьк/2 <sup>15</sup> )                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Counters                                            | TRF register                                                        | TCRmn register                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Count value setting                                 | TRF register                                                        | TDRmn register                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Modes                                               | <ul> <li>Input capture mode</li> <li>Output compare mode</li> </ul> | <ul> <li>Interval timer</li> <li>Square wave output</li> <li>External event counter</li> <li>Divider (channel 0 in unit 0 only)</li> <li>Input pulse interval measurement</li> <li>Measurement of high-/low-level width of input signal</li> <li>Delay counter</li> <li>one-shot pulse output <sup>Note 2</sup></li> <li>PWM output <sup>Note 2</sup></li> <li>Multiple PWM output <sup>Note 2</sup></li> </ul>                                                                 |
| Count operations                                    | Increment                                                           | Count up Note 3     Count down Note 3                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Timer input                                         | • TRFI pin<br>- Measured pulse input<br>(Input capture mode)        | <ul> <li>Channel 0 <ul> <li>Input from the TI00 pin</li> <li>Event input signal from the ELC</li> </ul> </li> <li>Channel 1 <ul> <li>Input from the TI01 pin</li> <li>Event input signal from the ELC</li> <li>Low-speed on-chip oscillator clock (fiL)</li> <li>Subsystem clock (fsuB)</li> </ul> </li> <li>Channel 2 <ul> <li>Input from the TI02 pin</li> </ul> </li> <li>Channel 3 <ul> <li>Input from the TI03 pin</li> <li>RxD0 (Serial input pin)</li> </ul> </li> </ul> |
| I/O pin selection<br>(output / input port)          | Yes                                                                 | No                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Simultaneous<br>channel operation<br>function       | No                                                                  | Yes Note 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Coordination with<br>event link controller<br>(ELC) | No                                                                  | Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

Notes: 1. Channels 1 and 3 can operate as 8-bit timers.

2. These modes are available by using a master channel to link with slave channels.

3. Count operations depend on modes specified.



## 2.2 Differences in Input Capture Mode

The input pulse interval measurement in RL78/G14 corresponds to input capture mode in R8C/36M group. Table 2.2 lists the differences between input capture mode in R8C/36M group and input pulse interval measurement in RL78/G14.

| ltem                                         | R8C/36M Group<br>(Input Capture Mode)                                                                                                                                                           | RL78/G14<br>(Input Pulse Interval Measurement)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Count<br>sources                             | f1, f2, f32                                                                                                                                                                                     | fтськ (between fcьк to fcьк/2 <sup>15</sup> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Count<br>operations                          | <ul> <li>Increment</li> <li>Transfer the value in the TRF register<br/>to the TRFM0 register at the valid edge<br/>of the measured pulse.</li> </ul>                                            | <ul> <li>Timer count register mn (TCRmn) operates as<br/>an up counter in the capture mode.</li> <li>When the channel start trigger bit (TSmn) of<br/>timer channel start register m (TSm) is set to 1,<br/>the TCRmn register counts up from 0000H in<br/>synchronization with the count clock.</li> <li>When the TImn pin input valid edge is<br/>detected, the count value of the TCRmn register<br/>is transferred (captured) to timer data register<br/>mn (TDRmn) and, at the same time, the TCRmn<br/>register is cleared to 0000H.</li> </ul> |
| Overflow<br>period                           | 1/fk × 65536<br>fk: Frequency of count source                                                                                                                                                   | Period of count clock × 65536                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Count start condition                        | The TSTART bit in the TRFCR0 register is set to 1 (count starts).                                                                                                                               | 1 is written to the TSmn bit in the TSm register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Count stop<br>conditions                     | The TSTART bit in the TRFCR0 register is set to 0 (count stops).                                                                                                                                | 1 is written to the TTmn bit in the TTm register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Interrupt<br>request<br>generation<br>timing | <ul> <li>The valid edge of TRFI input [capture interrupt]</li> <li>When timer RF overflows [timer RF interrupt]</li> </ul>                                                                      | When the TImn pin input valid edge is detected, INTTMmn is output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Counter<br>value reset<br>timing             | In the following cases, the value in the TRF register is set to 0000h.<br>• When the TSTART bit in the TRFCR0 register is set to 0 (count stops).                                               | When the TImn pin input valid edge is detected,<br>the count value of the TCRmn register is<br>transferred (captured) to timer data register mn<br>(TDRmn) and, at the same time, the TCRmn<br>register is cleared to 0000H.                                                                                                                                                                                                                                                                                                                          |
| Read from<br>timer                           | <ul> <li>The count value can be read out by reading the TRF register.</li> <li>The count value at the measured pulse valid edge input can be read out by reading the TRFM0 register.</li> </ul> | Read the TDRmn and TCRmn registers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Write to<br>timer                            | Write to the TRF and TRFM0 registers is disabled.                                                                                                                                               | Write to the TDRmn and TCRmn registers is<br>disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Select<br>functions                          | <ul><li>TRFI polarity selected</li><li>Digital filter function</li></ul>                                                                                                                        | <ul><li>Valid edge selected</li><li>Noise filter</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

Remark m: Unit number (m = 0, 1), n: Channel number (n = 0 to 3)



## 2.3 Differences in Output Compare Mode

Operation as PWM output in RL78/G14 corresponds to Output Compare Mode in R8C/36M group. Table 2.3 lists the differences between output compare mode in R8C/36M group and operation as PWM output in RL78/G14.

| Item                                | R8C/36M Group                                                                                                                                                                                                              | RL78/G14                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                     | (Output Compare Mode)                                                                                                                                                                                                      | (PWM Output)                                                                                                                                                                                                                                                                                                                                                                                             |
| Count sources                       | f1, f2, f32                                                                                                                                                                                                                | fтськ (between fcьк to fcьк/2 <sup>15</sup> )                                                                                                                                                                                                                                                                                                                                                            |
| Count operations                    | • Increment                                                                                                                                                                                                                | Two channels can be used as a set to<br>generate a pulse of any period and duty<br>factor.<br>The master channel operates in the<br>interval timer mode.<br>The slave channel operates in one-<br>count mode.                                                                                                                                                                                            |
| PWM waveform                        | PWM period: 1/fk × (n+1)<br>"L" level width: 1/fk × (m+1)<br>"H" level width: 1/fk × (n-m)<br>fk: Frequency of count source<br>m: Value set in the TRFM0 register<br>n: Value set in the TRFM1 register                    | Pulse period = {Set value of TDRmn<br>(master) + 1} × Count clock period<br>Duty factor [%] = {Set value of TDRmp<br>(slave)}/{Set value of TDRmn (master) +<br>1} × 100                                                                                                                                                                                                                                 |
| Count start<br>condition            | The TSTART bit in the TRFCR0 register is set to 1 (count starts).                                                                                                                                                          | 1 is written to the TSmn, TSHm1, or<br>TSHm3 bit in the TSm register                                                                                                                                                                                                                                                                                                                                     |
| Count stop<br>conditions            | The TSTART bit in the TRFCR0 register is set to 0 (count stops).                                                                                                                                                           | 1 is written to the TTmn, TTHm1, or<br>TTHm3 bit in the TTm register                                                                                                                                                                                                                                                                                                                                     |
| Interrupt request generation timing | <ul> <li>When compare 0 match is generated<br/>[compare 0 interrupt]</li> <li>When compare 1 match is generated<br/>[compare 1 interrupt]</li> <li>When time RF overflows [timer RF<br/>interrupt]</li> </ul>              | Master channel: If the channel start<br>trigger bit (TSmn) of timer channel start<br>register m (TSm) is set to 1, an interrupt<br>(INTTMmn) is output.<br>Slave channel: By using INTTMmn from<br>the master channel as a start trigger, the<br>TCRmp register loads the value of the<br>TDRmp register and the counter counts<br>down to 0000H. When the counter<br>reaches 0000H, it outputs INTTMmp. |
| Output pin<br>functions             | Programmable I/O port or output-<br>compare output                                                                                                                                                                         | Programmable I/O port or PWM function<br>output                                                                                                                                                                                                                                                                                                                                                          |
| Read from timer                     | <ul> <li>The count value can be read out by reading the TRF register.</li> <li>The value in the compare register can be read out by reading registers TRFM0 and TRFM1.</li> </ul>                                          | Read the registers TCRmn and TCRmp                                                                                                                                                                                                                                                                                                                                                                       |
| Write to timer                      | Write to the TRF register is disabled                                                                                                                                                                                      | Write to the register TDRmn and TDRmp                                                                                                                                                                                                                                                                                                                                                                    |
| Selectable<br>functions             | <ul> <li>Output-compare output pin selected</li> <li>Output level at the compare match</li> <li>Output level inverted</li> <li>Output level at the count stops</li> <li>Timing to set the TRF register to 0000h</li> </ul> | <ul> <li>Whether the timer interrupt is<br/>generated when counting is started</li> <li>Output pin level when pulse output is<br/>started</li> </ul>                                                                                                                                                                                                                                                     |

#### Table 2.3 Differences between Output Compare Mode and Operation as Square Wave Output

Remark m: Unit number (m = 0, 1), n: Channel number (n = 0, 2), p: Slave channel number (n = 0; p = 1, 2, 3, n = 2; p = 3)



## 2.4 Assigned I/O Pins

Table 2.4 lists the I/O pins assigned for use in R8C/36M group.

#### Table 2.4 R8C/36M Group I/O Pins

| Pin Name | Assigned Pins | I/O    |
|----------|---------------|--------|
| TRFI     | P8_3          | Input  |
| TRFO00   | P8_0          | Output |
| TRFO01   | P8_1          | Output |
| TRFO02   | P8_2          | Output |
| TRFO10   | P8_3          | Output |
| TRFO11   | P8_4          | Output |
| TRFO12   | P8_5          | Output |

Table 2.5 lists the I/O pins assigned for use in RL78/G14.

#### Table 2.5 RL78/G14 I/O Pins (64-pin products)

| Unit Number | Target Channel | Pin Name | Assigned Pins | I/O    |
|-------------|----------------|----------|---------------|--------|
| Unit 0      | Channel 0      | TI00     | P00           | Input  |
|             |                | TO00     | P01           | Output |
|             | Channel 1      | TI01     | P16           | Input  |
|             |                | TO01     | P16           | Output |
|             | Channel 2      | TI02     | P17           | Input  |
|             |                | TO02     | P17           | Output |
|             | Channel 3      | TI03     | P31           | Input  |
|             |                | TO03     | P31           | Output |



#### 2.5 Register Compatibility

Register compatibilities between timer RF in R8C/36M group and TAU in RL78/G14 are listed in Table 2.6.

#### Table 2.6 Register Compatibility

| ltem                                       | R8C/36M Group                                 | RL78/G14                                      |
|--------------------------------------------|-----------------------------------------------|-----------------------------------------------|
| Count start                                | <ul> <li>TRFCR0 register</li> </ul>           | TSm register                                  |
| Count start                                | TSTART bit                                    | Bit TSmn                                      |
| Count status flag                          | N/A                                           | TEm register                                  |
| Oount status hag                           |                                               | Bit TEmn                                      |
| Count stop                                 | <ul> <li>TRFCR0 register</li> </ul>           | TTm register                                  |
|                                            | TSTART bit                                    | Bit TTmn                                      |
|                                            |                                               | PMCxx register                                |
| Pin Select                                 | <ul> <li>TIMSR register</li> </ul>            | PMxx register                                 |
|                                            |                                               | Pxx register                                  |
| Operating mode select                      | <ul> <li>TRFCR1 register</li> </ul>           | TMRmn register                                |
| oporating mode coloct                      | TMOD bit                                      | Bits MDmn1 to MDmn3                           |
|                                            | TRFCR0 register                               | TPSm register                                 |
| Count source select                        | Bits TCK0 and TCK1                            | TMRmn register                                |
|                                            |                                               | Bits CKSmn0, CKSmn1, CCSmn                    |
| Timer                                      | TRF register                                  | Registers TCRmn, TDRmn                        |
|                                            |                                               | (TCRmn: read-only, TDRmn: read/write)         |
| Capture and compare                        | <ul> <li>Registers TRFM0 and TRFM1</li> </ul> | Registers TCRmn, TDRmn                        |
| register                                   |                                               | (TCRmn: read-only, TDRmn: read/write)         |
| Capture polarity select                    | TRFCR0 register                               | • TMRmn register                              |
|                                            | Bits TRFC03 and TRFC04                        | Bits CISmn0 and CISmn1                        |
| Input filter select                        | • TRFCR1 register                             | <ul> <li>Registers NFEN1 and NFEN2</li> </ul> |
|                                            | Bits TIPF0 and TIPF1                          |                                               |
| Independent channel operation/simultaneous |                                               | TMRmn register                                |
| channel operation                          | N/A                                           | Bits MASTERmn, SPLITmn Notes 1, 2             |
| (slave/master) select                      |                                               | Bits MASTERIIII, SPEITIIII                    |
| Count start and                            |                                               | TMRmn register                                |
| interrupt setting                          | N/A                                           | MDmn0 bit                                     |
| Counter overflow                           |                                               | TSRmn register                                |
| status                                     | N/A                                           | OVF bit                                       |
| Timer input select on                      |                                               | TIS0 register                                 |
| channels 1 and 3                           | N/A                                           | Bits TIS00 to TIS02, TIS04                    |
| <b></b>                                    |                                               | TOm register                                  |
| Timer output buffer                        | N/A                                           | TOmn bit                                      |
| The second second second                   |                                               | TOEm register                                 |
| Timer output enable                        | Register TRFOUT                               | TOEmn bit                                     |
|                                            | TRFCR0 register                               |                                               |
|                                            | Bit TRFC05                                    |                                               |
| Timer output laural                        | <ul> <li>TRFCR1 register</li> </ul>           | • TOI m register                              |
| Timer output level<br>control              | Bits TRFC14 and TRFC15                        | TOLm register     TOLmn bit                   |
| CONTION                                    | Bits TRFC16 and TRFC17                        |                                               |
|                                            | <ul> <li>TRFCR0 register</li> </ul>           |                                               |
|                                            | Bit TRFC06                                    |                                               |

Notes: 1. When channels 1 and 3 are in 8-bit Input Capture Mode, bits TSHm1 and TSHm3 are triggers to enable operation of (start) the higher 8-bit timer.

2. When channels 1 and 3 are in 8-bit Input Capture Mode, bits TEHm1 and TEHm3 indicate whether the higher 8-bit timer is enabled or stopped.





#### 3. How to migrate Timer RF in this sample code

In this sample program, the operation of timer RF of R8C/36M group is realized with TAU of RL78/G14 by the method shown in Table 3.1.

For detailed contents of the sample program, please refer to "4. Example of Migration from Input Capture Mode" ~ "5. Example of Migration from Output Compare Mode".

#### Table 3.1 How to migrate from R8C/36M group to RL78/G14 in this sample program

| Timer RF in R8C/36M | TAU in RL78/G14                  |
|---------------------|----------------------------------|
| Mode                | Mode                             |
| Input capture mode  | Input pulse interval measurement |
| Output compare mode | PWM function                     |



#### 4. Example of Migration from Input Capture Mode

#### 4.1 Specifications

When implementing input capture mode of timer RF in R8C/36M, RL78/G14 can use input pulse interval measurement function of TAU.

Counting is started by the valid edge of a pulse signal input to a timer input pin (TImn). The count value of the timer is captured at the valid edge of the next pulse. In this way, the interval of the input pulse can be measured.

Table 4.1 lists the peripheral functions to be used and their uses (example of migration from input capture mode), and Figure 4.1 shows the operation overview (example of migration from input capture mode).

## Table 4.1 Peripheral Functions to be Used and Their Uses (Example of Migration from Input Capture Mode)

| Peripheral Function                | Use                                      |
|------------------------------------|------------------------------------------|
| Timer array unit                   | Measure the interval of TImn input pulse |
| (input pulse interval measurement) |                                          |



Figure 4.1 Operation Overview (Example of Migration from Input Capture Mode)



## 4.2 Operation Check Conditions

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

| ltem                                                          | Description                                                     |
|---------------------------------------------------------------|-----------------------------------------------------------------|
| Microcontroller used                                          | RL78/G14 (R5F104LEAFB)                                          |
| Operating frequency                                           | High-speed on-chip oscillator (HOCO) clock: 32 MHz              |
|                                                               | CPU/peripheral hardware clock: 32 MHz                           |
| Operating voltage                                             | 5.0V (can run on a voltage range of 2.9 V to 5.5 V.)            |
|                                                               | LVD operation (VLVD): Reset mode 2.81 V (2.76 V to 2.87 V)      |
| Integrated development<br>environment (CS+)                   | CS+ V4.01.00 from Renesas Electronics Corp.                     |
| C compiler (CS+)                                              | CC-RL V1.03.00 from Renesas Electronics Corp.                   |
| Integrated development<br>environment (e <sup>2</sup> studio) | e <sup>2</sup> studio V5.2.0.020 from Renesas Electronics Corp. |
| C compiler (e <sup>2</sup> studio)                            | CC-RL V1.03.00 from Renesas Electronics Corp.                   |

#### **Table 4.2 Operation Check Conditions**

## 4.3 Description of Hardware

## 4.3.1 Hardware Configuration Example

Figure 4.2 shows an example of hardware configuration that is used for this chapter.



#### Figure 4.2 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<sub>DD</sub> or V<sub>ss</sub> 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_{LVD}$ ) that is specified as LVD.



#### 4.3.2 List of Pins to be used

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

#### Table 4.3 Pins to be Used and Their Functions

| Pin Name | I/O   | Description                                |
|----------|-------|--------------------------------------------|
| P31/TI03 | Input | Input pulse signals to the TAU0 channel 3. |

## 4.4 Description of Software

#### 4.4.1 Operation Outline

Each time a rising edge (valid edge) is detected on the timer input pin (TI03), the sample code described in this chapter captures the count value of the timer and measures the time interval between pulses which arrive at the timer input pin (TI03). When a timer interrupt (INTTM03) occurs upon completion of the capture, the sample code calculates the pulse interval and stores the calculation result in the on-chip RAM.

Table 4.4 lists the peripheral functions to be used and their uses. Figure 4.3 shows the timer and its interrupt operation.

(1) Initialize the TAU.

<Conditions for setting> Use the P31/TI03 pin to receive pulses. The operation clock for TAU0 channel 3 should be fclк. Set TAU0 channel 3 to the capture mode. Select "rising edge detection" as the input edge on the TI03 pin. Select the TI03 pin input valid edge to trigger the capture.

- (2) Set the TS03 bit of the timer channel start register 0 (TS0) to 1 to enable count operation. This clears the timer count register (TCR03) to 0000H and starts counting. The sample program executes a HALT instruction.
- (3) When a valid edge is detected, the value of the timer count register (TCR03) is captured and put into the timer data register (TDR03). A timer interrupt (INTTM03) occurs upon completion of the capture. The timer count register (TCR03) is cleared to 0000H and the TAU waits for the next valid edge input. An invalid value is captured when a timer interrupt (INTTM03) occurs upon completion of the first capture. This data is not used.
- (4) In the processing of a timer interrupt (INTTM03) which occurs upon completion of the second capture, the timer data register (TDR03)'s value (pulse width) is stored in the on-chip RAM.



#### Table 4.4 Peripheral Functions to be Used and Their Uses

| Peripheral Function | Use                                                                                    |
|---------------------|----------------------------------------------------------------------------------------|
| Timer array unit 0  | Measurement of the time interval between input pulses<br>on the timer input pin (TI03) |



Figure 4.3 Overview of Timer Operation and Interrupts



#### 4.4.2 List of Option Byte Setting

Table 4.5 summarizes the settings of the option bytes.

#### **Table 4.5 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 which uses 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.                            |

#### 4.4.3 List of Constant

Table 4.6 lists the constants that are used in this sample program.

#### Table 4.6 Constants for the Sample Program

| Constant                  | Setting | Description          |  |
|---------------------------|---------|----------------------|--|
| _0001_TAU_OVERFLOW_OCCURS | 0x0001U | Detects an overflow. |  |

#### 4.4.4 List of Variables

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

#### Table 4.7 Global Variables for the Sample Program

| Туре              | Variable Name    | Contents                                                       | Function Used               |
|-------------------|------------------|----------------------------------------------------------------|-----------------------------|
| volatile uint32_t | g_tau0_ch3_width | Temporary buffer which<br>holds the measured pulse<br>interval | r_tau0_channel3_interrupt() |



Migration Guide from R8C to RL78: Timer RF to Timer Array Unit

## 4.4.5 List of Functions

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

## Table 4.8 Functions

| Function Name               | Outline                                       |
|-----------------------------|-----------------------------------------------|
| R_TAU0_Channel3_Start()     | Starts operation of TAU0 channel 3.           |
| r_tau0_channel3_interrupt() | Processes timer interrupts on TAU0 channel 3. |

## 4.4.6 Function Specification

The followings are the functions that are used in this sample program.

| [Function Name] R | R_TAU0_Channel3_Start()                                                     |
|-------------------|-----------------------------------------------------------------------------|
| Synopsis          | TAU0 channel 3 operation start                                              |
| Header            | r_cg_macrodriver.h                                                          |
|                   | r_cg_timer.h                                                                |
|                   | r_cg_userdefine.h                                                           |
| Declaration       | void R_TAU0_Channel3_Start(void)                                            |
| Explanation       | This function unmasks TAU0 channel 3 interrupts and starts count operation. |
| Arguments         | None                                                                        |
| Return value      | None                                                                        |
| Remarks           | None                                                                        |

[Function Name] r\_tau0\_channel3\_interrupt()

| Synopsis     | TAU0 channel 3 timer interrupt processing                  |
|--------------|------------------------------------------------------------|
| Header       | r_cg_macrodriver.h                                         |
|              | r_cg_timer.h                                               |
|              | r_cg_userdefine.h                                          |
| Declaration  | <pre>static voidnear r_tau0_channel3_interrupt(void)</pre> |
| Explanation  | This function saves the interval value to RAM.             |
| Arguments    | None                                                       |
| Return value | None                                                       |
| Remarks      | None                                                       |
|              |                                                            |



## 4.4.7 Flow Chart

#### 4.4.6.1 Overall Flow

Figure 4.4 shows the overall flow of the sample program described in this chapter.



Figure 4.4 Overall Flow

## 4.4.6.2 Initialization Function

Figure 4.5 shows the flowchart for the initialization function.



#### Figure 4.5 Initialization Function



## 4.4.6.3 System Function

Figure 4.6 shows the flowchart for the system function.



**Figure 4.6 System Function** 



#### 4.4.6.4 CPU Clock Setup

Figure 4.7 shows the flowchart for setting up the CPU clock.



Figure 4.7 CPU Clock Setup

#### 4.4.6.5 **I/O Port Setup**

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



Figure 4.8 I/O Port Setup

Caution: Provide proper treatment for unused pins so that their electrical specifications are observed. Connect each of any unused input-only ports to V<sub>DD</sub> or V<sub>SS</sub> via a separate resistor.



#### 4.4.6.6 Timer Array Unit Setup

Figure 4.9 shows the flowchart for setting up the timer array unit.



#### Figure 4.9 Timer Array Unit Setup



Starting clock signal supply to the timer array unit 0 • Peripheral enable register 0 (PER0)

Start supplying clock signals to the timer array unit 0.

#### Symbol: PER0

| 7     | 6       | 5     | 4              | 3      | 2      | 1      | 0      |
|-------|---------|-------|----------------|--------|--------|--------|--------|
| RTCEN | IICA1EN | ADCEN | <b>IICA0EN</b> | SAU1EN | SAU0EN | TAU1EN | TAU0EN |
| Х     | Х       | Х     | Х              | Х      | Х      | Х      | 1      |

Bit 0

| TAU0EN | Control of timer array unit 0 input clock supply |  |
|--------|--------------------------------------------------|--|
| 0      | Stops input clock supply.                        |  |
| 1      | Enables input clock supply.                      |  |



## Migration Guide from R8C to RL78: Timer RF to Timer Array Unit

Configuring the timer clock frequency

• Timer clock select register 0 (TPS0) Select an operation clock for timer array unit 0.

Symbol: TPS0

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

| Bits 3 to | 0 0 |     |            |                      |          |               |              |          |           |
|-----------|-----|-----|------------|----------------------|----------|---------------|--------------|----------|-----------|
| PRS       | PRS | PRS | PRS        |                      | Op       | peration cloo | ck (CK00) se | lection  |           |
| 003       | 002 | 001 | PR5<br>000 |                      | fс∟к=    | fc∟ĸ=         | fс∟к=        | fc∟ĸ=    | fс∟к=     |
| 005       | 002 | 001 | 000        |                      | 2 MHz    | 4 MHz         | 8 MHz        | 20 MHz   | 32 MHz    |
| 0         | 0   | 0   | 0          | fс∟к                 | 2 MHz    | 4 MHz         | 8 MHz        | 20 MHz   | 32 MHz    |
| 0         | 0   | 0   | 1          | fclк/2               | 1 MHz    | 2 MHz         | 4 MHz        | 10 MHz   | 16 MHz    |
| 0         | 0   | 1   | 0          | fськ/2 <sup>2</sup>  | 500 kHz  | 1 MHz         | 2 MHz        | 5 MHz    | 8 MHz     |
| 0         | 0   | 1   | 1          | fськ/2 <sup>3</sup>  | 250 kHz  | 500 kHz       | 1 MHz        | 2.5 MHz  | 4 MHz     |
| 0         | 1   | 0   | 0          | fськ/2 <sup>4</sup>  | 125 kHz  | 250 kHz       | 500 kHz      | 1.25 MHz | 2 MHz     |
| 0         | 1   | 0   | 1          | fськ/2 <sup>5</sup>  | 62.5 kHz | 125 kHz       | 250 kHz      | 625 kHz  | 1 MHz     |
| 0         | 1   | 1   | 0          | fськ/2 <sup>6</sup>  | 31.3 kHz | 62.5 kHz      | 125 kHz      | 313 kHz  | 500 kHz   |
| 0         | 1   | 1   | 1          | fськ/2 <sup>7</sup>  | 15.6 kHz | 31.3 kHz      | 62.5 kHz     | 156 kHz  | 250 kHz   |
| 1         | 0   | 0   | 0          | fськ/2 <sup>8</sup>  | 7.81 kHz | 15.6 kHz      | 31.3 kHz     | 78.1 kHz | 125 kHz   |
| 1         | 0   | 0   | 1          | fськ/2 <sup>9</sup>  | 3.91 kHz | 7.81 kHz      | 15.6 kHz     | 39.1 kHz | 62.5 kHz  |
| 1         | 0   | 1   | 0          | fclк/2 <sup>10</sup> | 1.95 kHz | 3.91 kHz      | 7.81 kHz     | 19.5 kHz | 31.25 kHz |
| 1         | 0   | 1   | 1          | fclк/2 <sup>11</sup> | 977 Hz   | 1.95 kHz      | 3.91 kHz     | 9.77 kHz | 15.6 kHz  |
| 1         | 1   | 0   | 0          | fclк/2 <sup>12</sup> | 488 Hz   | 977 Hz        | 1.95 kHz     | 4.88 kHz | 7.81 kHz  |
| 1         | 1   | 0   | 1          | fclк/2 <sup>13</sup> | 244 Hz   | 488 Hz        | 977 Hz       | 2.44 kHz | 3.91 kHz  |
| 1         | 1   | 1   | 0          | fclк/2 <sup>14</sup> | 122 Hz   | 244 Hz        | 488 Hz       | 1.22 kHz | 1.95 kHz  |
| 1         | 1   | 1   | 1          | fclк/2 <sup>15</sup> | 61.0 Hz  | 122 Hz        | 244 Hz       | 610 Hz   | 977 Hz    |



Setting up the channel 3 operation mode

• Timer mode register 03 (TMR03)

Specify the operation mode, edge, trigger, channel and clocks.

Symbol: TMR03

| 15         | 14         | 13 | 12        | 11 | 10         | 9          | 8          | 7          | 6          | 5 | 4 | 3         | 2         | 1         | 0         |
|------------|------------|----|-----------|----|------------|------------|------------|------------|------------|---|---|-----------|-----------|-----------|-----------|
| CKS<br>031 | CKS<br>030 | 0  | CCS<br>03 | 0  | STS<br>032 | STS<br>031 | STS<br>030 | CIS<br>031 | CIS<br>030 | 0 | 0 | MD<br>033 | MD<br>032 | MD<br>031 | MD<br>030 |
| 0          | 0          | 0  | 0         | 0  | 0          | 0          | 1          | 0          | 1          | 0 | 0 | 0         | 1         | 0         | 0         |

Bits 15 and 14

| CKS031 | CKS030 | Selection of operation clock (fmck) of channel 3                 |
|--------|--------|------------------------------------------------------------------|
| 0      | 0      | Operation clock CK00 set by timer clock select register 0 (TPS0) |
| 0      | 1      | Operation clock CK02 set by timer clock select register 0 (TPS0) |
| 1      | 0      | Operation clock CK01 set by timer clock select register 0 (TPS0) |
| 1      | 1      | Operation clock CK03 set by timer clock select register 0 (TPS0) |

Bit 12

| CCS03 | Selection of count clock (fтськ) of channel 3                  |
|-------|----------------------------------------------------------------|
| 0     | Operation clock (fmck) specified by the CKS030 and CKS031 bits |
| 1     | Valid edge of input signal input from the TI03 pin             |

| Bits 10 to 8 | 8           |        |                                                                                                                                                |  |  |  |  |  |  |  |
|--------------|-------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| STS032       | STS031      | STS030 | Setting of start trigger or capture trigger of channel 3                                                                                       |  |  |  |  |  |  |  |
| 0            | 0           | 0      | Only software trigger start is valid (other trigger sources are unselected).                                                                   |  |  |  |  |  |  |  |
| 0            | 0           | 1      | Valid edge of the TI03 pin input is used as both the start trigger and capture trigger.                                                        |  |  |  |  |  |  |  |
| 0            | 1           | 0      | Both the edges of the TI03 pin input are used as a start trigger and a capture trigger.                                                        |  |  |  |  |  |  |  |
| 1            | 0           | 0      | Interrupt signal of the master channel is used (when the channel is used as a slave channel with the simultaneous channel operation function). |  |  |  |  |  |  |  |
| Ot           | her than ab | ove    | Setting prohibited                                                                                                                             |  |  |  |  |  |  |  |

| Bits 7 and 6 |        |                                                           |
|--------------|--------|-----------------------------------------------------------|
| CIS031       | CIS030 | Selection of TI03 pin input valid edge                    |
| 0            | 0      | Falling edge                                              |
| 0            | 1      | Rising edge                                               |
| 1            | 0      | Both edges (when low-level width is measured)             |
| I            | 0      | Start trigger: Falling edge, Capture trigger: Rising edge |
| 1            | 1      | Both edges (when high-level width is measured)            |
| I            | I      | Start trigger: Rising edge, Capture trigger: Falling edge |



| Symbo      | ol: TMR    | .03 |           |    |            |            |            |            |            |   |   |           |           |           |           |
|------------|------------|-----|-----------|----|------------|------------|------------|------------|------------|---|---|-----------|-----------|-----------|-----------|
| 15         | 14         | 13  | 12        | 11 | 10         | 9          | 8          | 7          | 6          | 5 | 4 | 3         | 2         | 1         | 0         |
| CKS<br>031 | CKS<br>030 | 0   | CCS<br>03 | 0  | STS<br>032 | STS<br>031 | STS<br>030 | CIS<br>031 | CIS<br>030 | 0 | 0 | MD<br>033 | MD<br>032 | MD<br>031 | MD<br>030 |
| 0          | 0          | 0   | 0         | 0  | 0          | 0          | 1          | 0          | 1          | 0 | 0 | 0         | 1         | 0         | 0         |

Bits 3 to 0

| MD033 | MD032    | MD031    | MD030 | Operation<br>mode of<br>channel 0 | Corresponding function                                                             | Count<br>operation of<br>TCR |
|-------|----------|----------|-------|-----------------------------------|------------------------------------------------------------------------------------|------------------------------|
| 0     | 0        | 0        | 1/0   | Interval timer<br>mode            | Interval timer / Square wave<br>output / Divider function / PWM<br>output (master) | Counting<br>down             |
| 0     | 1        | 0        | 1/0   | Capture mode                      | Input pulse interval<br>measurement                                                | Counting up                  |
| 0     | 1        | 1        | 0     | Event counter mode                | External event counter                                                             | Counting<br>down             |
| 1     | 0        | 0        | 1/0   | One-count<br>mode                 | Delay counter / One-shot pulse<br>output / PWM output (slave)                      | Counting<br>down             |
| 1     | 1        | 0        | 0     | Capture & one-<br>count mode      | Measurement of high-/low-level width of input signal                               | Counting up                  |
|       | Other th | an above |       | Setting prohibite                 | d                                                                                  |                              |

The operation of each mode varies depending on MD030 bit (see table below).

| Operation mode (Value set<br>by the MD033 to MD031 bits<br>(see table above))     | MD030 | Setting of starting counting and interrupt                                                                                                                                                              |
|-----------------------------------------------------------------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Interval timer mode (0, 0, 0)</li> <li>Capture mode (0, 1, 0)</li> </ul> | 0     | Timer interrupt is not generated when counting is started (timer output does not change, either).                                                                                                       |
|                                                                                   | 1     | Timer interrupt is generated when counting is started (timer output also changes).                                                                                                                      |
| • Event counter mode (0, 1, 1)                                                    | 0     | Timer interrupt is not generated when counting is started (timer output does not change, either).                                                                                                       |
| • One-count mode (1, 0, 0)                                                        | 0     | Start trigger is invalid during counting operation.<br>At that time, interrupt is not generated.                                                                                                        |
|                                                                                   | 1     | Start trigger is valid during counting operation.<br>At that time, interrupt is also generated.                                                                                                         |
| • Capture & one-count mode (1, 1, 0)                                              | 0     | Timer interrupt is not generated when counting is started<br>(timer output does not change, either).<br>Start trigger is invalid during counting operation.<br>At that time interrupt is not generated. |
| Other than above                                                                  |       | Setting prohibited                                                                                                                                                                                      |



Configuring the output value for the timer output pin

• Timer output register 0 (TO0)

Configure the output value for the timer output pin for channel 3.

#### Symbol: TO0

| ~  |    |    |    |    |    |   |   |   |   |   |   |      |      |      |      |
|----|----|----|----|----|----|---|---|---|---|---|---|------|------|------|------|
| 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 | TO03 | TO02 | TO01 | TO00 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0    | Х    | Х    | Х    |

| Bit 3 |
|-------|
|-------|

| TO03 | Timer output of channel 3 |
|------|---------------------------|
| 0    | Timer output value is "0" |
| 1    | Timer output value is "1" |

Enabling the timer output

• Timer output enable register 0 (TOE0)

Enable/disable the timer output for channel 3.

Symbol: TOE0

| 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 | TOE03 | TOE02 | TOE01 | TOE00 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0     | Х     | Х     | Х     |

| Bit 3 |                                                                                                                                                                                                              |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TOE03 | Timer output enable/disable of channel 3                                                                                                                                                                     |
| 0     | Timer output is disabled.<br>Timer operation is not applied to the TO03 bit and the output is fixed.<br>Writing to the TO03 bit is enabled and the level set in the TO03 bit is output from the<br>TO03 pin. |
| 1     | Timer output is enabled.<br>Timer operation is applied to the TO03 bit and an output waveform is generated.<br>Writing to the TO03 bit is ignored.                                                           |



## 4.4.6.8 Main Processing

Figure 4.10 shows the flowchart for main processing.



Figure 4.10 Main Processing



#### 4.4.6.9 Timer Array Unit 0 Operation Start

Figure 4.11 shows the flowchart for starting timer array unit operation.



Figure 4.11 Timer Array Unit 0 Operation Start



## Migration Guide from R8C to RL78: Timer RF to Timer Array Unit

- Configuring the timer interrupt
- Interrupt request flag register (IF1L) Clear the interrupt request flag.
- Interrupt mask flag register (MK1L) Enable interrupt processing.

#### Symbol: IF1L

| 7      | 6      | 5      | 4      | 3       | 2                 | 1                           | 0                           |
|--------|--------|--------|--------|---------|-------------------|-----------------------------|-----------------------------|
| TMIF03 | TMIF02 | TMIF01 | TMIF00 | IICAIF0 | SREIF1<br>TMIF03H | SRIF1<br>CSIIF11<br>IICIF11 | STIF1<br>CSIIF10<br>IICIF10 |
| 0      | Х      | Х      | Х      | Х       | Х                 | Х                           | Х                           |

#### Bit 7

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

#### Symbol: MK1L

| 7      | 6      | 5      | 4      | 3       | 2                 | 1                           | 0                           |
|--------|--------|--------|--------|---------|-------------------|-----------------------------|-----------------------------|
| ТММК03 | TMMK02 | TMMK01 | ТММК00 | ІІСАМКО | SREMK1<br>TMMK03H | SRMK1<br>CSIMK11<br>IICMK11 | STMK1<br>CSIMK10<br>IICMK10 |
| 0      | Х      | Х      | Х      | Х       | Х                 | Х                           | Х                           |

#### Bit 7

| ТММК03 | Interrupt processing control |  |  |  |  |
|--------|------------------------------|--|--|--|--|
| 0      | Interrupt servicing enabled  |  |  |  |  |
| 1      | Interrupt servicing disabled |  |  |  |  |

Configuring the timer startup

• Timer channel start register 0 (TS0)

Enable count operation of channel 3.

#### Symbol: TS0

| 15 | 14 | 13 | 12 | 11    | 10 | 9     | 8 | 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|----|----|----|----|-------|----|-------|---|---|---|---|---|------|------|------|------|
| 0  | 0  | 0  | 0  | TSH03 | 0  | TSH01 | 0 | 0 | 0 | 0 | 0 | TS03 | TS02 | TS01 | TS00 |
| 0  | 0  | 0  | 0  | Х     | 0  | Х     | 0 | 0 | 0 | 0 | 0 | 1    | Х    | Х    | Х    |

#### Bit 3

| TS03 | Operation enable (start) trigger of channel 3                                                                                                                                                  |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | No trigger operation                                                                                                                                                                           |
| 1    | The TE03 bit is set to 1 and the count operation becomes enabled.<br>The TCR03 register count operation start in the count operation enabled state varies<br>depending on each operation mode. |



## 4.4.6.10 INTTM03 Interrupt Processing

Figure 4.12 shows the flowchart for INTTM03 interrupt processing.



Figure 4.12 INTTM03 Interrupt Processing



## 5. Example of Migration from Output Compare Mode

## 5.1 Specifications

When implementing output compare mode of timer RF in R8C/36M, RL78/G14 can use PWM (Pulse Width Modulation) output of TAU.

Two channels are used as a set to generate a pulse with a specified period and a specified duty factor.

Table 5.1 lists the peripheral functions to be used and their uses (example of migration from output compare mode), and Figure 5.1 shows operation overview (example of migration from output compare mode).

# Table 5.1 Peripheral Functions to be Used and Their Uses (Example of Migration from Output Compare Mode)

| Peripheral Function                   | Use                                                      |
|---------------------------------------|----------------------------------------------------------|
| Timer array unit                      | Generate a pulse with a specified period and a specified |
| (PWM (Pulse Width Modulation) output) | duty factor                                              |



Figure 5.1 Operation Overview (Example of Migration from Output Compare Mode)



## 5.2 Operation Check Conditions

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

| Item                                                          | Description                                                     |
|---------------------------------------------------------------|-----------------------------------------------------------------|
| Microcontroller used                                          | RL78/G14 (R5F104LEAFB)                                          |
| Operating frequency                                           | High-speed on-chip oscillator (HOCO) clock: 32 MHz              |
|                                                               | CPU/peripheral hardware clock: 32 MHz                           |
| Operating voltage                                             | 5.0V (can run on a voltage range of 2.9 V to 5.5 V.)            |
|                                                               | LVD operation (VLVD): Reset mode 2.81 V (2.76 V to 2.87 V)      |
| Integrated development<br>environment (CS+)                   | CS+ V4.01.00 from Renesas Electronics Corp.                     |
| C compiler (CS+)                                              | CC-RL V1.03.00 from Renesas Electronics Corp.                   |
| Integrated development<br>environment (e <sup>2</sup> studio) | e <sup>2</sup> studio V5.2.0.020 from Renesas Electronics Corp. |
| C compiler (e <sup>2</sup> studio)                            | CC-RL V1.03.00 from Renesas Electronics Corp.                   |

#### **Table 5.2 Operation Check Conditions**

## 5.3 Description of Hardware

## 5.3.1 Hardware Configuration Example

Figure 5.3 shows an example of the hardware configuration used for this chapter.



#### Figure 5.2 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<sub>DD</sub> or V<sub>ss</sub> 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_{LVD}$ ) that is specified as LVD.



#### 5.3.2 List of Pins to be used

Table lists the pins to be used and their functions.

#### Table 5.3 Pins to be Used and Their Functions

| Pin Name | I/O    | Description     |
|----------|--------|-----------------|
| P31/TO03 | Output | PWM output port |

#### 5.4 Description of Software

#### 5.4.1 Operation Outline

The sample program covered in this chapter implements PWM by operating channel 0 and channel 3 together, and delivers a PWM output from P31/TO03.

TO03 outputs PWM with a duty factor of 50%.

Table 5.4 lists the peripheral functions to be used and their uses. Figure 5.3 shows the timer and its interrupt operation.

(1) Initialize the TAU.

<Conditions for setting> Set the P31/TO03 pin to a PWM output. Set TAU0 channel 0 to 2 ms cycle interval timer mode. Set TAU0 channel 3 to one-count mode. Initialize the duty ratio of the PWM output to 50%.

- (2) Operation starts when both the operation enable trigger bits for TAU0's channel 0 and channel 3 are set to 1 simultaneously. The sample program executes a HALT instruction.
- (3) When the counter of master channel (channel 0) reaches 0000H, the value of the TDR00 register is loaded again to the TCR00 register, and the counter counts down. At the same time, PWM output (TO03) goes to the active level ("H" level).
- (4) Master channel (channel 0) is used as a start trigger, the TCR03 register loads the value of the TDR03 register and the counter counts down to 0000H. When the counter of slave channel (channel 3) reaches 0000H, it waits until the next start trigger (from the master channel) is generated. At the same time, PWM output (TO03) goes to the inactive level ("L" level).
- (5) The operations described in (3) and (4) above are repeated.



Migration Guide from R8C to RL78: Timer RF to Timer Array Unit

 Table 5.4 Required Peripheral Functions and Their Uses

| Peripheral Function | Use                                                 |
|---------------------|-----------------------------------------------------|
| Timer array unit 0  | PWM output control for inversion of TO03 pin output |



Figure 5.3 Overview of Timer Operation and Interrupts



## 5.4.2 List of Option Byte Setting

Table 5.5 summarizes the settings of the option bytes.

#### **Table 5.5 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 V to 2.87 V)                |
| 000C2H/010C2H | 11101000B | HS mode, HOCO: 32 MHz                                    |
| 000C3H/010C3H | 10000100B | Enables the on-chip debugger.                            |

#### 5.4.3 List of Functions

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

#### **Table 5.6 Functions**

| Function              | Outline                         |
|-----------------------|---------------------------------|
| R_TAU0_Channel0_Start | TAU0 channel 0 start processing |

## 5.4.4 Function Specification

The followings are the functions that are used in this sample program.

[Function Name] R\_TAU0\_Channel0\_Start

| Synopsis     | TAU0 channel 0 start processing                             |  |  |
|--------------|-------------------------------------------------------------|--|--|
| Header       | r_cg_macrodriver.h                                          |  |  |
|              | r_cg_timer.h                                                |  |  |
|              | r_cg_userdefine.h                                           |  |  |
| Declaration  | void R_TAU0_Channel0_Start(void)                            |  |  |
| Explanation  | This function starts the count operation of TAU0 channel 0. |  |  |
| Arguments    | None                                                        |  |  |
| Return value | None                                                        |  |  |
| Remarks      | None                                                        |  |  |



# 5.4.5 Flow Chart

### 5.4.6.1 Overall Flow

Figure 5.4 shows the overall flow of the sample program described in this chapter.



Figure 5.4 Overall Flow

# 5.4.6.2 Initialization Function

Figure 5.5 shows the flowchart for the initialization function.



#### **Figure 5.5 Initialization Function**



# 5.4.6.3 System Function

Figure 5.6 shows the flowchart for the system function.



Figure 5.6 System Function



## 5.4.6.4 CPU Clock Setup

Figure 5.7 shows the flowchart for setting up the CPU clock.



Figure 5.7 CPU Clock Setup

# 5.4.6.5 I/O Port Setup

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



Figure 5.8 I/O Port Setup

 $\label{eq:caution: Caution: Provide proper treatment for unused pins so that their electrical specifications are observed. Connect each of any unused input-only ports to V_{DD} or V_{SS} via a separate resistor.$ 

# 5.4.6.6 Timer Array Unit Setup

Figures 5.9 and Table 5.10 show the flowchart for setting up the timer array unit.



Figure 5.9 Timer Array Unit Setup (1/2)





Figure 5.10 Timer Array Unit Setup (2/2)



# RL78/G14, R8C/36M Group Migration Guide from R8C to RL78: Timer RF to Timer Array Unit

Starting clock signal supply to the timer array unit 0

• Peripheral enable register 0 (PER0)

Start clock signal supply to the timer array unit 0.

#### Symbol: PER0

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

Bit 0

| TAU0EN | Control of timer array unit 0 input clock supply |
|--------|--------------------------------------------------|
| 0      | Stops input clock supply                         |
| 1      | Enables input clock supply                       |



# Migration Guide from R8C to RL78: Timer RF to Timer Array Unit

Configuring the timer clock frequency

• Timer clock select register 0 (TPS0)

Select an operation clock for timer array unit 0.

Symbol: TPS0

|   |   |            |            |   |   |            | 8          |            |            |            |            |            | 2          |            |            |
|---|---|------------|------------|---|---|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|
| 0 | 0 | PRS<br>031 | PRS<br>030 | 0 | 0 | PRS<br>021 | PRS<br>020 | PRS<br>013 | PRS<br>012 | PRS<br>011 | PRS<br>010 | PRS<br>003 | PRS<br>002 | PRS<br>001 | PRS<br>000 |
| 0 | 0 | Х          | Х          | 0 | 0 | Х          | Х          | Х          | Х          | Х          | Х          | 0          | 0          | 0          | 0          |

|            |            |            |            | Operation clock (CK00) selection |                |                |                |                 |                 |  |  |  |  |
|------------|------------|------------|------------|----------------------------------|----------------|----------------|----------------|-----------------|-----------------|--|--|--|--|
| PRS<br>003 | PRS<br>002 | PRS<br>001 | PRS<br>000 |                                  | fc∟ĸ=<br>2 MHz | fc∟κ=<br>4 MHz | fc∟k=<br>8 MHz | fс∟к=<br>20 MHz | fс∟к=<br>32 MHz |  |  |  |  |
| 0          | 0          | 0          | 0          | fс∟к                             | 2 MHz          | 4 MHz          | 8 MHz          | 20 MHz          | 32 MHz          |  |  |  |  |
| 0          | 0          | 0          | 1          | fclк/2                           | 1 MHz          | 2 MHz          | 4 MHz          | 10 MHz          | 16 MHz          |  |  |  |  |
| 0          | 0          | 1          | 0          | fськ/2 <sup>2</sup>              | 500 kHz        | 1 MHz          | 2 MHz          | 5 MHz           | 8 MHz           |  |  |  |  |
| 0          | 0          | 1          | 1          | fськ/2 <sup>3</sup>              | 250 kHz        | 500 kHz        | 1 MHz          | 2.5 MHz         | 4 MHz           |  |  |  |  |
| 0          | 1          | 0          | 0          | fськ/2 <sup>4</sup>              | 125 kHz        | 250 kHz        | 500 kHz        | 1.25 MHz        | 2 MHz           |  |  |  |  |
| 0          | 1          | 0          | 1          | fськ/2 <sup>5</sup>              | 62.5 kHz       | 125 kHz        | 250 kHz        | 625 kHz         | 1 MHz           |  |  |  |  |
| 0          | 1          | 1          | 0          | fськ/2 <sup>6</sup>              | 31.3 kHz       | 62.5 kHz       | 125 kHz        | 313 kHz         | 500 kHz         |  |  |  |  |
| 0          | 1          | 1          | 1          | fськ/2 <sup>7</sup>              | 15.6 kHz       | 31.3 kHz       | 62.5 kHz       | 156 kHz         | 250 kHz         |  |  |  |  |
| 1          | 0          | 0          | 0          | fськ/2 <sup>8</sup>              | 7.81 kHz       | 15.6 kHz       | 31.3 kHz       | 78.1 kHz        | 125 kHz         |  |  |  |  |
| 1          | 0          | 0          | 1          | fськ/2 <sup>9</sup>              | 3.91 kHz       | 7.81 kHz       | 15.6 kHz       | 39.1 kHz        | 62.5 kHz        |  |  |  |  |
| 1          | 0          | 1          | 0          | fclк/2 <sup>10</sup>             | 1.95 kHz       | 3.91 kHz       | 7.81 kHz       | 19.5 kHz        | 31.25 kHz       |  |  |  |  |
| 1          | 0          | 1          | 1          | fclк/2 <sup>11</sup>             | 977 Hz         | 1.95 kHz       | 3.91 kHz       | 9.77 kHz        | 15.6 kHz        |  |  |  |  |
| 1          | 1          | 0          | 0          | fclк/2 <sup>12</sup>             | 488 Hz         | 977 Hz         | 1.95 kHz       | 4.88 kHz        | 7.81 kHz        |  |  |  |  |
| 1          | 1          | 0          | 1          | fclк/2 <sup>13</sup>             | 244 Hz         | 488 Hz         | 977 Hz         | 2.44 kHz        | 3.91 kHz        |  |  |  |  |
| 1          | 1          | 1          | 0          | fclк/2 <sup>14</sup>             | 122 Hz         | 244 Hz         | 488 Hz         | 1.22 kHz        | 1.95 kHz        |  |  |  |  |
| 1          | 1          | 1          | 1          | fclk/2 <sup>15</sup>             | 61.0 Hz        | 122 Hz         | 244 Hz         | 610 Hz          | 977 Hz          |  |  |  |  |

Caution: For details on the register setup procedures, refer to RL78/G14 User's Manual: Hardware. x: Bits not used in this setting item



#### Migration Guide from R8C to RL78: Timer RF to Timer Array Unit RL78/G14, R8C/36M Group

Setting up the channel 0 operation mode

• Timer mode register 00 (TMR00)

Select an operation clock (fmck).

Select a count clock.

Select a start trigger and capture trigger.

Select a valid edge for timer input. Set up the operation mode.

#### Symbol: TMR00

| 15         | 14         | 13 | 12        | 11 | 10         | 9          | 8          | 7          | 6          | 5 | 4 | 3         | 2         | 1         | 0         |
|------------|------------|----|-----------|----|------------|------------|------------|------------|------------|---|---|-----------|-----------|-----------|-----------|
| CKS<br>001 | CKS<br>000 | 0  | CCS<br>00 | 0  | STS<br>002 | STS<br>001 | STS<br>000 | CIS<br>001 | CIS<br>000 | 0 | 0 | MD<br>003 | MD<br>002 | MD<br>001 | MD<br>000 |
| 0          | 0          | 0  | 0         | 0  | 0          | 0          | 0          | Х          | Х          | 0 | 0 | 0         | 0         | 0         | 1         |

#### Bits 15 and 14

| CKS001 | CKS000 | Selection of operation clock (fmck) of channel 0                 |
|--------|--------|------------------------------------------------------------------|
| 0      | 0      | Operation clock CK00 set by timer clock select register 0 (TPS0) |
| 0      | 1      | Operation clock CK02 set by timer clock select register 0 (TPS0) |
| 1      | 0      | Operation clock CK01 set by timer clock select register 0 (TPS0) |
| 1      | 1      | Operation clock CK03 set by timer clock select register 0 (TPS0) |

#### Bit 12

| CCS00 | Selection of count clock (ftclk) of channel 0                  |
|-------|----------------------------------------------------------------|
| 0     | Operation clock (fmck) specified by the CKS000 and CKS001 bits |
| 1     | Valid edge of input signal input from the TI00 pin             |

#### Bits 10 to 8 STS002 **STS001 STS000** Setting of start trigger or capture trigger of channel 0 Only software trigger start is valid (other trigger sources are 0 0 0 unselected). Valid edge of the TI00 pin input is used as both the start trigger and 1 0 0 capture trigger. Both the edges of the TI00 pin input are used as a start trigger and a 0 1 0 capture trigger. Interrupt signal of the master channel is used (when the channel is used 1 0 0 as a slave channel with the simultaneous channel operation function). Other than above Setting prohibited



| Symbol: | TMR | 00 |
|---------|-----|----|
|         |     |    |

| 15  | 14  | 13 | 12  | 11 | 10  | 9   | 8   | 7   | 6   | 5 | 4 | 3   | 2   | 1   | 0   |
|-----|-----|----|-----|----|-----|-----|-----|-----|-----|---|---|-----|-----|-----|-----|
| CKS |     | 0  | CCS | 0  |     | STS |     |     |     | 0 | 0 | MD  | MD  | MD  | MD  |
| 001 | 000 | v  | 00  | U  | 002 | 001 | 000 | 001 | 000 | v | v | 003 | 002 | 001 | 000 |
| 0   | 0   | 0  | 0   | 0  | 0   | 0   | 0   | Х   | Х   | 0 | 0 | 0   | 0   | 0   | 1   |

Bits 3 to 0

| MD003 | MD002    | MD001    | MD000 | Operation<br>mode of<br>channel 0 | Corresponding function                                                             | Count<br>operation of<br>TCR |  |
|-------|----------|----------|-------|-----------------------------------|------------------------------------------------------------------------------------|------------------------------|--|
| 0     | 0        | 0        | 1/0   | Interval timer<br>mode            | Interval timer / Square wave<br>output / Divider function / PWM<br>output (master) | Counting<br>down             |  |
| 0     | 1        | 0        | 1/0   | Capture mode                      | Input pulse interval<br>measurement                                                | Counting up                  |  |
| 0     | 1        | 1        | 0     | Event counter mode                | External event counter                                                             | Counting<br>down             |  |
| 1     | 0        | 0        | 1/0   | One-count<br>mode                 | Delay counter / One-shot pulse<br>output / PWM output (slave)                      | Counting<br>down             |  |
| 1     | 1        | 0        | 0     | Capture & one-<br>count mode      | Measurement of high-/low-level width of input signal                               | Counting up                  |  |
|       | Other th | an above |       | Setting prohibite                 | d                                                                                  |                              |  |

The operation of each mode varies depending on MD000 bit (see table below).

| Operation mode (Value set<br>by the MD003 to MD001 bits<br>(see table above))     | MD000 | Setting of starting counting and interrupt                                                                                                                                                              |
|-----------------------------------------------------------------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Interval timer mode (0, 0, 0)</li> <li>Capture mode (0, 1, 0)</li> </ul> | 0     | Timer interrupt is not generated when counting is started (timer output does not change, either).                                                                                                       |
|                                                                                   | 1     | Timer interrupt is generated when counting is started (timer output also changes).                                                                                                                      |
| • Event counter mode (0, 1, 1)                                                    | 0     | Timer interrupt is not generated when counting is started (timer output does not change, either).                                                                                                       |
| <ul> <li>One-count mode (1, 0, 0)</li> </ul>                                      | 0     | Start trigger is invalid during counting operation.<br>At that time, interrupt is not generated.                                                                                                        |
|                                                                                   | 1     | Start trigger is valid during counting operation.<br>At that time, interrupt is also generated.                                                                                                         |
| • Capture & one-count mode<br>(1, 1, 0)                                           | 0     | Timer interrupt is not generated when counting is started<br>(timer output does not change, either).<br>Start trigger is invalid during counting operation.<br>At that time interrupt is not generated. |
| Other than above                                                                  |       | Setting prohibited                                                                                                                                                                                      |



# RL78/G14, R8C/36M Group Migration Guide from R8C to RL78: Timer RF to Timer Array Unit

Setting up the channel 3 operation mode

- Timer mode register 03 (TMR03)
- Select an operation clock (fмск).
- Select a count clock.
- Select the 16/8-bit timer.
- Select a start trigger and capture trigger.
- Select a valid edge for timer input.
- Set up the operation mode.

| Symbol: | TMR03 |  |
|---------|-------|--|
|         |       |  |

| 15         | 14           | 13 | 12        | 11          | 10         | 9          | 8 | 7 | 6          | 5 | 4 | 3         | 2         | 1         | 0         |
|------------|--------------|----|-----------|-------------|------------|------------|---|---|------------|---|---|-----------|-----------|-----------|-----------|
| CKS<br>031 | 6 CKS<br>030 | 0  | CCS<br>03 | SPLIT<br>03 | STS<br>032 | STS<br>031 |   |   | CIS<br>030 | 0 | 0 | MD<br>033 | MD<br>032 | MD<br>031 | MD<br>030 |
| 0          | 0            | 0  | 0         | 0           | 1          | 0          | 0 | Х | Х          | 0 | 0 | 1         | 0         | 0         | 1         |

| Bits | 15 | and | 14 |
|------|----|-----|----|
|      |    |     |    |

| CKS031 | CKS030 | Selection of operation clock (fmck) of channel 3                 |
|--------|--------|------------------------------------------------------------------|
| 0      | 0      | Operation clock CK00 set by timer clock select register 0 (TPS0) |
| 0      | 1      | Operation clock CK02 set by timer clock select register 0 (TPS0) |
| 1      | 0      | Operation clock CK01 set by timer clock select register 0 (TPS0) |
| 1      | 1      | Operation clock CK03 set by timer clock select register 0 (TPS0) |

#### Bit 12

| CCS03 | Selection of count clock (fTCLK) of channel 3                    |
|-------|------------------------------------------------------------------|
| 0     | Operation clock (fмск) specified with the CKS030 and CKS031 bits |
| 1     | Valid edge of input signal input from the TI03 pin               |

#### Bit 11

| SPLIT03 | Selection of 8 or 16-bit timer operation for channel 3                                                                                              |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | Operates as 16-bit timer<br>(Operates in independent channel operation function or as slave channel in<br>simultaneous channel operation function.) |
| 1       | Operates as 8-bit timer                                                                                                                             |

| STS032 | STS031            | STS030 | Setting of start trigger or capture trigger of channel 3                                                                                       |
|--------|-------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | 0                 | 0      | Only software trigger start is valid (other trigger sources are unselected).                                                                   |
| 0      | 0                 | 1      | Valid edge of the TI03 pin input is used as both the start trigger and capture trigger.                                                        |
| 0      | 1                 | 0      | Both the edges of the TI03 pin input are used as a start trigger and a capture trigger.                                                        |
| 1      | 0 0               |        | Interrupt signal of the master channel is used (when the channel is used as a slave channel with the simultaneous channel operation function). |
| Oth    | Others than above |        | Setting prohibited                                                                                                                             |



Migration Guide from R8C to RL78: Timer RF to Timer Array Unit

| Symbol: | TMR | .03 |
|---------|-----|-----|
| 4 5     |     | 40  |

| 15  | 14  | 13 | 12  | 11    | 10  | 9   | 8   | 7   | 6   | 5 | 4 | 3   | 2   | 1   | 0   |
|-----|-----|----|-----|-------|-----|-----|-----|-----|-----|---|---|-----|-----|-----|-----|
| CKS | CKS | 0  | CCS | SPLIT | STS | STS | STS | CIS | CIS | 0 | 0 | MD  | MD  | MD  | MD  |
| 031 | 030 | U  | 03  | 03    | 032 | 031 | 030 | 031 | 030 | 0 | U | 033 | 032 | 031 | 030 |
| 0   | 0   | 0  | 0   | 0     | 1   | 0   | 0   | Х   | Х   | 0 | 0 | 1   | 0   | 0   | 1   |

Bits 3 to 0

| MD033 | MD032    | MD031    | MD030       | Operation<br>mode of<br>channel 3 | Corresponding function                                                             | Count<br>operation of<br>TCR |  |  |
|-------|----------|----------|-------------|-----------------------------------|------------------------------------------------------------------------------------|------------------------------|--|--|
| 0     | 0        | 0        | 1/0         | Interval timer<br>mode            | Interval timer / Square wave<br>output / Divider function / PWM<br>output (master) | Counting<br>down             |  |  |
| 0     | 1        | 0        | 1/0         | Capture mode                      | Input pulse interval<br>measurement                                                | Counting up                  |  |  |
| 0     | 1        | 1        | 0           | Event counter mode                | External event counter                                                             | Counting<br>down             |  |  |
| 1     | 0        | 0        | <b>1</b> /0 | One-count<br>mode                 | Delay counter / One-shot pulse<br>output / <b>PWM output (slave)</b>               | Counting<br>down             |  |  |
| 1     | 1        | 0        | 0           | Capture & one-<br>count mode      | Measurement of high-/low-level width of input signal                               | Counting up                  |  |  |
|       | Other th | an above |             | Setting prohibited                |                                                                                    |                              |  |  |

The operation of each mode varies depending on MD030 bit (see table below).

| Operation mode (Value set<br>by the MD033 to MD031 bits<br>(see table above))     | MD030 | Setting of starting counting and interrupt                                                                                                                                                              |
|-----------------------------------------------------------------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Interval timer mode (0, 0, 0)</li> <li>Capture mode (0, 1, 0)</li> </ul> | 0     | Timer interrupt is not generated when counting is started (timer output does not change, either).                                                                                                       |
|                                                                                   | 1     | Timer interrupt is generated when counting is started (timer output also changes).                                                                                                                      |
| • Event counter mode (0, 1, 1)                                                    | 0     | Timer interrupt is not generated when counting is started (timer output does not change, either).                                                                                                       |
| • One-count mode (1, 0, 0)                                                        | 0     | Start trigger is invalid during counting operation. At that time, interrupt is not generated.                                                                                                           |
|                                                                                   | 1     | Start trigger is valid during counting operation. At that time, interrupt is also generated.                                                                                                            |
| <ul> <li>Capture &amp; one-count mode<br/>(1, 1, 0)</li> </ul>                    | 0     | Timer interrupt is not generated when counting is started<br>(timer output does not change, either). Start trigger is invalid<br>during counting operation. At that time interrupt is not<br>generated. |
| Other than above                                                                  |       | Setting prohibited                                                                                                                                                                                      |



| L78/                   | G14, F             | <b>R8C/</b>                      | 36M C              | Group                       | )                     | Mig                    | ration              | Guide  | e from  | R8C     | to RL  | .78: Time  | er RF to T  | imer Array    | /Un |
|------------------------|--------------------|----------------------------------|--------------------|-----------------------------|-----------------------|------------------------|---------------------|--------|---------|---------|--------|------------|-------------|---------------|-----|
| • Time                 | er data            | regis                            | ter 00 (           | TDR0                        | 0)                    | vycle tir<br>vycle tim |                     |        |         |         |        |            |             |               |     |
|                        | ol: TD             |                                  |                    |                             |                       |                        |                     |        |         |         |        |            |             |               |     |
| 15                     | 14                 | 1:                               | 3 1                | 2                           | 11                    | 10                     | 9                   | 8      | 7       | 6       |        | 5 4        | 3           | 2 1           | 0   |
|                        |                    |                                  |                    |                             |                       |                        |                     |        |         |         |        |            |             |               |     |
| Config                 | 2<br>guring        | [ms] :<br>the P                  | = (1/32<br>WM ou   | [MHz]<br>atput d            | ]) × (]<br>luty ra    | rdr00                  | ount clo<br>setting |        | le time |         |        | ⇒          | TDR00 set   | tting = 63999 | )   |
| Conf                   |                    | he PV                            | ter 03 (<br>VM ou  |                             |                       | io.                    |                     |        |         |         |        |            |             |               |     |
| 15                     | 01. 1D<br>1        |                                  | 13                 | 12                          | 2                     | 11                     | 10                  | 9      | 8       | 7       | 6      | 5          | 4 3         | 2 1           | C   |
|                        |                    |                                  |                    |                             |                       |                        |                     |        |         |         |        |            |             |               |     |
| Time<br>Set u<br>Symbo | g up th<br>er outp | e time<br>out mo<br>imer o<br>M0 | er outp<br>ode reg | ut moo<br>ister 0<br>mode 1 | le<br>(TON<br>for ead | ИО)<br>ch chan         |                     |        | c       | F       |        | ⇒<br>3     | TDR03 set   | tting = 32000 |     |
| 15<br>0                | 14<br>0            | 13<br>0                          | 12<br>0            | 11<br>0                     | 10<br>0               | 9                      | 8                   | 7<br>0 | 6<br>0  | 5<br>0  | 4      | 3<br>TOM03 |             | -             | 0   |
| 0                      | 0                  | 0                                | 0                  | 0                           | 0                     | 0                      | 0                   | 0      | 0       | 0       | 0      | 101003     |             |               | 0   |
| Bit 3                  |                    | 0                                | 0                  | 0                           | 0                     |                        |                     |        | Ū       |         |        |            | X           | Х             | 0   |
| то                     | M03                | Ma                               | otor ol            |                             |                       |                        |                     |        |         | -       |        | of channe  |             | in at almost  |     |
| (                      | 0                  |                                  | ster cr            |                             | ο ουτρ                | out mo                 | ue (to p            | Jroauc | e logg  | ie outp | out by | umer inte  | errupt reql | uest signal   |     |
|                        | 4                  |                                  |                    |                             | -                     |                        | •                   |        |         |         |        |            | t request   | -             |     |

(INTTM03) of the master channel, and reset by the timer interrupt request signal

Caution: For details on the register setup procedures, refer to RL78/G14 User's Manual: Hardware. x: Bits not used in this setting item

(INTTM0p) of the slave channel)

1



# RL78/G14, R8C/36M Group Migration Guide from R8C to RL78: Timer RF to Timer Array Unit

Configuring the output level for the timer output pin

• Timer output level register 0 (TOL0)

Configure the output level for the timer output pin for each channel.

#### Symbol: TOL0

| 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 | TOL03 | TOL02 | TOL01 | 0 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0     | Х     | Х     | 0 |

Bit 3

| TOL03 | Control of timer output level of channel 3 |
|-------|--------------------------------------------|
| 0     | Positive logic output (active-high)        |
| 1     | Negative logic output (active-low)         |

Configuring the output value for the timer output pin

• Timer output register 0 (TO0)

Configure the output value for the timer output pin for each channel.

Symbol: TO0

| 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 | TO03 | TO02 | TO01 | TO00 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0    | Х    | Х    | 0    |

Bit 3

| DIU  |                           |
|------|---------------------------|
| TO03 | Timer output of channel 3 |
| 0    | Timer output value is "0" |
| 1    | Timer output value is "1" |

Bit 0

| TO00 | Timer output of channel 0 |
|------|---------------------------|
| 0    | Timer output value is "0" |
| 1    | Timer output value is "1" |



# Migration Guide from R8C to RL78: Timer RF to Timer Array Unit

Enabling the timer output

• Timer output enable register 0 (TOE0) Enable/disable the timer output for each channel.

#### Symbol: TOE0

| 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 | TOE03 | TOE02 | TOE01 | TOE00 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 1     | Х     | Х     | 0     |

| Bit 3 |                                                                                                   |
|-------|---------------------------------------------------------------------------------------------------|
| TOE03 | Timer output enable/disable of channel 3                                                          |
|       | Timer output is disabled.                                                                         |
| 0     | Timer operation is not applied to the TO03 bit and the output is fixed.                           |
|       | Writing to the TO03 bit is enabled and the level set in the TO03 bit is output from the TO03 pin. |
|       | Timer output is enabled.                                                                          |
| 1     | Timer operation is applied to the TO03 bit and an output waveform is generated.                   |
|       | Writing to the TO03 bit is ignored.                                                               |

| Bit 0 |                                                                                                                                                                                                              |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TOE00 | Timer output enable/disable of channel 0                                                                                                                                                                     |
| 0     | Timer output is disabled.<br>Timer operation is not applied to the TO00 bit and the output is fixed.<br>Writing to the TO00 bit is enabled and the level set in the TO00 bit is output from the<br>TO00 pin. |
| 1     | Timer output is enabled.<br>Timer operation is applied to the TO00 bit and an output waveform is generated.<br>Writing to the TO00 bit is ignored.                                                           |



# Migration Guide from R8C to RL78: Timer RF to Timer Array Unit

Setting up the PWM output pin

• Port register (P3)

Set the output latch.

#### Symbol: P3

| 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0   |
|---|---|---|---|---|---|-----|-----|
| 0 | 0 | 0 | 0 | 0 | 0 | P31 | P30 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0   | Х   |

Bit 1

| P31 | Output data control |
|-----|---------------------|
| 0   | Output 0            |
| 1   | Output 1            |

• Port mode register (PM3) Select the PM31 I/O mode.

Symbol: PM3

| <b>7</b> | 6 | 5 | 4 | 3 | 2 | 1    | 0    |
|----------|---|---|---|---|---|------|------|
| 1        | 1 | 1 | 1 | 1 | 1 | PM31 | PM30 |
| 1        | 1 | 1 | 1 | 1 | 1 | 0    | Х    |

Bit 1

| PM31 | P31 pin I/O mode selection                                           |
|------|----------------------------------------------------------------------|
| 0    | Output mode (the pin functions as an output port (output buffer on)) |
| 1    | Input mode (the pin functions as an input port (output buffer off))  |



# 5.4.6.7 Main Processing

Figure 5.11 shows the flowchart for main processing.



Figure 5.11 Main Processing



# 5.4.6.8 Timer Array Unit Startup

Figure 5.12 shows the flowchart for starting the operation of the timer array unit.



Figure 5.12 Timer Array Unit Startup



# Migration Guide from R8C to RL78: Timer RF to Timer Array Unit

Enabling the timer output

• Timer output enable register 0 (TOE0) Enable/disable the timer output for each channel.

#### Symbol: TOE0

| 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 | TOE03 | TOE02 | TOE01 | TOE00 |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 1     | Х     | Х     | Х     |

| Timer output enable/disable of channel 3                                                          |
|---------------------------------------------------------------------------------------------------|
| Timer output is disabled.                                                                         |
| Timer operation is not applied to the TO03 bit and the output is fixed.                           |
| Writing to the TO03 bit is enabled and the level set in the TO03 bit is output from the TO03 pin. |
| Timer output is enabled.                                                                          |
| Timer operation is applied to the TO03 bit and an output waveform is generated.                   |
| Writing to the TO03 bit is ignored.                                                               |
|                                                                                                   |

Configuring the timer startup

• Timer channel start register 0 (TS0)

Enable count operation of channel 0 and channel 3.

Symbol: TS0

| 15 | 14 | 13 | 12 | 11    | 10 | 9     | 8 | 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|----|----|----|----|-------|----|-------|---|---|---|---|---|------|------|------|------|
| 0  | 0  | 0  | 0  | TSH03 | 0  | TSH01 | 0 | 0 | 0 | 0 | 0 | TS03 | TS02 | TS01 | TS00 |
| 0  | 0  | 0  | 0  | Х     | 0  | Х     | 0 | 0 | 0 | 0 | 0 | 1    | Х    | Х    | 1    |

Bit 3

| TS03 | Operation enable (start) trigger of channel 3                                                                                                                                                  |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | No trigger operation                                                                                                                                                                           |
| 1    | The TE03 bit is set to 1 and the count operation becomes enabled.<br>The TCR03 register count operation start in the count operation enabled state varies<br>depending on each operation mode. |

Bit 0

| TS00 | Operation enable (start) trigger of channel 0                                                                                                                                                  |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | No trigger operation                                                                                                                                                                           |
| 1    | The TE00 bit is set to 1 and the count operation becomes enabled.<br>The TCR00 register count operation start in the count operation enabled state varies<br>depending on each operation mode. |



# RL78/G14, R8C/36M Group Migration Guide from R8C to RL78: Timer RF to Timer Array Unit

# 6. Sample Code

Sample code can be downloaded from the Renesas Electronics website.

# 7. Reference Application Note

RL78/G13 Timer Array Unit (Pulse Interval Measurement) CC-RL (R01AN2702) The latest versions can be downloaded from the Renesas Electronics website.

# 8. Reference Documents

User's Manual: Hardware RL78/G14 User's Manual: Hardware (R01UH0186) R8C/36M Group User's Manual: Hardware (R01UH0259) The latest versions can be downloaded from the Renesas Electronics website.

Technical Update/Technical News The latest information can be downloaded from the Renesas Electronics website.

# Website and Support

Renesas Electronics Website <u>http://www.renesas.com/</u>

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

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



# **Revision History**

|      |                | Descript | ion                  |
|------|----------------|----------|----------------------|
| Rev. | Date           | Page     | Summary              |
| 1.00 | Aug. 1, 2017   | -        | First edition issued |
|      | 7 kig. 1, 2011 |          |                      |

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

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

#### 1. Handling of Unused Pins

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

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

#### 2. Processing at Power-on

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

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

Access to reserved addresses is prohibited.

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

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

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

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

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

#### Notice

- Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation or any other use of the circuits, software, and information in the design of your product or system. Renesas Electronics disclaims any and all liability for any losses and damages incurred by you or third parties arising from the use of these circuits, software, or information.
- Renesas Electronics hereby expressly disclaims any warranties against and liability for infringement or any other disputes involving patents, copyrights, or other intellectual property rights of third parties, by or arising from the use of Renesas Electronics products or technical information described in this document, including but not limited to, the product data, drawing, chart, program, algorithm, application examples.
- 3. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 4. You shall not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part. Renesas Electronics disclaims any and all liability for any losses or damages incurred by you or third parties arising from such alteration, modification, copy or otherwise misappropriation of Renesas Electronics products.
- 5. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The intended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below.
  - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; and industrial robots etc.

"High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control (traffic lights); large-scale communication equipment; key financial terminal systems; safety control equipment; etc. 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 (space and undersea repeaters; nuclear power control systems; aircraft control systems; key plant systems; military equipment; etc.). Renesas Electronics disclaims any and all liability for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for which the product is not intended by Renesas Electronics.

- 6. When using the Renesas Electronics products, refer to the latest product information (data sheets, user's manuals, application notes, "General Notes for Handling and Using Semiconductor Devices" in the reliability handbook, etc.), and ensure that usage conditions are within the ranges specified by Renesas Electronics with respect to maximum ratings, operating power supply voltage range, heat radiation characteristics, installation, etc. Renesas Electronics disclaims any and all liability for any malfunctions or failure or accident 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 Renesas Electronics 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 ensure to implement safety measures to guard them against the possibility of bodily injury, injury or damage caused by fire, and social damage in the event of failure or malfunction of Renesas Electronics products, such as safety design for hardware and software including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures by your own responsibility as warranty for your products/system. Because the evaluation of microcomputer software alone is very difficult and not practical, 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 investigate applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive carefully and sufficiently and sue Renesas Electronics products in compliance with all these applicable laws and regulations. Renesas Electronics disclaims any and all liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 9. Renesas Electronics products and technologies shall not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations. You shall not use Renesas Electronics products or technologies for (1) any purpose relating to the development, design, manufacture, use, stockpiling, etc., of weapons of mass destruction, such as nuclear weapons, chemical weapons, or biological weapons, or missiles (including unmanned aerial vehicles (UAVs)) for delivering such weapons, (2) any purpose relating to the development, design, manufacture, or use of conventional weapons, or (3) any other purpose of disturbing international peace and security, and you shall not sell, export, lease, transfer, or release Renesas Electronics products or technologies to any third party whether directly with knowledge or reason to know that the third party or any other party will engage in the activities described above. When exporting, selling, transferring, etc., Renesas Electronics products or technologies, you shall comply with any applicable export control laws and regulations promulgated and administered by the governments of the countries asserting iurisdiction over the parties or transactions.
- 10. Please acknowledge and agree that you shall bear all the losses and damages which are incurred from the misuse or violation of the terms and conditions described in this document, including this notice, and hold Renesas Electronics harmless, if such misuse or violation results from your resale or making Renesas Electronics products available any third party.
- 11. This document shall not be reprinted, 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
- (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

(Rev.3.0-1 November 2016)

# RENESAS

#### SALES OFFICES

#### **Renesas Electronics Corporation**

http://www.renesas.com

Renesas Electronics America Inc. 2801 Scott Boulders: 1+408-588-6130 Renesas Electronics Canada Limited 251 Yonge Street, Suite 8309 Richmond Hill, Ontario Canada L4C 973 Tei: +1-905-237-2004 Renesas Electronics Curope Limited Dukes Meadow, Milibaard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K Tei: +44-1625-685-100, Fax: +44-1622-585-900 Renesas Electronics Curope GmbH Arcadiastrasse 10, 40472 Düsseldorf, Germany Tei: +49-211-6503-0, Fax: +44-1622-585-900 Renesas Electronics (China) Co., Ltd. Romon 709, Quantum Piaza, No. 27 ZhiChunLu Haidian District, Beijing 100191, P.R.China Tei: +49-213-253-1155, Fax: +48-1-0225-7679 Renesas Electronics (Shanghai) Co., Ltd. Niti 301, Tower A, Central Towers, 555 Langao Road, Putuo District, Shanghai, P. R. China 200333 Tei: +66-21-2226-0888, Fax: +66-21-2226-0999 Renesas Electronics Hong Kong Limited Unit 1001-1611, 16/F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong Tei: +88-0-255-5569, Fax: +865-0-228 Renesas Electronics Singapore Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong Tei: +88-2-205-6088, Fax: +852-2286-9092 Renesas Electronics Singapore Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong Tei: +882-2157-5960, Teix: +886-2417-59607 Renesas Electronics Singapore Place, 103 Tei: +882-2157-5960, Teix: +886-2417-59670 Renesas Electronics Mangyais Sch.Bhd. Unit 1207, TBotok B, Meanar Amcorp, Amcorp Trade Centre, No. 18, JIn Persiaran Barat, 46050 Petaling Jaya, Selangor Darul Ehsan, Malaysia Tei: +66-23-7955-9300, Fax: +60-27955-9300 Renesas Electronics Malaysia Sch.Bhd. Unit 1207, Block B, Meanar Amcorp, Amcorp Trade Centre, No. 18, JIn Persiaran Barat, 46050 Petaling Jaya, Selangor Darul Ehsan, Malaysia Tei: +60-37955-9300, Fax: +60-37955-9510 Renesas Electronics Malaysia Sch.Bhd. Unit 1207, Block B, Meanar Amcorp, Amcorp Trade Centre, No. 18, JIn Persiaran Barat, 46050 Petaling Jaya, Selangor Darul Ehsan, Malaysia Tei: +60-37955-9300, Fax: +60-40-67208777 Re