# Old Company Name in Catalogs and Other Documents

On April 1<sup>st</sup>, 2010, NEC Electronics Corporation merged with Renesas Technology Corporation, and Renesas Electronics Corporation took over all the business of both companies. Therefore, although the old company name remains in this document, it is a valid Renesas Electronics document. We appreciate your understanding.

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

April 1<sup>st</sup>, 2010 Renesas Electronics Corporation

Issued by: Renesas Electronics Corporation (http://www.renesas.com)

Send any inquiries to http://www.renesas.com/inquiry.

#### 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.
- 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. 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; anticrime 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 majorityowned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.



# SH7080 Group

# Data Transfer Controller (DTC) in Chain Transfer Mode

# Introduction

This application note describes the chain transfer mode of the data transfer controller (DTC). It is intended as reference material to help in the design of user software.

# **Target Device**

SH7086

# Contents

| 1. | Specification               | . 2 |
|----|-----------------------------|-----|
| 2. | Applicable Conditions       | . 2 |
| 3. | Description of Modules Used | . 3 |
| 4. | Principles of Operation     | . 6 |
| 5. | Description of Software     | 10  |
| 6. | Flowcharts                  | 22  |
| 7. | Documents for Reference     | 26  |

# 1. Specification

**CENESAS** 

In this sample application, ADI interrupt requests from the A/D converter of the SH7086 activate the DTC for data transfer in normal transfer mode.

A/D conversion is performed once on analog input channels 0 to 3 (AN0 to AN3) in continuous scan mode. The DTC transfers the converted data in ADDR0 to the on-chip RAM. After the data in ADDR0 have been transferred, the DTC transfers the converted data in ADDR1 to the RAM. An overview of the operation is presented in figure 1.



Figure 1 Overview of DTC Operation

# 2. Applicable Conditions

The applicable conditions for this sample application are shown in table 1.

| Item                | Setting                                                                                                                                                                                                                                                     |                                                                                            |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| Device              | SH7086 (R5F70865                                                                                                                                                                                                                                            | )                                                                                          |
| Operating frequency | Internal clock                                                                                                                                                                                                                                              | $I\phi = 80 \text{ MHz}$                                                                   |
|                     | Bus clock                                                                                                                                                                                                                                                   | $B\phi = 40 \text{ MHz}$                                                                   |
|                     | Peripheral clock                                                                                                                                                                                                                                            | $P\phi = 40 \text{ MHz}$                                                                   |
|                     | MTU2 clock                                                                                                                                                                                                                                                  | $MP\phi = 40 MHz$                                                                          |
|                     | MTU2S clock                                                                                                                                                                                                                                                 | $MI\phi = 80 MHz$                                                                          |
| Operating mode      | Single-chip mode                                                                                                                                                                                                                                            |                                                                                            |
| Development tool    | development enviror                                                                                                                                                                                                                                         | mbedded Workshop Ver.4.03.00.001 (integrated<br>nment)<br>e Standard Toolchain (V.9.1.1.0) |
|                     | SuperH RISC engine                                                                                                                                                                                                                                          | e C/C++ Compiler (V.9.01.01)<br>enesas Technology)                                         |
| C compiler options  | High-performance Embedded Workshop default settings:<br>[ -cpu=sh2 -object="\$(CONFIGDIR)\\$(FILELEAF).obj" -debug -gbr=auto -<br>chgincpath -errorpath -global_volatile=0 -opt_range=all -infinite_loop=0 -<br>del_vacant_loop=0 -struct_alloc=1 -nologo ] |                                                                                            |

# 3. Description of Modules Used

In this sample application, the DTC transfers data to the on-chip RAM when activated by an ADI interrupt request.

The functions of the DTC of SH7080 Group products are outlined in table 2.

#### Table 2DTC Function Overview

| Item                                                                                                                     | Overview                                                                                                                                                 |
|--------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Number of channels                                                                                                       | Transfer is possible any number of channels.                                                                                                             |
| Chain transfer                                                                                                           | Chain transfer is possible (data transfer can be performed multiple times in response to a single activation source).                                    |
|                                                                                                                          | <ul> <li>Chain transfer is only possible after data transfer has been performed<br/>for the specified number of times (when the counter = 0).</li> </ul> |
| Transfer mode                                                                                                            | <ul> <li>Normal transfer, repeat transfer or block transfer mode can be selected.</li> </ul>                                                             |
|                                                                                                                          | <ul> <li>Increment decrement or fixed can be selected for the source and destination addresses.</li> </ul>                                               |
| Address space The transfer source and destination addresses can be specified to select a 4-Gbyte address space directly. |                                                                                                                                                          |
| Transfer data size                                                                                                       | Data transfer size can be specified by one byte, word or longword.                                                                                       |
| Interrupt source                                                                                                         | <ul> <li>An interrupt request can be issued to the CPU after one data transfer<br/>completion.</li> </ul>                                                |
|                                                                                                                          | <ul> <li>An interrupt request can be issued to the CPU after all specified data<br/>transfer completion.</li> </ul>                                      |
| Bus release timing                                                                                                       | Timing is selected from five types.                                                                                                                      |
| Priority of DTC activation                                                                                               | Priority of the DTC activation can be selected fro two types.                                                                                            |
| Others                                                                                                                   | Read skip of the transfer-control information can be specified.                                                                                          |
|                                                                                                                          | <ul> <li>Writeback skip is executed for the fixed transfer source and destination<br/>addresses.</li> </ul>                                              |
|                                                                                                                          | Module stop mode can be set.                                                                                                                             |
|                                                                                                                          | Short address mode can be set.                                                                                                                           |



