

# RL78/G10

# Two-Phase Encoding Software Control CC-RL

R01AN2549EJ0100 Rev.1.00 2016.3.11

## Introduction

This application note explains how to detect a phase difference in external input signals with RL78/G10 software using the pulse-width measurement function of the timer array unit (TAU).

## **Target Device**

RL78/10 (R5F10Y16ASP)

When using this application note for other microcomputers, please modify it according to the corresponding specification and evaluate thoroughly before use.

## Contents

| 1. Specifications                           | 3 |
|---------------------------------------------|---|
| 2. Operating Conditions                     | 4 |
| 3. Related Application Notes                | 4 |
| <ul> <li>4. Hardware Explanation</li></ul>  | 5 |
| 5. Software Explanation                     | 6 |
| 5.1 Operation Outline                       | 6 |
| 5.2 Option Byte Settings                    | 7 |
| 5.3 Constants                               |   |
| 5.4 Variables                               |   |
| 5.5 Functions (subroutines)                 |   |
| 5.6 Function (subroutine) Specifications    |   |
| 5.7 Flowcharts                              |   |
| 5.7.1 CPU Initialization Function1          |   |
| 5.7.2 I/O Port Settings                     |   |
| 5.7.3 Clock Oscillation Circuit Setting     |   |
| 5.7.4 Timer Array Unit Setting              |   |
| 5.7.5 Main Processing                       |   |
| 5.7.6 Interrupt Processing Address Settings |   |
| 5.7.7 INTTM00 Interrupt Processing          |   |
| 5.7.8 INTTM01 Interrupt Processing          |   |
| 5.7.9 Interrupt Processing (count-up)       |   |
| 5.7.10 Interrupt Processing (count-down)3   | 3 |
| 6. Sample Code                              | 4 |
| 7. Documents for Reference                  | 4 |



## 1. Specifications

This application uses the pulse-width measurement function of the timer array unit (TAU) to detect a phase difference in the external input signals and count up or down

Table 1.1 shows the peripheral function and corresponding usage, and Figure 1.1 shows an operational overview of the pulse-width measurement function.

## Table 1.1 Peripheral Functions and Corresponding Usage

| Peripheral Function | Usage                            |
|---------------------|----------------------------------|
| Timer array unit    | Pulse-width measurement function |



Figure 1.1 Operational Overview



## 2. Operating Conditions

The sample code in this application note runs under the following operating conditions.

|                                                 | <b>. . .</b>                                                          |
|-------------------------------------------------|-----------------------------------------------------------------------|
| Item                                            | Description/Specification                                             |
| MCU used                                        | RL78/G10 (R5F10Y16ASP)                                                |
| Operating frequency                             | <ul> <li>High-speed on-chip oscillator clock (HOCO): 20MHz</li> </ul> |
|                                                 | CPU/peripheral hardware clock: 20MHz                                  |
| Operating voltage                               | 3.0V                                                                  |
|                                                 | SPOR detection voltage                                                |
|                                                 | When power supply falls: TYP. 2.84V (2.70V to 2.96V)                  |
|                                                 | When power supply rises: TYP. 2.90V (2.76V to 3.02V)                  |
| Integrated development<br>environment(CS+)      | CS+ E3.01.00G (manufactured by Renesas Electronics)                   |
| Assembler(CS+)                                  | CC-RL V1.00.00.03 (manufactured by Renesas Electronics)               |
| Integrated development<br>environment(e2studio) | e2studio V4.1.0.018G (manufactured by Renesas Electronics)            |
| Assembler(e2studio)                             | CC-RL V4.0.0.2 (manufactured by Renesas Electronics)                  |
| Ports used                                      | RL78/G10 target board (QB-R5F10Y16-TB)                                |
|                                                 |                                                                       |

| able 2.1 | Operating | Conditions |
|----------|-----------|------------|
| able 2.1 | Operating | Conditi    |

## 3. Related Application Notes

Application notes related to this document are shown below. Please refer to these as needed.

RL78/G10 Initialization (R01AN0454E) Application Note

## 4. Hardware Explanation

## 4.1 Hardware Configuration Example

Figure 4.1 shows the hardware configuration example used in this application note.



Figure 4.1 Hardware Configuration Example

Note: 1. This simplified circuit diagram was created to show an overview of connections only.
 When designing your circuit, make sure the design includes sufficient pin processing and meets electrical characteristic requirements. (Connect each input-only port to V<sub>DD</sub> or V<sub>SS</sub> through a resistor.)
 Make V<sub>DD</sub> higher than the RESET release voltage (V<sub>SPOR</sub>) set in SPOR.



## 4.2 Pin List

Table 4.1 provides a list of the pins used in this document and their functions.

| Pin Name  | Input/Output | Function |
|-----------|--------------|----------|
| P137/TI00 | Input        | Clock A  |
| P04/TI01  | Input        | Clock B  |

#### Table 4.1 List of Pins and Functions

