

# R8C/27 Group Timer RC in PWM2 Mode

R01AN1273EJ0110 Rev. 1.10 June 1, 2012

# 1. Abstract

This document describes how to set up and use timer RC in PWM2 mode in the R8C/27 Group.

# 2. Introduction

The application example described in this document is applied to the following MCU and parameter(s):

#### • MCU: R8C/27 Group

This program can be used with other R8C/Tiny Series which have the same special function registers (SFRs) as the R8C/27 Group. Check the manual for any additions and modifications to functions. Careful evaluation is recommended before using this application note.

Note on oscillation stabilization wait time

In chapter 4.2.1 , select the high-speed on-chip oscillator after starting the high-speed on-chip oscillator and waiting until oscillation stabilizes.



# 3. Applications

# 3.1 Timer RC

Timer RC is a 16-bit timer with four I/O pins. Timer RC uses either f1 or fOCO40M as its operation clock. Table 3.1 lists the Timer RC Operation Clock.

#### Table 3.1 Timer RC Operation Clock

| Condition                                                                  | Timer RC Operation Clock |
|----------------------------------------------------------------------------|--------------------------|
| Count source is f1, f2, f4, f8, f32, or TRCCLK input (bits TCK2 to TCK0 in | f1                       |
| TRCCR1 register are set to a value from 000b to 101b)                      |                          |
| Count source is fOCO40M (bits TCK2 to TCK0 in TRCCR1 register are set      | fOCO40M                  |
| to 110b)                                                                   |                          |

Table 3.2 lists the Timer RC I/O Pins, and Figure 3.1 shows a Timer RC Block Diagram.

Timer RC has three modes:

• Timer mode

| - Input capture function    | The counter value is captured to a register, using an external signal as the trigger. |
|-----------------------------|---------------------------------------------------------------------------------------|
| - Output compare function   | Matches between the counter and register values are detected. (Pin output state       |
|                             | changes when a match is detected.)                                                    |
| The following two modes use | the output compare function:                                                          |

Т • PWM mode

- Pulses of a given width are output continuously. • PWM2 mode
  - A one-shot waveform or PWM waveform is output following the trigger after the wait time has elapsed.

Input capture function, output compare function, and PWM mode settings may be specified independently for each pin.

In PWM2 mode, waveforms are output based on a combination of the counter and the register. Pin function is decided by the mode.





# Figure 3.1 Timer RC Block Diagram

#### Table 3.2 Timer RC I/O Pins

| Pin Name                            | I/O   | Function                                                      |
|-------------------------------------|-------|---------------------------------------------------------------|
| TRCIOA(P1_1)                        | I/O   | Function differs according to the mode. Refer to descriptions |
| TRCIOB(P1_2)                        |       | of individual modes for details.                              |
| TRCIOC(P5_3 or P3_4) <sup>(1)</sup> |       |                                                               |
| TRCIOD(P5_4 or P3_5) <sup>(1)</sup> |       |                                                               |
| TRCCLK(P3_3)                        | Input | External clock input                                          |
| TRCTRG(P1_1)                        | Input | PWM2 mode external trigger input                              |

NOTE:

1. The pins used for TRCIOC and TRCIOD can be selected. Refer to the description of bits TRCIOCSEL and TRCIODSEL in the PINSR3 register in the **R8C/27 Group Hardware Manual** for details.



# 3.2 Registers Associated with Timer RC

Table 3.3 lists the Registers Associated with Timer RC. Figures 3.2 to 3.11 show details of the registers associated with timer RC.

|                | ĺ       | Ì                                   | Мо                                   | de    |       |                                                                                                                  |
|----------------|---------|-------------------------------------|--------------------------------------|-------|-------|------------------------------------------------------------------------------------------------------------------|
| Address        | Symbol  | Tir<br>Input<br>Capture<br>Function | ner<br>Output<br>Compare<br>Function | PWM   | PWM2  | Related Information                                                                                              |
| 0120h          | TRCMR   | Valid                               | Valid                                | Valid | Valid | Timer RC mode register<br>Figure 3.2 TRCMR Register                                                              |
| 0121h          | TRCCR1  | Valid                               | Valid                                | Valid | Valid | Timer RC control register 1<br>Figure 3.3 TRCCR1 Register<br>Figure 3.16 TRCCR1 Register for PWM2 Mode           |
| 0122h          | TRCIER  | Valid                               | Valid                                | Valid | Valid | Timer RC interrupt enable register<br>Figure 3.4 TRCIER Register                                                 |
| 0123h          | TRCSR   | Valid                               | Valid                                | Valid | Valid | Timer RC status register<br>Figure 3.5 TRCSR Register                                                            |
| 0124h          | TRCIOR0 | Valid                               | Valid                                | _     | -     | Timer RC I/O control register 0, timer RC I/O control<br>register 1<br>Figure 3.11 Registers TRCIOR0 and TRCIOR1 |
| 0125h          | TRCIOR1 |                                     |                                      |       |       |                                                                                                                  |
| 0126h<br>0127h | TRC     | Valid                               | Valid                                | Valid | Valid | Timer RC counter<br>Figure 3.6 TRC Register                                                                      |
| 0128h<br>0129h | TRCGRA  | Valid                               | Valid                                | Valid | Valid | Timer RC general registers A, B, C, and D<br>Figure 3.7 Registers TRCGRA, TRCGRB,                                |
| 012Ah<br>012Bh | TRCGRB  |                                     |                                      |       |       | TRCGRC, and TRCGRD                                                                                               |
| 012Ch<br>012Dh | TRCGRC  | -                                   |                                      |       |       |                                                                                                                  |
| 012Eh<br>012Fh | TRCGRD  |                                     |                                      |       |       |                                                                                                                  |
| 0130h          | TRCCR2  | -                                   | -                                    | -     | Valid | Timer RC control register 2<br>Figure 3.8 TRCCR2 Register                                                        |
| 0131h          | TRCDF   | Valid                               | _                                    | _     | Valid | Timer RC digital filter function select register<br>Figure 3.9 TRCDF Register                                    |
| 0132h          | TRCOER  | _                                   | Valid                                | Valid | Valid | Timer RC output mask enable register<br>Figure 3.10 TRCOER Register                                              |

