# 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.

# **H8SX Family**

# DTC Block Transfer

# Introduction

This application note describes using the data transfer controller (DTC) function to transfer five blocks of data, each comprising two bytes, and outputting the transferred data to I/O ports (P1 and P2).

The DTC block transfer function makes it possible to transfer data while bypassing the CPU. When a block area is specified as the transfer destination data area (or transfer source data area), the address register specified as the block area is restored to its initial state after transfer of each block completes.

# Target Devices

- H8SX/1663 Group
- H8SX/1622 Group
- H8SX/1638 Group
- H8SX/1648 Group, H8SX/1648A Group, H8SX/1648L Group, H8SX/1648G Group, H8SX/1648H Group
- H8SX/1658R Group
- H8SX/1668R Group

# Preface

This application note was prepared using the H8SX/1668R Group, one of the devices on which operation has been confirmed, as the basis.

This program can be used with other H8SX Family MCUs that have the same internal I/O registers as the devices on which operation has been confirmed. Check the latest version of the manual for any additions and modifications to functions.

Careful evaluation is recommended before using this application note.

### Contents

| 1. | Specifications        | . 2 |
|----|-----------------------|-----|
| 2. | Applicable Conditions | . 3 |
| 3. | Functions Used        | . 4 |
| 4. | Operation             | . 7 |
| 5. | Software Description  | . 8 |
| 6. | Notes                 | 24  |
| 7. | Reference Documents   | 24  |

### 1. Specifications

The specifications of this application note cover using the data transfer controller (DTC) function to transfer five blocks of data, each comprising two bytes, and outputting the transferred data to I/O ports.

Figure 1 shows an overview of the operations described in this application note. The detailed specifications for the operations described in this application note are listed below.

- The 16-bit timer pulse unit (TPU) compare match A interrupt is set as the DTC activation source.
- The TPU period is set to 10 µsec.
- The DTC transfer data size is set to byte.
- The DTC total transfer size is set to 10 bytes (2 bytes × 5 blocks).
- After when the entire DTC data transfer completes, P31 is set to high level in the DTC transfer end interrupt handling routine.



Figure 1 Operation Overview



# 2. Applicable Conditions

### Table 1 Applicable Conditions