### 5. Software Explanation

## 5.1 Operation Outline

This application note explains how to use the TAU pulse-width measurement function to detect a phase difference between external input signals from pins T100 and T101, and then count up or down, correspondingly.

The timer array unit should be set as follows:

#### Setting conditions

- The TAU is used in the pulse-width measurement mode without generating an interrupt when starting up.
- Start trigger/capture trigger: valid edge of TI00/TI01 pin input
- Valid edge of external input signal: select both edges
- Operation clock and counter clock of each channel: select CK00
- Operation clock CK00: select 9.77[kHz]
- Enable the noise filter.

Table 5.1 lists the conditions for counter addition and subtraction.

| TI00 (Clock A) | L  | 1  | Н            | Ļ  | L            | 1  | Н  | $\downarrow$ |
|----------------|----|----|--------------|----|--------------|----|----|--------------|
| TI01 (Clock B) | 1  | Н  | $\downarrow$ | L  | $\downarrow$ | L  | 1  | Н            |
| Counter        | +1 | +1 | +1           | +1 | -1           | -1 | -1 | -1           |

#### Table 5.1 Counter Addition/Subtraction Conditions

Figure 5.1 shows an example of the phase difference detection operation.



Figure 5.1 Phase Difference Detection Example

## 5.2 Option Byte Settings

Table 5.2 shows the option byte settings. Set the optimal value for your system as required.

| Table | 5.2 | Option Byte Settings |
|-------|-----|----------------------|
|       |     |                      |

| Address | Setting Value                            | Description                                          |
|---------|------------------------------------------|------------------------------------------------------|
| 000C0H  | 11101110B Watchdog timer operation stops |                                                      |
|         |                                          | (counting stopped after reset)                       |
| 000C1H  | 11110111B                                | SPOR detection voltage                               |
|         |                                          | When power supply falls: TYP. 2.84V (2.70V to 2.96V) |
|         |                                          | When power supply rises: TYP. 2.90V (2.76V to 3.02V) |
|         |                                          | Uses P125 as reset pin.                              |
| 000C2H  | 11111001B                                | High-speed on-chip oscillator clock (HOCO): 20MHz    |
| 000C3H  | 10000101B                                | Enables on-chip debug operation                      |

## 5.3 Constants

Table 5.3 lists the constants used in the sample code.

## Table 5.3 Constants

| Constant Name | Setting<br>Value | Description           |
|---------------|------------------|-----------------------|
| RESOLUTION    | 60*4             | Maximum counter value |

### 5.4 Variables

Table 5.4 lists the variables used in the sample code.

| Table | 5.4 | Variables |  |
|-------|-----|-----------|--|
|       |     |           |  |

| Variable Name | Description                |
|---------------|----------------------------|
| PROCEADDRA    | INTTI00 processing address |
| PROCEADDRB    | INTTI01 processing address |
| RCOUNT        | Counter                    |
| PROCTABLE     | Processing address table   |

## 5.5 Functions (subroutines)

Table 5.5 lists the functions (subroutines) used in the sample code.

| Function Name | Description                         |
|---------------|-------------------------------------|
| main          | TAU operation start processing      |
| IINTTM00      | TAU0 channel 0 interrupt processing |
| IINTTM01      | TAU0 channel 1 interrupt processing |

#### Table 5.5 Functions (subroutines)

## 5.6 Function (subroutine) Specifications

The following are the specifications of functions (subroutines) used in the sample code.

Function Name: main

| Outline      | Main processing                                                                                                                                                                                                                           |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description  | Starts channel 0 and 1 operations, and releases TAU0 channel 0 and 1 interrupt masks. Also sets the initial value of the processing addresses executed when INTTM00 and INTTM01 are generated to PROCEADDRA and PROCEADDRB, respectively. |
| Argument     | None                                                                                                                                                                                                                                      |
| Return Value | None                                                                                                                                                                                                                                      |
| Notes        | None                                                                                                                                                                                                                                      |

#### Function Name: IINTTM00

| TAU0 channel 0 interrupt processing                                                                                                                                                                                                                                                                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Executes the process of the processing address set in PROCEADDRA when the INTTM00 interrupt is generated. Also obtains the processing address to be executed when the next interrupt is generated. The address is obtained from PROCTABLE based on Clock A and Clock B signal levels, and is set in PROCEADDRA and PROCEADDRB. |
| None                                                                                                                                                                                                                                                                                                                           |
| None                                                                                                                                                                                                                                                                                                                           |
| None                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                |

#### Function Name: IINTTM01

| Outline      | TAU0 channel 1 interrupt processing                                                                                                                                                                                                                                                                                            |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description  | Executes the process of the processing address set in PROCEADDRB when the INTTM01 interrupt is generated. Also obtains the processing address to be executed when the next interrupt is generated. The address is obtained from PROCTABLE based on Clock A and Clock B signal levels, and is set in PROCEADDRA and PROCEADDRB. |
| Argument     | None                                                                                                                                                                                                                                                                                                                           |
| Return Value | None                                                                                                                                                                                                                                                                                                                           |
|              |                                                                                                                                                                                                                                                                                                                                |