#### Table 3.3 Registers Associated with Timer RC

– : Invalid



| b7 b6 b5 | b4 b3 b2 b1 b0 |            |                                                                    |                                                              |            |
|----------|----------------|------------|--------------------------------------------------------------------|--------------------------------------------------------------|------------|
|          |                | Symbol     | Address                                                            | After Reset                                                  |            |
|          |                | TRCMR      | 0120h                                                              | 01001000b                                                    |            |
|          |                | Bit Symbol | Bit Name                                                           | Function                                                     | RW         |
|          |                | PWMB       | PWM mode of TRCIOB select bit <sup>(2)</sup>                       | 0: Timer mode<br>1: PWM mode                                 | RW         |
|          |                | PWMC       | PWM mode of TRCIOC select bit <sup>(2)</sup>                       | 0: Timer mode<br>1: PWM mode                                 | RW         |
|          |                | PWMD       | PWM mode of TRCIOD select bit <sup>(2)</sup>                       | 0: Timer mode<br>1: PWM mode                                 | RW         |
|          |                | PWM2       | PWM2 mode select bit                                               | 0: PWM 2 mode<br>1: Timer mode or PWM mode                   | RW         |
|          |                | BFC        | TRCGRC register function select bit <sup>(3)</sup>                 | 0: General register<br>1: Buffer register of TRCGRA register | RW         |
|          |                | BFD        | TRCGRD register function select<br>bit                             | 0: General register<br>1: Buffer register of TRCGRB register | RW         |
|          |                | (b6)       | Nothing is assigned. If necessary,<br>When read, the content is 1. | set to 0.                                                    | <b> </b> - |
|          |                | TSTART     | TRC count start bit                                                | 0: Count stops<br>1: Count starts                            | RW         |

1. For notes on PWM2 mode, refer to the R8C/27 Group Hardware Manual.

2. These bits are enabled when the PWM2 bit is set to 1 (timer mode or PWM mode).

3. Set the BFC bit to 0 (general register) in PWM2 mode.

Figure 3.2 TRCMR Register



| b7 b6             | b5 b4 b3 b2 b1 b0 | O week al        | <b>A</b> -1-1                                  |                                                                                                     |    |
|-------------------|-------------------|------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------|----|
| <b>└</b> <u>╷</u> | ┯┷┯┹┱┹┲┷┯┷┯┛      | Symbol<br>TRCCR1 | Address<br>0121h                               | After Reset<br>00h                                                                                  |    |
|                   |                   | Bit Symbol       | Bit Name                                       | Function                                                                                            | RW |
|                   |                   | TOA              | TRCIOA output level select bit <sup>(1)</sup>  | Function varies according to the operating mode (function). <sup>(2)</sup>                          | RW |
|                   |                   | тов              | TRCIOB output level select bit <sup>(1)</sup>  |                                                                                                     | RW |
|                   |                   | тос              | TRCIOC output level select bit <sup>(1)</sup>  |                                                                                                     | RW |
|                   |                   | TOD              | TRCIOD output level select bit <sup>(1)</sup>  |                                                                                                     | RW |
|                   |                   | ТСК0             | Count source select bits <sup>(1)</sup>        | b6 b5 b4<br>0 0 0: f1<br>0 0 1: f2                                                                  | RW |
|                   |                   | TCK1             |                                                | 0 1 0: f4<br>0 1 1: f8<br>1 0 0: f32                                                                | RW |
|                   |                   | TCK2             |                                                | <ol> <li>1 0 1: TRCCLK input rising edge</li> <li>1 0: fOCO40M</li> <li>1 1: Do not set.</li> </ol> | RW |
|                   |                   | CCLR             | TRC counter clear select bit <sup>(2, 3)</sup> | 0: Disable clear (free-running<br>operation)<br>1: Clear by compare match in the<br>TRCGRA register | RW |

1. Set to these bits when the TSTART bit in the TRCMR register is set to 0 (count stops).

2. Bits CCLR, TOA, TOB, TOC and TOD are disabled for the input capture function of the timer mode.