| Item                                  | Description                                     |                                   |  |  |  |
|---------------------------------------|-------------------------------------------------|-----------------------------------|--|--|--|
| Operating frequency                   | Input clock:                                    | 12.5 MHz                          |  |  |  |
|                                       | System clock (I                                 | 50 MHz (12.5 MHz multiplied by 4) |  |  |  |
|                                       | Peripheral module clock (P                      | 25 MHz (12.5 MHz multiplied by 2) |  |  |  |
|                                       | External bus module clock (B <sub>\$\$</sub> ): | 50 MHz (12.5 MHz multiplied by 4) |  |  |  |
| Operating voltage                     | 3.3V                                            |                                   |  |  |  |
| Operating mode                        | Mode 7 (MD3 = 0, MD2 = 1, MD                    | 1 = 1, MD0 = 1, MD_CLK = 0)       |  |  |  |
| Integrated development<br>environment | High-performance Embedded W                     | orkshop Version 4.04.01.001       |  |  |  |
| C/C++ compiler                        | Renesas Technology                              |                                   |  |  |  |
|                                       | H8 Family, H8S Family, and H8S                  | SX Family (V.6.02.00)             |  |  |  |
| Compile options                       | -cpu=H8SXA:24,-optimize=1                       |                                   |  |  |  |
| Optimizing linkage editor             | Renesas Technology                              |                                   |  |  |  |
|                                       | Optimizing Linkage Editor (V.9.0                | 3.00)                             |  |  |  |
| Linker options                        | -start = PResetPRG,PIntPRG/04                   | 400,                              |  |  |  |
|                                       | P,C,C\$DSEC,C\$BSEC,I                           | D/0800,                           |  |  |  |
|                                       | CDTCV/03560,                                    |                                   |  |  |  |
|                                       | B,R/0FF2000,                                    |                                   |  |  |  |
|                                       | S/0FFBE00                                       |                                   |  |  |  |

### 3. Functions Used

# 3.1 Data Transfer Controller (DTC)

To use the DTC, the transfer data must be stored in the data area (RAM). When the DTC is activated, the transfer data is read from the data area (RAM) and transferred to the DTC's internal resource. After data transfer completes, the transfer data in the DTC's internal resource is written back to the data area (RAM). By preparing transfer data in the data area, it is possible to perform data transfer using any number of channels specified by the user. The supported transfer modes are normal transfer mode, repeat transfer mode, and block transfer mode. The transfer source address used by the DTC is specified in the source address register (SAR), and the transfer destination address is specified in the destination address register (DAR). After each transfer, SAR and DAR are independently incremented or decremented, or they remain fixed. The DTC transfer modes are shown in table 2.

#### Table 2 DTC Transfer Modes

| Transfer Mode       | Size of Data Transferred at One<br>Transfer Request              | Memory Address Increment<br>or Decrement        | Transfer Count         |
|---------------------|------------------------------------------------------------------|-------------------------------------------------|------------------------|
| Normal              | 1 byte/word/longword                                             | Incremented/decremented by 1, 2, or 4, or fixed | 1 to 65536             |
| Repeat*1            | 1 byte/word/longword                                             | Incremented/decremented by 1, 2, or 4, or fixed | 1 to 256* <sup>3</sup> |
| Block* <sup>2</sup> | Block size specified by CRAH<br>(1 to 256 bytes/words/longwords) | Incremented/decremented by 1, 2, or 4, or fixed | 1 to 65536             |

Notes: 1. Either source or destination is specified to repeat area.

2. Either source or destination is specified to block area.

3. After transfer of the specified transfer count, initial state is recovered to continue the operation.

# 3.2 Block Transfer Mode

In block transfer mode, one activation source causes one block of data to be transferred. Either the transfer source or the transfer destination is designated as a block area by the DTC transfer mode select (DTS) bit in the DTC mode register (MRB). The block size can be 1 to 256 bytes (or 1 to 256 words or 1 to 256 longwords). When the transfer of one block ends, the block size counter (CRAL) and address register (SAR when DTS = 1 or DAR when DTS = 0) specified as the block area are restored to their initial state. The other address register is consecutively incremented or decremented, or left fixed. From 1 to 65,536 transfers can be specified. An interrupt request to the CPU can be generated when transfer of the specified number of blocks ends. Table 3 lists the register functions in block transfer mode, and figure 2 shows the memory map in block transfer mode.

| Function               | Written Back Value                                                       |
|------------------------|--------------------------------------------------------------------------|
| Source address         | DTS = 0: Incremented/decremented/fixed*                                  |
|                        | DTS = 1: SAR initial value                                               |
| Destination address    | DTS = 0: DAR initial value                                               |
|                        | DTS = 1: Incremented/decremented/fixed*                                  |
| Block size storage     | CRAH                                                                     |
| Block size counter     | CRAH                                                                     |
| Block transfer counter | CRB – 1                                                                  |
|                        | Source address Destination address Block size storage Block size counter |

#### Table 3 Register Function in Block Transfer Mode

Note: \* Transfer information writeback is skipped.



# Figure 2 Memory Map in Block Transfer Mode (When Transfer Destination is Specified as Block Area)

# 3.3 DTC Vector Table and Arrangement in Memory

Figure 3 shows the arrangement of the DTC vector table in memory (RAM). In this application note, the DTC transfer data is specified in short address mode, so the DTC mode register (MRA), SAR, MRB, DAR, DTC, DTC transfer counter register A (CRA), and DTC transfer counter register B (CRB) are arranged in order, starting from address H'FF5000.



Figure 3 DTC Vector Table and Arrangement in Memory (Example of This Application Note)



### 4. Operation

Figure 4 shows the operation described in this application note.



Figure 4 Operation



### 5. Software Description

### 5.1 Structures

#### Table 4 List of Structures

| Туре           | Туре           | Variable<br>Name | Туре             | Variable<br>Name | No. of<br>Bits | Description          | Used by<br>Functions |
|----------------|----------------|------------------|------------------|------------------|----------------|----------------------|----------------------|
| struct dtc_tag | union          | R_mrasar         | unsigned<br>char | R_mra            | 8              | MRA setting<br>value | blkmn                |
|                |                |                  | unsigned<br>long | R_sar            | 32             | SAR setting value    | blkmn                |
|                | union          | R_mrbdar         | unsigned<br>char | R_mrb            | 8              | MRB setting value    | blkmn                |
|                |                |                  | unsigned<br>long | R_dar            | 32             | DAR setting value    | blkmn                |
|                | unsigned short | R_cra            | —                | _                | 16             | CRA setting value    | blkmn                |
|                | unsigned short | R_crb            |                  |                  | 16             | CRB setting value    | blkmn                |

# 5.2 Symbolic Constants

#### Table 5 List of Symbolic Constants

| Constant Name | Setting Value                         | Description                                   | Used by<br>Functions |
|---------------|---------------------------------------|-----------------------------------------------|----------------------|
| TRINF         | (*(volatile struct dtc_tag*)0xFF5000) | DTC register data start address<br>(H'FF5000) | blkmn                |

### 5.3 ROM Variables

#### Table 6 List of ROM Variables

| Туре                   | Variable Name | Setting Value                                                           | Description                               | Used by<br>Functions |
|------------------------|---------------|-------------------------------------------------------------------------|-------------------------------------------|----------------------|
| const unsigned<br>char | PATTBL[5][2]  | H'11 , H'22<br>H'44 , H'55<br>H'77 , H'88<br>H'AA , H'BB<br>H'DD , H'EE | Transfer data                             | blkmn                |
| const unsigned<br>long | dtcad         | (unsigned long)<br>&TRINF.R_mrasar.R_mra                                | DTC register data start address (H'FF500) | blkmn                |



# 5.4 List of Functions

#### Table 7 List of Functions

| Function Name  | Description                                                                                                                                                                         |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PowerON_Reset  | <ul> <li>Initial settings function<br/>Initializes status pointer (SP), sets interrupt mask bits, sets uninitialized/initialized<br/>data, calls main function.</li> </ul>          |
| main           | <ul> <li>Main function<br/>Calls block transfer initial settings function and starts TPU operation.</li> </ul>                                                                      |
| blkmn          | <ul> <li>Block transfer initial settings function<br/>Makes clock settings, MSTP settings, I/O port output settings, TPU initial settings,<br/>and DTC initial settings.</li> </ul> |
| INT_TGI0A_TPU0 | <ul> <li>DTC transfer end interrupt function (activation source: TPU compare match A)<br/>Clears flag, stops TPU operation, and determines end of DTC block transfer.</li> </ul>    |

### 5.5 Functions

#### 5.5.1 PowerON\_Reset Function

(1) Functional Overview

The PowerON\_Reset function initializes the status pointer (SP) and uses embedded functions and standard library functions to set interrupt mask bits and set uninitialized/initialized data. Then it calls the main function.

- (2) Arguments
- None
- (3) Returned values None
- (4) Description of internal I/O registers used None
- (5) Flowchart



Figure 5 Flowchart (PowerON\_Reset)

#### 5.5.2 main Function

#### (1) Functional Overview

The main function calls the block transfer initial settings function to make initial settings for DTC block transfer and starts TPU operation, which activates the DTC.

- (2) Arguments
  - None
- (3) Returned values

None

(4) Description of internal I/O registers used

The internal registers used by this function are shown below. Note that the setting values shown are those used in this application note and differ from the initial values.

• Mode Control Register (MDCR) - Number of bits: 16, Address: H'FFFDC0

| Bit | Bit Name | Set<br>Value | R/W | Descriptions                                                                               |
|-----|----------|--------------|-----|--------------------------------------------------------------------------------------------|
| 15  | MDS7     | 0            | R   | This pin indicates a value set with the mode pin (MD3)                                     |
| 11  | MDS3     | 0            | R   | Mode Select 3 to 0                                                                         |
| 10  | MDS2     | 1            | R   | These bits indicate the operating mode selected by the mode pins                           |
| 9   | MDS1     | 0            | R   | (MD2 to MD0).                                                                              |
| 8   | MDS0     | 0            | R   | When MDCR is read, the signal levels input on pins MD2 to MD0 are latched into these bits. |

• Timer Start Register (TSTR) - Number of bits: 8, Address: H'FFFFBC

|     |          | Set   |     |                                                                                       |
|-----|----------|-------|-----|---------------------------------------------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                                                          |
| 0   | CST0     | 1     | R/W | This bit select operation or stoppage for TCNT.<br>1: TCNT_0 performs count operation |



(5) Flowchart



Figure 6 Flowchart (main Function)

### 5.5.3 blkmn Function

#### (1) Functional Overview

The blkmn function makes system clock settings, I/O port register initial settings, DTC initial settings, and TPU initial settings.

- (2) Arguments None
- (3) Returned values

None

(4) Description of internal I/O registers used

0-1

The internal registers used by this function are shown below. Note that the setting values shown are those used in this application note and differ from the initial values.

• System Clock Control Register (SCKCR) - Number of bits: 16, Address: H'FFFDC4

|     |          | Set   |     |                                                                         |
|-----|----------|-------|-----|-------------------------------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                                            |
| 10  | ICK2     | 0     | R/W | System Clock (I                                                         |
| 9   | ICK1     | 0     | R/W | These bits select the frequency of the system clock provided to the     |
| 8   | ICK0     | 0     | R/W | CPU, EXDMAC, DMAC, and DTC. The ratio to the input clock is as follows: |
|     |          |       |     | 000: × 4                                                                |
| 6   | PCK2     | 0     | R/W | Peripheral Module Clock (P                                              |
| 5   | PCK1     | 0     | R/W | These bits select the frequency of the peripheral module clock. The     |
| 4   | PCK0     | 1     | R/W | ratio to the input clock is as follows:                                 |
|     |          |       |     | 001: × 2                                                                |
| 2   | BCK2     | 0     | R/W | External Bus Clock (B                                                   |
| 1   | BCK1     | 0     | R/W | These bits select the frequency of the external bus clock. The ratio    |
| 0   | BCK0     | 0     | R/W | to the input clock is as follows:<br>000: × 4                           |

• System Control Register (SYSCR) - Number of bits: 16, Address: H'FFFDC2

|     |          | Set   |     |                                 |
|-----|----------|-------|-----|---------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                    |
| 1   | DTCMD    | 1     | R/W | DTC Mode Select                 |
|     |          |       |     | Selects DTC operating mode.     |
|     |          |       |     | 1: DTC is in short address mode |

 Module Stop Control Register A (MSTPCRA) - Number of bits: 16, Address: H'FFFDC8 MSTPCRA controls the module stop state. Setting a bit to 1 makes the corresponding module enter the module stop state, and clearing the bit to 0 clears the module stop state.

|     |          | Set   |     |                                               |
|-----|----------|-------|-----|-----------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                  |
| 12  | MSTPA12  | 0     | R/W | Data transfer controller (DTC)                |
| 0   | MSTPA0   | 0     | R/W | 16-bit timer pulse unit (TPU channels 5 to 0) |

- Data Direction Register (P1DDR) Number of bits: 8, Address: H'FFFB80
- Data Direction Register (P2DDR) Number of bits: 8, Address: H'FFFB81
- Data Direction Register (P3DDR) Number of bits: 8, Address: H'FFFB82
  - Function: The DDRs are 8-bit write-only registers whose bits specify the input or output status of the corresponding ports. Reading the DDRs has no effect and returns an undefined value. When the general I/O port function is selected, the corresponding pin functions as an output port when a bit in the DDRs is set to 1 and as an input port when cleared to 0.

Setting values: P1DDR H'0xFF

- : P2DDR H'0xFF
- : P3DDR H'0x02
- Data Register (P1DR) Number of bits: 8, Address: H'FFFF50
- Data Register (P2DR) Number of bits: 8, Address: H'FFFF51
- Data Register (P3DR) Number of bits: 8, Address: H'FFFF52
- Function: The DRs are 8-bit readable/writable registers that store output data for pins used as general output ports. Setting values: P1DR H'0x00
  - : P2DR H'0x00
    - : P3DR H'0x00
- DTC Vector Base Register (DTCVBR) Number of bits: 32, Address: H'FFFD80

Function: DTCVBR is a 32-bit register that specifies the base address for vector table address calculation. Bits 31 to 28 and bits 11 to 0 are fixed at 0 and writing to them has no effect. The initial value of DTCVBR is H'00000000.

Setting value: H'00003000



• DTC Control Register (DTCCR) - Number of bits: 8, Address: H'FFFF30

| Bit | Bit Name | Set<br>Value | R/W | Descriptions                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|----------|--------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | RRS      | 0            | R/W | DTC Transfer Information Read Skip Enable                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|     |          |              |     | Controls the vector address read and transfer information read. A DTC vector number is always compared with the vector number for the previous activation. If the vector numbers match and this bit is set to 1, the DTC data transfer is started without reading a vector address and transfer information. If the previous DTC activation is a chain transfer, the vector address read and transfer information read are always performed.<br>0: Transfer read skip is not performed. |
| 3   | RCHNE    | 0            | R/W | Chain Transfer Enable After DTC Repeat Transfer<br>Enables/disables the chain transfer while transfer counter (CRAL)<br>is 0 in repeat transfer mode.<br>In repeat transfer mode, the CRAH value is written to CRAL when<br>CRAL is 0. Accordingly, chain transfer may not occur when CRAL<br>is 0. If this bit is set to 1, the chain transfer is enabled when CRAH<br>is written to CRAL.<br>0: Disables the chain transfer after repeat transfer                                     |

DTC Source Address Register (SAR) - Number of bits: 32, Address: H'FF5001
Function: SAR is a 32-bit register that designates the source address of data to be transferred by the DTC.
SAR cannot be accessed directly by the CPU.
Setting value: H'0009A6

• DTC Destination AddressRegister (DAR) - Number of bits: 32, Address: H'FF5005

Function: DAR is a 32-bit register that designates the destination address of data to be transferred by the DTC. In short address mode, the lower 24 bits of DAR are valid and bits 31 to 24 are ignored. In this case, the upper eight bits are filled with the value specified by bit 23. DAR cannot be accessed directly by the CPU.
 Setting value: H'FFFF50

 DTC Mode Register A (MRA) - Number of bits: 8, Address: H'FF5000 MRA selects DTC operating mode. MRA cannot be accessed directly by the CPU.

-

|     |          | Set   |     |                                                 |
|-----|----------|-------|-----|-------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                    |
| 7   | MD1      | 1     | R/W | Specify DTC transfer mode.                      |
| 6   | MD0      | 0     | R/W | 10: Block transfer mode                         |
| 5   | Sz1      | 0     | R/W | Specify the size of data to be transferred.     |
| 4   | Sz0      | 0     | R/W | 00: Byte-size transfer                          |
| 3   | SM1      | 1     | R/W | Specify an SAR operation after a data transfer. |
| 2   | SM0      | 0     | R/W | 10: SAR is incremented after a transfer         |
|     |          |       |     |                                                 |

0.4

• DTC Mode Register B (MRB) - Number of bits: 8, Address: H'FF5004 MRB selects DTC operating mode. MRB cannot be accessed directly by the CPU.

|     |          | Set   |     |                                                                 |
|-----|----------|-------|-----|-----------------------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                                    |
| 7   | CHNE     | 0     | R/W | DTC Chain Transfer Enable                                       |
|     |          |       |     | 0: Disables the chain transfer                                  |
| 6   | CHNS     | 0     | R/W | DTC Chain Transfer Select                                       |
|     |          |       |     | 0: Chain transfer every time                                    |
| 5   | DISEL    | 0     | R/W | DTC Interrupt Select                                            |
|     |          |       |     | When this bit is set to 1, a CPU interrupt request is generated |
|     |          |       |     | every time after a data transfer ends.                          |
| 4   | DTS      | 0     | R/W | DTC Transfer Mode Select                                        |
|     |          |       |     | 0: Specifies the destination as repeat or block area            |
| 3   | DM1      | 1     | R/W | Destination Address Mode 1 and 0                                |
| 2   | DM0      | 0     | R/W | Specify a DAR operation after a data transfer.                  |
|     |          |       |     | 10: DAR is incremented after a transfer                         |
|     |          |       |     |                                                                 |

DTC Transfer Counter Register A (CRA) - Number of bits: 16, Address: H'FF5008
 Function: CRA is a 16-bit register that specifies the number of data transfers to be performed by the DTC. In block transfer mode, CRA is divided into two parts: the upper eight bits (CRAH) and the lower eight bits (CRAL). CRAH holds the block size, and CRAL functions as a block-size counter. CRA cannot be accessed directly by the CPU.

 Setting value: H'0202

• DTC Transfer Counter Register B (CRB) - Number of bits: 16, Address: H'FF500A

Function: CRB is a 16-bit register that specifies the number of data transfers to be performed by the DTC in block transfer mode. It functions as a 16-bit transfer counter (1 to 65,536) and is decremented at each data transfer. When the counter value reaches H'0000, the DTCEn bit corresponding to the activation source is cleared and then an interrupt request to the CPU is generated. CRB cannot be accessed directly by the CPU.

Setting value: H'0005

• DTC Enable Register (DTCERB) - Number of bits: 16, Address: H'FFFF22

|     |          | Set   |     |                                                                                                                                                         |
|-----|----------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                                                                                                                            |
| 13  | DTCERB13 | 1     | R/W | DTC Activation Enable 15 to 0<br>Setting this bit to 1 specifies a relevant interrupt source to a DTC<br>activation source.<br>Activation source: TGI0A |

• Timer Start Register (TSTR) - Number of bits: 8, Address: H'FFFFBC

|     |          | Set   |     |                                                  |
|-----|----------|-------|-----|--------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                     |
| 0   | CST0     | 0     | R/W | This bit selects operation or stoppage for TCNT. |
|     |          |       |     | 0: TCNT0 count operation is stopped              |

• Timer Status Register (TSR) - Number of bits: 8, Address: H'FFFFC5

|     |          | Set   |     |                                           |
|-----|----------|-------|-----|-------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                              |
| 7   | TCFD     | 1     | R   | Count Direction Flag<br>1: TCNT counts up |

• Timer Mode Register (TMDR) - Number of bits: 8, Address: H'FFFFC1

|     |          | Set   |     |                               |
|-----|----------|-------|-----|-------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                  |
| 3   | MD3      | 0     | R/W | Modes 3 to 0                  |
| 2   | MD2      | 0     | R/W | Set the timer operating mode. |
| 1   | MD1      | 0     | R/W | 0000: Normal operation        |
| 0   | MD0      | 0     | R/W |                               |

• Timer Control Register (TCR) - Number of bits: 8, Address: H'FFFFC0

|     |          | Set   |     |                                                       |
|-----|----------|-------|-----|-------------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                          |
| 7   | CCLR2    | 0     | R/W | TCNT Counter Clear Source Select                      |
| 6   | CCLR1    | 0     | R/W | 001: TCNT cleared at TGRA compare match/input capture |
| 5   | CCLR0    | 1     | R/W |                                                       |
| 4   | CKEG1    | 0     | R/W | Input Clock Edge Select                               |
| 3   | CKEG0    | 0     | R/W | 00: Count at falling edge of internal clock           |
| 2   | TPSC2    | 0     | R/W | TCNT Counter Clock Select                             |
| 1   | TPSC1    | 0     | R/W | 000: Internal clock, count on P                       |
| 0   | TPSC0    | 0     | R/W |                                                       |

• Timer I/O Control Register (TIOR) - Number of bits: 8, Address: H'FFFFC2

|     |          | Set   |     |                       |
|-----|----------|-------|-----|-----------------------|
| Bit | Bit Name | Value | R/W | Descriptions          |
| 3   | IOA3     | 0     | R/W | TIOCA0 Pin Function   |
| 2   | IOA2     | 0     | R/W | 0000: Output disabled |
| 1   | IOA1     | 0     | R/W |                       |
| 0   | IOA0     | 0     | R/W |                       |



|     |          | Set   |     |                                                                                          |
|-----|----------|-------|-----|------------------------------------------------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                                                             |
| 0   | SYNC0    | 0     | R/W | Timer Synchronization 0                                                                  |
|     |          |       |     | This bit select whether operation is independent of or synchronized with other channels. |
|     |          |       |     | 0: TCNT_0 operate independently.                                                         |
|     |          |       |     | (TCNT presetting/clearing is unrelated to other channels.)                               |

• Timer Synchronization Register (TSYR) - Number of bits: 8, Address: H'FFFFBD

• Timer Interrupt Enable Register (TIER) - Number of bits: 8, Address: H'FFFFC4

|     |          | Set   |     |                                                  |
|-----|----------|-------|-----|--------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                     |
| 0   | TGIEA    | 1     | R/W | TGR Interrupt Enable A                           |
|     |          |       |     | 1: Interrupt requests (TGIA) by TGFA bit enabled |

Timer General Register A\_0 (TGRA\_0) - Number of bits: 16, Address: H'FFFFC8
 Function: TGRA\_0 is a 16-bit readable/writable register what functions as both an output compare and an input capture register. It cannot be accessed in 8-bit units. Always access TGRA\_0 in 16-bit units.

 Setting value: H'00F9

• Timer Counter (TCNT) - Number of bits: 16, Address: H'FFFFC6

Function: TCNT is a 16-bit readable/writable counter. There are six TCNT counters, one for each channel. TCNT is initialized to H'0000 after a reset or in hardware standby mode. It cannot be accessed in 8-bit units. Always access TCNT in 16-bit units.

Setting value: H'0000



(5) Flowchart



Figure 7 Flowchart (blkmn Function-1.)











Figure 9 Flowchart (blkmn Function-3.)

### 5.5.4 DTC End Interrupt Function

#### (1) Functional Overview

The DTC end interrupt function disables TGI0A compare match output as the activation source for DTC block transfers.

- (2) Arguments None
- (3) Returned values

None

(4) Description of internal I/O registers used

The internal registers used by this function are shown below. Note that the setting values shown are those used in this application note and differ from the initial values.

• Timer Status Register (TSR) - Number of bits: 8, Address: H'FFFFC5

|     |          | Set   |     |                                                                  |
|-----|----------|-------|-----|------------------------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                                     |
| 0   | TGFA     | 0     | R/W | Output Compare Flag A                                            |
|     |          |       |     | Status flag that indicates the occurrence of TGRA compare match. |
|     |          |       |     | [Clearing conditions]                                            |
|     |          |       |     | When DTC is activated by a TGIA interrupt while the DISEL bit in |
|     |          |       |     | MRB of DTC is 0                                                  |

• Timer Start Register (TSTR) - Number of bits: 8, Address: H'FFFFBC

|     |          | Set   |     |                                                  |
|-----|----------|-------|-----|--------------------------------------------------|
| Bit | Bit Name | Value | R/W | Descriptions                                     |
| 0   | CST0     | 0     | R/W | This bit selects operation or stoppage for TCNT. |
|     |          |       |     | 0: TCNT0 count operation is stopped              |



(5) Flowchart



Figure 10 Flowchart (DTC End Interrupt)

### 6. Notes

When a conflict occurs between an overwrite (setting to 1 or 0) of the DTC enable register (DTCER) and the generation of a DTC activation source interrupt, activation of the DTC and interrupt exception processing by the CPU may both occur at the same time. In some cases, two interrupts may be generated at once. If there is a possibility of conflict between an overwrite of DTCER and generation of a DTC activation source interrupt, mask the interrupt when writing to DTCER. For details, see the relevant hardware manual or technical news/technical update.

# 7. Reference Documents

Hardware Manuals
 H8SX/1668R Group Hardware Manual
 H8SX/1658R Group Hardware Manual

 H8SX/1663 Group Hardware Manual

 H8SX/1648, H8SX/1648A, H8SX/1648L, H8SX/1648G, H8SX/1648H Group Hardware Manual

 H8SX/1638 Group Hardware Manual

 H8SX/1622 Group Hardware Manual

 H8SX/1622 Group Hardware Manual

 (The latest version can be downloaded from the Renesas Technology Web site.)

- Development Environment Manual H8S/300, H8/300 Series C/C++ Compiler Package User's Manual (The latest version can be downloaded from the Renesas Technology Web site.)
- Technical News/Technical Updates (The latest information can be downloaded from the Renesas Technology Web site.)



### Website and Support

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

Inquiries <u>http://www.renesas.com/inquiry</u> <u>csc@renesas.com</u>

#### **Revision Record**

|      |           | Descripti | ion                  |
|------|-----------|-----------|----------------------|
| Rev. | Date      | Page      | Summary              |
| 1.00 | Jan.22.09 | —         | First edition issued |

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



#### Notes regarding these materials

- 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
  - (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.

#### © 2009. Renesas Technology Corp., All rights reserved.