Notes None



## 5.7 Flowcharts

Figure 5.2 shows the entire flow of the sample code described in this application note.





#### 5.7.1 CPU Initialization Function

Figure 5.3 shows the flowchart for the CPU initialization function.



Figure 5.3 CPU Initialization Function

### 5.7.2 I/O Port Settings

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



Figure 5.4 I/O Port Settings

Note: When designing circuits, always make sure unused ports are properly processed and all electrical characteristics are met. Also make sure each unused input-only port is connected to V<sub>DD</sub> or V<sub>SS</sub> through a resister.

#### **Clock B pin setting**

• Port Mode Register (PM0)

Select PM04 input/output.

Symbol: PM0

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

Bit 4

| PM04 | PM04 input/output mode select  |
|------|--------------------------------|
| 0    | Output mode (output buffer ON) |
| 1    | Input mode (output buffer OFF) |

## 5.7.3 Clock Oscillation Circuit Setting

Figure 5.5 shows the flowchart for setting the clock oscillation circuit.



Figure 5.5 Clock Oscillation Circuit Setting

Note: For more details on the CPU clock settings (SINICLK), refer to the "Flowcharts" section in the RL78/G10 Initialization (R01AN1454J) Application Note.

## 5.7.4 Timer Array Unit Setting

Figure 5.6 shows the flowchart for setting the timer array unit (TAU).









### **Enable Timer Array Unit Clock Supply**

• Peripheral Enable Register (PER0)

Enable clock supply to timer array unit.

#### Symbol: PER0

| 7       | 6                  | 5     | 4                    | 3 | 2      | 1 | 0      |
|---------|--------------------|-------|----------------------|---|--------|---|--------|
| TMKAEN* | CPMEN <sup>*</sup> | ADCEN | IICA0EN <sup>*</sup> | 0 | SAU0EN | 0 | TAU0EN |
| х       | х                  | х     | х                    | 0 | х      | 0 | 1      |

\*Note: 16-pin products only

Bit 0

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

#### **Timer Array Unit Interrupt Level Settings**

• Priority Specification Flag Registers (PR00L, PR10L, PR00H, PR10H) Set the interrupt levels in the timer array unit.

#### Symbol: PR00L

| 7       | 6        | 5       | 4      | 3        | 2     | 1     | 0       |
|---------|----------|---------|--------|----------|-------|-------|---------|
| TMPR000 | TMPR001H | SREPR00 | SRPR00 | STPR00   | PPR01 | PPR00 | WDTIPR0 |
|         |          |         |        | SCIPR000 |       |       |         |
|         |          |         |        | IICPR000 |       |       |         |
| 1       | x        | x       | x      | x        | x     | x     | x       |

Symbol: PR10L

| 7       | 6        | 5       | 4      | 3        | 2     | 1     | 0       |
|---------|----------|---------|--------|----------|-------|-------|---------|
| TMPR100 | TMPR101H | SREPR10 | SRPR10 | STPR10   | PPR11 | PPR10 | WDTIPR1 |
|         |          |         |        | SCIPR100 |       |       |         |
|         |          |         |        | IICPR100 |       |       |         |
| 0       | х        | x       | x      | х        | x     | х     | x       |

Bit 7

| TMPR100 | TMPR000 | Priority level selection        |
|---------|---------|---------------------------------|
| 0       | 0       | Specify level 0 (high priority) |
| 0       | 1       | Specify level 1                 |
| 1       | 0       | Specify level 2                 |
| 1       | 1       | Specify level 3 (low priority)  |

Symbol: PR00H

| 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0       |
|---|---|---|---|---|-------|-------|---------|
| 1 | 1 | 1 | 1 | 1 | KRPR0 | ADPR0 | TMPR001 |
| х | х | х | х | х | х     | х     | 1       |

Symbol: PR10H

| 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0       |
|---|---|---|---|---|-------|-------|---------|
| 1 | 1 | 1 | 1 | 1 | KRPR1 | ADPR1 | TMPR101 |
| x | х | х | х | х | х     | х     | 0       |

Bit 0

| TMPR101 | TMPR001 | Priority level selection        |
|---------|---------|---------------------------------|
| 0       | 0       | Specify level 0 (high priority) |
| 0       | 1       | Specify level 1                 |
| 1       | 0       | Specify level 2                 |
| 1       | 1       | Specify level 3 (low priority)  |

Note: For more details on register settings, refer to the RL78/G10 User's Manual Hardware Version.

#### **Timer Array Unit Operation Stop Setting**

• Timer Channel Stop Register (TT0)

Stops channel operation in timer array unit.

Symbol: TT0