3. The TRC counter performs a free-running operation for the input capture function of the timer mode independent of the CCLR bit setting.

Figure 3.3 TRCCR1 Register





Figure 3.4 **TRCIER Register** 



|  | b2 b1 b0 | Symbol<br>TRCSR | Address<br>0123h                      | After Reset<br>01110000b                                                                                                                     |    |
|--|----------|-----------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|----|
|  |          | Bit Symbol      | Bit Name                              | Function                                                                                                                                     | RW |
|  |          | IMFA            | Input capture/compare match flag A    | [Source for setting this bit to 0]<br>Write 0 after read <sup>(1)</sup> .                                                                    | RW |
|  |          | IMFB            | Input capture/compare match flag B    | [Source for setting this bit to 1]<br>Refer to the table below .                                                                             | RW |
|  |          | IMFC            | Input capture/compare match flag C    |                                                                                                                                              | RW |
|  |          | IMFD            | Input capture/compare match flag D    |                                                                                                                                              | RW |
|  |          |                 | Nothing is assigned. If necessary, se | et to 0.                                                                                                                                     |    |
|  |          | (b6 - b4)       | When read, the content is 1.          |                                                                                                                                              | _  |
|  |          | OVF             | Overflow flag                         | [Source for setting this bit to 0]<br>Write 0 after read <sup>(1)</sup> .<br>[Source for setting this bit to 1]<br>Refer to the table below. | RW |

NOTE:

1. The writing results are as follow s:

 $\mbox{ \bullet}$  This bit is set to 0 when the read result is 1 and 0 is written to the same bit.

 $\bullet$  This bit remains unchanged even if the read result is 0 and 0 is written to the same bit.

(This bit remains 1 even if it is set to 1 from 0 after reading, and writing 0.)

• This bit remains unchanged if 1 is written to it.

|            | Timer Mo                                                                                                   | de                     |                     |                 |
|------------|------------------------------------------------------------------------------------------------------------|------------------------|---------------------|-----------------|
| Bit Symbol | Input capture Function                                                                                     | Output Compare         | PWM Mode            | PWM2 Mode       |
|            |                                                                                                            | Function               |                     |                 |
| IMFA       | TRCIOA pin input edge <sup>(1)</sup>                                                                       | When the values of the | e registers TRC and | d TRCGRA match. |
| IMFB       | TRCIOB pin input edge <sup>(1)</sup>                                                                       | When the values of the | e registers TRC and | d TRCGRB match. |
| IMFC       | TRCIOC pin input edge <sup>(1)</sup> When the values of the registers TRC and TRCGRC match. <sup>(2)</sup> |                        | 1 TRCGRC            |                 |
| IMFD       | TRCIOD pin input edge <sup>(1)</sup> When the values of the registers TRC and TRCGRD match. <sup>(2)</sup> |                        | d TRCGRD            |                 |
| OVF        | When the TRC register overflow s.                                                                          |                        |                     |                 |

NOTES:

1. Edge selected by bits IOj1 to IOj0 (j = A, B, C, or D).

2. Includes the condition that bits BFC and BFD are set to 1 (buffer registers of registers TRCGRA and TRCGRB).

Figure 3.5 TRCSR Register









Figure 3.7 Registers TRCGRA, TRCGRB, TRCGRC, and TRCGRD





3. In the mode and Fwwmbdde, these bits a





- 1. These bits are enabled for the input capture function.
- These bits are enabled when in PWM2 mode and bits TCEG1 to TCEG0 in the TRCCR2 register are set to 01b, 10b, or 11b (TRCTRG trigger input enabled).
- Figure 3.9 TRCDF Register







| Timer RC I/O Cont | rol Register | 0 <sup>(1)</sup>                                                |                                                         |    |
|-------------------|--------------|-----------------------------------------------------------------|---------------------------------------------------------|----|
|                   | Symbol       | Address                                                         | After Reset                                             |    |
|                   | TRCIOR0      | 0124h                                                           | 10001000b                                               |    |
|                   | Bit Symbol   | Bit Name                                                        | Function                                                | RW |
|                   | IOA0         | TRCGRA control bits                                             | Function varies according to the operating mode         | RW |
|                   | IOA1         | 1                                                               | (function).                                             | RW |
|                   | IOA2         | TRCGRA mode select bit <sup>(2)</sup>                           | 0: Output compare function<br>1: Input capture function | RW |
|                   | (b3)         | Reserved bit                                                    | Set to 1.                                               | RW |
|                   | IOB0         | TRCGRB control bits                                             | Function varies according to the operating mode         | RW |
|                   | IOB1         |                                                                 | (function).                                             | RW |
|                   | IOB2         | TRCGRB mode select bit <sup>(3)</sup>                           | 0: Output compare function<br>1: Input capture function | RW |
|                   | (b7)         | Nothing is assigned. If necessa<br>When read, the content is 1. | ary, set to 0.                                          | —  |

NOTES:

- 1. The TRCIOR0 register is enabled in timer mode. It is disabled in modes PWM and PWM2.
- 2. When the BFC bit in the TRCMR register is set to 1 (buffer register of TRCGRA register), set the IOC2 bit in the TRCIOR1 register to the same value as the IOA2 bit in the TRCIOR0 register.
- 3. When the BFD bit in the TRCMR register is set to 1 (buffer register of TRCGRB register), set the IOD2 bit in the TRCIOR1 register to the same value as the IOB2 bit in the TRCIOR0 register.

#### Timer RC I/O Control Register 1<sup>(1)</sup>

| b7 b6 | b5 b4 | b3 b2 | b1 b0 |                                              |                                              |                                                         |    |
|-------|-------|-------|-------|----------------------------------------------|----------------------------------------------|---------------------------------------------------------|----|
|       |       | М     |       | Symbol                                       | Address                                      | After Reset                                             |    |
|       |       | TT    | ΤT    | TRCIOR1                                      | 0125h                                        | 10001000b                                               |    |
|       |       |       |       | Bit Symbol                                   | Bit Name                                     | Function                                                | RW |
|       |       |       |       | IOC0                                         | TRCGRC control bits                          | Function varies according to the operating mode         | RW |
|       |       |       |       | IOC1                                         |                                              | (function).                                             | RW |
|       |       | L     |       | IOC2                                         | TRCGRC mode select bit <sup>(2)</sup>        | 0: Output compare function<br>1: Input capture function | RW |
|       |       |       |       | Nothing is assigned. If necessary, set to 0. |                                              |                                                         |    |
|       |       |       |       | (b3)                                         | When read, the content is 1.                 |                                                         |    |
|       | L     |       |       | IOD0                                         | TRCGRD control bits                          | Function varies according to the operating mode         | RW |
|       |       |       |       | IOD1                                         |                                              | (function).                                             | RW |
|       |       |       |       | IOD2                                         | TRCGRD mode select bit <sup>(3)</sup>        | 0: Output compare function<br>1: Input capture function | RW |
|       |       |       |       | —                                            | Nothing is assigned. If necessary, set to 0. |                                                         |    |
|       |       |       |       | (b7)                                         | When read, the content is 1.                 |                                                         | _  |
| NOT   |       |       |       |                                              |                                              |                                                         |    |

NOTES:

- 1. The TRCIOR1 register is enabled in timer mode. It is disabled in modes PWM and PWM2.
- 2. When the BFC bit in the TRCMR register is set to 1 (buffer register of TRCGRA register), set the IOC2 bit in the TRCIOR1 register to the same value as the IOA2 bit in the TRCIOR0 register.
- 3. When the BFD bit in the TRCMR register is set to 1 (buffer register of TRCGRB register), set the IOD2 bit in the TRCIOR1 register to the same value as the IOB2 bit in the TRCIOR0 register.





# 3.3 Common Items for Multiple Modes

# 3.3.1 Count Source

The method of selecting the count source is common to all modes. Table 3.4 lists the Count Source Selection, and Figure 3.12 shows a Count Source Block Diagram

| Table 3.4 | Count Source Selection |
|-----------|------------------------|
|-----------|------------------------|

| Count Source                        | Selection Method                                                                                                                                            |
|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| f1, f2, f4, f8, f32                 | Count source selected using bits TCK2 to TCK0 in TRCCR1 register                                                                                            |
| fOCO40M                             | FRA00 bit in FRA0 register set to 1 (high-speed on-chip oscillator on) and bits TCK2 to TCK0 in TRCCR1 register are set to 110b (fOCO40M)                   |
| External signal input to TRCCLK pin | Bits TCK2 to TCK0 in TRCCR1 register are set to 101b (count source is rising edge of external clock) and PD3_3 bit in PD3 register is set to 0 (input mode) |



Figure 3.12 Count Source Block Diagram

The pulse width of the external clock input to the TRCCLK pin should be three cycles or more of the timer RC operation clock (see **Table 3.1 Timer RC Operation Clock**).

To select fOCO40M as the count source, set the FRA00 bit in the FRA0 register set to 1 (high-speed on-chip oscillator on), and then set bits TCK2 to TCK0 in the TRCCR1 register to 110b (fOCO40M).



# 3.3.2 Buffer Operation

Bits BFC and BFD in the TRCMR register are used to select the TRCGRC or TRCGRD register as the buffer register for the TRCGRA or TRCGRB register.

- Buffer register for TRCGRA register: TRCGRC register
- Buffer register for TRCGRB register: TRCGRD register

Buffer operation differs depending on the mode.

Table 3.5 lists the Buffer Operation in Each Mode.

| Table 3.5 | Buffer Operation in Each Mode |
|-----------|-------------------------------|
|-----------|-------------------------------|

| Function, Mode          | Transfer Timing                                                                                                  | Transfer Destination Register                                           |
|-------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| Input capture function  | Input capture signal input                                                                                       | Contents of TRCGRA (TRCGRB)<br>register are transferred to buffer       |
|                         |                                                                                                                  | register                                                                |
| Output compare function | Compare match between TRC register                                                                               | Contents of buffer register are                                         |
| PWM mode                | and TRCGRA (TRCGRB) register                                                                                     | transferred to TRCGRA (TRCGRB) register                                 |
| PWM2 mode               | <ul> <li>Compare match between TRC<br/>register and TRCGRA register</li> <li>TRCTRG pin trigger input</li> </ul> | Contents of buffer register (TRCGRD) are transferred to TRCGRB register |