A block diagram of the DTC is shown in figure 3.



Figure 2 Block Diagram of the DTC

- DTC mode register A (MRA) and DTC mode register B (MRB) MRA and MRB are 8-bit registers that control the operating mode of the DTC.
- DTC source address register (SAR) SAR is a 32-bit register that designates the source address of data to be transferred by the DTC.
- DTC destination address register (DAR)
   DAR is a 32-bit register that designates the destination address of data to be transferred by the DTC.
- DTC transfer count register A (CRA) CRA is a 16-bit register that designates the number of times data is to be transferred by the DTC. In normal transfer mode, CRA functions as a 16-bit transfer counter (1 to 65,536). In repeat transfer mode, CRA is divided into two parts: the upper eight bits (CRAH) and the lower eight bits (CRAL). CRAH holds the number of transfers while CRAL functions as an 8-bit transfer counter. In block transfer mode, CRA is divided into tow parts: the upper eight bits (CRAH) and the lower eight bits (CRAL). CRAH holds the block size while CRAL functions as an 8-bit blocksize counter.
- DTC transfer count register (CRB) CRB is a 16-bit register. In block transfer mode it specifies the number of times blocks are to be transferred.
- The DTC enable register (DTCER) DTCER which is comprised of eight registers, DTCERA to DTCERE, is a 16-bit register that specifies DTC activation interrupt sources.
- The DTC control register (DTCCR) DTCCR is an 8-bit register that specifies transfer information read skip.
- The DTC vector base register (DTCVBR) DTCVBR is a 32-bit register that specifies the base address for vector table address calculation.
- Six registers, the DTC mode register (MRA), DTC mode register B (MRB), DTC source address register (SAR), DTC destination address register (DAR), DTC transfer count register A (CRA) and DTC transfer count register B (CRB) are not directly accessible from the CPU. When an event corresponding to a DTC activation source occurs, the necessary information for these registers is selected from the set of register information stored in the on-chip RAM and then transferred to the registers so that the DTC transfer can proceed. On completion of the transfer, the contents of these registers are written back to the on-chip RAM. Accordingly, you can have the user program store information for these registers in desired addresses within the on-chip RAM.
- Note: For details on the operational specifications, see the section on the data transfer controller (DTC) in the SH7080 Group Hardware Manual.

# 4. Principles of Operation

Operations for this sample application are described below.

Figure 4 is a timing diagram for A/D conversion, DTC activation and data transfer. The processes are shown in table 3.

In this sample application, the ADI interrupt request is the DTC activation source. In addition, only channels AN0 and AN1 are used for DTC transfer although all A/D conversion proceeds on all of the specified channels (in this case, four channels) in continuous scan mode.

Firstly, the ADI interrupt is enabled, and then the ADST bit is set to 1 to start A/D conversion (figure 3, (1)). When the ADF bit is set to 1 automatically at the end of the A/D conversion, an ADI interrupt request is generated and the DTC is activated (figure 3, (2)). Even if an ADI interrupt request is generated, no interrupt occurs if the DTC is activated. Then, the DTC transfers A/D-converted data in ADDR0 to the previously reserved area in RAM (figure 3, (3)). After that, the DTC also transfers A/D-converted data in ADDR1 to the area in RAM in succession. When the data transfer ends, the ADF bit is automatically cleared (figure 3, (4)). The A/D conversion in this sample application is performed in continuous scan mode. Therefore, the ADST bit is not automatically cleared. When the DTC transfer ends and the ADF bit is set to 1, the DTCE bit is cleared automatically, thereby causing an ADI interrupt (figure 3, (5)). In the processing routine for this interrupt, the ADST bit is cleared to stop the A/D converter (figure 3, (6)).



Figure 3 Timing of A/D Conversion and DTC Transfer



#### Table 3 Processes

|     | Software Processing                               | Hardware Processing                       |
|-----|---------------------------------------------------|-------------------------------------------|
| (1) | Enable an ADI interrupt.                          |                                           |
|     | Set the ADST bit to 1 (for start A/D conversion). |                                           |
| (2) |                                                   | Set the ADF bit to 1.                     |
|     |                                                   | Generate an ADI interrupt request.        |
|     |                                                   | Activate the DTC.                         |
| (3) | —                                                 | Transfer data from ADDR0 to the RAM area. |
| (4) | —                                                 | Transfer data from ADDR1 to the RAM area. |
| (5) | _                                                 | Set the ADF bit to 1.                     |
|     |                                                   | Clear the DTCE bit to 0.                  |
|     |                                                   | Generate an ADI interrupt.                |
| (6) | Clears the ADST bit (to stop the A/D converter).  | _                                         |

# SH7080 Group Data Transfer Controller (DTC) in Chain Transfer Mode

A more detailed timing diagram of the DTC transfer operations is given as figure 4.

