

# V850E2/MN4

# **DMA Control**

R01AN0925EJ0100 Rev.1.00 Jan 30, 2012

# Introduction

This application note explains how to set up the DMA (Direct Memory Access) and also gives an outline of the operation and describes the procedures for using a sample program. The sample program supports DMA transfer between locations in internal memory and between the internal memory and the internal peripheral I/O.

# **Target Device**

V850E2/MN4 Microcontrollers

#### **Contents**

| 1. | Overview           | . 2 |
|----|--------------------|-----|
|    |                    |     |
| 2. | Usage Environment  | . 5 |
|    | ŭ                  |     |
| 3. | Software           | . 6 |
|    |                    |     |
| 4. | Sample Application | . 7 |

#### 1. Overview

This sample program illustrates the usage examples of the DMAC (Direct Memory Access Controller) and DTFR (DMA Trigger Factor Register).

The parameters required for the transfer of data are stored in the DMAC, which transfers data in response to DMA transfer requests. As an example of software DMA transfer requests, the main points in the operation of the software to transfer data between locations in internal memory are illustrated below.

See section 4.1 "Flow Charts" for the details of the individual operations.



Figure 1.1 Example of Software DMA Transfer Request

The DTFR (DMA Trigger Factor Register) is used to select the interrupt signal which becomes the trigger for DMA from among all interrupt signals. Requests from the DTFR for the DMA transfer of data are handled by the DMAC. Specifically, the signal to be used as a DMA transfer request is selected from among the 128 input interrupt signals by the setting in DTFRn (n = 15 to 0). As an example of a hardware DMA transfer request, the main points in transferring data with a timer interrupt as the trigger are illustrated below. The data from internal RAM are output via port P0.

See section 4.1 "Flow Charts" for the details of the individual operations.



Figure 1.2 Example of Hardware DMA Transfer Request

#### 1.1 Initialization

The general registers and functional pins are initialized.

<Port setup>

- Port n function control expansion registers (PFCEn)
- Port n function control registers (PFCn)
- Port n mode control registers (PMCn)
- Port n mode register (PMn)

### 1.2 DMAC Setup

The parameters required for the transfer of data are set in the DMAC. See section 4.2 for details.

- A transfer source address, a transfer destination address, and a transfer data size
- Chip select signals for a transfer source and a transfer destination
- A next transfer source address, a next transfer destination address, and a next transfer data size (as necessary)

## 1.3 DTFR Setup

The interrupt signal which will act as the DMA transfer factor is set.

#### 1.4 DMAC Start

DMA transfer is enabled and the software request bit is set at the same time to start the DMAC transferring data in response to a software transfer request.

DMA transfer is enabled to start the DMAC transferring data in response to hardware transfer requests. Actual data transfer only starts when a request for transfer from the DTFR is triggered by an interrupt signal.

### 1.5 Wait for End of Transfer and End of Transfer

A transfer end interrupt generated after the DMA transfer indicates the end of transfer. Clearing the DMA transfer end status bit completes DMA transfer. The next address setting function can be used to automatically set the parameters for the next transfer.

### 2. Usage Environment

This section explains the circuit diagram and development environment to run this sample program.

### 2.1 Circuit Diagram

See "V850E2/MN4 Target Board User Manual: QB-V850E2MN4DUAL-TB (R20UT0683XJ)" for the details of the circuit diagram.

During data transfer between the internal memory and the internal peripheral I/O, the P0 port is set as the destination for transfer and acts as the output for the data.

The LEDs are connected to port 13. The P13\_7 pin is used for LED1. The P13\_6 pin is used for LED2.

# 2.2 Development Environment

It is necessary to install the tools that are listed below to run the sample program.

#### CubeSuite+

The integrated development environment CubeSuite+ from Renesas Electronics provides various software development tools that are necessary for the user to develop applications. The user can use these tools seamlessly and easily in various development stages including coding, assembly, compilation, debugging using an emulator or simulator, and flash programming.

#### MINICUBE

MINICUBE is a general-purpose in-circuit emulator from Renesas Electronics which adopts the JTAG interface system. It allows the user to debug an onboard real processor and provides highly transparent and stable emulation functionalities. An adapter is required to connect a TB board to MINICUBE.

#### • Multi

Green Hills software, Inc. integrated development tool suit.

### • IAR Embedded Workbench

IAR Systems integrated development tool suit.

# 3. Software

This section describes the organization of the compressed files to be downloaded.

# 3.1 File Organization

The compressed files to be downloaded consist of the files that are listed below.

| File Name<br>(Tool Structure) | Description                        | Common<br>Source File | CubeSuite+<br>File | Multi File |
|-------------------------------|------------------------------------|-----------------------|--------------------|------------|
| crtE.s                        | Hardware initialization processing |                       | •                  |            |
| startup.s                     |                                    |                       |                    | •          |
| V850E2MN4.dir                 | Link directive file                |                       | •                  |            |
| V850E2_MN4 DMA.ld             | 1                                  |                       |                    | •          |
| vector.s                      | Vector table                       |                       |                    | •          |
| dma.h                         | Variable and function declarations | •                     |                    |            |
| main.c                        | Main processing                    | •                     |                    |            |
| initial.c                     | Software initialization processing | •                     |                    |            |
| dma_control.c                 | DMA control                        | •                     |                    |            |
| taua0_control.c               | Timer control as DMA start trigger | •                     |                    |            |
| interrupt.c                   | Interrupt processing               | •                     |                    |            |

# 4. Sample Application

This section explains how to set up the DMAC and the DTFR.

### 4.1 Flow Charts

The flow charts of this sample program are given below.

# 4.1.1 Main Processing

The main processing transfers data between locations in internal memory and between the internal RAM and internal peripheral I/O, after which processing ends.

See sections 4.1.2 and 4.1.3 for the details of the individual transfer processing.



**Figure 4.1 Main Processing Flowchart** 

#### 4.1.2 **Inter-Memory Transfer Processing**

This inter-memory transfer processing transfers data of specified size from the specified transfer source address to the transfer destination address. In this example, DMA transfer is started by the software.



Figure 4.2 Inter-Memory Transfer Processing

# 4.1.3 Memory-to-Peripheral I/O Transfer Processing Flow

This memory-to-peripheral I/O transfer processing transfers data from the transfer source address to peripheral I/O. In this example, DMA transfer is started by a timer interrupt.



Figure 4.3 Memory-to-Peripheral I/O Transfer Processing Flow

### 4.1.4 Interrupt Processing

The V850E2/MN4 is able to generate an interrupt when DMA transfer ends or the transfer count matches.