When the output compare function, PWM mode, or PWM2 mode, and the TRCGRC or TRCGRD register is also functioning as a buffer register, the IMFC bit or IMFD bit in the TRCSR register is set to 1 when a compare match with the TRC register occurs.



# 3.3.3 Digital Filter

The input to TRCTRG or TRCIOj (j = A, B, C, or D) is sampled, and the level is considered to be determined when three matches occur. The digital filter function and sampling clock are selected using the TRCDF register. Figure 3.13 shows a Block Diagram of Digital Filter.



Figure 3.13 Block Diagram of Digital Filter



# 3.3.4 Forced Cutoff of Pulse Output

When using the timer mode's output compare function, the PWM mode, or the PWM2 mode, pulse output from the TRCIOj (j = A, B, C, or D) output pin can be forcibly cut off and the TRCIOj pin set to function as a programmable I/O port by means of input to the INTO pin.

A pin used for output by the timer mode's output compare function, the PWM mode, or the PWM2 mode can be set to function as the timer RC output pin by setting the Ej bit in the TRCOER register to 0 (timer RC output enabled). If "L" is input to the INT0 pin while the PTO bit in the TRCOER register is set to 1 (pulse output forced cutoff signal input INT0 enabled), bits EA, EB, EC, and ED in the TRCOER register are all set to 1 (timer RC output disabled, TRCIOj output pin functions as the programmable I/O port). When one or two cycles of the timer RC operation clock after "L" input to the INT0 pin (refer to **Table 3.1 Timer RC Operation Clock**) has elapsed, the TRCIOj output pin becomes a programmable I/O port.

Make the following settings to use this function.

- Set the pin state following forced cutoff of pulse output (high impedance (input), "L" output, or "H" output) (refer to the **R8C/27 Group Hardware Manual**).
- Set the INT0EN bit to 1 (INT0 input enabled) and the INT0PL bit to 0 (one edge) in the INTEN register.
- Set the PD4\_5 bit in the PD4 register to 0 (input mode).
- Select the INTO digital filter by means of bits INTOF1 to INTOF0 in the INTF register.
- Set the PTO bit in the TRCOER register to 1 (pulse output forced cutoff signal input INTO enabled).

The IR bit in the INTOIC register is set to 1 (interrupt request) in accordance with the setting of the POL bit and a change in the  $\overline{INT0}$  pin input (refer to the **R8C/27 Group Hardware Manual**). For details on interrupts, refer to the **R8C/27 Group Hardware Manual**.





Figure 3.14 Forced Cutoff of Pulse Output



# 3.4 PWM2 Mode

This mode outputs a single PWM waveform. After a given wait time has elapsed following the trigger, the pin output switches to active level. Then, after a given time, the output switches back to inactive level. Furthermore, the counter stops at the same time the output returns to inactive level, making it possible to use PWM2 mode to output a programmable wait one-shot waveform.

Since timer RC uses multiple general registers in PWM2 mode, other modes cannot be used in conjunction with it.

Figure 3.15 shows a Block Diagram of PWM2 Mode, Table 3.6 lists the Specifications of PWM2 Mode, Figure 3.16 shows the register associated with PWM2 mode, Table 3.7 lists the Functions of TRCGRj Register in PWM2 Mode, and Figures 3.17 to 3.19 show Operating Examples of PWM2 Mode.



Figure 3.15 Block Diagram of PWM2 Mode