In DTC transfer, DTC activation sources (in this case, ADI interrupt request) generate DTC requests. Mastership of the internal bus is secured and the DTC is activated (figure 4(1)). The address where the control information for the transfer starts is read from the vector table of ADI activation sources (figure 4 (2)) that has been set up for this example. The information is then read, starting at the given address (figure 4 (3)). After that, the data is transferred from the source address (ADDR0) to the destination address (on-chip RAM) (figure 4 (4)). The transfer control information is then written back (figure 4 (5)). This is followed by reading of the next set of transfer control information after which the data from the source for the next transfer (ADDR1) are transferred to the destination address (in the on-chip RAM) (figure 4 (6)). The ADF bit is automatically cleared in response to reading of the ADDR (figure 4 (7)).

Finally, the control information for the transfer is written back (figure 4 (8)). The DTC releases the bus after the writeback operation (figure 4 (9)).



Figure 4 Detailed Timing Chart of DTC Transfer



The flow of data in memory for the operations shown in zones (2) to (6) of figure 4 is illustrated in figure 5 and described in table 4.



Figure 5 Flow of Data in Memory

#### Table 4Description of Figure 5

#### DTC Function

| (1) | Reads the address (base address + H'400 + interrupt source (ADI) vector number $\times$ 4) of the transfer-<br>control information from the vector for this activation source (ADI). |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (2) | Reading of the transfer-control information 1                                                                                                                                        |
|     | This information specifies the data size, source address, destination address, etc. for the first transfer                                                                           |
| (3) | Transfers the amount of data specified as the size by the transfer-control information 1 from the source address 1 (ADDR0) to the destination address 1 (in RAM).                    |
| (4) | Reading of the transfer-control information 2                                                                                                                                        |
|     | This information specifies the data size, source address, destination address, etc. for the second transfer                                                                          |
| (5) | Transfers the amount of data specified as the size by the transfer-control information 2 from the source address 2 (ADDR0) to the destination address 2 (in RAM).                    |



## 5. Description of Software

## 5.1 List of Functions

The functions used in this sample application are listed below.

#### Table 5List of Functions

| Function Name   | Description                                                 |  |
|-----------------|-------------------------------------------------------------|--|
| main()          | Performs DTC transfer and calls the A/D conversion routine. |  |
| ad_conv()       | A/D conversion routine                                      |  |
| INT_AD0_ADI0 () | ADI interrupt routine                                       |  |

## 5.2 Variables Used

The variables used in this sample application are listed below.

#### Table 6 List of Variables

| Variable/Label Name              | Description                                              | Reference<br>Function |
|----------------------------------|----------------------------------------------------------|-----------------------|
| unsigned short D_data[DTC_COUNT] | data.<br>DTC_COUNT is the number of times transfer is to | main()                |
|                                  | proceed, i.e. 2 for this sample application.             |                       |
| unsigned short dummy             | Variable for reading the interrupt source bit            | main()                |

## 5.3 Section Settings

The sections of the program for this sample application are assigned as shown below.

The vector for a DTC activation source used in this sample application is as follows.

#### Table 7 Section Settings

| Address    | Section Name          | Description                                             |
|------------|-----------------------|---------------------------------------------------------|
| H'0000000  | DVECTTBL, DINTTBL,    | DVECTTBL: Exception vector table                        |
|            | PIntPRG               | DINTTBL: Interrupt vector table                         |
|            |                       | PIntPRG: Interrupt program                              |
| H'00000800 | PResetPRG             | Reset program                                           |
| H'00001000 | P, C\$BSEC, C\$DEC, D | P: Program area                                         |
|            |                       | C\$BSEC: Holds an address for B section initialization. |
|            |                       | C\$DEC: Holds an address for D section initialization.  |
|            |                       | D: Holds data.                                          |
| H'FFFF4000 | B, R                  | B: uninitialized data area.                             |
|            |                       | R: initialized data area.                               |
| H'FFFF6720 | DDTC_AD0_ADI          | Vector for the DTC activation source (ADI interrupt     |
|            |                       | requests)                                               |
| H'FFFFBC00 | S                     | Stack area                                              |

# 5.4 Register Settings

The registers used in this sample application are described below. The settings below are the values used in this application and differ from the initial values.

# 5.4.1 Clock Oscillator (CPG) Settings

- 1. Frequency Control Register (FRQCR)
  - Function: Specifies the frequency division ratios for the internal clock (Ιφ), bus clock (Βφ), peripheral clock (Pφ), MTU2S clock (ΜΙφ), and MTU2 clock (ΜΡφ).

Set value: H'0241

