

RL78/G13

DMA Controller (PWM Output)

R01AN0740EJ0100 Rev. 1.00 Feb. 01, 2012

#### Introduction

This application note explains how to use the PWM output function of the timer array unit (TAU) through the DMA controller. The sample application covered in this application note controls the brightness of an LED using the PWM output function. It starts the DMA controller using the timer interrupt from channel 2 of the timer array unit 0 as the trigger. The application transfers data from the on-chip RAM to the TDR01 register of the TAU0 through the DMA controller. The brightness of the LED is controlled by changing the duty factor of the PWM output.

# **Target Device**

RL78/G13

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

# Contents

| 1.   | Specifications                                         | . 3 |
|------|--------------------------------------------------------|-----|
| 2.   | Operation Check Conditions                             | . 5 |
| 3.   | Related Application Note                               | . 5 |
| 4.   | Description of the Hardware                            | . 6 |
| 4.1  | Hardware Configuration Example                         | . 6 |
| 4.2  | List of Pins to be Used                                | . 6 |
| 5.   | Software Description                                   | . 7 |
| 5.1  | Operation Outline                                      | . 7 |
| 5.2  | List of Option Byte Settings                           | . 8 |
| 5.3  | List of Constants                                      | . 8 |
| 5.4  | List of Variables                                      | . 8 |
| 5.5  | List of Functions                                      | . 9 |
| 5.6  | Function Specifications                                | . 9 |
| 5.7  | Flowcharts                                             | 11  |
| 5.7  | 1 Initialization Function                              | 12  |
| 5.7  | 2 System Function                                      | 13  |
| 5.7  | 3 I/O Port Setup                                       | 14  |
| 5.7  | 4 CPU Clock Setup                                      | 16  |
| 5.7  | 5 TAU0 Setup                                           | 17  |
| 5.7  | 6 Initializing DMA Controller                          | 19  |
| 5.7  | 7 Main Processing                                      | 25  |
| 5.7  | 8 DMA Transfer Enable Processing                       | 26  |
| 5.7  | 9 Starting TAU0 (Channels 0 and 1)                     | 29  |
| 5.7  | 10 Starting TAU0 (Channel 2)                           | 30  |
| 5.7  | 11 TAU0 Timer Interrupt Processing (Channel 2)         | 31  |
| 5.7  | 12 DMA Transfer End Interrupt Processing               |     |
| 6.   | Sample Code                                            | 33  |
| 7.   | Documents for Reference                                | 33  |
| Revi | sion Record                                            | 34  |
| Gan  | eral Precautions in the Handling of MPII/MCII Products | 35  |

# 1. Specifications

The sample application covered in this application note generates PWM output by operating channel 0 of the timer array unit 0 (TAU0) as the master and channel 1 as a slave in simultaneous operation. The PWM output is connected to LED1 (for PWM output) to control the brightness of the LED.

Channel 2 of the TAU0 (with an interval time of 500 ms) and the DMA controller are used to change the duty factor of the PWM output at regular intervals. The output to LED2 (for status update) is inverted at the timing when the duty factor is changed.

Table 1.1 shows peripheral functions to be used and their uses. Figure 1.1 presents an overview of the PWM output operation. Table 1.2 shows the relationship between the duty factors of the PWM output and the brightness of the LED. Figure 1.2 is a timing chart which outlines the PWM output operation.

| Peripheral Function | Use                                                                                                                                                                                                                                                                  |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer array unit 0  | This unit is used to set the PWM function by operating channel 0 and channel 1 in simultaneous operation and deliver a PWM output from the TO01 pin.  Channel 2 is set up as an interval timer to generate timer interrupts (INTTM02) at regular intervals (500 ms). |
| DMA Controller      | INTTM02 is selected as the DMA start source and the duty factor of the PWM output is changed when an INTTM02 occurs.                                                                                                                                                 |

Table 1.1 Peripheral Functions to be Used and their Uses



Figure 1.1 Overview of PWM Output Operation

Note: The first change in the duty factor of the PWM output occurs in one second after power is turned on.

Table 1.2 Relationship between Duty Factors of PWM Output and Brightness of LED