| 7 | 6 | 5 | 4 | 3     | 2     | 1    | 0    |
|---|---|---|---|-------|-------|------|------|
| 0 | 0 | 0 | 0 | TT03* | TT02* | TT01 | TT00 |
| 1 | х | х | х | х     | х     | 0    | 0    |

\*Note: 16-pin products only

Bits 0 and 1

| TT01, TT00 | Operation stop trigger of channel                        |  |  |  |
|------------|----------------------------------------------------------|--|--|--|
| 0          | No trigger operation                                     |  |  |  |
| 1          | TE0n is cleared to 0, and counting operation is stopped. |  |  |  |

## **Timer Clock Frequency Setting**

• Timer Clock Select Register 0 (TPS0)

Select timer array unit operation clock.

Symbol: TPS0

| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| PRS013 | PRS012 | PRS011 | PRS010 | PRS003 | PRS002 | PRS001 | PRS000 |
| x      | х      | х      | х      | 0      | 1      | 1      | 0      |

| PRS | PRS | PRS | PRS |                      | Sele      | ection of opera | ation clock (C | K00)    |         |
|-----|-----|-----|-----|----------------------|-----------|-----------------|----------------|---------|---------|
| 003 | 002 | 001 | 000 |                      | fclк      | fc∟к            | fclк           | fclк    | fськ    |
|     |     |     |     |                      | = 1.25MHz | = 2.5MHz        | = 5MHz         | = 10MHz | = 20MHz |
| 0   | 0   | 0   | 0   | fclk                 | 1.25MHz   | 2.5MHz          | 5MHz           | 10MHz   | 20MHz   |
| 0   | 0   | 0   | 1   | fclк/2               | 625kHz    | 1.25MHz         | 2.5MHz         | 5MHz    | 10MHz   |
| 0   | 0   | 1   | 0   | fclк/2 <sup>2</sup>  | 313kHz    | 625kHz          | 1.25MHz        | 2.5MHz  | 5MHz    |
| 0   | 0   | 1   | 1   | fськ/2 <sup>3</sup>  | 156kHz    | 313kHz          | 625kHz         | 1.25MHz | 2.5MHz  |
| 0   | 1   | 0   | 0   | fськ/2 <sup>4</sup>  | 78.1kHz   | 156kHz          | 313kHz         | 625kHz  | 1.25MHz |
| 0   | 1   | 0   | 1   | fськ/2 <sup>5</sup>  | 39.1kHz   | 78.1kHz         | 156kHz         | 313kHz  | 625kHz  |
| 0   | 1   | 1   | 0   | fськ/2 <sup>6</sup>  | 19.5kHz   | 39.1kHz         | 78.1kHz        | 156kHz  | 313kHz  |
| 0   | 1   | 1   | 1   | fськ/2 <sup>7</sup>  | 9.77kHz   | 19.5kHz         | 39.1kHz        | 78.1kHz | 156kHz  |
| 1   | 0   | 0   | 0   | fськ/2 <sup>8</sup>  | 4.88kHz   | 9.77kHz         | 19.5kHz        | 39.1kHz | 78.1kHz |
| 1   | 0   | 0   | 1   | fськ/2 <sup>9</sup>  | 2.44kHz   | 4.88kHz         | 9.77kHz        | 19.5kHz | 39.1kHz |
| 1   | 0   | 1   | 0   | fськ/2 <sup>10</sup> | 1.22kHz   | 2.44kHz         | 4.88kHz        | 9.77kHz | 19.5kHz |
| 1   | 0   | 1   | 1   | fськ/2 <sup>11</sup> | 610Hz     | 1.22kHz         | 2.44kHz        | 4.88kHz | 9.77kHz |
| 1   | 1   | 0   | 0   | fськ/2 <sup>12</sup> | 305Hz     | 610Hz           | 1.22kHz        | 2.44kHz | 4.88kHz |
| 1   | 1   | 0   | 1   | fськ/2 <sup>13</sup> | 153Hz     | 305Hz           | 610Hz          | 1.22kHz | 2.44kHz |
| 1   | 1   | 1   | 0   | fclк/2 <sup>14</sup> | 76.3Hz    | 153Hz           | 305Hz          | 610Hz   | 1.22kHz |
| 1   | 1   | 1   | 1   | fclк/2 <sup>15</sup> | 38.1Hz    | 76.3Hz          | 153Hz          | 305Hz   | 610Hz   |

## **Channel 0, 1 Operating Mode Settings**

• Timer Mode Registers 00, 01 (TMR00H, TMR00L, TMR01H, TMR01L)

Select operation clock ( $f_{MCK}$ ).

Select count clock ( $f_{TCLK}$ ).

Set start trigger and capture trigger.

Select timer input valid edge.

Set operating mode.

#### Symbol: TMR0nH