In the case of data transfer between locations in internal RAM, an interrupt signal (INTDMACT0) is generated when the amount of data transferred corresponds to the transfer count setting in the transfer number compare register (DTCC). LED1 is then turned on by the transfer number match interrupt function, int\_dmact0.

In the case of data transfer between the internal RAM and the internal peripheral I/O, a transfer completion interrupt signal (INTDMA1) is generated when DMA transfer has been executed the number of times specified by the transfer count register (DTC). The transfer end interrupt function, int\_dma1, clears the transfer end flag and then turns LED2 on.



**Figure 4.4 Interrupt Processing** 

# 4.2 Register Setup

This section explains how to set up the relevant registers according to the flow charts shown in section 4.1. The registers described below must be configured to control the DMAC.

# 4.2.1 Port Setup

In this sample program, during data transfer between the internal memory and the internal peripheral I/O, the P0 port is set as the destination for transfer and acts as the output for the data. The LEDs are connected to port 13. The pertinent control registers must be set up as summarized in the table below. The P13\_7 pin is used for LED1. The P13\_6 pin is used for LED2.

| Macro | Pin        | PMC | PFCE | PFC | PM | Corresponding function |
|-------|------------|-----|------|-----|----|------------------------|
| PORT  | P0_0 to 15 | 0   | 0    | 0   | 0  | Port mode, output      |
|       | P13_6      | 0   | 0    | 0   | 0  | Port mode, output      |
|       | P13_7      | 0   | 0    | 0   | 0  | Port mode, output      |

Setting example:

```
/* P0: io,output */
PFCE0 = 0x0000;
PFC0 = 0x0000;
PMC0 = 0x0000;
PM0 = 0x0000;

/* P13_6,7: LEDs,io,OUTPUT */
PFCE13 = 0x0000;
PFC13 = 0x0000;
PMC13 = 0x0000;
PMC13 = 0x0000;
PMC13 = 0x0000;
```

# 4.2.2 DMA Transfer Status Register (DTSn)

The DTSn register has the DMA transfer end status, the DMA transfer status, the DMA transfer error flag, and the hardware DMA transfer request flag. This register enables or disables DMA transfer by using the DTE bit. This register starts and stops software DMA transfer by using the SR bit.

Access This register can be read or written in 8- or 1-bit units. Address DTS15: FFFF 768A<sub>H</sub>, DTS14: FFFF 765A<sub>H</sub>, DTS13: FFFF 762A<sub>H</sub>, DTS12: FFFF 75FAH, DTS11: FFFF 75CAH, DTS10: FFFF 759AH, DTS9: FFFF 756AH, DTS8: FFFF 753AH, DTS7: FFFF 748AH, DTS6: FFFF 745AH, DTS5: FFFF 742AH, DTS4: FFFF 73FAH, DTS3: FFFF 73CA<sub>H</sub>, DTS2: FFFF 739A<sub>H</sub>, DTS1: FFFF 736A<sub>H</sub>, DTS0: FFFF 733AH Initial Value 00H 6 4 3 2 1 0 DTSnDTE DTSnTC DTSnDT 0 DTSnER DTSnDR DTSnSR 0 R/W R/W R R R R R/W

Table 10-27 DTSn register contents (1/2)

| Bit position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7            | DTSnTC   | DMA transfer end status This bit indicates that DMA transfer has been completed. Write "0" to this bit to clear it after reading "1" from it. It is recommended to write this bit using bit manipulation such as CLR1.  0: DMA transfer not completed 1: DMA transfer completed                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| 6            | DTSnDT   | DT DMA transfer status This bit indicates that a DMA transfer request has been acknowledged and that DMA transfer is in progress. It is not set (to "1") when only a DMA transfer request is issued. This bit is cleared (to "0") when DMA transfer has been completed. If the DTSnDTE bit is "0", this bit can be cleared by the user. (It can also be written at the same time as the DTSnDTE bit.) 0: DMA transfer request acknowledged 1: DMA transfer in progress                                                                                     |  |  |  |  |  |
| 3            | DTSnER   | DMA transfer error flag This bit indicates that a DMA transfer error has occurred in channel n. It is cleared (to "0") when the DTRCx.DTRCxERR bit is cleared. Note that this bit is read-only.  0: No DMA transfer error  1: DMA transfer error                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| 2            | DTSnDR   | Hardware DMA transfer request flag This bit indicates that channel n has a hardware DMA transfer request. It is cleared (to "0") when the hardware DMA transfer request is deasserted. This bit operates regardless of the status of the DTSnDTE bit. It is not set (to "1") by a software DMA transfer request, or by a hardware DMA transfer request when a software DMA transfer request is selected by the DMA transfer request select register. Note that this bit is read-only. 0: No hardware DMA transfer request 1: Hardware DMA transfer request |  |  |  |  |  |
| 1            | DTSnSR   | Software DMA transfer request This bit selects a software DMA transfer request. If a software DMA transfer request is selected by the DMA transfer request select register, writing "1" to this bit and the DTSnDTE bit starts DMA transfer. This bit is automatically cleared (to "0") when DMA transfer has been completed. Writing "0" to this bit aborts DMA transfer.  0: No software DMA transfer request  1: Software DMA transfer request                                                                                                          |  |  |  |  |  |

Figure 4.5 DTSn Register Format (1/2)

| Bit position | Bit name | Function                                                                                                                                                                                                                                                                                                                  |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0            | DTSnDTE  | DMA transfer enable                                                                                                                                                                                                                                                                                                       |
|              |          | This bit enables or disables DMA transfer. DMA transfer is executed if "1" is written to this bit and a DMA transfer request is issued. This bit is automatically cleared (to "0") if the MLE bit is "0" when DMA transfer has been completed. DMA transfer is aborted if "0" is written to this bit during DMA transfer. |
|              |          | 0: Disables DMA transfer                                                                                                                                                                                                                                                                                                  |
|              |          | 1: Enables DMA transfer                                                                                                                                                                                                                                                                                                   |

Figure 4.6 DTSn Register Format (2/2)

# Setting examples

| DTSODTE = 0x1; /* permit DMA transfer */ DTS0SR = 0x1; /* transfer start */ | DTS0DTE = 0x1;<br>DTS0SR = 0x1; | /* permit DMA transfer */ /* transfer start */ |  |
|-----------------------------------------------------------------------------|---------------------------------|------------------------------------------------|--|
|-----------------------------------------------------------------------------|---------------------------------|------------------------------------------------|--|

#### 4.2.3 DMA Source Address Registers (DSAnL and DSAnH)

These registers set a DMA transfer source address.