| Duty factor | Brightness of LED1 |
|-------------|--------------------|
| 10%         | 90%                |
| 30%         | 70%                |
| 50%         | 50%                |
| 70%         | 30%                |
| 90%         | 10%                |



Figure 1.2 Timing Chart which Outlines PWM Output Operation

# 2. Operation Check Conditions

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

**Table 2.1 Operation Check Conditions** 

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

# 3. Related Application Note

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

RL78/G13 Initialization (R01AN0451E) Application Note

# 4. Description of the Hardware

# 4.1 Hardware Configuration Example

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



Figure 4.1 Hardware Configuration

Caution: 1. The purpose of this circuit is only to provide the connection outline and the circuit is simplified accordingly. When designing and implementing an actual circuit, provide proper pin treatment and make sure that the hardware's electrical specifications are met (connect the input-only ports separately to  $V_{DD}$  or  $V_{SS}$  via a resistor).

- 2. Connect any pins whose name begins with  $EV_{SS}$  to  $V_{SS}$  and any pins whose name begins with  $EV_{DD}$  to  $V_{DD}$ , respectively.
- 3.  $V_{DD}$  must be held at not lower than the reset release voltage  $(V_{LVI})$  that is specified as LVD.

### 4.2 List of Pins to be Used

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

Table 4.1 Pins to be Used and their Functions

| Pin Name | I/O    | Description                                         |
|----------|--------|-----------------------------------------------------|
| P16/TO01 | Output | PWM output port                                     |
| P10      | Output | LED port to indicate the update of the duty factor. |

## 5. Software Description

## 5.1 Operation Outline

The sample application covered in this application note uses the PWM function by operating channels 0 and 1 of the TAU0 in simultaneous operation. The PWM output from P16/TO01 is used to control the brightness of LED1.

The application uses channel 2 of the TAU0 (with an interval time of 500 ms) and the DMA controller to change the duty factor of the PWM output at certain intervals. The output to LED2 (for status update) is inverted at the timing when the duty factor is changed.

#### (1) Initialize the DMA controller.

<Conditions for setting>

- Set the DMA transfer direction to "on-chip RAM to SFR."
- Use a timer interrupt (INTTM02) from timer channel 2 as the DMA start source.
- Set the transfer data size to 16 bits.
- Set the DMA transfer destination to timer data register 01 (TDR01).
- Set the DMA transfer source to the start address of the variable dma\_buffer [].
- Set the number of times of DMA transfer to 5.

#### (2) Initialize the TAU0.

<Conditions for setting>

- Set the P16/TO01 pin to a PWM output.
- Set channel 0 of the TAU0 to 2-ms cycle interval timer mode.
- Set channel 1 of the TAU0 to one-count mode.
- Use channel 2 of the TAU0 in 500-ms interval timer mode.
- Initialize the duty factor of the PWM output to 10%.
- Use a timer interrupt (INTTM02) from channel 2 of the TAU0.
- (3) Start operation by setting both the operation enable trigger bits for channels 0 and 1 of the TAU0 simultaneously to 1. Also, set the operation enable trigger bit of channel 2 of the TAU0 to 1.
- (4) Execute a HALT instruction and wait for a timer interrupt (INTTM02) from channel 2 of the TAU0 and a transfer end interrupt (INTDMA0) from channel 0 of the DMA controller.
- (5) Cancel the HALT mode when timer interrupts (INTTM02) occur at intervals of 500 ms.
- (6) Increase the duty factor from 10% to 90% ( $10\% \rightarrow 30\% \rightarrow 50\% \rightarrow 70\% \rightarrow 90\%$ ) in units of 20% each time a timer interrupt (INTTM02) from channel 2 of the TAU0 occurs.
- (7) When the duty factor reaches 90%, the DMA controller is set up again so that it repeats transfer starting at a duty factor of 10% by a subsequent DMA transfer end interrupt (INTDMA0) of channel 0 of the DMA controller.
- (8) After the processing of the timer interrupt (INTTM02) from channel 2 of the TAU0 is completed and after the processing of the transfer end interrupt (INTDMA0) from channel 0 of the DMA controller is completed, the application reexecutes the HALT instruction and waits for a timer interrupt (INTTM02) from channel 2 of the TAU0 and a transfer end interrupt (INTDMA0) from channel 0 of the TAU0.