| 7      | 6 | 5 | 4     | 3        | 2      | 1      | 0      |
|--------|---|---|-------|----------|--------|--------|--------|
| CKS0n1 | 0 | 0 | CCS0n | SPLIT01* | STS0n2 | STS0n1 | STS0n0 |
| 0      | 0 | 0 | 0     | 0        | 0      | 0      | 1      |

\*Note: TMR01H only

Bit 7

| CKS0n1 | Selection of operation clock (f <sub>MCK</sub> ) of channel n    |
|--------|------------------------------------------------------------------|
| 0      | Operation clock CK00 set by timer clock select register 0 (TPS0) |
| 1      | Operation clock CK01 set by timer clock select register 0 (TPS0) |

#### Bit 4

| CCS0n | Selection of count clock (fTCLK) of channel n               |
|-------|-------------------------------------------------------------|
| 0     | Operation clock (f <sub>MCK</sub> ) specified by CKS0n1 bit |
| 1     | Valid edge of input signal from TI0n pin                    |

#### Bit 3

| ſ | SPLIT01* | Selection of channel 1 8-bit /16-bit timer operation |  |  |  |
|---|----------|------------------------------------------------------|--|--|--|
|   | 0        | Operates as 16-bit timer                             |  |  |  |
|   | 1        | Operates as 8-bit timer                              |  |  |  |

\*Note: TMR01H only



## Bits 2-0

| STS0n2 | STS0n1         | STS0n0 | Setting of channel n start trigger/capture trigger                                                                                                                                            |
|--------|----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | 0              | 0      | Only software trigger start valid                                                                                                                                                             |
|        |                |        | (other trigger sources are invalid)                                                                                                                                                           |
| 0      | 0              | 1      | Use T10n pin input valid edge as start trigger/capture trigger.                                                                                                                               |
| 0      | 1              | 0      | Use both edges of T10n pin input as triggers, one each for start                                                                                                                              |
|        |                |        | trigger/capture.                                                                                                                                                                              |
| 1      | 0              | 0      | For one-shot pulse output, PWM output function, and multiple PWM output function slave channel: use master channel interrupt request signal (INTTM0n) as start trigger.                       |
| 1      | 1              | 0      | For two-channel input one-shot pulse output slave channel: use master channel interrupt request signal (INTTM0n) as start trigger. Use the slave channel's TI0 pin valid edge as end trigger. |
| Othe   | er than the al | oove   | Do not set                                                                                                                                                                                    |

#### Note: 1. n = 0, 1

Symbol: TMR0nL

| 7      | 6      | 5 | 4 | 3     | 2     | 1     | 0     |
|--------|--------|---|---|-------|-------|-------|-------|
| CIS0n1 | CIS0n0 | 0 | 0 | MD0n3 | MD0n2 | MD0n1 | MD0n0 |
| 1      | 0      | 0 | 0 | 0     | 1     | 0     | 0     |

Bits 7 and 6

| CIS0n1 | CIS0n0 | Selection of TI0n pin input valid edge                    |  |  |  |  |
|--------|--------|-----------------------------------------------------------|--|--|--|--|
| 0      | 0      | Falling edge                                              |  |  |  |  |
| 0      | 1      | Rising edge                                               |  |  |  |  |
| 1      | 0      | Both edges (when low-level width is measured)             |  |  |  |  |
|        |        | Start trigger: falling edge; capture trigger: rising edge |  |  |  |  |
| 1      | 1      | Both edges (when high level-width is measured)            |  |  |  |  |
|        |        | Start trigger: rising edge; capture trigger: falling edge |  |  |  |  |

#### Bits 3-0

| MD<br>0n3 | MD<br>0n2 | MD<br>0n1 | MD<br>0n0 | Setting of operation<br>mode of channel n | Corresponding function                                                                                           | Count operation<br>of TCR |
|-----------|-----------|-----------|-----------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------------------|
| 0         | 0         | 0         | 1/0       | Interval timer mode                       | Interval timer/square wave<br>output/divider function/ PWM<br>output (master)                                    | Down count                |
| 0         | 1         | 0         | 1/0       | Capture mode                              | Input pulse width measurement/<br>two-channel input one-shot pulse<br>output (slave)                             | Up count                  |
| 0         | 1         | 1         | 0         | Event counter mode                        | External event counter                                                                                           | Down count                |
| 1         | 0         | 0         | 1/0       | One-count mode                            | Delay counter/one-shot pulse<br>output/tow-channel input one-shot<br>pulse output (master)/PWM<br>output (slave) | Down count                |
| 1         | 1         | 0         | 0         | Capture & one-<br>count mode              | Measurement of high-/low-level width input signal                                                                | Up count                  |
| Ot        | her than  | the abo   | Ve        | Setting prohibited                        |                                                                                                                  |                           |

The MD0n0 bit operations vary according to the operating mode, as show in the following table.