Access This register can be read or written in 16-bit units.

Address DSA15L: FFFF 7664µ, DSA14L: FFFF 7634µ, DSA13L: FFFF 7604µ,

DSA12L: FFFF 75D4H, DSA11L: FFFF 75A4H, DSA10L: FFFF 7574H, DSA9L: FFFF 7544H, DSA8L: FFFF 7514H, DSA7L: FFFF 7464H,

DSA6L: FFFF 7434H, DSA5L: FFFF 7404H, DSA4L: FFFF 73D4H,

DSA3L: FFFF 73A4H, DSA2L: FFFF 7374H, DSA1L: FFFF 7344H,

DSA0L: FFFF 7314H

Initial Value 0000H

| 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   |
|------|------|------|------|------|------|-----|-----|
| SA15 | SA14 | SA13 | SA12 | SA11 | SA10 | SA9 | SA8 |
| R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W | R/W |
| 7    | 6    | 5    | 4    | 3    | 2    | 1   | 0   |
| SA7  | SA6  | SA5  | SA4  | SA3  | SA2  | SA1 | SAO |
| P/W  | PAV  | P.W  | D/M  | BAN  | P/W  | DW. | B/W |

Table 10-11 DSAnL register contents

| Bit position | Bit name    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0         | SA15 to SA0 | DMA source address These bits set the lower 16 bits of the transfer source address of channel n. If this register is referenced during DMA transfer, the address from which data is to be transferred next can be read. When referencing this register, it is recommended to access this register together with DSAnH in 32-bit units. If the NSAV bit of the DNSAnH register is not set (to "1") when DMA transfer has been completed, the values of these bits return to the values when DMA transfer was started. |

#### Cautions