#### 5.2 **List of Option Byte Settings**

Table 5.1 summarizes the settings of the option bytes.

**Option Byte Settings** Table 5.1

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

#### 5.3 **List of Constants**

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

Table 5.2 **Constants for the Sample Program** 

| Constant                    | Setting | Description                                  |
|-----------------------------|---------|----------------------------------------------|
| DUTY_FACTOR_BASE            | 640     | Value of 1% duty factor                      |
| DUTY_PATTERN_NUM            | 5       | Number of duty factor patterns               |
| _0002_TAU_CH1_OUTPUT_ENABLE | 0x0002U | TOE0 value to enable the TO01                |
| _0001_TAU_CH0_START_TRG_ON  | 0x0001U | TS0 value to enable channel 0 of TAU0        |
| _0002_TAU_CH1_START_TRG_ON  | 0x0002U | TS0 value to enable channel 1 of TAU0        |
| _0004_TAU_CH2_START_TRG_ON  | 0x0004U | TS0 value to enable channel 2 of TAU0        |
| _0005_DMA0_BYTE_COUNT       | 0x0005U | Number of times of DMA transfer by channel 0 |

#### 5.4 **List of Variables**

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

Table 5.3 **Global Variable** 

| Type     | e Variable Name Contents |                               | Function Used             |
|----------|--------------------------|-------------------------------|---------------------------|
| uint16_t | duty_array[ DUTY_PATTE   | Array of duty factor patterns | R_DMAC0_Create_UserInit() |
|          | RN_NUM]                  |                               | R_DMAC0_Interrupt()       |

#### 5.5 List of Functions

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

#### Table 5.4 Functions

| Function Name             | Outline                                            |
|---------------------------|----------------------------------------------------|
| R_DMAC0_Start             | DMA0 transfer enabling                             |
| R_TAU0_Channel0_Start     | PWM timer count start processing                   |
| R_TAU0_Channel2_Start     | Timer count start processing to change duty factor |
| R_DMAC0_Interrupt         | DMA0 transfer end interrupt                        |
| R_TAU0_Channel2_Interrupt | Timer interrupt of timer channel 2                 |

# 5.6 Function Specifications

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

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

Synopsis DMA0 transfer enabling

Header r\_cg\_dmac.h

Declaration void R\_DMAC0\_Start(void);

Explanation This function starts controlling DMA transfer.

It performs the following operations:

• Clears the DMA transfer end interrupt request.

Enables DMA transfer end interrupts.

Enables DMA transfer and transitions to the DMA transfer trigger wait mode.

Arguments None Return value None Remarks None

#### [Function Name] R\_TAU0\_Channel0\_Start

Synopsis PWM timer count start processing

Header r\_cg\_timer.h

Declaration void R\_TAU0\_Channel0\_Start(void);

Explanation This function enables channel 1 for timer outputs.

It starts channels 0 and 1 for counting.

Arguments None
Return value None
Remarks None

#### [Function Name] R\_TAU0\_Channel2\_Start

Synopsis Timer count start processing to change duty factor

Header r\_cg\_timer.h

Declaration void R\_TAU0\_Channel2\_Start(void);

Explanation This function clears the timer interrupt flag of channel 2.

It enables the timer interrupt of channel 2.

It starts channel 2 for counting.

Arguments None Return value None Remarks None

### [Function Name] R\_DMAC0\_Interrupt

Synopsis DMA0 transfer end interrupt

Header r\_cg\_dmac.h

Declaration \_\_interrupt void R\_DMAC0\_Interrupt(void);

Explanation This interrupt processing is performed when the specified number of times of DMA transfer is

finished.

It resets the on-chip RAM address and the number of times of DMA transfer.

Arguments None Return value None Remarks None

### Function Name] R\_TAU0\_Channel2\_Interrupt

Synopsis Timer interrupt of timer channel 2

Header r\_cg\_timer.h

Declaration \_\_interrupt void R\_TAU0\_Channel2\_Interrupt(void);