| Operating Mode<br>(set in MD0n3-MD0n1)                  | MD0n0 | Setting of starting counting and interrupt                                                                                                                                                                      |
|---------------------------------------------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul><li>Interval timer mode</li><li>(0, 0, 0)</li></ul> | 0     | Timer interrupt is not generated when counting is started (timer output does not change, either)                                                                                                                |
| • Capture mode<br>(0, 1, 0)                             | 1     | Timer interrupt is generated when counting is started (timer output also changes)                                                                                                                               |
| <ul><li>Event counter mode</li><li>(0, 1, 1)</li></ul>  | 0     | Timer interrupt is not generated when counting is started (timer output does not change, either)                                                                                                                |
| • One-count mode<br>(1, 0, 0)                           | 0     | Start trigger is invalid during counting operation.<br>At that time, a timer interrupt is not generated.                                                                                                        |
|                                                         | 1     | Start trigger is valid during counting operation.<br>At that time, a timer interrupt is not generated.                                                                                                          |
| Capture & one-count mode (1, 1, 0)                      | 0     | Timer interrupt is not generated when counting is<br>started (timer output does not change, either)<br>Start trigger is invalid during counting operation.<br>At that time, a timer interrupt is not generated. |
| Other than the above                                    |       | Setting prohibited                                                                                                                                                                                              |

#### Note: 1. n = 0, 1

#### **Timer Output Enable Setting**

• Timer Output Enable Register 0 (TOE0)

Enable timer output.

Symbol: TOE0

| 7 | 6 | 5 | 4 | 3 | 2 | 1     | 0     |
|---|---|---|---|---|---|-------|-------|
| 0 | 0 | 0 | 0 | 0 | 0 | TOE01 | TOE00 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0     | 0     |

Bits 1 and 0

| TOE0n | Channel n timer output enable/disable                                                                                                                                                                |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Timer output disabled<br>Timer operation is not reflected in the TO0n bit, output is fixed.<br>Write operation to bit TO0n bit is enabled, the level set in TO0n bit is output from the TO0n<br>pin. |
| 1     | Timer output enabled<br>Timer operation is reflected in TO0n bit, output waveform is generated.<br>Write operation to TO0n bit is ignored.                                                           |

#### Note: 1. n = 0, 1

2. For more details on register settings, refer to the RL78/G10 User's Manual Hardware Version.

#### **Timer Output Pin Output Setting**

• Timer Output Register 0 (TO0)

Set timer output.

Symbol: TO0

| 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    |
|---|---|---|---|---|---|------|------|
| 0 | 0 | 0 | 0 | 0 | 0 | TO01 | TO00 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0    |

Bits 1 and 0

| TO0n | Channel n timer output    |  |  |  |  |
|------|---------------------------|--|--|--|--|
| 0    | Timer output value is "0" |  |  |  |  |
| 1    | Timer output value is "1" |  |  |  |  |

#### Note: 1. n = 0, 1

## **Noise Filter Setting**

• Noise Filter Enable Register 1 (NFEN1)

Turn noise filter ON/OFF.

Symbol: NFEN1

| 7 | 6 | 5 | 4 | 3 | 2 | 1       | 0       |
|---|---|---|---|---|---|---------|---------|
| 0 | 0 | 0 | 0 | 0 | 0 | TNFEN01 | TNFEN00 |
| 0 | 0 | 0 | 0 | 0 | 0 | 1       | 1       |

Bits 1 and 0

| TNFEN0n | Turn noise filter ON/OFF for TI0n pin input signal |
|---------|----------------------------------------------------|
| 0       | Noise filter OFF                                   |
| 1       | Noise filter ON                                    |

Note: 1. n = 0, 1



#### **TAU Interrupt Mask Setting**

• MK0L, MK0H) Interrupt Mask Flag Registers (MK0L, MK0H) Set interrupt masks.

#### Symbol: MK0L

| 7      | 6       | 5      | 4     | 3                           | 2    | 1    | 0      |
|--------|---------|--------|-------|-----------------------------|------|------|--------|
| ТММК00 | TMMK01H | SREMK0 | SRMK0 | STMK0<br>CSIMK00<br>IICMK00 | PMK1 | PMK0 | WDTIMK |
| 1      | х       | х      | х     | х                           | х    | х    | х      |

#### Bit 7

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

#### Symbol: MK0H

| 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0      |
|---|---|---|---|---|------|------|--------|
| 1 | 1 | 1 | 1 | 1 | KRMK | ADMK | TMMK01 |
| 1 | 1 | 1 | 1 | 1 | х    | х    | 1      |

#### Bit 0

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

### 5.7.5 Main Processing

Figure 5.7 shows the flowchart for main processing.





## **Timer Array Unit Operation Enable**

• Timer Channel Start Register 0 (TS0)

Enable channel operation for timer array unit.

Symbol: TS0

| 7 | 6 | 5 | 4 | 3     | 2                 | 1    | 0    |
|---|---|---|---|-------|-------------------|------|------|
| 0 | 0 | 0 | 0 | TS03* | TS02 <sup>*</sup> | TS01 | TS00 |
| 1 | х | x | х | х     | х                 | 1    | 1    |