| Item                                | Specification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Count source                        | f1, f2, f4, f8, f32, fOCO40M, or external signal (rising edge) input to TRCCLK pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| Count operation                     | Increment TRC register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| PWM waveform                        | PWM period: 1/fk × (m + 1) (no TRCTRG input)<br>Active level width: 1/fk × (n - p)<br>Wait time from count start or trigger: 1/fk × (p + 1)<br>fk: Count source frequency<br>m: TRCGRA register setting value<br>n: TRCGRB register setting value<br>p: TRCGRC register setting value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|                                     | TRCTRG input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| Count start conditions              | <ul> <li>Bits TCEG1 to TCEG0 in the TRCCR2 register are set to 00b (TRCTRG trigger disabled)<br/>1 (count starts) is written to the TSTART bit in the TRCMR register.</li> <li>Bits TCEG1 to TCEG0 in the TRCCR2 register are set to 01b, 10b, or 11b (TRCTRG trigger enabled).</li> <li>When the TSTART bit in the TRCMR register is set to 1 (count starts), and TRCIOB output is inactive level, a trigger is input to the TRCTRG pin</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| Count stop conditions               | <ul> <li>O (count stops) is written to the TSTART bit in the TRCMR register while the CSEL bit in the TRCCR2 register is set to 0 or 1.</li> <li>The TRCIOB pin outputs the initial level in accordance with the value of the TOB bit in the TRCCR1 register. The TRC register retains the value before count stops.</li> <li>The count stops due to a compare match with TRCGRA while the CSEL bit in the TRCCR2 register is set to 1.</li> <li>The TRCIOB pin outputs the initial level. The TRC register retains the value before count stops due to a compare match with TRCGRA while the CSEL bit in the TRCCR2 register is set to 1.</li> <li>The TRCIOB pin outputs the initial level. The TRC register retains the value before count stops if the CCLR bit in the TRCCR1 register is set to 0. The TRC register is set to 0000h if the CCLR bit in the TRCCR1 register is set to 1.</li> </ul> |  |  |
| Interrupt request generation timing | <ul> <li>Compare match (contents of TRC and TRCGRj registers match)</li> <li>The TRC register overflows</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| TRCIOA/TRCTRG pin<br>function       | Programmable I/O port or TRCTRG input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| TRCIOB pin function                 | PWM output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| TRCIOC and TRCIOD pin functions     | Programmable I/O port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| INT0 pin function                   | Programmable I/O port, pulse output forced cutoff signal input, or INTO interrupt input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| Read from timer                     | The count value can be read by reading the TRC register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| Write to timer                      | The TRC register can be written to.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| Select functions                    | <ul> <li>External trigger and valid edge selected<br/>The edge or edges of the signal input to the TRCTRG pin can be used as the PWM output<br/>trigger: rising edge, falling edge, or both rising and falling edges</li> <li>Buffer operation (refer to 3.3.2 Buffer Operation)</li> <li>Pulse output forced cutoff signal input (refer to 3.3.4 Forced Cutoff of Pulse Output)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|                                     | Digital filter (refer to 3.3.3 Digital Filter)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |

# Table 3.6 Specifications of PWM2 Mode

j = A, B, C, or D



| b7 b6 l | b5 b4 b3 | 3 b2 | b1 b0 |            |                                               |                                                                                                                                                                                                                                                                                                                                |    |
|---------|----------|------|-------|------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
|         |          |      |       | Symbol     | Address                                       | After Reset                                                                                                                                                                                                                                                                                                                    |    |
|         |          | Т    | ТΤ    | TRCCR1     | 0121h                                         | 00h                                                                                                                                                                                                                                                                                                                            |    |
|         |          |      |       | Bit Symbol | Bit Name                                      | Function                                                                                                                                                                                                                                                                                                                       | RW |
|         |          |      |       | TOA        | TRCIOA output level select bit <sup>(1)</sup> | Disabled in the PWM2 mode                                                                                                                                                                                                                                                                                                      | RW |
|         |          |      |       | ТОВ        | TRCIOB output level select bit <sup>(1)</sup> | 0: Active level "H"<br>(Initial output "L"<br>"H" output by compare match in the<br>TRCGRC register<br>"L" output by compare match in the<br>TRCGRB register)<br>1: Active level "L"<br>(Initial output "H"<br>"L" output by compare match in the<br>TRCGRC register<br>"H" output by compare match in the<br>TRCGRB register) | RW |
|         |          |      |       | TOC        | TRCIOC output level select bit <sup>(1)</sup> | Disabled in the PWM2 mode                                                                                                                                                                                                                                                                                                      | RW |
|         |          |      |       | TOD        | TRCIOD output level select bit <sup>(1)</sup> | -                                                                                                                                                                                                                                                                                                                              | RV |
|         |          |      |       | TCK0       | Count source select bits <sup>(1)</sup>       | b6 b5 b4<br>0 0 0: f1<br>0 0 1: f2                                                                                                                                                                                                                                                                                             | RW |
|         |          |      |       | TCK1       |                                               | 0 1 0:f4<br>0 1 1:f8<br>1 0 0:f32                                                                                                                                                                                                                                                                                              | RW |
|         |          |      |       | TCK2       |                                               | <ol> <li>1 0 1: TRCCLK input rising edge</li> <li>1 0: fOCO40M</li> <li>1 1: Do not set.</li> </ol>                                                                                                                                                                                                                            | RW |
|         |          |      |       | CCLR       | TRC counter clear select bit                  | 0 : Disable clear (free-running operation)<br>1 : Clear by compare match in the<br>TRCGRA register                                                                                                                                                                                                                             | RW |

1. Set to these bits when the TSTART bit in the TRCMR register is set to 0 (count stops).

#### Figure 3.16 TRCCR1 Register for PWM2 Mode

| Register | Setting | Register Function                                                                                | PWM2 Output Pin |
|----------|---------|--------------------------------------------------------------------------------------------------|-----------------|
| TRCGRA   | -       | General register. Set the PWM period.                                                            |                 |
| TRCGRB   | -       | General register. Set the PWM output change point.                                               |                 |
| TRCGRC   | BFC = 0 | General register. Set the PWM output change point (wait time after trigger).                     |                 |
| TRCGRD   | BFD = 0 | (Not used in PWM2 mode)                                                                          | -               |
| TRCGRD   | BFD = 1 | Buffer register. Set the next PWM output change point (refer to <b>3.3.2 Buffer Operation</b> ). | TRCIOB pin      |

j = A, B, C, or D