Explanation This function inverts the polarity of the output from P10.

Arguments None Return value None Remarks None

# 5.7 Flowcharts

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



Figure 5.1 Overall Flow

# 5.7.1 Initialization Function

Figure 5.2 shows the flowchart for the initialization function.



Figure 5.2 Initialization Function

# 5.7.2 System Function

Figure 5.3 shows the flowchart for the system function.



Figure 5.3 System Function

# 5.7.3 I/O Port Setup

Figure 5.4 shows the flowchart for I/O port setup.



Figure 5.4 I/O Port Setup

Note: Refer to the section entitled "Flowcharts" in RL78/G13 Initialization Application Note (R01AN0451E) for the configuration of the unused ports.

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

Setting up the pin for the LED for indicating the duty factor update status

- Port register 1 (P1)
- Port mode register 1 (PM1)

# Symbol: P1

| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| P17 | P16 | P15 | P14 | P13 | P12 | P11 | P10 |
| 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### Bit 0

| P10 | P10 pin output data control (in output mode) |  |  |  |  |  |
|-----|----------------------------------------------|--|--|--|--|--|
| 0   | Output 0                                     |  |  |  |  |  |
| 1   | Output 1                                     |  |  |  |  |  |

# Symbol: PM1

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

#### Bit 0

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

# 5.7.4 CPU Clock Setup

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



Figure 5.5 CPU Clock Setup

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

# 5.7.5 TAU0 Setup

Figures 5.6 and 5.7 show the flowchart for setting up the TAU0.



Figure 5.6 TAU0 Setup (1/2)



Figure 5.7 TAU0 Setup (2/2)

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

# 5.7.6 Initializing DMA Controller

Figure 5.8 shows the flowchart for initializing the DMA controller.



Figure 5.8 Initializing DMA Controller

## Disabling DMA channel 0

• DMA operation control register (DRC0)

Symbol: DRC0

| 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|------|---|---|---|---|---|---|------|
| DEN0 | 0 | 0 | 0 | 0 | 0 | 0 | DST0 |
| 1    | 0 | 0 | 0 | 0 | 0 | 0 | 0    |

#### Bit 7

| DEN0 | DMA operation enable flag                                                              |
|------|----------------------------------------------------------------------------------------|
| 0    | Disables DMA channel 0 (stops operating clock of DMA).  Disables DMA setup processing. |
| 1    | Enables DMA channel 0. Enables DMA setup processing.                                   |

#### Bit 0

| DST0 | DMA transfer mode flag                                      |  |  |  |  |  |
|------|-------------------------------------------------------------|--|--|--|--|--|
| 0    | DMA transfer of DMA channel 0 is completed.                 |  |  |  |  |  |
| 1    | DMA transfer of DMA channel 0 is not completed (still under |  |  |  |  |  |
|      | execution).                                                 |  |  |  |  |  |

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

### Initialization for DMA transfer end interrupts

- Interrupt request flag register (IF0H) Clear interrupt request flag.
- Interrupt mask flag register (MK0H) Clear interrupt mask.
- Priority specification flag register (PR00H, PR10H) Interrupt level: Level 3 (lowest level)

Symbol: IF0H

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

#### Bit 3

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

# Symbol: MK0H

| 7      | 6       | 5       | 4      | 3      | 2      | 1       | 0       |
|--------|---------|---------|--------|--------|--------|---------|---------|
| SREMK0 | SRMK0   | STMK0   |        |        | SREMK2 | SRMK2   | STMK2   |
| TMMK01 | CSIMK01 | CSIMK00 | DMAMK1 | DMAMK0 | TMMK11 | CSIMK21 | CSIMK20 |
| Н      | IICMK01 | IICMK00 |        |        | Н      | IICMK21 | IICMK20 |
| Х      | X       | X       | X      | 1      | X      | X       | X       |

#### Bit 3

| DMAMK0 | Interrupt processing control   |
|--------|--------------------------------|
| 0      | Enables interrupt processing.  |
| 1      | Disables interrupt processing. |

# Symbol: PR00H