\*Note: 16-pin product only

Bits 0 and 1

| TS01, TS00 | Channel operation enable (start) trigger                      |  |  |  |  |
|------------|---------------------------------------------------------------|--|--|--|--|
| 0          | No trigger operation                                          |  |  |  |  |
| 1          | TE0n bit is et to 1, and the count operation becomes enabled. |  |  |  |  |

## **TAU Interrupt Request Clear Flag**

• Interrupt Request Flag Register (IF0L, IF0H)

Clear interrupt request flag.

Symbol: IF0L

| 7      | 6       | 5      | 4     | 3                           | 2    | 1    | 0      |
|--------|---------|--------|-------|-----------------------------|------|------|--------|
| TMIF00 | TMIF01H | SREIF0 | SRIF0 | STIF0<br>CSIIF00<br>IICIF00 | PIF1 | PIF0 | WDTIIF |
| 0      | х       | х      | x     | х                           | х    | х    | х      |

#### Bit 7

| TMIF00 | Interrupt Request Flag                                                 |  |  |  |
|--------|------------------------------------------------------------------------|--|--|--|
| 0      | Interrupt request signal is not generated                              |  |  |  |
| 1      | Interrupt request signal is generated, goes to interrupt request state |  |  |  |

#### Symbol: IF0H

| 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0      |
|---|---|---|---|---|------|------|--------|
| 1 | 1 | 1 | 1 | 1 | KRIF | ADIF | TMIF01 |
| 1 | 1 | 1 | 1 | 1 | х    | х    | 0      |

#### Bit 0

| TMIF01 | Interrupt Processing Control                                    |  |  |  |
|--------|-----------------------------------------------------------------|--|--|--|
| 0      | Interrupt request signal is not generated                       |  |  |  |
| 1      | Interrupt request signal is generated, interrupt request status |  |  |  |

#### **TAU Interrupt Mask Setting**

• Interrupt Mask Flag Registers (MK0L, MK0H) Set interrupt masks.

Symbol: MK0L

| 7      | 6       | 5      | 4     | 3       | 2    | 1    | 0      |
|--------|---------|--------|-------|---------|------|------|--------|
| TMMK00 | TMMK01H | SREMK0 | SRMK0 | STMK0   | PMK1 | PMK0 | WDTIMK |
|        |         |        |       | CSIMK00 |      |      |        |
|        |         |        |       | IICMK00 |      |      |        |
| 0      | x       | x      | x     | x       | x    | x    | x      |

Bit 7

| TMMK00 | Interrupt processing control  |
|--------|-------------------------------|
| 0      | Interrupt processing enabled. |
| 1      | Interrupt processing disabled |

#### Symbol: MK0H

| 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0      |
|---|---|---|---|---|------|------|--------|
| 1 | 1 | 1 | 1 | 1 | KRMK | ADMK | TMMK01 |
| 1 | 1 | 1 | 1 | 1 | х    | х    | 0      |

#### Bit 0

| l | TMMK01 | Interrupt processing control  |  |  |  |  |
|---|--------|-------------------------------|--|--|--|--|
|   | 0      | Interrupt processing enabled  |  |  |  |  |
|   | 1      | Interrupt processing disabled |  |  |  |  |

## 5.7.6 Interrupt Processing Address Settings

Figure 5.8 shows the flowchart for setting the interrupt processing addresses.



Figure 5.8 Interrupt Processing Address Setting

Processing addresses are set according to the processing address table (PROCTABLE), as shown in Figure 5.6.

| OFFSET | Processing Address | Interrupt Processing Execution Conditions                  |
|--------|--------------------|------------------------------------------------------------|
| +0     | COUNTDOWN          | Rising edge of Clock A when Clock A and B are both 0       |
| +2     | COUNTUP            | Rising edge of Clock B when Clock A and B are both 0       |
| +4     | COUNTUP            | Falling edge of Clock A when Clock A is 1 and Clock B is 0 |
| +6     | COUNTDOWN          | Rising edge of Clock B when Clock A is 1 and Clock B is 0  |
| +8     | COUNTUP            | Rising edge of Clock A when Clock A is 0 and Clock B is 1  |
| +10    | COUNTDOWN          | Falling edge of Clock B when Clock A is 0 and Clock B is 1 |
| +12    | COUNTDOWN          | Falling edge of Clock A when Clocks A and B are both 1.    |
| +14    | COUNTUP            | Falling edge of Clock B when Clocks A and B are both 1.    |

| Table | 5.6 | Processing | Address <b>T</b> | <b>Fable</b> | (PROCTABLE) |
|-------|-----|------------|------------------|--------------|-------------|
|-------|-----|------------|------------------|--------------|-------------|

### 5.7.7 INTTM00 Interrupt Processing

Figure 5.9 shows the flowchart for INTTM00 interrupt processing.