| Bit      | Bit Name  | Set Value | Description                                                                   |
|----------|-----------|-----------|-------------------------------------------------------------------------------|
| 15       |           | 0         | Reserved                                                                      |
| 14 to 12 | IFC[2:0]  | 000       | Internal Clock (I                                                             |
|          |           |           | 000: $\times$ 1 (I $\phi$ = 80 MHz for an input clock frequency of 10 MHz)    |
| 11 to 9  | BFC[2:0]  | 001       | Bus Clock (B) Frequency Division Ratio                                        |
|          |           |           | 001: $\times$ 1/2 (B $\phi$ = 40 MHz for an input clock frequency of 10 MHz)  |
| 8 to 6   | PFC[2:0]  | 001       | Peripheral Clock (P) Frequency Division Ratio                                 |
|          |           |           | 001: $\times$ 1/2 (P $\phi$ = 40 MHz for an input clock frequency of 10 MHz)  |
| 5 to 3   | MIFC[2:0] | 000       | MTU2S Clock (MI                                                               |
|          |           |           | 000: $\times$ 1 (MI $\phi$ = 80 MHz for an input clock frequency of 10 MHz)   |
| 2 to 0   | MPFC[2:0] | 001       | MTU2 Clock (MP                                                                |
|          |           |           | 001: $\times$ 1/2 (MP $\phi$ = 40 MHz for an input clock frequency of 10 MHz) |

#### 5.4.2 Power-Down Mode Settings

1. Standby Control Register 2 (STBCR2)

Function:Controls the operation of individual modules in power-down mode.Set value:H'28

| Bit    | Bit Name | Set Value | Description                                                      |
|--------|----------|-----------|------------------------------------------------------------------|
| 7      | MSTP7    | 0         | Module Stop Bit 7                                                |
|        |          |           | When set to 1, stops the clock supply to the to the on-chip RAM. |
|        |          |           | When set to 0, activates the on-chip RAM.                        |
| 6      | MSTP6    | 0         | Module Stop Bit 6                                                |
|        |          |           | When set to 1, stops the clock supply to the to the ROM.         |
|        |          |           | When set to 0, activates the ROM.                                |
| 5      |          | 1         | Reserved                                                         |
| 4      | MSTP4    | 0         | Module Stop Bit 4                                                |
|        |          |           | When set to 1, stops the clock supply to the to the DTC.         |
|        |          |           | When set to 0, activates the DTC.                                |
| 3      | MSTP3    | 1         | Module Stop Bit 3                                                |
|        |          |           | When set to 1, stops the clock supply to the to the DMAC.        |
|        |          |           | When set to 0, activates the DMAC.                               |
| 2 to 0 |          | All 0     | Reserved                                                         |

Standby Control Register 4 (STBCR4)
 Function: Controls the operation of individual modules in power-down mode.
 Set value: H'FE

| Bit  | Bit Name | Set Value | Description                                                |
|------|----------|-----------|------------------------------------------------------------|
| 7    | MSTP23   | 1         | Module Stop Bit 23                                         |
|      |          |           | When set to 1, stops the clock supply to the to the MTU2S. |
| _    |          |           | When set to 0, activates the MTU2S.                        |
| 6    | MSTP22   | 1         | Module Stop Bit 22                                         |
|      |          |           | When set to 1, stops the clock supply to the to the MTU2.  |
|      |          |           | When set to 0, activates the MTU2.                         |
| 5    | MSTP21   | 1         | Module Stop Bit 21                                         |
|      |          |           | When set to 1, stops the clock supply to the to the CMT.   |
|      |          |           | When set to 0, activates the CMT.                          |
| 4, 3 | —        | All 1     | Reserved                                                   |
| 2    | MSTP18   | 1         | Module Stop Bit 18                                         |
|      |          |           | When set to 1, stops the clock supply to the to the AD_2.  |
|      |          |           | When set to 0, activates the AD_2.                         |
| 1    | MSTP17   | 1         | Module Stop Bit 17                                         |
|      |          |           | When set to 1, stops the clock supply to the to the AD_1.  |
|      |          |           | When set to 0, activates the AD_1.                         |
| 0    | MSTP16   | 0         | Module Stop Bit 16                                         |
|      |          |           | When set to 1, stops the clock supply to the to the AD_0.  |
|      |          |           | When set to 0, activates the AD_0.                         |



#### 5.4.3 Interrupt Controller Settings

1. Interrupt Priority Register K (IPRK) Function: Sets priority levels for interrupt sources. Set value: H'F000

| Bit      | Bit Name | Set Value | Description                                                                                                                   |
|----------|----------|-----------|-------------------------------------------------------------------------------------------------------------------------------|
| 15 to 12 | A/D0, 1  | All 1     | Set the priority level of the A/D0 and A/D1 interrupt sources.<br>(The maximum value, 15, is set in this sample application). |
| 11 to 8  | A/D2     | All 0     | Set the priority level of the A/D2 interrupt source.<br>(The initial value is set in this sample application).                |
| 7 to 0   |          | All 0     | Reserved                                                                                                                      |

# 5.4.4 DTC Settings

1. DTC Mode Register A (MRA)

Function: Selects DTC operating mode. MRA cannot be accessed directly by the CPU. Transfer-control information should be stored in the on-chip RAM.

Set value: H'10

| Bit  | Bit Name | Set Value | Description                                                     |
|------|----------|-----------|-----------------------------------------------------------------|
| 7, 6 | MD[1:0]  | 00        | DTC Mode 1/0                                                    |
|      |          |           | Specifies DTC transfer mode.                                    |
|      |          |           | (Normal transfer mode is specified in this sample application.) |
| 5, 4 | Sz[1:0]  | 01        | DTC Data Transfer Size 1 and 0                                  |
|      |          |           | Specifies the size of data to be transferred.                   |
|      |          |           | (One word is specified in this sample application.)             |
| 3, 2 | SM[1:0]  | 00        | Source Address Mode 1 and 0                                     |
|      |          |           | Specifies an SAR operation after a data transfer.               |
|      |          |           | (SAR is fixed after transfer in this sample application.)       |
| 1, 0 |          | All 0     | Reserved                                                        |

#### 2. DTC Mode Register B (MRB)

**I**≺ENES∆S

Function: Selects operating mode. MRB cannot be accessed directly by the CPU. Transfer-control information should be stored in the on-chip RAM.

Chain transfer (first transfer) settings

Set value: H'C8

| Bit  | Bit Name | Set Value | Description                                                                                                                                                                                                                                                                                      |
|------|----------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | CHNE     | 0         | DTC Chain Transfer Enable<br>Specifies the chain transfer.<br>(Chain transfer is enabled in this sample application.)                                                                                                                                                                            |
| 6    | CHNS     | 0         | DTC Chain Transfer Select<br>Selects conditions of chain transfer. (In this sample application, chain<br>transfer proceeds when the transfer counter is 0.)                                                                                                                                      |
| 5    | DISEL    | 0         | DTC Interrupt Select<br>When this bit is set to 1, an interrupt request is issued to the CPU after<br>each data transfer or block transfer.<br>When this bit is set to 0, an interrupt request is issued to the CPU after<br>data transfer has been completed for the specified number of times. |
| 4    | DTS      | 0         | DTC Transfer Mode Select<br>Specifies either the source or destination as repeat or block area during<br>repeat or block transfer mode.<br>(used in the case of repeat transfer and block transfer modes.)                                                                                       |
| 3, 2 | DM[1:0]  | 10        | Destination Address Mode 1 and 0<br>Specifies the DAR operation after data transfer. (The DAR is<br>incremented after transfer in case of this sample application.)                                                                                                                              |
| 1, 0 |          | 00        | Reserved                                                                                                                                                                                                                                                                                         |



Settings after chain transfer (second transfer)

Set value: H'08

| Bit  | Bit Name | Set Value | Description                                                                |
|------|----------|-----------|----------------------------------------------------------------------------|
| 7    | CHNE     | 0         | DTC Chain Transfer Enable                                                  |
|      |          |           | Specifies the chain transfer.                                              |
|      |          |           | (Chain transfer is disabled for this sample application.)                  |
| 6    | CHNS     | 0         | DTC Chain Transfer Select                                                  |
|      |          |           | Specifies the chain transfer condition.                                    |
|      |          |           | (Used in case of chain transfer.)                                          |
| 5    | DISEL    | 0         | DTC Interrupt Select                                                       |
|      |          |           | When this bit is set to 1, an interrupt request is issued to the CPU after |
|      |          |           | each data transfer or block transfer.                                      |
|      |          |           | When this bit is set to 0, an interrupt request is issued to the CPU after |
|      |          |           | data transfer has been completed for the specified number of times.        |
| 4    | DTS      | 0         | DTC Transfer Mode Select                                                   |
|      |          |           | Specifies either the source or destination as repeat or block area during  |
|      |          |           | repeat or block transfer mode.                                             |
|      |          |           | (Used in the case of repeat transfer and block transfer modes.)            |
| 3, 2 | DM[1:0]  | 10        | Destination Address Mode 1 and 0                                           |
|      |          |           | Specifies the DAR operation after data transfer. (The DAR is               |
|      |          |           | incremented after transfer in case of this sample application.)            |
| 1, 0 |          | 00        | Reserved                                                                   |

3. DTC Source Address Register (SAR)

Function: Designates the source address of data to be transferred by the DTC. SAR cannot be accessed directly by the CPU. Transfer-control information should be stored in the on-chip RAM.

Chain transfer (first transfer) settings

Set value: H'FFFFC900 (&AD0.ADDR0)

Settings after chain transfer (second transfer)

Set value: H'FFFFC902 (&AD0.ADDR1)

4. DTC Destination Address Register (DAR)

Function: Designates the source address of data to be transferred by the DTC. DAR cannot be accessed directly by the CPU. Transfer-control information should be stored in the on-chip RAM.

Chain transfer (first transfer) settings

Set value: H'FFFF4420 (&(D\_data[0]))

Settings after chain transfer (second transfer)

Set value: H'FFFF4422 (&(D\_data[1]))



5. DTC Transfer Count Register (CRA)

Function: Specifies the DTC data transfer count.

In normal transfer mode, CRA functions as a 16-bit transfer counter (1 to 65,536). It is decremented by 1 every time data is transferred, and bit DTCEn (n = 15 to 0) corresponding to the activation source is cleared and then an interrupt is requested to the CPU when the count reaches H'0000. The transfer count is 1 when CRA = H'0001, 65,535 when CRA = H'FFFF, and 65,536 when CRA = H'0000.

CRA cannot be accessed directly by the CPU. Transfer-control information should be stored in the on-chip RAM.

Chain transfer (first transfer) settings

Set value: H'0001 (once)

Settings after chain transfer (second transfer)

Set value: H'0001 (once)

- 6. DTC Transfer Count Register B (CRB)
  - Function: Designates the number of times data is to be transferred by the DTC in block transfer mode. CRB cannot be accessed directly by the CPU. Transfer-control information should be stored in the on-chip RAM.

Since there is no block transfer in this sample application the initial values are left intact.

Set value: H'0000 (initial value)



#### 7. DTC Enable Register D (DTCERD)

Function: Selects an interrupt source for activating the DTC. The other DTC enable registers are not used for this sample application.

The clearing and setting conditions for each bit in the DTECERD are shown below.

[Clearing conditions]

- Writing 0 to the it after reading it as 1
- Completion of one data transfer and the DISEL bit in MRB = 1
- Completion of the specified number of transfers

[Setting conditions]

— Writing 1 to the bit after reading it as 0

Set value: H'0020

| Bit    | Bit Name | Set Value | Description                                                  |
|--------|----------|-----------|--------------------------------------------------------------|
| 15     | DTCERD15 | 0         | When set to 1, selects TGIA_4S as the DTC activation source. |
| 14     | DTCERD14 | 0         | When set to 1, selects TGIB_4S as the DTC activation source. |
| 13     | DTCERD13 | 0         | When set to 1, selects TGIC_4S as the DTC activation source. |
| 12     | DTCERD12 | 0         | When set to 1, selects TGID_4S as the DTC activation source. |
| 11     | DTCERD11 | 0         | When set to 1, selects TGIV_4S as the DTC activation source. |
| 10     | DTCERD10 | 0         | When set to 1, selects TGIU_4S as the DTC activation source. |
| 9      | DTCERD9  | 0         | When set to 1, selects TGIV_4S as the DTC activation source. |
| 8      | DTCERD8  | 0         | When set to 1, selects TGIW_4S as the DTC activation source. |
| 7      | DTCERD7  | 0         | When set to 1, selects CMI_0 as the DTC activation source.   |
| 6      | DTCERD6  | 0         | When set to 1, selects CMI_1 as the DTC activation source.   |
| 5      | DTCERD5  | 1         | When set to 1, selects ADI_0 as the DTC activation source.   |
| 4      | DTCERD4  | 0         | When set to 1, selects ADI_1 as the DTC activation source.   |
| 3      | DTCERD3  | 0         | When set to 1, selects ADI_2 as the DTC activation source.   |
| 2 to 0 |          | All 0     | Reserved                                                     |

# RENESAS

8. DTC Control Register (DTCCR) Function: Specifies transfer-control information read skip.

Set value: H'00

**Bit Name** 

Bit

Set Value Description

| DIL    | DILINAIIIE | Set value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 5 | _          | All 0     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 4      | RRS        | 0         | DTC Transfer-Control information Read Skip Enable<br>Controls the vector address read and transfer-control information read.<br>A DTC vector number is always compared with the vector number for<br>the previous activation. If the vector numbers match and this bit is set to<br>1, the DTC data transfer is started without reading a vector address and<br>Transfer-control information. If the previous DTC activation is a chain<br>transfer, the vector address read and transfer-control information read<br>are always performed. |
| 3      | RCHNE      | 0         | Chain Transfer Enable After DTC Repeat Transfer<br>Enables or disables chain transfer while transfer counter is 0 in repeat<br>transfer mode.                                                                                                                                                                                                                                                                                                                                                                                               |
| 2, 1   |            | All 0     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0      | ERR        | 0         | Transfer Stop Flag<br>Indicates that the DTC address error or NMI request has occurred. If a<br>DTC address error or NMI occurs while the DTC is active, address error<br>handling or NMI handling processing is executed after the DTC has<br>released the bus mastership. The DTC stops in the transfer-control<br>information writing state after transferring data.<br>[Clearing condition]<br>• Writing of 0 to this bit after reading it as 1                                                                                         |

9. DTC Vector Base Register (DTCVBR)

Function:Specifies the base address for vector table address calculation.Set value:H'FFFF6000

# RENESAS

#### 10. Bus Function Extending Register (BSCEHR)

Function: This register sets the DTC bus release timing, etc.

Set value: BSCEHR is not set in this sample application and the initial values are used on an as-is basis.

| Bit    | Bit Name | Initial Value | Description                                                                                                                                                                                                                                                                                                             |
|--------|----------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | DTLOCK   | 0             | DTC Lock Enable<br>Specifies the timing of bus release by the DTC.                                                                                                                                                                                                                                                      |
| 14     | CSSTP1   | 0             | Select Bus Release on NOP Cycle Generation by DTC<br>Specifies whether or not the bus is released in response to<br>requests from the CPU for external space access on generation of<br>the NOP cycle that follows reading of the vector address.                                                                       |
| 13     |          | 0             | Reserved                                                                                                                                                                                                                                                                                                                |
| 12     | CSSTP2   | 0             | Select Bus Release during Burst-Mode-DMAC/DTC Transfer                                                                                                                                                                                                                                                                  |
| 11     | DTBST    | 0             | DTC Burst Enable<br>Selects whether or not the DTC retains the bus mastership and<br>remains continuously active until all transfer operations are<br>complete when multiple DTC activation requests have been<br>generated.                                                                                            |
| 10     | DTSA     | 0             | DTC Short Address Mode<br>Designates whether the information that specifies a DTC transfer<br>takes up 3 or 4 longwords.                                                                                                                                                                                                |
| 9      | CSSTP3   | 0             | Select Priority for External Memory Access by CPU                                                                                                                                                                                                                                                                       |
| 8      | DTPR     | 0             | Application of Priority in DTC Activation<br>When multiple DTC activation requests are generated before the<br>DTC is activated, specify whether transfer starts from the first<br>request to have been generated or is in accord with the priority<br>order for DTC activation requests.<br>However, when multiple DTC |
| 7 to 5 |          | All 0         | Reserved                                                                                                                                                                                                                                                                                                                |
| 4      | DMMTU4   | 0             | Enable Burst-Mode DMAC Transfer with TGIA_4 Activation Source                                                                                                                                                                                                                                                           |
| 3      | DMMTU3   | 0             | Enable Burst-Mode DMAC Transfer with TGIA_3 Activation<br>Source                                                                                                                                                                                                                                                        |
| 2      | DMMTU2   | 0             | Enable Burst-Mode DMAC Transfer with TGIA_2 Activation<br>Source                                                                                                                                                                                                                                                        |
| 1      | DMMTU1   | 0             | Enable Burst-Mode DMAC Transfer with TGIA_1 Activation<br>Source                                                                                                                                                                                                                                                        |
| 0      | DMMTU0   | 0             | Enable Burst-Mode DMAC Transfer with TGIA_0 Activation<br>Source                                                                                                                                                                                                                                                        |



#### 5.4.5 A/D Conversion Settings

1. A/D Control/Status Register\_0 (ADCSR\_0) Function: Controls A/D conversion and sets A/D conversion time. Set value: H'401B

| Bit    | Bit Name  | Set Valu | e Description                                                              |
|--------|-----------|----------|----------------------------------------------------------------------------|
| 15     | ADF       | 0        | A/D End Flag                                                               |
|        |           |          | A status flag that indicates the end of A/D conversion.                    |
|        |           |          | [Setting condition]                                                        |
|        |           |          | <ul> <li>End of A/D conversion on all the channels in scan mode</li> </ul> |
|        |           |          | [Clearing conditions]                                                      |
|        |           |          | <ul> <li>Writing of 0 to this it after reading it as 1</li> </ul>          |
|        |           |          | DMAC or DTC activation by an ADI interrupt to read ADDR                    |
| 14     | ADIE      | 1        | A/D Interrupt Enable                                                       |
|        |           |          | When set to 1, generation of an ADI .interrupt by ADF is enabled.          |
| 13, 12 |           | All 0    | Reserved                                                                   |
| 11     | TRGE      | 0        | Trigger Enable                                                             |
|        |           |          | Disables triggering of A/D conversion when TRGE = 1.                       |
| 10     |           | 0        | Reserved                                                                   |
| 9      | CONADF    | 0        | ADF Control                                                                |
|        |           |          | Controls setting of the ADF bit in 2-channel scan mode.                    |
| 8      | STC       | 0        | State Control                                                              |
|        |           |          | Sets the A/D conversion time.                                              |
|        |           |          | (50 cycles is set in this sample application.)                             |
| 7, 6   | CKSL[1:0] | 00       | Clock Select 1 and 0                                                       |
|        |           |          | Select the A/D conversion time.                                            |
|        |           |          | (P                                                                         |
| 5, 4   | ADM[1:0]  | 01       | A/D Mode 1 and 0                                                           |
|        |           |          | Select the A/D conversion mode.                                            |
|        |           |          | (4-channel scan mode is selected in this sample application.)              |
| 3      | ADCS      | 1        | A/D Continuous Scan                                                        |
|        |           |          | Continuous scan mode is selected in this sample application.               |
| 2 to 0 | CH[2:0]   | 011      | Channel Select 2 to 0                                                      |
|        |           |          | Select analog input channels for A/D conversion.                           |
|        |           |          | (Channels AN0 to AN3 are selected in this sample application.)             |



2. A/D Control Register \_0 (ADCR\_0) Function: Controls A/D conversion. Set value: H'0000

| Bit     | Bit Name | Set Value | Description                                                                                                                                                                                                                                                    |
|---------|----------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15, 14  |          | All 0     | Reserved                                                                                                                                                                                                                                                       |
| 13      | ADST     | 0         | A/D Start<br>When cleared to 0, A/D conversion is stopped and the A/D converter<br>enters the idle state.<br>When set to 1, A/D conversion is started.<br>Cleared to 0 automatically in single mode when A/D conversion end on<br>the selected single channel. |
| 12 to 0 |          | All 0     | Reserved                                                                                                                                                                                                                                                       |

#### 3. A/D Trigger Select Register\_0 (ADTSR\_0)

Function:Enables an A/D conversion started by an external trigger signal.Set value:H'0000 (initial value)

An external trigger signal is not used in this sample application. Thus, ADSTR\_0 is not set and its the values are used on an as-is basis.

| Bit      | Bit Name    | Initial Value | Description                                                                                                                                                                             |
|----------|-------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15 to 12 | TRG11S[3:0] | 0000          | A/D Trigger 1 Group 1 Select 3 to 0<br>Select an external trigger, MTU2 trigger or MTU2S trigger to start<br>A/D conversion for group 1 when A/D module 1 is in 2-channel<br>scan mode. |
| 11 to 8  | TRG01S[3:0] | 0000          | A/D Trigger 0 Group 1 Select 3 to 0<br>Select an external trigger, MTU2 trigger or MTU2S trigger to start<br>A/D conversion for group 1 when A/D module 0 is in 2-channel<br>scan mode. |
| 7 to 4   | TRG1S[3:0]  | 0000          | A/D Trigger 1 Select 3 to 0<br>Select an external trigger, MTU2 trigger or MTU2S trigger to start<br>A/D conversion for A/D module 1.                                                   |
| 3 to 0   | TRG0S[3:0]  | 0000          | A/D Trigger 0 Select 3 to 0<br>Select an external trigger, MTU2 trigger or MTU2S trigger to start<br>A/D conversion for A/D module 1.                                                   |



# 6. Flowcharts

Flowcharts for this sample application are given below.

#### 6.1 Main Routine





# SH7080 Group Data Transfer Controller (DTC) in Chain Transfer Mode





# 6.2 A/D Conversion Routine





# 6.3 ADI Interrupt Routine





# 7. Documents for Reference

- Software Manual SH-1/SH-2/SH-DSP Software Manual The most up-to-date version of this document is available on the Renesas Technology Website.
- Hardware Manual SH7080 Group Hardware Manual The most up-to-date version of this document is available on the Renesas Technology Website.



# Website and Support

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

Inquiries

http://www.renesas.com/inquiry csc@renesas.com

# **Revision Record**

|      |           | Descript | tion                 |  |
|------|-----------|----------|----------------------|--|
| Rev. | Date      | Page     | Summary              |  |
| 1.00 | Jan.18.08 | _        | First edition issued |  |
|      |           |          |                      |  |
|      |           |          |                      |  |
|      |           |          |                      |  |
|      |           |          |                      |  |

#### Notes regarding these materials

- 1. This document is provided for reference purposes only so that Renesas customers may select the appropriate Renesas products for their use. Renesas neither makes warranties or representations with respect to the accuracy or completeness of the information contained in this document nor grants any license to any intellectual property rights or any other rights of Renesas or any third party with respect to the information in this document.
- 2. Renesas shall have no liability for damages or infringement of any intellectual property or other rights arising out of the use of any information in this document, including, but not limited to, product data, diagrams, charts, programs, algorithms, and application circuit examples.
- 3. You should not use the products or the technology described in this document for the purpose of military applications such as the development of weapons of mass destruction or for the purpose of any other military use. When exporting the products or technology described herein, you should follow the applicable export control laws and regulations, and procedures required by such laws and regulations.
- 4. All information included in this document such as product data, diagrams, charts, programs, algorithms, and application circuit examples, 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 products listed in this document, please confirm the latest product information with a Renesas sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas such as that disclosed through our website. (http://www.renesas.com)
- 5. Renesas has used reasonable care in compiling the information included in this document, but Renesas assumes no liability whatsoever for any damages incurred as a result of errors or omissions in the information included in this document.
- 6. When using or otherwise relying on the information in this document, you should evaluate the information in light of the total system before deciding about the applicability of such information to the intended application. Renesas makes no representations, warranties or guaranties regarding the suitability of its products for any particular application and specifically disclaims any liability arising out of the application and use of the information in this document or Renesas products.
- 7. With the exception of products specified by Renesas as suitable for automobile applications, Renesas products are not designed, manufactured or tested for applications or otherwise in systems the failure or malfunction of which may cause a direct threat to human life or create a risk of human injury or which require especially high quality and reliability such as safety systems, or equipment or systems for transportation and traffic, healthcare, combustion control, aerospace and aeronautics, nuclear power, or undersea communication transmission. If you are considering the use of our products for such purposes, please contact a Renesas sales office beforehand. Renesas shall have no liability for damages arising out of the uses set forth above.
- 8. Notwithstanding the preceding paragraph, you should not use Renesas products for the purposes listed below: (1) artificial life support devices or systems
  - (2) surgical implantations

KENESAS

- (3) healthcare intervention (e.g., excision, administration of medication, etc.)
- (4) any other purposes that pose a direct threat to human life

Renesas shall have no liability for damages arising out of the uses set forth in the above and purchasers who elect to use Renesas products in any of the foregoing applications shall indemnify and hold harmless Renesas Technology Corp., its affiliated companies and their officers, directors, and employees against any and all damages arising out of such applications.

- 9. You should use the products described herein within the range specified by Renesas, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas shall have no liability for malfunctions or damages arising out of the use of Renesas products beyond such specified ranges.
- 10. Although Renesas endeavors to improve the quality and reliability of its products, IC products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Please be sure to implement safety measures to guard against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas 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 applicable measures. Among others, since the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or system manufactured by you.
- 11. In case Renesas products listed in this document are detached from the products to which the Renesas products are attached or affixed, the risk of accident such as swallowing by infants and small children is very high. You should implement safety measures so that Renesas products may not be easily detached from your products. Renesas shall have no liability for damages arising out of such detachment.
- 12. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written approval from Renesas.
- 13. Please contact a Renesas sales office if you have any questions regarding the information contained in this document, Renesas semiconductor products, or if you have any other inquiries.

© 2008. Renesas Technology Corp., All rights reserved.