| 7       | 6        | 5        | 4       | 3       | 2       | 1        | 0        |
|---------|----------|----------|---------|---------|---------|----------|----------|
| SREPR00 | SRPR00   | STPR00   |         |         | SREPR02 | SRPR02   | STPR02   |
| TMPR001 | CSIPR001 | CSIPR000 | DMAPR01 | DMAPR00 | TMPR011 | CSIPR021 | CSIPR020 |
| Н       | IICPR001 | IICPR000 |         |         | Н       | IICPR021 | IICPR020 |
| Х       | Х        | Х        | Х       | 1       | х       | х        | х        |

# Symbol: PR10H

| 7       | 6        | 5        | 4       | 3       | 2       | 1        | 0        |
|---------|----------|----------|---------|---------|---------|----------|----------|
| SREPR10 | SRPR10   | STPR10   |         |         | SREPR12 | SRPR12   | STPR12   |
| TMPR101 | CSIPR101 | CSIPR100 | DMAPR11 | DMAPR10 | TMPR111 | CSIPR121 | CSIPR120 |
| Н       | IICPR101 | IICPR100 |         |         | Н       | IICPR121 | IICPR120 |
| Х       | Х        | Х        | X       | 1       | X       | Х        | Х        |

#### Bit 3

| DMAPR10 | DMAPR00 | Priority level selection        |
|---------|---------|---------------------------------|
| 0       | 0       | Specify level 0 (highest level) |
| 0       | 1       | Specify level 1                 |
| 1       | 0       | Specify level 2                 |
| 1       | 1       | Specify level 3 (lowest level)  |

# Setting up DMA channel 0 transfer mode

• DMA mode control register (DMC0)

Set DMA transfer direction from on-chip RAM to SFR.

Set transfer data size to 16 bits.

Specify DMA transfer on DMA start request.

Select CSI00 transfer end/buffer empty interrupt as DMA start source.

## Symbol: DMC0

| 7    | 6    | 5   | 4      | 3     | 2     | 1     | 0     |
|------|------|-----|--------|-------|-------|-------|-------|
| STG0 | DRS0 | DS0 | DWAIT0 | IFC03 | IFC02 | IFC01 | IFC00 |
| Х    | 1    | 1   | 0      | 0     | 1     | 0     | 0     |

#### Bit 6

| DRS0 | Selection of DMA transfer direction |
|------|-------------------------------------|
| 0    | SFR to on-chip RAM                  |
| 1    | On-chip RAM to SFR                  |

#### Bit 5

| 1   | 16 bits                                              |
|-----|------------------------------------------------------|
| 0   | 8 bits                                               |
| DS0 | Specification of transfer data size for DMA transfer |

### Bit 4

| DWAIT0 | Pending of DMA transfer                                         |
|--------|-----------------------------------------------------------------|
| 1 0    | Executes DMA transfer upon DMA start request (no held pending). |
| 1      | Holds DMA start request pending if any.                         |

Bits 3 to 0