#### 5.7.8 INTTM01 Interrupt Processing

Figure 5.10 shows the flowchart for INTTM01 interrupt processing.



Figure 5.10 INTTM01 Interrupt Processing

## 5.7.9 Interrupt Processing (count-up)

Figure 5.11 shows the flowchart of count-up interrupt processing.





### 5.7.10 Interrupt Processing (count-down)

Figure 5.12 shows the flowchart of count-down interrupt processing.



## 6. Sample Code

The sample code is available on the Renesas Electronics Website.

## 7. Documents for Reference

RL78/G10 User's Manual: Hardware Rev.3.00 (R01UH0384E) RL78 Family User's Manual: Software Rev.2.20 (R01US0015E) (The latest versions of the documents are available on the Renesas Electronics Website.) Technical Updates/Technical Brochures (The latest versions of the documents are available on the Renesas Electronics Website.)

## Website and Support

Renesas Electronics Website

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

Inquiries

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

| Revision Record | RL78/G10 Two-Phase Encoding Software Control |
|-----------------|----------------------------------------------|
|-----------------|----------------------------------------------|

| Rev. | Date          | Description |                      |  |
|------|---------------|-------------|----------------------|--|
|      |               | Page        | Summary              |  |
| 1.00 | Mar. 11. 2016 |             | First edition issued |  |

General Precautions in the Handling of MPU/MCU Products

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

- 1. Handling of Unused Pins
- Handle unused pins in accord with the directions given under Handling of Unused Pins in the manual.
  - The input pins of CMOS products are generally in the high-impedance state. In operation with unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of LSI, an associated shoot-through current flows internally, and malfunctions occur due to the false recognition of the pin state as an input signal become possible. Unused pins should be handled as described under Handling of Unused Pins in the manual.
- 2. Processing at Power-on
- The state of the product is undefined at the moment when power is supplied.
  - The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the moment when power is supplied.

In a finished product where the reset signal is applied to the external reset pin, the states of pins are not guaranteed from the moment when power is supplied until the reset process is completed.

In a similar way, the states of pins in a product that is reset by an on-chip power-on reset function are not guaranteed from the moment when power is supplied until the power reaches the level at which resetting has been specified.

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

#### Notice

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

"Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; and industrial robots etc.

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

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

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

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



#### SALES OFFICES

#### **Renesas Electronics Corporation**

http://www.renesas.com

Renesas Electronics America Inc. 2801 Scott Boulevard Santa Clara, CA 95050-2549, U.S.A. Tel: +1-408-588-6000, Fax: +1-408-588-6130 Renesas Electronics Canada Limited 9251 Yonge Street, Suite 8309 Richmond Hill, Ontario Canada L4C 9T3 Tel: +1-905-237-2004 Renesas Electronics Europe Limited Dukes Meadow, Milboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K Tet: +44.1628-585-100, Fax: +44.1628-585-900 Renesas Electronics Europe GmbH Arcadiastrasse 10, 40472 Dusseldorf, Germany Tel: +49-211-6503-0, Fax: +49-211-6503-1327 Renesas Electronics (China) Co., Ltd. Room 1709, Quantum Plaza, No.27 ZhiChunLu Haidian District, Beijing 100191, P.R.China Tet: +86-10-8235-1155, Fax: +86-10-8235-7679 Renesas Electronics (Shanghai) Co., Ltd. Unit 301, Tower A, Central Towers, 555 Langao Road, Putuo District, Shanghai, P. R. China 200333 Tet: +86-21-2226-0888, Fax: +86-21-2226-0999 Unit 1601-1611, 16/F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong Tel: +852-2265-6688, Fax: +852 2886-9022 Renesas Electronics Hong Kong Limited Renesas Electronics Taiwan Co., Ltd. 13F, No. 363, Fu Shing North Road, Taipei 10543, Taiwan Tet. +886-2-8175-9600, Fax: +886 2-8175-9670 Renesas Electronics Singapore Pte. Ltd. 80 Bendemeer Road, Unit #08-02 Hyllux Innovation Centre, Singapore 339949 Tet: +65-6213-0200, Fax: +65-6213-0300 Renesas Electronics Malaysia Sdn.Bhd. Unit 1207, Block B, Menara Amcorp, Amcorp Trade Centre, No. 18, Jln Persiaran Barat, 46050 Petaling Jaya, Selangor Darul Ehsan, Malaysia Tel: +68.3-7955.59300, Fax: +60.3-7955-9510 Renesas Electronics India Pvt. Ltd. No.777C, 100 Feet Road, HALII Stage, Indiranagar, Bangalore, India Tet +91-80-67208700, Fax: +91-80-67208777 Renesas Electronics Korea Co., Ltd. 12F., 234 Teheran-ro, Gangnam-Gu, Seou Tel: +82-2-558-3737, Fax: +82-2-558-5141 oul, 135-080, Korea