- Writing these bits is prohibited while DMA transfer is enabled (DTSn.DTSnDTE bit = 1). If they are written, the operation is not
- 2. Set an address by accessing in 32-bit units while the DTSnDTE bit is "0" in order to avoid data being transferred from an address that has not been completely set.
- 3. DMA transfer of misaligned data is not supported. The lower 4 bits of an address corresponding to the transfer data size are as follows (x indicates

The operation is not guaranteed if a setting other than the following is made.

| Data size | SA3 | SA2 | SA1 | SAO |
|-----------|-----|-----|-----|-----|
| 8 bits    | ×   | ×   | ×   | ×   |
| 16 bits   | ×   | ×   | ×   | 0   |
| 32 bits   | ×   | ×   | . 0 | 0   |
| 128 bits  | 0   | 0   | 0   | 0   |

Figure 4.7 DSAnL Register Format

Access This register can be read or written in 16-bit units. Address DSA15H: FFFF 7666<sub>H</sub>, DSA14H: FFFF 7636<sub>H</sub>, DSA13H: FFFF 7606<sub>H</sub>, DSA12H: FFFF 75D6H, DSA11H: FFFF 75A6H, DSA10H: FFFF 7576H, DSA9H: FFFF 7546H, DSA8H: FFFF 7516H, DSA7H: FFFF 7466H, DSA6H: FFFF 7436H, DSA5H: FFFF 7406H, DSA4H: FFFF 73D6H, DSA3H: FFFF 73A6H, DSA2H: FFFF 7376H, DSA1H: FFFF 7346H, DSA0H: FFFF 7316H Initial Value 0000H 10 15 14 13 12 11 9 8 0 0 **SA28 SA27** SA26 SA25 SA24 0 R R R/W R/W RW R/W R/W 7 5 4 3 2 0 **SA23** SA22 **SA21** SA20 **SA19 SA18 SA17 SA16** R/W R/W R/W R/W R/W R/W RW R/W

Table 10-12 DSAnH register contents

| Bit position | Bit name     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 12:0         | SA28 to SA16 | DMA source address These bits set the higher 13 bits of the transfer source address of channel n. If this register is referenced during DMA transfer, the address from which data is to be transferred next can be read. When referencing this register, it is recommended to access this register together with DSAnL in 32-bit units. If the NSAV bit of the DNSAnH register is not set (to "1") when DMA transfer has been completed, the values of these bits return to the values when DMA transfer was started. |  |  |  |

### Cautions

- Writing these bits is prohibited while DMA transfer is enabled (DTSn.DTSnDTE bit = 1). If they are written, the operation is not guaranteed.
- Set an address by accessing in 32-bit units while the DTSnDTE bit is "0" in order to avoid data being transferred from an address that has not been completely set.

Figure 4.8 DSAnH Register Format

### Setting example

DSA0 = 0x1EDFA000; /\* set transfer source address \*/

# 4.2.4 DMA Destination Address Register (DDAnL DDAnH)

These registers set a DMA transfer destination address.

Access This register can be read or written in 16-bit units.

Address DDA15L: FFFF 7674H, DDA14L: FFFF 7644H, DDA13L: FFFF 7614H,

DDA12L: FFFF 75E4<sub>H</sub>, DDA11L: FFFF 75B4<sub>H</sub>, DDA10L: FFFF 7584<sub>H</sub>, DDA9L: FFFF 7554<sub>H</sub>, DDA8L: FFFF 7524<sub>H</sub>, DDA7L: FFFF 7474<sub>H</sub>, DDA6L: FFFF 7444<sub>H</sub>, DDA5L: FFFF 7414<sub>H</sub>, DDA4L: FFFF 73E4<sub>H</sub>,

DDA3L: FFFF 73B4H, DDA2L: FFFF 7384H, DDA1L: FFFF 7354H,

DDAOL: FFFF 7324H

Initial Value 0000H

| 15   | 14   | 13   | 12   | 11   | 10   | 9   | В   |
|------|------|------|------|------|------|-----|-----|
| DA15 | DA14 | DA13 | DA12 | DA11 | DA10 | DA9 | DAB |
| R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W | R/W |
| 7    | 6    | 5    | 4    | 3    | 2    | 1   | 0   |
| DA7  | DA6  | DA5  | DA4  | DA3  | DA2  | DA1 | DAO |
| R/W  | R/W  | RW   | R/W  | R/W  | R/W  | R/W | R/W |

Table 10-17 DDAnL register contents

| Bit position | Bit name    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0         | DA15 to DA0 | DMA destination address These bits specify the lower 16 bits of the transfer destination address of channel n. If this register is referenced during DMA transfer, the address to which data is to be transferred next can be read. When referencing this register, it is recommended to access this register together with DDAnH in 32-bit units. If the NDAV bit of the DNDAnH register is not set (to "1") when DMA transfer has been completed, the values of these bits return to the values when DMA transfer was started. |

#### Cautions

- Writing these bits is prohibited while DMA transfer is enabled (DTSn.DTSnDTE bit = 1). If they are written, the operation is not guaranteed.
- Set an address by accessing in 32-bit units while the DTSnDTE bit is "0" in order to avoid data being transferred from an address that has not been completely set.
- If an error occurs in the transfer target in the read cycle of DMA transfer, the write cycle is not executed but the destination address is updated.
- 4. DMA transfer of misaligned data is not supported. The lower 4 bits of an address corresponding to the transfer data size are as follows (x indicates any bit). The operation is not guaranteed if a setting other than the following is made.

| Data size | DA3 | DA2 | DA1 | DAO |  |
|-----------|-----|-----|-----|-----|--|
| 8 bits    | ×   | ×   | ×   | ×   |  |
| 16 bits   | ×   | ×   | ×   | 0   |  |
| 32 bits   | ×   | ×   | 0   | 0   |  |
| 128 bits  | 0   | 0   | 0   | 0   |  |

Figure 4.9 DDAnL Register Format

Access This register can be read or written in 16-bit units. Address DDA15H: FFFF 7676H, DDA14H: FFFF 7646H, DDA13H: FFFF 7616H, DDA12H: FFFF 75E6H, DDA11H: FFFF 75B6H, DDA10H: FFFF 7586H, DDA9H: FFFF 7556H, DDA8H: FFFF 7526H, DDA7H: FFFF 7476H, DDA6H: FFFF 7446H, DDA5H: FFFF 7416H, DDA4H: FFFF 73E6H, DDA3H: FFFF 73B6H, DDA2H: FFFF 7386H, DDA1H: FFFF 7356H, DDA0H: FFFF 7326H Initial Value 0000<sub>H</sub> 10 8 15 14 13 12 11 0 0 **DA28 DA27** DA26 DA25 DA24 0 R R/W R/W RW R/W R/W 7 6 5 4 3 2 0 DA19 **DA23 DA22 DA21 DA20 DA18 DA17 DA16** R/W RW R/W RW R/W R/W R/W R/W

Table 10-18 DDAnH register contents

| Bit position | Bit name     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:0         | DA28 to DA16 | DMA destination address These bits specify the higher 13 bits of the transfer destination address of channel n. If this register is referenced during DMA transfer, the address to which data is to be transferred next can be read. When referencing this register, it is recommended to access this register together with DDAnL in 32-bit units. If the NDAV bit of the DNDAnH register is not set (to "1") when DMA transfer has been completed, the values of these bits return to the values when DMA transfer was started. |

#### Cautions

- Writing these bits is prohibited while DMA transfer is enabled (DTSn.DTSnDTE bit = 1). If they are written, the operation is not guaranteed.
- Set an address by accessing in 32-bit units while the DTSnDTE bit is "0" in order to avoid data being transferred from an address that has not been completely set.
- If an error occurs in the transfer target in the read cycle of DMA transfer, the write cycle is not executed but the destination address is updated.

Figure 4.10 DDAnH Register Format

### Setting example

DDA0 = 0x1EDFB000; /\* set transfer destination address \*/

# 4.2.5 DMA Source Chip Select Register (DSCn)

This register specifies an area to be selected as a transfer source of channel n.

Access This register can be read or written in 16-bit units.

Address DSC15: FFFF 7668<sub>H</sub>, DSC14: FFFF 7638<sub>H</sub>, DSC13: FFFF 7608<sub>H</sub>,

DSC12: FFFF 75D8 $_{\rm H}$ , DSC11: FFFF 75A8 $_{\rm H}$ , DSC10: FFFF 7578 $_{\rm H}$ , DSC9: FFFF 7548 $_{\rm H}$ , DSC8: FFFF 7518 $_{\rm H}$ , DSC7: FFFF 7468 $_{\rm H}$ ,

DSC6: FFFF 7438<sub>H</sub>, DSC5: FFFF 7408<sub>H</sub>, DSC4: FFFF 73D8<sub>H</sub>, DSC3: FFFF 73A8<sub>H</sub>, DSC2: FFFF 7378<sub>H</sub>, DSC1: FFFF 7348<sub>H</sub>,

DSC0: FFFF 7318<sub>H</sub>

Initial Value 0001H

15 14 13 12 10 8 11 0 0 0 0 0 0 R R R R R R R R 7 6 5 4 3 2 0 1 0 0 0 0 0 SCS<sub>1</sub> SCS<sub>0</sub> SCSE R R R R R/W R/W R/W

Table 10-13 DSCn register contents

| Bit name             | Function                                                                                              |                                              |                                                                  |                        |  |  |
|----------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------|------------------------------------------------------------------|------------------------|--|--|
| SCS1<br>SCS0<br>SCSE | DMA source chip select These bits specify an area to be selected as the transfer source of channel n. |                                              |                                                                  |                        |  |  |
|                      | SCS1 SCS0 SCSE Selected area                                                                          |                                              |                                                                  |                        |  |  |
|                      | 0 0 1 External memory area, P-bus periphe area, and H-bus peripheral I/O area                         |                                              |                                                                  |                        |  |  |
|                      | 0                                                                                                     | 0 1 0 Internal flash memory and internal RAM |                                                                  |                        |  |  |
|                      | Other than                                                                                            | n above                                      |                                                                  | Setting prohibited     |  |  |
|                      | SCS1<br>SCS0                                                                                          | SCS1 DMA source These bits SCSE SCS1 0       | SCS1 DMA source chip selective and SCS0 SCSE SCS1 SCS0 SCS1 SCS0 | DMA source chip select |  |  |

#### Cautions

- Writing these bits is prohibited while DMA transfer is enabled (DTSn.DTSnDTE bit = 1). If they are written, the operation is not guaranteed.
- Set the SCS0 and SCSE bits so that only one of them is "1". If both of these bits are set to 1, the operation is not guaranteed.
- 3. Be sure to set the SCS1 bit to "0".

Figure 4.11 DSCn Register Format

#### Setting example

DSC0 = 0x0002; /\* set DMA source is inner RAM \*/

# 4.2.6 DMA Destination Chip Select register (DDCn)

This register specifies an area to be selected as a transfer destination of channel n.

Access This register can be read or written in 16-bit units.

Address DDC15: FFFF 7678<sub>H</sub>, DDC14: FFFF 7648<sub>H</sub>, DDC13: FFFF 7618<sub>H</sub>,

DDC12: FFFF 75E8<sub>H</sub>, DDC11: FFFF 75B8<sub>H</sub>, DDC10: FFFF 7588<sub>H</sub>, DDC9: FFFF 7558<sub>H</sub>, DDC8: FFFF 7528<sub>H</sub>, DDC7: FFFF 7478<sub>H</sub>,

DDC6: FFFF 7448<sub>H</sub>, DDC5: FFFF 7418<sub>H</sub>, DDC4: FFFF 73E8<sub>H</sub>,

DDC3: FFFF 73B8<sub>H</sub>, DDC2: FFFF 7388<sub>H</sub>, DDC1: FFFF 7358<sub>H</sub>,

DDC0: FFFF 7328<sub>H</sub>

Initial Value 0001<sub>H</sub>

| 15 | 14 | 13 | 12 | 11 | 10   | 9    | 8    |
|----|----|----|----|----|------|------|------|
| 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0    |
| R  | R  | R  | R  | R  | R    | R    | R    |
|    |    |    |    |    |      |      |      |
| 7  | 6  | 5  | 4  | 3  | 2    | 1    | 0    |
| 0  | 0  | 0  | 0  | 0  | DCS1 | DCS0 | DCSE |
| R  | R  | R  | R  | R  | R/W  | R/W  | R/W  |

Table 10-19 DDCn register contents

| Bit position | Bit name             | Function                                                                                                              |          |      |                                                                                |  |  |
|--------------|----------------------|-----------------------------------------------------------------------------------------------------------------------|----------|------|--------------------------------------------------------------------------------|--|--|
| 2<br>1<br>0  | DCS1<br>DCS0<br>DCSE | DMA destination chip select<br>These bits specify an area to be selected as the transfer destination of channel<br>n. |          |      |                                                                                |  |  |
|              |                      | DCS1                                                                                                                  | DCS0     | DCSE | Selected area                                                                  |  |  |
|              |                      | 0                                                                                                                     | 0        | 1    | External memory area, P-bus peripheral I/O area, and H-bus peripheral I/O area |  |  |
|              |                      | 0                                                                                                                     | 1        | 0    | Internal flash memory and internal RAM                                         |  |  |
|              |                      | Other th                                                                                                              | an above | •    | Setting prohibited                                                             |  |  |

#### Cautions

- Writing these bits is prohibited while DMA transfer is enabled (DTSn.DTSnDTE bit = 1). If they are written, the operation is not guaranteed.
- Set the DCS0 and DCSE bits so that only one of them is "1". If both of these bits are set to 1, the operation is not guaranteed.
- 3. Be sure to set the DCS1 bit to "0".

Figure 4.12 DDCn Register Format

### Setting examples

DDC0 = 0x0002; /\* set DMA destination is inner RAM \*/

DDC1 = 0x0001; /\* set DMA destination is IO \*/

### 4.2.7 DMA Transfer Count Register (DTCn)

This register specifies the number of times of DMA transfers (DMA transfer count). When this register is referenced during DMA transfer, the remaining number of times of DMA transfer to be executed can be read.



Cautions

 Writing these bits is prohibited while DMA transfer is enabled (DTSn.DTSnDTE bit = 1). If they are written, the operation is not guaranteed.

to be executed

If an error occurs in the transfer target in the read cycle of DMA transfer, the write cycle is not executed but the destination address is updated.

Transfer executed 32,767 times or 32,767 times of transfer

Figure 4.13 DTCn Register Format

7FFFH

#### Setting examples

DTC0 = 0x0004; /\* set times of DMA transfer \*/
DTC1 = 0x0001; /\* set times of DMA transfer \*/

# 4.2.8 DMA Transfer Control Register (DTCTn)

This register specifies parameters, such as DMA transfer data size.

Access This register can be read or written in 16-bit units. Address DTCT15: FFFF 7688<sub>H</sub>, DTCT14: FFFF 7658<sub>H</sub>, DTCT13: FFFF 7628<sub>H</sub>, DTCT12: FFFF 75F8<sub>H</sub>, DTCT11: FFFF 75C8<sub>H</sub>, DTCT10: FFFF 7598<sub>H</sub>, DTCT9: FFFF 7568H, DTCT8: FFFF 7538H, DTCT7: FFFF 7488H, DTCT6: FFFF 7458H, DTCT5: FFFF 7428H, DTCT4: FFFF 73F8H, DTCT3: FFFF 73C8<sub>H</sub>, DTCT2: FFFF 7398<sub>H</sub>, DTCT1: FFFF 7368<sub>H</sub>, DTCT0: FFFF 7338H Initial Value 0000H 15 14 13 12 11 10 8 0 DS<sub>1</sub> DS<sub>0</sub> MLE 0 0 0 0 R R R/W RW R/W R 7 6 5 4 2 0 3 SACM<sub>1</sub> SACMO DACM1 DACMO DSM 0 0 0 R R R/W

Table 10-26 DTCTn register contents (1/2)

| Bit position | Bit name       | Function                                                                                                                                                                                                                                                                                                                       |                                                                                    |                                                                                                                                                                                                                                                                            |  |  |  |  |
|--------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 14<br>13     | DS1<br>DS0     | DMA transfer data size These bits specify the DMA transfer data size of channel n.                                                                                                                                                                                                                                             |                                                                                    |                                                                                                                                                                                                                                                                            |  |  |  |  |
|              |                | DS1                                                                                                                                                                                                                                                                                                                            | DSo                                                                                | Transfer data size                                                                                                                                                                                                                                                         |  |  |  |  |
|              |                | 0                                                                                                                                                                                                                                                                                                                              | 0                                                                                  | 8 bits                                                                                                                                                                                                                                                                     |  |  |  |  |
|              |                | 0                                                                                                                                                                                                                                                                                                                              | 1                                                                                  | 16 bits                                                                                                                                                                                                                                                                    |  |  |  |  |
|              |                | 1                                                                                                                                                                                                                                                                                                                              | 0                                                                                  | 32 bits                                                                                                                                                                                                                                                                    |  |  |  |  |
|              |                | 1                                                                                                                                                                                                                                                                                                                              | 1                                                                                  | 128 bits                                                                                                                                                                                                                                                                   |  |  |  |  |
|              |                | If this bit is set (to "1"), the DTSn.DTSnDTE bit is not cleared upon completion of DMA transfer. Even if the DTSnTC bit is not cleared, DMA transfer is executed if a DMA transfer request is issued.  0: Clears DTSnDTE bit upon completion of DMA transfer.  1: Does not clear DTSnDTE bit upon completion of DMA transfer. |                                                                                    |                                                                                                                                                                                                                                                                            |  |  |  |  |
|              |                | executed if a<br>0: Clears D                                                                                                                                                                                                                                                                                                   | DMA trans                                                                          | the DTSnTC bit is not cleared, DMA transfer is<br>fer request is issued.<br>t upon completion of DMA transfer.                                                                                                                                                             |  |  |  |  |
| 7<br>6       | SACM1<br>SACM0 | executed if a<br>0: Clears D<br>1: Does not<br>DMA transfer                                                                                                                                                                                                                                                                    | DMA trans<br>TSnDTE bit<br>clear DTS<br>source add<br>ecity the di                 | the DTSnTC bit is not cleared, DMA transfer is<br>fer request is issued.<br>It upon completion of DMA transfer.<br>nDTE bit upon completion of DMA transfer.                                                                                                               |  |  |  |  |
| •            |                | executed if a<br>0: Clears D<br>1: Does not<br>DMA transfer<br>These bits sp                                                                                                                                                                                                                                                   | DMA trans<br>TSnDTE bit<br>clear DTS<br>source add<br>ecity the di                 | the DTSnTC bit is not cleared, DMA transfer is<br>fer request is issued.<br>It upon completion of DMA transfer.<br>nDTE bit upon completion of DMA transfer.                                                                                                               |  |  |  |  |
| •            |                | executed if a 0: Clears D 1: Does not DMA transfer These bits sp n is to be cou                                                                                                                                                                                                                                                | DMA trans<br>TSnDTE bit<br>clear DTS<br>source add<br>ecity the di<br>nted.        | the DTSnTC bit is not cleared, DMA transfer is<br>ler request is issued.  t upon completion of DMA transfer.  nDTE bit upon completion of DMA transfer.  dress counting direction rection in which the transfer source address of channe                                   |  |  |  |  |
| •            |                | executed if a 0: Clears D 1: Does not DMA transfer These bits sp n is to be cou                                                                                                                                                                                                                                                | DMA trans<br>TSnDTE bi<br>clear DTS<br>source ad<br>ecity the di<br>nted.          | the DTSnTC bit is not cleared, DMA transfer is fer request is issued.  It upon completion of DMA transfer.  InDTE bit upon completion of DMA transfer.  Idress counting direction rection in which the transfer source address of channe  Counting direction               |  |  |  |  |
| •            |                | executed if a 0: Clears D 1: Does not DMA transfer These bits sp n is to be cou                                                                                                                                                                                                                                                | DMA trans<br>TSnDTE bi<br>clear DTS<br>source ad<br>ecify the di<br>nted.  SACMO 0 | the DTSnTC bit is not cleared, DMA transfer is fer request is issued.  It upon completion of DMA transfer.  InDTE bit upon completion of DMA transfer.  Idress counting direction  rection in which the transfer source address of channe  Counting direction  Incremented |  |  |  |  |

Figure 4.14 DTCTn Register Format (1/2)

| Bit position | Bit name         |                                                                                                                                                       | Function                                                                                                                                                                                                                                             |             |                                                                                                                              |  |  |  |
|--------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 5<br>4       | DACM1<br>DACM0   | DMA transfer destination address counting direction These bits specify the direction in which the transfer destination ad channel n is to be counted. |                                                                                                                                                                                                                                                      |             | rection in which the transfer destination address of                                                                         |  |  |  |
|              |                  | 0                                                                                                                                                     | DACM1                                                                                                                                                                                                                                                | DACM0       | Counting direction                                                                                                           |  |  |  |
|              |                  |                                                                                                                                                       | 0                                                                                                                                                                                                                                                    | 0           | Incremented                                                                                                                  |  |  |  |
|              |                  |                                                                                                                                                       | 0                                                                                                                                                                                                                                                    | 1           | Decremented                                                                                                                  |  |  |  |
|              |                  |                                                                                                                                                       | 1                                                                                                                                                                                                                                                    | 0           | Fixed                                                                                                                        |  |  |  |
|              |                  |                                                                                                                                                       | 1                                                                                                                                                                                                                                                    | 1           | Setting prohibited                                                                                                           |  |  |  |
| 0            | DSM              | This b<br>pins.<br>0: R<br>1: W<br>The D                                                                                                              | DMA signal mode This bit specifies the output timing for the DMAAK[0:5] and DMATC[0:5] output pins.  0: Read cycle 1: Write cycle The DSM bit is provided only for the DTCD0 to DTCD5 registers. The DTCD6 to DTCD15 registers do not have this bit. |             |                                                                                                                              |  |  |  |
| Ca           | (E<br>gı<br>2. T | TSn.D<br>uarante<br>ne opei                                                                                                                           | TSnDT<br>eed.<br>ration c                                                                                                                                                                                                                            | E bit = 1). | bited while DMA transfer is enabled If they are written, the operation is not guaranteed if the SACM[1:0] and DACM[1:0] bits |  |  |  |

Figure 4.15 DTCTn Register Format (2/2)

3. Be sure to set bits 11 and 0 to "0".

# Setting examples

```
DTCT0 = 0x1000; /* 8bit data size;donot clear DTE;
increment at tranfer source;
increment at tranfer destination;
output at read cycle */
DTCT1 = 0x3000; /* 16bit data size;donot clear DTE;
increment at tranfer source;
increment at tranfer destination;
output at read cycle */
```

# 4.2.9 DMA Transfer Request Select Register (DTRSn)

This register specifies assignment of a DMA transfer request. A software DMA transfer request or a hardware DMA transfer request can be selected as a DMA transfer request.

This register can be read or written in 16-bit units. DTRS15: FFFF 7660<sub>H</sub>, DTRS14: FFFF 7630<sub>H</sub>, DTRS13: FFFF 7600<sub>H</sub>, Address DTRS12: FFFF 75D0<sub>H</sub>, DTRS11: FFFF 75A0<sub>H</sub>, DTRS10: FFFF 7570<sub>H</sub>, DTRS9: FFFF 7540H, DTRS8: FFFF 7510H, DTRS7: FFFF 7460H, DTRS6: FFFF 7430H, DTRS5: FFFF 7400H, DTRS4: FFFF 73D0H, DTRS3: FFFF 73A0<sub>H</sub>, DTRS2: FFFF 7370<sub>H</sub>, DTRS1: FFFF 7340<sub>H</sub>, DTRS0: FFFF 7310H Initial Value 0000<sub>H</sub> 15 14 13 12 11 10 8 0 0 0 0 0 0 0 0 R R R R R R

6 0 7 5 4 3 2 1 DTR<sub>3</sub> DTR2 0 0 DTR<sub>1</sub> DTR<sub>0</sub> 0 0 R/W R R R R R/W R/W R/W

Table 10-10 DTRSn register contents

| Bit position | Bit name        | Function                                                                                              |                                          |   |   |                               |  |
|--------------|-----------------|-------------------------------------------------------------------------------------------------------|------------------------------------------|---|---|-------------------------------|--|
| 3:0          | DTR3 to<br>DTR0 | DMA transfer request assignment These bits specify assignment of a DMA transfer request to channel n. |                                          |   |   |                               |  |
|              |                 | DTR3                                                                                                  | DTR3 DTR2 DTR1 DTR0 DMA transfer request |   |   |                               |  |
|              |                 | 0                                                                                                     | 0 0                                      |   | 0 | Software DMA transfer request |  |
|              |                 | 0                                                                                                     | 0                                        | 0 | 1 | Hardware DMA transfer request |  |
|              |                 | Other tha                                                                                             | n above                                  |   |   | Setting prohibited            |  |
|              | 1               |                                                                                                       |                                          |   |   |                               |  |

#### Cautions

- Writing these bits is prohibited while DMA transfer is enabled (DTSn.DTSnDTE bit = 1). If they are written, the operation is not guaranteed.
- 2. The operation is not guaranteed if DTR[3:0] are set to a prohibited status.

Figure 4.16 DTRSn Register Format

#### Setting examples

| DTRS0 = $0x0000$ ; | /* software transfer request */ |  |
|--------------------|---------------------------------|--|
| DTRS1 = $0x0001$ ; | /* hardware transfer request */ |  |

# 4.2.10 DTFR Control Register (DTFRn)

This register enables or disables the operation of the DMA source selector of channel n and selects the transfer source.



Bit position

REQEN

This bit enables or disables operation of the DMA source selector of channel n.
1: Enables operation of source selector
0: Stops operation of source selector. Does not issue DMA transfer request (DMARQ).
The settings of IFCn6 to IFCn0 are valid. Requests are always sampled.

These bits select the transfer source.
The set values are shown in Table 10-2 "DMA start sources (0 to 63)".

Figure 4.17 DTFRn Register Format

#### Setting example

| DTFR0 = 0x0000;    | /* software transfer request */                        |
|--------------------|--------------------------------------------------------|
| DTFR1 = $0x8020$ ; | /* set hardware transfer request of dmac1 is taua0i0*/ |

Table 4.1 DMA Start Sources (1/2)

| DTFRn.IFCn[6:0] | Interrupt to start DMA |
|-----------------|------------------------|
| 0               | INTPO                  |
| 1               | INTP1                  |
| 2               | INTP2                  |
| 3               | INTP3                  |
| 4               | INTP4                  |
| 5               | INTP5                  |
| 6               | INTP6                  |
| 7               | INTP7                  |
| 8               | INTP8                  |
| 9               | INTP9                  |
| 10              | INTP10                 |
| 11              | INTP11                 |
| 12              | INTP12                 |
| 13              | INTP13                 |
| 14              | INTP14                 |
| 15              | INTP15                 |
| 16              | INTP16                 |
| 17              | INTP17                 |
| 18              | INTP18                 |
| 19              | INTP19                 |
| 20              | INTP20                 |
| 21              | INTP21                 |
| 22              | INTP22                 |
| 23              | INTP23                 |
| 24              | INTP24                 |
| 25              | INTP25                 |
| 26              | INTP26                 |
| 27              | INTP27                 |
| 28              | INTADCA0I0             |
| 29              | INTADCA0I1             |
| 30              | INTADCA012             |
| 31              | INTADCAOILLT           |

| DTFRn.IFCn[6:0] | Interrupt to start DMA |
|-----------------|------------------------|
| 32              | INTTAUA0I0             |
| 33              | INTTAUA0I1             |
| 34              | INTTAUA0I2             |
| 35              | INTTAUA0I3             |
| 36              | INTTAUA0I4             |
| 37              | INTTAUA0I5             |
| 38              | INTTAUA016             |
| 39              | INTTAUA017             |
| 40              | INTTAUA018             |
| 41              | INTTAUA019             |
| 42              | INTTAUA0I10            |
| 43              | INTTAUA0I11            |
| 44              | INTTAUA0I12            |
| 45              | INTTAUA0I13            |
| 46              | INTTAUA0I14            |
| 47              | INTTAUA0I15            |
| 48              | INTTAUA1IO             |
| 49              | INTTAUA111             |
| 50              | INTTAUA1I2             |
| 51              | INTTAUA1I3             |
| 52              | INTTAUA114             |
| 53              | INTTAUA115             |
| 54              | INTTAUA116             |
| 55              | INTTAUA117             |
| 56              | INTTAUA118             |
| 57              | INTTAUA119             |
| 58              | INTTAUA1I10            |
| 59              | INTTAUA1111            |
| 60              | INTTAUA1I12            |
| 61              | INTTAUA1I13            |
| 62              | INTTAUA1I14            |
| 63              | INTTAUA1115            |

Table 4.2 DMA Start Sources (2/2)

| DTFRn.IFCn[6:0] | Interrupt to start DMA |
|-----------------|------------------------|
| 64              | INTTAUA2I2             |
| 65              | INTTAUA2I3             |
| 66              | INTTAUA2I4             |
| 67              | INTTAUA2I5             |
| 68              | INTTAUA3I0             |
| 69              | INTTAUA3I1             |
| 70              | INTTAUA3I2             |
| 71              | INTTAUA3I3             |
| 72              | INTTAUA3I4             |
| 73              | INTTAUA3I5             |
| 74              | INTTAUA3I6             |
| 75              | INTTAUA317             |
| 76              | INTTAUA318             |
| 77              | INTTAUA3I9             |
| 78              | INTTAUA3I10            |
| 79              | INTTAUA3I11            |
| 80              | INTTAUA3I12            |
| 81              | INTTAUA3I13            |
| 82              | INTTAUA3I14            |
| 83              | INTTAUA3I15            |
| 84              | INTTAUJ0I0             |
| 85              | INTTAUJ0I1             |
| 86              | INTTAUJ0I2             |
| 87              | INTTAUJ0I3             |
| 88              | INTENCA0IOV            |
| 89              | INTENCA0IUD            |
| 90              | INTENCA0I0             |
| 91              | INTENCA0I1             |
| 92              | INTENCA0IEC            |
| 93              | INTENCA10V             |
| 94              | INTENCATIUD            |
| 95              | INTENCA110             |

| DTFRn.IFCn[6:0] | Interrupt to start DMA |
|-----------------|------------------------|
| 96              | INTENCA1I1             |
| 97              | INTENCATIEC            |
| 98              | INTTAPAOIPEKO          |
| 99              | INTTAPA0IVLY0          |
| 100             | INTTAPA2ADOUT0         |
| 101             | INTTAPA0ADOUT0         |
| 102             | INTTAPA0ADOUT1         |
| 103             | INTTAPA1IPEK0          |
| 104             | INTTAPA1IVLY0          |
| 105             | INTTAPA3ADOUT0         |
| 106             | INTTAPA1ADOUT0         |
| 107             | INTTAPA1ADOUT1         |
| 108             | INTCSIH0IR             |
| 109             | INTCSIHOIC             |
| 110             | INTCSIH1IR             |
| 111             | INTCSIH1IC             |
| 112             | INTCSIH2IR             |
| 113             | INTCSIH2IC             |
| 114             | INTCSIH3IR             |
| 115             | INTCSIH3IC             |
| 116             | INTCSIGOIR             |
| 117             | INTCSIG0IC             |
| 118             | INTCSIG1IR             |
| 119             | INTCSIG1IC             |
| 120             | INTCSIG2IR             |
| 121             | INTCSIG2IC             |
| 122             | INTCSIG3IR             |
| 123             | INTCSIG3IC             |
| 124             | INTCSIG4IR             |
| 125             | INTCSIG4IC             |
| 126             | INTCSIGSIR             |
| 127             | INTCSIGSIC             |

# 4.3 Function Specifications

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

# 4.3.1 Main Processing (main.c)

[Function Name] main ()

[Function] Calls necessary initialization functions before entering an infinite loop.

[Arguments] None [Return Value] None

[Startup Method] Enters the main function after hardware initialization.

[SFRs Used] DTS0SR, TAUA0TS

[Calling Function] None
[Variables] None
[File name] main.c
[Notes] None

## 4.3.2 Software Initialization Processing (initial.c)

[Function Name] port\_initial()

[Function] Sets up ports and their mode.

[Arguments] None [Return Value] None [Startup Method] Call

[SFRs Used] PFCE0, PFC0, PMC0, PM0, PFCE13, PFC13, PMC13, PM13

[Calling Function]main()[Variables]None[File Name]initial.c[Notes]None

[Function Name] cg initial()

[Function] Initializes the special clock frequency control register.

[Arguments] None [Return Value] None [Startup Method] Call SFRCTL3 [SFRs Used] [Calling Function] main() [Variables] None [File Name] initial.c [Notes] None

[Function Name] hbus\_initial()

[Function] Initializes the AHB bus.

[Arguments] None [Return Value] None [Startup Method] Call

[SFRs Used] ETARCFG0, ETARADRS0, ETARMASK0

[Calling Function] main()
[Variables] None
[File Name] initial.c
[Notes] None

[Function Name] board\_initial()

[Function] Sets up the initial state of the LEDs.

[Arguments] None [Return Value] None [Startup Method] Call [SFRs Used] P13 [Calling Function] main() [Variables] None [File Name] initial.c [Notes] None

[Function Name] ram\_initial()

[Function] Sets up the initial state of the internal RAM.

[Arguments] None [Return Value] None [Startup Method] Call [SFRs Used] None [Calling Function] main()

[Variables] DMA\_source, DMA\_IO

[File Name] initial.c [Notes] None

#### 4.3.3 DMA Control Processing (dma\_control.c)

[Function Name] dma0 initial()

[Function] Sets up the operation of the DMA.

[Arguments] None [Return Value] None [Startup Method] Call

[SFRs Used] ICDMA0, ICDMACT0, DTS0, DSA0, DDA0, DSC0, DDC0, DTC0, DTCC0, DTCT0,

DTRS0

[Calling Function] main()
[Variables] None

[File Name] dma\_control.c

[Notes] None

[Function Name] dma1\_initial()

[Function] Sets up the operation of the ADC.

[Arguments] None [Return Value] None [Startup Method] Call

[SFRs Used] ICDMA1, ICDMACT1, DTS1, DSA1, DDA1, DSC1, DDC1, DTC1, DTCT1,

DTRS1, DTFR1

[Calling Function] main()
[Variables] None

[File Name] dma\_control.c

[Notes] None

### 4.3.4 Interrupt Processing (interrupt.c)

[Function Name] int\_dma1()

[Function] Processes DMA transfer end interrupt.

[Arguments] None [Return Value] None

[Startup Method] Request INTDMA1 is present in an unmasked state.

[SFRs Used] DTS1TC, P13

[Calling Function]None[Variables]None[File Name]interrupt.c[Notes]None

[Function Name] int dmact0()

[Function] Processes DMA transfer count match interrupt.

[Arguments] None [Return Value] None

[Startup Method] Request INTDMACT0 is present in an unmasked state.

[SFRs Used] P13 [Calling Function] None [Variables] None [File Name] interrupt.c [Notes] None

# 4.3.5 Timer Control Processing (taua0\_control.c)

[Function Name] taua0\_initial()

[Function] Sets up the inverter function so that INTTAUAOIO becomes the trigger for DMA1.

[Arguments] None [Return Value] None [Startup Method] Call

[SFRs Used] TAUA0TPS, TAUA0BRS, TAUA0CMOR0, TAUA0CMUR0, TAUA0CDR0,

TAUA0TOE, TAUA0TOM, TAUA0TOC, TAUA0TOL, TAUA0TDE, TAUA0TDM, TAUA0TDL, TAUA0TRE, TAUA0TRO, TAUA0TRC, TAUA0TME, TAUA0RDE,

TAUAORDS, TAUAORDM, TAUAORDC

[Calling Function] main() [Variables] None

[File Name] taua0\_control.c

[Notes] None

# **Website and Support**

Renesas Electronics Website <a href="http://www.renesas.com/">http://www.renesas.com/</a>

Inquiries

http://www.renesas.com/inquiry

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

# **Revision Record**

# Description

| Rev. | Date         | Page | Summary              |
|------|--------------|------|----------------------|
| 1.00 | Jan 30, 2012 | _    | First edition issued |

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

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

#### 1. Handling of Unused Pins

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

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

— The characteristics of MPU/MCU in the same group but having different type numbers may differ because of the differences in internal memory capacity and layout pattern. When changing to products of different type 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 others.
- 3. 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.
- 6. 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
- 7. 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.
  - 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. Reneasa Electronics shall have no liability for malfunctions or damages arising out of the
- 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 ns 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 BoHS Directive. Benesas 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.
7th Floor, Quantum Plaza, No.27 ZhiChunLu 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-2868-9318, Fast: +852-2868-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: +82-2-558-3737, Fax. +82-2-558-5141

© 2012 Renesas Electronics Corporation. All rights reserved