| IFC03 | IFC02     | IFC01    | IFC00 | Selection of DMA start source |                                                                                                              |  |  |  |
|-------|-----------|----------|-------|-------------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|
| IFC03 | IFC02     | IFCUI    | 1500  | Trigger Signal                | Description                                                                                                  |  |  |  |
| 0     | 0         | 0        | 0     | -                             | Disables DMA transfer by interrupt.                                                                          |  |  |  |
|       |           |          |       |                               | (Only software trigger is enabled.)                                                                          |  |  |  |
| 0     | 0         | 0        | 1     | INTAD                         | A/D conversion end interrupt                                                                                 |  |  |  |
| 0     | 0         | 1        | 0     | INTTM00                       | End of timer channel 0 count end or capture end interrupt                                                    |  |  |  |
| 0     | 0         | 1        | 1     | INTTM01                       | End of timer channel 1 count end or capture end interrupt                                                    |  |  |  |
| 0     | 1         | 0        | 0     | INTTM02                       | End of timer channel 2 count end or capture end interrupt                                                    |  |  |  |
| 0     | 1         | 0        | 1     | INTTM03                       | End of timer channel 3 count end or capture end interrupt                                                    |  |  |  |
| 0     | 1         | 1        | 0     | INTST0/INTCSI00               | UART0 transmission transfer end or buffer<br>empty interrupt/CSI00 transfer end or buffer<br>empty interrupt |  |  |  |
| 0     | 1         | 1        | 1     | INTSR0/INTCSI01               | UART0 reception transfer end interrupt/CSI01 transfer end or buffer empty interrupt                          |  |  |  |
| 1     | 0         | 0        | 0     | INTST1/INTCSI10               | UART1 transmission transfer end or buffer<br>empty interrupt/CSI10 transfer end or buffer<br>empty interrupt |  |  |  |
| 1     | 0         | 0        | 1     | INTSR1/INTCSI11               | UART1 reception transfer end interrupt/CSI11 transfer end or buffer empty interrupt                          |  |  |  |
| 1     | 0         | 1        | 0     | INTST2/INTCSI20               | UART2 transmission transfer end or buffer<br>empty interrupt/CSI20 transfer end or buffer<br>empty interrupt |  |  |  |
| 1     | 0         | 1        | 1     | INTSR2/INTCSI21               | UART2 reception transfer end interrupt/CSI21 transfer end or buffer empty interrupt                          |  |  |  |
|       | Other tha | an above |       | Setting prohibited            |                                                                                                              |  |  |  |

Setting up SFR for DMA channel 0 transfer

• DMA SFR address register 0 (DSA0) Set SFR for the source of DMA transfer

Symbol: DSA0

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

Set the lower 8 bits of TDR01 (SFR address: 0xFFF1A).

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

Setting up DMA channel 0 source RAM address

• DMA RAM address register 0 (DRA0) Set the RAM address of DMA transfer source.

Symbol: DRA0



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

Setting up DMA channel 0 transfer count

• DMA byte count register 0 (DBC0) Specify DMA transfer count.

Symbol: DBC0



Set the number of times of DMA transfer to 5.

# 5.7.7 Main Processing

Figure 5.9 shows the flowchart for main processing.



Figure 5.9 Main Processing

# 5.7.8 DMA Transfer Enable Processing

Figure 5.11 shows the flowchart for the DMA transfer enable processing.



Figure 5.11 DMA Transfer Enable Processing

Preparing for enabling DMA transfer end interrupts

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

# Symbol: IF0H

| _ | 7       | 6       | 5       | 4      | 3      | 2         | 1       | 0       |
|---|---------|---------|---------|--------|--------|-----------|---------|---------|
|   | SREIF0  | SRIF0   | STIF0   |        |        | SREIF2    | SRIF2   | STIF2   |
|   | TMIF01H | CSIIF01 | CSIIF00 | DMAIF1 | DMAIF0 | TMIF11H   | CSIIF21 | CSIIF20 |
|   | TMIFUTH | IICIF01 | IICIF00 |        |        | TIVIIFTTH | IICIF21 | IICIF20 |
|   | Χ       | X       | X       | X      | 0      | X         | Х       | Χ       |

### Bit 3

| DMAIF0 | Interrupt request flag                                   |  |  |  |  |
|--------|----------------------------------------------------------|--|--|--|--|
| 0      | lo interrupt request signal is generated                 |  |  |  |  |
| 1      | Interrupt request is generated, interrupt request status |  |  |  |  |

### Symbol: MK0H

|   | 7      | 6       | 5       | 4      | 3      | 2      | 1       | 0       |
|---|--------|---------|---------|--------|--------|--------|---------|---------|
| Ī | SREMK0 | SRMK0   | STMK0   |        |        | SREMK2 | SRMK2   | STMK2   |
| ı | TMMK01 | CSIMK01 | CSIMK00 | DMAMK1 | DMAMK0 | TMMK11 | CSIMK21 | CSIMK20 |
|   | Н      | IICMK01 | IICMK00 |        |        | Н      | IICMK21 | IICMK20 |
|   | Χ      | X       | X       | X      | 0      | X      | X       | X       |

Bit 3

| DMAMK0 | Interrupt processing control   |
|--------|--------------------------------|
| 0      | Enables interrupt processing.  |
| 1      | Disables interrupt processing. |