BFC, BFD: Bits in TRCMR register

NOTE:

1. Do not set the TRCGRB and TRCGRC registers to the same value.



Figure 3.17 Operating Example of PWM2 Mode (TRCTRG Trigger Input Disabled)

RENESAS



Figure 3.18 Operating Example of PWM2 Mode (TRCTRG Trigger Input enabled)

RENESAS



Figure 3.19 Operating Example of PWM2 Mode (Duty 0% and Duty 100%)



# 3.5 Timer RC Interrupt

Timer RC generates a timer RC interrupt request from five sources. The timer RC interrupt uses the single TRCIC register (bits IR and ILVL0 to ILVL2) and a single vector.

Table 3.8 lists the Registers Associated with Timer RC Interrupt, and Figure 3.20 is a Timer RC Interrupt Block Diagram.

| Table 3.8 | Registers Associated with Timer RC Interrupt |
|-----------|----------------------------------------------|
|-----------|----------------------------------------------|

| Timer RC Status Register | Timer RC Interrupt Enable Register | Timer RC Interrupt Control Register |
|--------------------------|------------------------------------|-------------------------------------|
| TRCSR0                   | TRCIER                             | TRCIC                               |



#### Figure 3.20 Timer RC Interrupt Block Diagram

Like other maskable interrupts, the timer RC interrupt is controlled by the combination of the I flag, IR bit, bits ILVL0 to ILVL2, and IPL. However, it differs from other maskable interrupts in the following respects because a single interrupt source (timer RC interrupt) is generated from multiple interrupt request sources.

- The IR bit in the TRCIC register is set to 1 (interrupt requested) when a bit in the TRCSR register is set to 1 and the corresponding bit in the TRCIER register is also set to 1 (interrupt enabled).
- The IR bit is set to 0 (no interrupt request) when the bit in the TRCSR register or the corresponding bit in the TRCIER register is set to 0, or both are set to 0. In other words, the interrupt request is not maintained if the IR bit is once set to 1, but the interrupt is not acknowledged.
- If after the IR bit is set to 1, another interrupt source is triggered, the IR bit remains set to 1 and does not change.
- If multiple bits in the TRCIER register are set to 1, use the TRCSR register to determine the source of the interrupt request.
- The bits in the TRCSR register are not automatically set to 0 when an interrupt is acknowledged. Set them to 0 within the interrupt routine. Refer to **Figure 3.5 TRCSR Register**, for the procedure for setting these bits to 0.

#### Refer to Figure 3.4 TRCIER Register, for details on the TRCIER register.

Refer to the **R8C/27 Group Hardware Manual** for details on the TRCIC register and for information on interrupt vectors.



# 3.6 Notes on Timer RC

# 3.6.1 TRC Register

• The following note applies when the CCLR bit in the TRCCR1 register is set to 1 (clear TRC register at compare match with TRCGRA register).

When using a program to write a value to the TRC register while the TSTART bit in the TRCMR register is set to 1 (count starts), ensure that the write does not overlap with the timing with which the TRC register is set to 0000h.

If the timing of the write to the TRC register and the setting of the TRC register to 0000h coincide, the write value will not be written to the TRC register and the TRC register will be set to 0000h.

Reading from the TRC register immediately after writing to it can result in the value previous to the write being read out. To prevent this, execute the JMP.B instruction between the read and the write instructions.
 Program Example MOV.W #XXXXh, TRC ;Write

| xample | MOV.W | #XXXXh, TRC | ;Write             |
|--------|-------|-------------|--------------------|
|        | JMP.B | L1          | ;JMP.B instruction |
| L1:    | MOV.W | TRC,DATA    | ;Read              |

# 3.6.2 TRCSR Register

Reading from the TRCSR register immediately after writing to it can result in the value previous to the write being read out. To prevent this, execute the JMP.B instruction between the read and the write instructions.

| Program Example | MOV.B | #XXh, TRCSR | ;Write             |
|-----------------|-------|-------------|--------------------|
|                 | JMP.B | L1          | ;JMP.B instruction |
| L1:             | MOV.B | TRCSR,DATA  | ;Read              |

# 3.6.3 Count Source Switching

• Stop the count before switching the count source. Switching procedure:

- (1) Set the TSTART bit in the TRCMR register to 0 (count stops).
- (2) Change the settings of bits TCK2 to TCK0 in the TRCCR1 register.

• After switching the count source from fOCO40M to another clock, allow a minimum of two cycles of f1 to elapse after changing the clock setting before stopping fOCO40M.

Switching procedure:

- (1) Set the TSTART bit in the TRCMR register to 0 (count stops).
- (2) Change the settings of bits TCK2 to TCK0 in the TRCCR1 register.
- (3) Wait for a minimum of two cycles of f1.
- (4) Set the FRA00 bit in the FRA0 register to 0 (high-speed on-chip oscillator off).

# 3.6.4 TRCMR Register in PWM2 Mode

When the CSEL bit in the TRCCR2 register is set to 1 (count stops at compare match with the TRCGRA register), do not set the TRCMR register at compare match timing of registers TRC and TRCGRA.



## 4. Program Overview