Setting up DMA channel 0 operation trigger wait mode

• DMA operation control register (DRC0)

### Symbol: DRC0

| 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|------|---|---|---|---|---|---|------|
| DEN0 | 0 | 0 | 0 | 0 | 0 | 0 | DST0 |
| 1    | 0 | 0 | 0 | 0 | 0 | 0 | 1    |

### Bit 7

| DEN0 | DMA operation enable flag                                           |
|------|---------------------------------------------------------------------|
| 0    | Disables operation of DMA channel 0 (stops operating clock of DMA). |
| 0    | Disables DMA setup processing.                                      |
| 1    | Enables operation of DMA channel 0.                                 |
|      | Enables DMA setup processing.                                       |

### Bit 0

| DST0 | DMA transfer mode flag                                                  |
|------|-------------------------------------------------------------------------|
| 0    | DMA transfer of DMA channel 0 DMA is completed.                         |
| 1 1  | DMA transfer of DMA channel 0 is not completed (still under execution). |

The DMA trigger wait mode is entered by setting DST0 to 1 after enabling DMA operation (DEN0 = 1).

# 5.7.9 Starting TAU0 (Channels 0 and 1)

Figure 5.11 shows the flowchart for starting the TAU0 (channels 0 and 1).



Figure 5.11 Starting TAU0 (Channels 0 and 1)

Caution: For details on the procedure for setting up the TAU0 (R\_TAU0\_Create ()), refer to the section entitled "Flowcharts" in RL78/G13 Timer Array Unit (PWM Output) Application Note (R01AN0455E).

# 5.7.10 Starting TAU0 (Channel 2)

Figure 5.12 shows the flowchart for starting the TAU0 (channel 2).



Figure 5.12 Starting TAU0 (Channel 2)

Caution: For details on the procedure for setting up the TAU0 (R\_TAU0\_Create ()), refer to the section entitled "Flowcharts" in RL78/G13 Timer Array Unit (PWM Output) Application Note (R01AN0455E).

# 5.7.11 TAU0 Timer Interrupt Processing (Channel 2)

Figure 5.13 shows the flowchart for the TAU0 timer interrupt processing (channel 2).



Figure 5.13 TAU0 Timer Interrupt Processing (Channel 2)

# 5.7.12 DMA Transfer End Interrupt Processing

Figure 5.14 shows the flowchart for the DMA transfer end interrupt processing.



Figure 5.14 DMA Transfer End Interrupt Processing

# 6. Sample Code

The sample code is available on the Renesas Electronics Website.

#### 7. Documents for Reference

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

RL78 Family User's Manual: Software (R01US0015E)

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

Technical Updates/Technical Brochures

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

# **Website and Support**

Renesas Electronics Website

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

#### Inquiries

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

| Revision Record | RL78/G13 DMA Controller (PWM Output) |
|-----------------|--------------------------------------|
|-----------------|--------------------------------------|

| Rev. | Date          | Description |                      |  |
|------|---------------|-------------|----------------------|--|
|      |               | Page        | Summary              |  |
| 1.00 | Feb. 01, 2012 | _           | First edition issued |  |
|      |               |             |                      |  |

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

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

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

- 1. Handling of Unused Pins
- Handle unused pins in accord with the directions given under Handling of Unused Pins in the manual.
  - The input pins of CMOS products are generally in the high-impedance state. In operation with unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of LSI, an associated shoot-through current flows internally, and malfunctions occur due to the false recognition of the pin state as an input signal become possible. Unused pins should be handled as described under Handling of Unused Pins in the manual.
- 2. Processing at Power-on
- The state of the product is undefined at the moment when power is supplied.
  - The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the moment when power is supplied.
    In a finished product where the reset signal is applied to the external reset pin, the states of pins are not guaranteed from the moment when power is supplied until the reset process is completed.
    In a similar way, the states of pins in a product that is reset by an on-chip power-on reset function are not guaranteed from the moment when power is supplied until the power reaches the level at which resetting has been specified.
- 3. Prohibition of Access to Reserved Addresses
- · Access to reserved addresses is prohibited.
  - The reserved addresses are provided for the possible future expansion of functions. Do not access
    these addresses; the correct operation of LSI is not guaranteed if they are accessed.
- 4. Clock Signals
- After applying a reset, only release the reset line after the operating clock signal has become stable.
   When switching the clock signal during program execution, wait until the target clock signal has stabilized.
  - When the clock signal is generated with an external resonator (or from an external oscillator) during a reset, ensure that the reset line is only released after full stabilization of the clock signal. Moreover, when switching to a clock signal produced with an external resonator (or by an external oscillator) while program execution is in progress, wait until the target clock signal is stable.
- 5. Differences between Products
- Before changing from one product to another, i.e. to one with a different part number, confirm that the change will not lead to problems.
  - The characteristics of MPU/MCU in the same group but having different part numbers may differ because of the differences in internal memory capacity and layout pattern. When changing to products of different part numbers, implement a system-evaluation test for each of the products.

#### Notice

- 1. All information included in this document is current as of the date this document is issued. Such information, however, is subject to change without any prior notice. Before purchasing or using any Renesas Electronics products listed herein, please confirm the latest product information with a Renesas Electronics sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas Electronics such as that disclosed through our website
- 2. 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
- You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part
- 4. 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.
- 5. When exporting the 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. You should not use Renesas Electronics products or the 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. 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.
- 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 products are classified according to the following three quality grades: "Standard", "High Quality", and "Specific". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below. 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 categorized as "Specific" without the prior written consent of Renesas Electronics. Further, you may not use any Renesas Electronics product for any application for which it is not intended without the prior written consent of Renesas Electronics. 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 an application categorized as "Specific" or for which the product is not intended where you have failed to obtain the prior written consent of Renesas Electronics. The quality grade of each Renesas Electronics product is "Standard" unless otherwise expressly specified in a Renesas Electronics data sheets or data books, etc.
  - "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.
  - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anti-crime systems; safety equipment; and medical equipment not specifically designed for life support.
  - "Specific": Aircraft: aerospace equipment; submersible repeaters; nuclear reactor control systems; medical equipment or systems for life support (e.g. artificial life support devices or systems), surgical implantations, or healthcare intervention (e.g. excision, etc.), and any other applications or purposes that pose a direct threat to human life.
- 8. 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.
- 9. 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 system manufactured by you.
- 10. 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.
- 11. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written consent of Renesas Electronics
- 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products, or if you have any other inquiries.
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its majority-owned subsidiaries

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



#### **SALES OFFICES**

#### Renesas Electronics Corporation

http://www.renesas.com

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

Renesas Electronics America Inc. 2880 Scott Boulevard Santa Clara, CA 95050-2554, U.S.A. Tel: +1-408-588-6000, Fax: +1-408-588-6130

Renesas Electronics Canada Limited 1101 Nicholson Road, Newmarket, Ontario L3Y 9C3, Canada Tel: +1-905-898-5441, Fax: +1-905-898-3220

Renesas Electronics Europe Limited
Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K
Tel: +44-1628-585-100, Fax: +44-1628-585-900

Renesas Electronics Europe GmbH

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

Renesas Electronics (China) Co., Ltd.

Th Floor, Quantum Plaza, No.27 JhChunLu Haidian District, Beijing 100083, P.R.China Tel: +86-10-8235-1155, Fax: +86-10-8235-7679

Renesas Electronics (Shanghai) Co., Ltd.
Unit 204, 205, AZIA Center, No. 1233 Lujiazui Ring Rd., Pudong District, Shanghai 200120, China Tel: +86-21-5877-1818, Fax: +86-21-6887-7858 / -7898

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

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

Renesas Electronics Singapore Pte. Ltd.
1 harbourFront Avenue, #06-10, keppel Bay Tower, Singapore 098632 Tel: +65-6213-0200, Fax: +65-6278-8001

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

Renesas Electronics Korea Co., Ltd. 11F., Samik Lavied' or Bidg., 720-2 Yeoksam-Dong, Kangnam-Ku, Seoul 135-080, Korea Tel: 482-2-558-3737, Fax: +822-2-58-5141

© 2012 Renesas Electronics Corporation. All rights reserved.