This program can be used on timer RC to output a single PWM waveform with the same period at the PWM period (200  $\mu$ s). The output signal is as follows.

TRCIOB pin: active level ("H")  $100 \ \mu s = 40 \ \text{MHz} \times (\text{TRCGRB} - \text{TRCGRC})$ = 25 ns × (6000 - 2000) = 25 ns × 4000

Set TRCGRA to the PWM period (100  $\mu$ s). 100  $\mu$ s = 40 MHz × (TRCGRA + 1) = 25 ns × 4000

TRCGRC register setting (50  $\mu$ s) TRCGRB register setting (50  $\mu$ s)

The setting conditions of this program are as follows:

• Select the high-speed on-chip oscillator (fOCOM40M) as count source.

- Clear timer RC counter (TRC) at compare match with TRCGRA.
- For the TRCIOB pin, set the output level to active ("H") and the initial level to inactive ("L")
- Output an active level signal ("L") from the TRCIOB output pin at compare match with TRC and TRCGRC.
- Output an in active level signal ("H") from the TRCIOC output pin at compare match with TRC and TRCGRB.
- Disable TRCTRG trigger input.
- Do not use the pulse output forced cutoff input function.

Figure 4.1 shows the Pin Used.



Figure 4.1 Pin Used



# 4.1 Function Table

Table 4.1

| Declaration               | void timer_rc_init  | void timer_rc_init(void)                              |         |  |
|---------------------------|---------------------|-------------------------------------------------------|---------|--|
| Overview                  | SFR initial setting | SFR initial setting associated with timer RC          |         |  |
| Argument                  | Argument name       | Argument name                                         |         |  |
|                           | None                | None                                                  |         |  |
| Variable used<br>(global) | Variable name       |                                                       | Usage   |  |
|                           | None                |                                                       |         |  |
| Return value              | Туре                | Value                                                 | Meaning |  |
|                           | None                |                                                       |         |  |
| Function                  | Initialize the SFR  | Initialize the SFR registers associated with timer RC |         |  |



# 4.2 Flow chart

# 4.2.1 Main Function





# 4.2.2 Timer RC SER Initial Setting





# 5. Sample Programming Code

A sample program can be downloaded from the Renesas Electronics website.

# 6. Reference Documents

User's Manual: Hardware R8C/27 Group Hardware Manual The latest version can be downloaded from the Renesas Electronics website.

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

# Website and Support

Renesas Electronics website http://www.renesas.com

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



# R8C/27 Group

**REVISION HISTORY** 

R8C/27 Group Timer RC in PWM2 Mode

| Rev. | Date         | Description |                                                     |  |
|------|--------------|-------------|-----------------------------------------------------|--|
|      |              | Page        | Summary                                             |  |
| 1.00 | Dec 01, 2006 | _           | First Edition issued                                |  |
| 1.10 | June 1, 2012 | 1           | 1 Note on oscillation stabilization wait time added |  |
|      |              | -           | Previous document number: REJ05B0840                |  |

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



# General Precautions in the Handling of MPU/MCU Products

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

1. Handling of Unused Pins

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

- The input pins of CMOS products are generally in the high-impedance state. In operation with 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 one with a different part number, confirm that the change will not lead to problems.

— The characteristics of MPU/MCU in the same group but having different part numbers may differ because of the differences in internal memory capacity and layout pattern. When changing to products of different part numbers, implement a system-evaluation test for each of the products.

#### Notice

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

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

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

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

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



#### SALES OFFICES

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

#### **Renesas Electronics Corporation**

http://www.renesas.com

 Renesas Electronics America Inc.

 2880 Scott Boulevard Santa Clara, CA 95050-2554, U.S.A.

 Tel: +1-408-588-6000, Fax: +1-408-588-6130

 Renesas Electronics Canada Limited

 101 Nicholson Road, Newmarket, Ontario L3Y 9C3, Canada

 Tel: +1-905-989-5441, Fax: +1-905-988-3220

 Renesas Electronics Europe Limited

 Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K

 Tel: +49-215-85100, Fax: +44-1628-585-900

 Renesas Electronics Europe GmbH

 Arcadiastrase 10, 40472 Dusseldorf, Germany

 Tel: +92-21-65030, Fax: +44-1628-585-900

 Renesas Electronics China) Co., Ltd.

 The Floor, Quantum Plaza, No.27 ZhiChunLu Haidian District, Beijing 100083, P.R.China

 Tel: +92-21-65030, Fax: +48-21-858-7679

 Renesas Electronics (Shanghai) Co., Ltd.

 Unit 204, 205, AZIA Center, No.1233 Lujiazui Ring Rd., Pudong District, Shanghai 200120, China

 Tel: +85-257-1816, Fax: +852-2886-7789

 Renesas Electronics Hong Kong Limited

 Unit 1601-1613, 16/F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong

 Tel: +852-2886-9318, Fax: +852 2886-9022/9044

 Renesas Electronics Taiwan Co., Ltd.

 137. No. 363, Fu Shing Month Road, Taipei, Taiwan

 138., No. 353, Fu Shing Month Road, Taipei, Taiwan

 <t