

# **RX Family**

# DTC Module Using Firmware Integration Technology

R01AN1819EJ0220 Rev.2.20 Feb 01, 2019

#### Introduction

This application note describes the Data Transfer Controller (DTC) module which uses Firmware Integration Technology (FIT). This module uses DTC to control data transfer process using DTC software module. In this document, this module is referred to as the DTC FIT module.

### **Target Devices**

- RX110 Group, RX111 Group, RX113 Group, RX130 Group
- RX230 Group, RX231 Group, RX23T Group, RX24T Group, RX24U Group
- RX64M Group, RX65N Group, RX651 Group, RX66T Group
- RX71M Group
- RX72T Group

When using this application note with other Renesas MCUs, careful evaluation is recommended after making modifications to comply with the alternate MCU.

#### **Related Documents**

- Firmware Integration Technology User's Manual (R01AN1833)
- RX Family Board Support Package Module Using Firmware Integration Technology (R01AN1685)
- RX Family Adding Firmware Integration Technology Modules to Projects (R01AN1723)
- RX Family Adding Firmware Integration Technology Modules to CS+ Projects (R01AN1826)
- Renesas e2 studio Smart Configurator User Guide (R20AN0451)
- RX Family DMA Controller DMACA Control Module Using Firmware Integration Technology (R01AN2063)
- RX Family Sample Program to use DTC module for sequence transfer Firmware Integration Technology (R01AN3434)

## Contents

| 1.        | Overview                                    | . 3 |
|-----------|---------------------------------------------|-----|
| 1.1       | DTC FIT Module                              | . 3 |
| 1.2       | Overview of DTC FIT Module                  | . 3 |
| 1.3       | API Overview                                | . 5 |
| 1.4       | DTC IP Version                              | 5   |
|           |                                             |     |
| 2.        | API Information                             |     |
| 2.1       | Hardware Requirements                       |     |
| 2.2       | Software Requirements                       | 6   |
| 2.3       | Supported Toolchain                         |     |
| 2.4       | Interrupt Vector                            |     |
| 2.5       | Header Files                                |     |
| 2.6       | Integer Types                               |     |
| 2.7       | Configuration Overview                      |     |
| 2.8       | Code Size                                   |     |
| 2.9       | Parameters1                                 |     |
|           | Return Values1                              |     |
|           | Callback function1                          |     |
|           | Adding the FIT Module to Your Project1      |     |
| 2.13      | s "for", "while" and "do while" statements1 | 15  |
| •         | ADI E collect                               |     |
| 3.        | API Functions                               |     |
|           | 0TC_Open()                                  |     |
|           | TC_Close()                                  |     |
|           | TC_Create()                                 |     |
|           | TC_CreateSeq()                              |     |
|           | TC_Control()                                |     |
| K_D       | TC_GetVersion()                             | 39  |
| 4.        | Pin Setting                                 | 10  |
| 5.        | Appendices4                                 | 11  |
| 5.<br>5.1 | Confirmed Operation Environment             |     |
| 5.1       | Troubleshooting                             |     |
| J.Z       | Troubleshooting                             | r۷  |
| 6.        | Reference Documents                         | 13  |

## 1. Overview

### 1.1 DTC FIT Module

The DTC FIT module can be used by being implemented in a project as an API. See section 2.12, Adding the FIT Module to Your Project for details on methods to implement this FIT module into a project.

### 1.2 Overview of DTC FIT Module

The DTC FIT module supports 3 transfer modes:

- Normal transfer mode
- Repeat transfer mode
- Block transfer mode

Each mode can enable Chain transfer and Sequence transfer functionality or not. For additional details, see the "Data Transfer Controller" section of the User's Manual: Hardware.

The DTC is activated by interrupt requests from interrupt sources. The user should create transfer information corresponding to each activation source or many consecutive information elements in the case of chain transfers. Transfer information consists of a start address for source and destination and, configuration information controlling how the DTC will transfer the data. When the DTC in activated, it will read the corresponding Transfer information and start the transfer.

DTC reads start address of a Transfer data that belongs to a specified interrupt source in DTC Vector table. This Vector table is an array of 4 byte addresses and start address of Transfer data (n) that belong to interrupt source with vector number (n) will be stored at the row of table (element of array) having index (4 \* n).



Figure 1.1 DTC Vector and Transfer Information

The user must allocate a memory space for DTC Vector table on RAM area before using DTC and the size (in byte units) of allocated memory depends on the maximum vector number value of interrupt sources supported by DTC and it is specified by equate DTC\_VECTOR\_TABLE\_SIZE\_BYTES defined in file r\_dtc\_rx\_target.h for each MCU in "targets" folder; this default value is a value which supports all available activation source define in Interrupt Vector Table ( For example, if it is RX111, it is 0x3E4 (0x3E4 = 249 \* 4). if it is RX64M, it is 0x400 (0x400 = 256 \* 4).). The start address of DTC Vector table must be in 1-Kbyte units and user may also use the Linker to allocate Vector table at compilation time.

The DTC can work on 2 address modes: short mode and full mode. In short mode, the size of one Transfer data is 3 long words (12 bytes) and DTC can access to a 16-Mbyte memory space in the range 0x00000000 to 0x007FFFFF and 0xFF800000 to 0xFFFFFFFF. In full mode, the size of one Transfer data is 4 long words (16 bytes) and DTC can access to a 4-Gbyte memory space (0x00000000 to 0xFFFFFFFF).

By default, DTC will read Transfer data whenever an activation interrupt is raised. When there are 2 or many continuous active times just caused by an activation source, the user can skip the read process from the moment of second activation time to increase the performance of DTC because the content of Transfer data is already existed in DTC from the previous active time. To enable the Transfer Data Read Skip, the user can configure at initialization time by R\_DTC\_Open() or can use R\_DTC\_Control() with command DTC\_CMD\_DATA\_READ\_SKIP\_ENABLE.

To initialize DTC, the R\_DTC\_Open() is called. This function will start supplying clock to DTC, and write the start address of DTC vector table to DTC Vector Base Register (DTCVBR). When using the sequence transfer, DTC index table address is written to DTC index table base register (DTCIBR). Also the function initializes the settings for Transfer Data Read Skip, DTC address mode and the DTCER registers corresponding to the configuration selections of user in r\_dtc\_rx\_config.h.

The users shall provide configuration selections to R\_DTC\_Create() function to create Transfer data corresponding to a specific interrupt source. A Transfer data contains start address of source and destination and configuration information about how DTC will transfer data content from source to destination area. In R\_DTC\_Create(), the start address of Transfer data is stored in DTC vector table at the row according with the input vector number.

R\_DTC\_CreateSeq() creates the transfer information for sequence transfer and stores the start address of the transfer information at the specified location of the sequence number in DTC index table.

The R\_DTC\_Control() is used to select (or deselect) an interrupt as a DTC activation source, start or stop supplying clock to DTC, enable or disable Transfer Data Read Skip, abort the current chain transfer process, and enable or disable or abort the sequence transfer.

DTC is active when the activation source raises an interrupt. It will read the Transfer data corresponding to the vector number of activation interrupt to self-configure, and then transfer the data. Users can also use R\_DTC\_Control() to get the current status of DTC: whether DTC is in progress, the vector number of current active interrupt. The driver also support aborting the current Chain transfer process and sequence transfer process via R DTC Control() function.

### **Usage Conditions of DTC FIT Module**

The usage conditions of the module are as follows.

- The r\_bsp default lock function must be used.
- A single common bit must be used as the DMAC module stop setting bit and the DTC module stop setting bit.

#### 1.3 **API Overview**

Table 1.1 lists the API functions included in this module.

Table 1.1 API Functions

| Function Name      | Description                                                             |
|--------------------|-------------------------------------------------------------------------|
| R_DTC_Open()       | Initialization Processing                                               |
| R_DTC_Close()      | End Processing                                                          |
| R_DTC_Create()     | Register and Activation Source Setting Processing                       |
| R_DTC_CreateSeq()  | Register and Activation Source Setting Processing for sequence transfer |
| R_DTC_Control()    | Operation Setting Processing                                            |
| R_DTC_GetVersion() | Version Information Acquisition Processing                              |

#### 1.4 **DTC IP Version**

Table 1.2 lists relations about the DTC IP Version and target device.

The argument specifications of R\_DTC\_Create() function and the R\_DTC\_CreateSeq() function variable for the difference in DTC IP version. Refer to 3, API Functions.

Table 1.2 Lists of DTC IP Version

| DTC IP Version | Target Device                                                   |
|----------------|-----------------------------------------------------------------|
| DTCa           | RX110 Group, RX111 Group, RX113 Group, RX130 Group              |
|                | RX230 Group, RX231 Group, RX23T Group, RX24T Group, RX24U Group |
|                | RX64M Group, RX66T Group                                        |
|                | RX71M Group, RX72T Group                                        |
| DTCb           | RX65N Group                                                     |

## 2. API Information

This FIT module has been confirmed to operate under the following conditions.

### 2.1 Hardware Requirements

The MCU used must support the following functions:

- DTC (DTCa or DTCb)
- ICU

## 2.2 Software Requirements

This driver is dependent upon the following FIT module:

Renesas Board Support Package (r\_bsp)

### 2.3 Supported Toolchain

This driver has been confirmed to work with the toolchain listed in 5.1, Confirmed Operation Environment.

### 2.4 Interrupt Vector

The DTC interrupt is enabled by executing the  $R_DTC_Create()$  function or the  $R_DTC_CreateSeq()$  (with specified condition) (while the macro definition DTC is 1).

Table 2.1 lists the interrupt vector used in the DTC FIT Module.

Table 2.1 DTC Interrupt vector

| Interrupt timing                                                                  | struct member      |                                   |
|-----------------------------------------------------------------------------------|--------------------|-----------------------------------|
| When data transfer a specified number of times finished, Interrupt occurs to CPU. | response_interrupt | DTC_INTERRUPT_AFTER_ALL_COMPLETE  |
| Every time data transfer, Interrupt occurs to CPU.                                | -                  | DTC_INTERRUPT_PER_SINGLE_TRANSFER |

### 2.5 Header Files

All API calls and their supporting interface definitions are located in r\_dtc\_rx\_if.h.

r\_dtc\_rx\_target.h file should be included by User's application, when allocating a memory space for DTC Vector table on RAM area using DTC\_VECTOR\_TABLE\_SIZE\_BYTES definition.

### 2.6 Integer Types

This project uses ANSI C99. These types are defined in stdint.h.

# 2.7 Configuration Overview

The configuration option settings of this module are located in r\_dtc\_rx\_config.h. The option names and setting values are listed in the table below:

| Configuration options                    | in r dtc rx config.h                              |
|------------------------------------------|---------------------------------------------------|
|                                          | SPECIFY WHETHER TO INCLUDE CODE FOR               |
| DTC_CFG_PARAM_CHECKING_ENABLE            | API PARAMETER CHECKING                            |
| Note:                                    | 0: Compiles out parameter checking.               |
| The default value is the value of        | 1: Includes parameter checking.                   |
| BSP_CFG_PARAM_CHECKING_ENABLE in the     | Default value is set to                           |
| r_bsp_config.h file.                     | BSP_CFG_PARAM_CHECKING_ENABLE to re-              |
|                                          | use the system default setting.                   |
|                                          | SPECIFY WHETHER THE DTCER REGISTERS               |
| DTC_CFG_DISABLE_ALL_ACT_SOURCE           | WILL BE CLEARED IN R_DTC_OPEN()                   |
| Note:                                    | DTC_DISABLE: Do nothing.                          |
| The default value is "DTC_ENABLE".       | DTC_ENABLE: Clear all DTCER registers in          |
|                                          | R_DTC_Open().                                     |
| DTC CCC CHORT ADDRESS MODE               | SPECIFY WHICH ADDRESS MODE IS                     |
| DTC_CFG_SHORT_ADDRESS_MODE               | SUPPORTED BY DTC                                  |
| Note:                                    | DTC_DISABLE: Select the Full-address mode.        |
| The default value is "DTC_DISABLE".      | DTC_ENABLE: Select the Short-address mode.        |
| DTC CEC TRANSCER DATA BEAD SKID EN       | SPECIFY WHETHER THE TRANSFER DATA                 |
| DTC_CFG_TRANSFER_DATA_READ_SKIP_EN Note: | READ SKIP IS ENABLED                              |
|                                          | DTC_DISABLE: Disable Transfer Data Read Skip.     |
| The default value is "DTC_ENABLE".       | DTC_ENABLE: Enable Transfer Data Read Skip.       |
|                                          | SPECIFY WHETHER THE DMAC FIT MODULE IS            |
|                                          | USED WITH DTC FIT MODULE                          |
|                                          | DTC_DISABLE: DMAC FIT module is not used with     |
| DTC_CFG_USE_DMAC_FIT_MODULE              | DTC FIT module.                                   |
| Note:                                    | DTC_ENABLE: DMAC FIT module is used with DTC      |
| The default value is "DTC_ENABLE".       | FIT module.                                       |
| THE deladit value is BTO_ENVIDEE.        |                                                   |
|                                          | When DMAC FIT module is not used and              |
|                                          | "DTC_ENABLE" is set, the compiling error will be  |
|                                          | generated.                                        |
|                                          | SPECIFY WHETHER THE SEQUENCE                      |
|                                          | TRANSFER IS USED.                                 |
|                                          | DTC_DISABLE: SEQUENCE TRANSFER is not             |
|                                          | DTC_ENABLE: SEQUENCE TRANSFER is used.            |
|                                          | DIC_ENABLE. SEQUENCE TRANSPER IS used.            |
|                                          | When defined as "DTC ENABLE", set                 |
| DTC_CFG_USE_SEQUENCE_TRANSFER            | DTC_CFG_SHORT_ADDRESS_MODE to                     |
| Note:                                    | "DTC_DISABLE".                                    |
| The default value is "DTC_DISABLE".      | When defined both this definition and             |
|                                          | DTC CFG SHORT ADDRESS MODE as                     |
|                                          | "DTC_ENABLE", the compiling error will be         |
|                                          | generated.                                        |
|                                          | When defined as "DTC_ENABLE" for the MCU not      |
|                                          | supporting sequence transfer, the compiling error |
|                                          | will be generated as well.                        |

# 2.8 Code Size

Typical code sizes associated with this module are listed below.

The ROM (code and constants) and RAM (global data) sizes are determined by the build-time configuration options described in 2.7, Configuration Overview. The table lists reference values when the C compiler's compile options are set to their default values, as described in 2.3, Supported Toolchain. The compile option default values are optimization level: 2, optimization type: for size, and data endianness: little-endian. The code size varies depending on the C compiler version and compile options.

| ROM, RAM, and Stack Code Sizes |                      |                                    |                                             |         |  |
|--------------------------------|----------------------|------------------------------------|---------------------------------------------|---------|--|
| Device                         | Category             | Memory Used                        | t                                           | Remarks |  |
| RX111                          | ROM                  | 998 bytes                          |                                             |         |  |
|                                | RAM                  | 9 bytes<br>+2,024 bytes (Note5, 6) |                                             |         |  |
|                                | Max. user stack      | 52 bytes                           |                                             |         |  |
|                                | Max. interrupt stack | -                                  |                                             |         |  |
| RX231                          | ROM                  | 1,236 bytes                        |                                             |         |  |
|                                | RAM                  | 9 bytes<br>+2,024 bytes (Note5, 6) |                                             |         |  |
|                                | Max. user stack      | 52 bytes                           |                                             |         |  |
|                                | Max. interrupt stack | -                                  |                                             |         |  |
| RX65N                          | ROM                  | 1,740 bytes (Note6)                | 1,920<br>bytes<br>(Note7)                   |         |  |
|                                | RAM                  | 9 bytes<br>+2,048 bytes (Note5, 6) | 9 bytes<br>+3,072<br>bytes<br>(Note5,<br>7) |         |  |
|                                | Max. user stack      | 56 bytes                           | 56 bytes                                    |         |  |
|                                | Max. interrupt stack | -                                  | -                                           |         |  |
| RX66T                          | ROM                  | 1536 bytes (Note6)                 |                                             |         |  |
|                                | RAM                  | 9 bytes<br>+2,048 bytes (Note5, 6) |                                             |         |  |
|                                | Max. user stack      | 52 bytes                           |                                             |         |  |
|                                | Max. interrupt stack | -                                  |                                             |         |  |
| RX71M                          | ROM                  | 1,664 bytes                        |                                             |         |  |
|                                | RAM                  | 9 bytes<br>+2,048 bytes (Note5, 6) |                                             |         |  |
|                                | Max. user stack      | 52 bytes                           |                                             |         |  |
|                                | Max. interrupt stack | -                                  |                                             |         |  |
| RX72T                          | ROM                  | 1,515 bytes                        |                                             |         |  |
|                                | RAM                  | 9 bytes<br>+2,048 bytes (Note5, 6) |                                             |         |  |
|                                | Max. user stack      | 60 bytes                           |                                             |         |  |
|                                | Max. interrupt stack | -                                  |                                             |         |  |

Note 1 The memory sizes listed apply when the default settings listed in 2.7, "Compile Settings", are used. The memory sizes differ according to the definitions selected.

Note 2 Under confirmation conditions listed the following

- r\_dtc\_rx.c
- r\_dtc\_rx\_target.c
- Note 3 The required memory sizes differ according to the C compiler version and the compile conditions.
- Note 4 The memory sizes listed apply when the little endian. The above memory sizes also differ according to endian mode.
- Note 5 The DTC FIT module secures the memory required for the DTC Vector table and the DTC index table using the malloc() function.For this memory size, refer to #define DTC\_VECTOR\_TABLE\_SIZE\_BYTES in r\_dtc\_rx\_target.h.
- Note 6 Only when DTC\_CFG\_USE\_SEQUENCE\_TRANSFER set DTC\_DISABLE.
- Note 7 Only when DTC\_CFG\_USE\_SEQUENCE\_TRANSFER set DTC\_ENABLE.

#### 2.9 Parameters

This section describes the parameter structure used by the API functions in this module. The structure is located in  $r_dtc_rx_if$ , has are the prototype declarations of API functions.

### 2.9.1 r dtc rx if.h

```
/* Short-address mode */
typedef struct st_transfer_data { /* 3 long words */
   uint32_t lw1;
   uint32_t lw2;
   uint32_t lw3;
} dtc_transfer_data_t;
/* Full-address mode */
typedef struct st_transfer_data { /* 4 long words */
   uint32_t lw1;
   uint32 t lw2;
   uint32_t lw3;
   uint32 t lw4;
} dtc transfer data t;
/* Transfer data configuration */
/* Moved struct dtc_transfer_data_cfg_t to r_dtc_rx_target_if.h */
typedef enum e_dtc_command {
   DTC_CMD_DTC_START,
                              /* DTC will accept activation requests.
   DTC_CMD_DTC_STOP,
                             /* DTC will not accept new activation request.
                                                                              * /
   DTC_CMD_ACT_SRC_ENABLE,
                  /* Enable an activation source specified by vector number.
                                                                              * /
   DTC CMD ACT SRC DISABLE,
                                                                              * /
                  /* Disable an activation source specified by vector number.
   DTC_CMD_DATA_READ_SKIP_ENABLE, /* Enable Transfer Data Read Skip.
   DTC_CMD_DATA_READ_SKIP_DISABLE, /* Disable Transfer Data Read Skip.
                                   /* Get the current status of DTC.
   DTC_CMD_STATUS_GET,
   DTC_CMD_CHAIN_TRANSFER_ABORT
                             /* Abort the current Chain transfer process.
   DTC_CMD_SEQUENCE_TRANSFER_ENABLE /* Enable sequence transfer
   DTC_CMD_SEQUENCE_TRANSFER_DISABLE
                                        /* Disable Sequence transfer
   DTC_CMD_SEQUENCE_TRANSFER_ABORT
                                        /* Abort sequence transfer
} dtc_command_t;
```

### 2.9.2 r\_dtc\_rx\_target\_if.h

dtc\_transfer\_data\_cfg\_t has different definition according to DTC IP Version.

#### 1. DTCa

```
typedef struct st_dtc_transfer_data_cfg {
                                                /* DTC transfer mode
      dtc_transfer_mode_t
                              transfer_mode;
      dtc_data_size_t
                              data_size;
                                               /* Size of data
      dtc_src_addr_mode_t
                              src_addr_mode;
                                               /* Address mode of source
      dtc_chain_transfer_t
                              chain_transfer_enable;
                                         /* Chain transfer is enabled or not
      dtc_chain_transfer_mode_t chain_transfer_mode;
                                        /* How chain transfer is performed
                              response_interrupt;
      dtc_interrupt_t
                                       /* How response interrupt is raised
      dtc_repeat_block_side_t repeat_block_side;/* Side being repeat or block */
                                              /* Address mode of destination*/
      dtc_dest_addr_mode_t dest_addr_mode;
                                                                              * /
      uint32 t
                              source_addr;
                                               /* Start address of source
      uint32_t
                              dest_addr; /* Start address of destination
                              transfer_count; /* Transfer count
                                                                              * /
      uint32_t
      uint16_t
                              block_size;
                                   /* Size of a block in block transfer mode */
                                                /* Reserve bit
      uint16_t
                              rsvi
} dtc_transfer_data_cfg_t;
```

#### 2. DTCb

```
typedef struct st_dtc_transfer_data_cfg {
     dtc_transfer_mode_t transfer_mode;
                                                /* DTC transfer mode
     dtc_data_size_t
                              data_size;
                                                /* Size of data
     dtc src addr mode t
                              src addr mode;
                                                /* Address mode of source
     dtc chain transfer t
                              chain_transfer_enable;
                                         /* Chain transfer is enabled or not
     dtc chain transfer mode t chain transfer mode;
                                         /* How chain transfer is performed
                              response_interrupt;
     dtc_interrupt_t
                                         /* How response interrupt is raised
     dtc_repeat_block_side_t repeat_block_side;/* Side being repeat or block */
                              dest_addr_mode;    /* Address mode of destination*/
     dtc_dest_addr_mode_t
     uint32_t
                              source_addr;
                                               /* Start address of source
                                                                               * /
     uint32_t
                              dest_addr; /* Start address of destination
     uint32_t
                              transfer_count; /* Transfer count
     uint16_t
                              block_size;
                                    /* Size of a block in block transfer mode */
     uint16_t
                                                /* Reserve bit
                                                                               * /
                              rsv;
     dtc_write_back_t
                              writeback_disable;
                         /* Transfer information writeback is enabled or not
                                                                               * /
     dtc_sequence_end_t
                             sequence_end;
                                /* Sequence transfer is continued or end
                                                                               * /
     dtc_refer_index_table_t refer_index_table_enable;
                                /* Index table reference is enabled or not
                                                                               * /
     dtc disp add t
                              disp add enable;
                  /* Displacement value is added to the source address or not */
} dtc_transfer_data_cfg_t;
```

#### 2.10 Return Values

This section describes return values of API functions. This enumeration is located in r\_dtc\_rx\_if.h as are the prototype declarations of API functions.

```
DTC_SUCCESS_DMAC_BUSY = 0,
          /* One or some DMAC resources are locked by another process.
   DTC_SUCCESS,
   DTC_ERR_OPENED,
                              /* DTC was initialized already.
   DTC_ERR_NOT_OPEN,
                              /* DTC module is not initialized yet.
   DTC_ERR_INVALID_ARG,
                              /* Arguments are invalid.
   DTC_ERR_INVALID_COMMAND,
                              /* Command parameters are invalid.
   DTC_ERR_NULL_PTR,
                              /* Argument pointers are NULL.
   DTC_ERR_BUSY
                    /* The DTC resources are locked by another process.
   DTC_ERR_ACT
                              /* Data transfer is in progress
} dtc_err_t;
```

### 2.11 Callback function

DTC FIT module don't use callback function.

#### 2.12 Adding the FIT Module to Your Project

This module must be added to each project in which it is used. Renesas recommends the method using the Smart Configurator described in (1) or (3) below. However, the Smart Configurator only supports some RX devices. Please use the methods of (2) or (4) for RX devices that are not supported by the Smart Configurator.

- (1) Adding the FIT module to your project using the Smart Configurator in e<sup>2</sup> studio By using the Smart Configurator in e<sup>2</sup> studio, the FIT module is automatically added to your project. Refer to "Renesas e<sup>2</sup> studio Smart Configurator User Guide (R20AN0451)" for details.
- (2) Adding the FIT module to your project using the FIT Configurator in e<sup>2</sup> studio By using the FIT Configurator in e<sup>2</sup> studio, the FIT module is automatically added to your project. Refer to "Adding Firmware Integration Technology Modules to Projects (R01AN1723)" for details.
- (3) Adding the FIT module to your project using the Smart Configurator in CS+ By using the Smart Configurator Standalone version in CS+, the FIT module is automatically added to your project. Refer to "Renesas e² studio Smart Configurator User Guide (R20AN0451)" for details.
- (4) Adding the FIT module to your project in CS+ In CS+, please manually add the FIT module to your project. Refer to "Adding Firmware Integration Technology Modules to CS+ Projects (R01AN1826)" for details.

## 2.13 "for", "while" and "do while" statements

In this module, "for", "while" and "do while" statements (loop processing) are used in processing to wait for register to be reflected and so on. For these loop processing, comments with "WAIT\_LOOP" as a keyword are described. Therefore, if user incorporates fail-safe processing into loop processing, user can search the corresponding processing with "WAIT\_LOOP".

The following shows example of description.

```
while statement example:

/* WAIT_LOOP */
while(0 == SYSTEM.OSCOVFSR.BIT.PLOVF)

{
    /* The delay period needed is to make sure that the PLL has stabilized. */
}

for statement example:

/* Initialize reference counters to 0. */

/* WAIT_LOOP */

for (i = 0; i < BSP_REG_PROTECT_TOTAL_ITEMS; i++)

{
    g_protect_counters[i] = 0;
}

do while statement example:

/* Reset completion waiting */

do

{
    reg = phy_read(ether_channel, PHY_REG_CONTROL);
    count++;
} while ((reg & PHY_CONTROL_RESET) && (count < ETHER_CFG_PHY_DELAY_RESET)); /* WAIT_LOOP */
```

## 3. API Functions

## R\_DTC\_Open()

This function is run first when using the APIs of the DTC FIT module.

#### **Format**

dtc\_err\_t R\_DTC\_Open (void)

#### **Parameters**

None.

#### **Return Values**

```
[DTC_SUCCESS] /* Successful operation */
[DTC_ERR_OPENED] /* DTC has been initialized already. */
[DTC_ERR_BUSY] /* Resource has been locked by other process. */
```

### **Properties**

Prototype declarations are contained in r\_dtc\_rx\_if.h.

### **Description**

Locks\*1 the DTC and starts supplying clock to DTC, then initializes DTC vector table, address mode, Data Transfer Read Skip. When setting DTC\_CFG\_DISABLE\_ALL\_ACT\_SOURCE to DTC\_ENABLE in r\_dtc\_rx\_config.h, all DTCER registers are cleared. When setting DTC\_CFG\_USE\_SEQUENCE\_TRANSFER to DTC\_ENABLE, the area used in DTC index table is secured.

Note: 1. The DTC FIT module uses the r\_bsp default lock function. As a result, the DTC is in the locked state after a successful end.

#### **Example**

```
dtc_err_t ret;
/* Call R_DTC_Open() */
ret = R_DTC_Open();
```

#### **Special Notes:**

Set #define BSP\_CFG\_HEAP\_BYTES in r\_bsp\_config.h to the value greater than #define DTC\_VECTOR\_TABLE\_SIZE\_BYTES in r\_dtc\_rx\_target.h.

This is to secure the DTC Vector table area using the malloc() function in the DTC FIT module.

## R\_DTC\_Close()

This function is used to release the resources of the DTC.

#### **Format**

dtc\_err\_t R\_DTC\_Close (void)

#### **Parameters**

None.

#### **Return Values**

/\* Successful operation \*/ [DTC\_SUCCESS] [DTC\_SUCCESS\_DMAC\_BUSY] /\* Successful operation. One or some DMAC resources are locked. \*/

### **Properties**

Prototype declarations are contained in r\_dtc\_rx\_if.h.

#### **Description**

Unlocks\*1 the DTC and disable all DTC activation source by clearing the DTC Activation Enable Register DTCERn; stop supplying clock to DTC and put it to Module stop state.

If in addition all DMAC channels have been unlocked, the function sets the DMAC and DTC to the module stop state.\*2

- Note: 1. The DTC FIT module uses the r\_bsp default lock function. As a result, the DTC is in the unlocked state after a successful end.
  - 2. Because a shared bit is used as both the DMAC module stop setting bit and the DTC module stop setting bit, the function confirms that all DMAC channels are unlocked before making the module stop setting. (For details, see the "Low Power Consumption" section in the User's Manual: Hardware.

Change the processing method to match the combination of modules used, as shown below.

| DMAC Control                                                                       | DTC Control                                                                         | Processing Method |
|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-------------------|
| DMACA FIT module                                                                   | DTC FIT module                                                                      | See case 1.       |
| (lock function control function present, DTC lock state checking function present) | (lock function control function present, DMAC lock state checking function present) |                   |
| Other than the above                                                               |                                                                                     | See case 2.       |

### Case 1: Using the r\_bsp Default Lock Function and Controlling the DMAC with the DMAC FIT Module\*1

The function uses the  $r_bsp$  default lock function to confirm that all DMAC channels are unlocked and that the DTC is unlocked, then puts the DTC into the module stop state.

Note: 1. A necessary condition is that the DMAC FIT module has a module stop control function that confirms the locked state of the DTC.

#### **Case 2: Control Other Than the Above**

The user must provide code to confirm that all DMAC channels are unlocked and that the DTC is unlocked (not in use). The DTC FIT module includes an empty function for this purpose.

If the r\_bsp default lock function is not used, insert the program code for checking the locked/unlocked state of all the DMAC channels and the DTC after the line marked /\* do something \*/ in the r\_dtc\_check\_DMAC\_locking\_byUSER() function in the file r\_dtc\_rx\_target.c.

Note that bool type shown below should be used for the return value of the r\_dtc\_check\_DMAC\_locking\_byUSER() function.

### Returns value of r\_dtc\_check\_DMAC\_locking\_byUSER()

[true] /\* All DMAC channels are unlocked. \*/

[false] /\* One or some DMAC channels are locked. \*/

### **Example**

```
dtc_err_t ret;
ret = R_DTC_Close();
```

#### **Special Notes:**

When controlling the DMAC without using the DMAC FIT module, make sure to monitor the usage of the DMAC and control locking and unlocking of the DMAC so that calling this function does not set the DMAC to the module stop state. Note that even if the DMAC has not been activated, it is necessary to keep it in the locked state when not making DMAC transfer settings.

## R\_DTC\_Create()

This function is used to make DTC register settings and to specify the activation source.

#### **Format**

```
dtc_err_t R_DTC_Create (

dtc_activation_source_t act_source,

dtc_transfer_data_t *p_transfer_data,

dtc_transfer_data_cfg_t *p_data_cfg,

uint32_t chain_transfer_nr
)
```

#### **Parameters**

dtc\_activation\_source\_t act\_source
Activation source.

dtc\_transfer\_data\_t \*p\_transfer\_data

Pointer to start address of Transfer data area on RAM.

```
dtc_transfer_data_cfg_t *p_data_cfg
```

Pointer to settings for Transfer data

In the case of DTCb, the setting to the following structure members is invalid. This function sets the following values.

```
p_data_cfg->writeback_disable = DTC_WRITEBACK_ENABLE;
p_data_cfg->sequence_end = DTC_SEQUENCE_TRANSFER_CONTINUE;
p_data_cfg->refer_index_table_enable = DTC_REFER_INDEX_TABLE_DISABLE;
p_data_cfg->disp_add_enable = DTC_SRC_ADDR_DISP_ADD_DISABLE;
```

#### uint32\_t chain\_transfer\_nr

Number of chain transfer

The number of Transfer data and corresponding configurations is (number of chain transfer + 1). Example: if chain\_transfer\_nr = 1, it means that there are 2 continuous Transfer data and 2 corresponding configurations and the first configuration enable the chain transfer.

The type definition of a Transfer data (\* p\_transfer\_data) depends on the address mode and the details are shown as below and the users will use this data type to allocate memory for Transfer data exactly:

```
#if (1 == DTC_CFG_SHORT_ADDRESS_MODE) /* Short address mode */
typedef struct st_transfer_data { /* 3 long words */
    uint32_t lw1;
    uint32_t lw2;
    uint32_t lw3;
} dtc_transfer_data_t;
#else /* Full-address mode */
typedef struct st_transfer_data { /* 4 long words */
    uint32_t lw1;
    uint32_t lw2;
    uint32_t lw2;
    uint32_t lw3;
    uint32_t lw4;
} dtc_transfer_data_t;
#endif
```

The type of "Pointer to settings for Transfer data(\* p\_data\_cfg)" is different by the DTC IP version. The data structure of configuration is below:

#### 1. DTCa

```
typedef struct st_dtc_transfer_data_cfg {
                                               /* DTC transfer mode
     dtc_transfer_mode_t transfer_mode;
                                               /* Size of data
     dtc_data_size_t
                             data_size;
                                               /* Address mode of source
     dtc_src_addr_mode_t
                             src_addr_mode;
     dtc_chain_transfer_t
                             chain_transfer_enable;
                                        /* Chain transfer is enabled or not
     dtc_chain_transfer_mode_t chain_transfer_mode;
                                       /* How chain transfer is performed
     dtc_interrupt_t
                             response_interrupt;
                                       /* How response interrupt is raised
     dtc_repeat_block_side_t repeat_block_side;/* Side being repeat or block */
     dtc_dest_addr_mode_t dest_addr_mode; /* Address mode of destination*/
     uint32_t
                             source_addr;
                                              /* Start address of source
                                                                             * /
     uint32 t
                             dest_addr; /* Start address of destination
     uint32 t
                             transfer_count; /* Transfer count
     uint16_t
                             block size;
                                   /* Size of a block in block transfer mode */
     uint16 t
                                               /* Reserve bit
                             rsv;
} dtc_transfer_data_cfg_t;
```

#### 2. DTCb

```
typedef struct st_dtc_transfer_data_cfg {
     dtc_transfer_mode_t transfer_mode;
                                             /* DTC transfer mode
                                              /* Size of data
     dtc_data_size_t
                             data_size;
                                              /* Address mode of source
     dtc_src_addr_mode_t src_addr_mode;
     dtc_chain_transfer_t
                            chain_transfer_enable;
                                        /* Chain transfer is enabled or not
     dtc_chain_transfer_mode_t chain_transfer_mode;
                                        /* How chain transfer is performed
     dtc interrupt t
                             response_interrupt;
                                        /* How response interrupt is raised */
     dtc_repeat_block_side_t repeat_block_side;/* Side being repeat or block */
                            dest_addr_mode; /* Address mode of destination*/
     dtc_dest_addr_mode_t
                             source_addr; /* Start address of source
     uint32_t
                             dest_addr; /* Start address of destination
     uint32_t
                             transfer_count;  /* Transfer count
                                                                             * /
     uint32_t
     uint16_t
                             block_size;
                                   /* Size of a block in block transfer mode */
                                               /* Reserve bit
     uint16 t
                             rsv;
     dtc_write_back_t
                             writeback_disable;
                        /* Transfer information writeback is enabled or not
                             sequence_end;
     dtc_sequence_end_t
                               /* Sequence transfer is continued or end
                                                                             * /
     dtc_refer_index_table_t refer_index_table_enable;
                               /* Index table reference is enabled or not
                             disp_add_enable;
                 /* Displacement value is added to the source address or not */
} dtc_transfer_data_cfg_t;
```

The following enumerate definitions indicate configurable options for above structures:

```
/* Configurable options for DTC Transfer mode */
typedef enum e_dtc_transfer_mode
   } dtc_transfer_mode_t;
/* Configurable options for DTC Data transfer size */
typedef enum e_dtc_data_size
   } dtc_data_size_t;
/* Configurable options for Source address addressing mode */
typedef enum e dtc src addr mode
   DTC_SRC_ADDR_FIXED = (0),
DTC_SRC_ADDR_INCR = (2 << 2),</pre>
                                /* = (0 << 2): Source address is fixed. */
                    /* Source address is incremented after each transfer. */
   DTC\_SRC\_ADDR\_DECR = (3 << 2),
                    /* Source address is decremented after each transfer. */
} dtc _src_addr_mode_t;
/* Configurable options for Chain transfer */
typedef enum e_dtc_chain_transfer
                                            /* Disable Chain transfer. */
   DTC_CHAIN_TRANSFER_DISABLE = (0),
                                DTC_CHAIN_TRANSFER_ENABLE
} dtc_chain_transfer_t;
/* Configurable options for how chain transfer is performed */
typedef enum e_dtc_chain_transfer_mode
   DTC_CHAIN_TRANSFER_CONTINUOUSLY = (0),
                /* = (0 << 6): Chain transfer is performed continuously. */
   DTC_CHAIN_TRANSFER_NORMAL = (1 << 6)
^{\prime \star} Chain transfer is performed only when the counter is changed to 0 or CRAH. ^{\star \prime}
} dtc_chain_transfer_mode_t;
/* Configurable options for Interrupt */
typedef enum e dtc interrupt
{
   DTC INTERRUPT AFTER ALL COMPLETE = (0),
     /* Interrupt is generated when specified data transfer is completed. */
   DTC INTERRUPT PER SINGLE TRANSFER = (1 << 5)
     /* Interrupt is generated when each transfer time is completed. */
} dtc_interrupt_t;
/* Configurable options for Side to be repeat or block */
typedef enum e_dtc_repeat_block_side
   DTC_REPEAT_BLOCK_DESTINATION = (0),
     /* = (0 << 4): Destination is repeat or block area. */
   DTC_REPEAT_BLOCK_SOURCE = (1 << 4)
     /* Source is repeat or block area. */
} dtc_repeat_block_side_t;
```

```
/* Configurable options for Destination address addressing mode */
typedef enum e_dtc_dest_addr_mode
    DTC_DES_ADDR_FIXED = (1 << 2), /* Destination address is fixed. */
    DTC DES ADDR INCR = (2 << 2),
        /* Destination address is incremented after each transfer. */
    DTC_DES_ADDR_DECR = (3 << 2)
        /* Destination address is decremented after each transfer. */
} dtc_dest_addr_mode_t;
/* Configurable options to write back transfer information */
typedef enum e_dtc_write_back
      DTC_WRITEBACK_ENABLE = (0), /* Writeback is enabled */
      DTC_WRITEBACK_DISABLE = (1) /* Writeback is disabled */
} dtc_write_back_t;
/* Configurable option to continue/end sequence transfer */
typedef enum e_dtc_sequence_end
      DTC_SEQUENCE_TRANSFER_CONTINUE = (0), /* Sequence transfer is continued */
      DTC SEQUENCE TRANSFER END
                                = (1) /* Sequence transfer is ended */
} dtc_sequence_end_t;
/* Configurable options for index table reference */
typedef enum e_dtc_refer_index_table
      DTC_REFER_INDEX_TABLE_DISABLE = (0), /* Index table is not referred */
      DTC_REFER_INDEX_TABLE_ENABLE = (1 << 1) /* Index table is referred */
} dtc_refer_index_table_t;
/* Configurable options to add/not to add Displacement value to the destination
address */
typedef enum e_dtc_disp_add
      DTC_SRC_ADDR_DISP_ADD_DISABLE = (0),
                  /* Displacement value is not added to the source address */
      DTC_SRC_ADDR_DISP_ADD_ENABLE = (1)
                  /* Displacement value is added to the source address */
} dtc_disp_add_t;
```

The transfer\_count is set from 1 to 65536 in Normal transfer mode and Block transfer mode, from 1 to 256 in Repeat transfer mode.

The block size value is set from 1 to 256 in Block transfer mode.

In short address mode, the start address of Transfer data (second argument), source area and destination area is in range (0x00000000 to 0x007FFFFF and 0xFF800000 to 0xFFFFFFFF).

### **Return Values**

```
[DTC_SUCCESS] /* Successful operation */
[DTC_ERR_NOT_OPEN] /* DTC is not initialized yet. */
[DTC_ERR_INVALID_ARG] /* Parameters are invalid. */
[DTC_ERR_NULL_PTR] /* Argument pointers are NULL. */
```

#### **Properties**

Prototype declarations are contained in r\_dtc\_rx\_if.h.

#### **Description**

Writes the configuration to Transfer data.

Writes the start address of Transfer data corresponding to interrupt number into DTC vector table.

#### **Example**

#### Case 1: In the case of No chain transfer

```
dtc_transfer_data_cfg_t td_cfg;
dtc_activation_source_t act_src = DTCE_ICU_SWINT; /* activation source is
Software Interrupt */
dtc_transfer_data_t transfer_data; /* assume that DTC address mode is full
mode */
dtc_err_t ret;
uint32_t src = 1234;
uint32_t des[3];
uint8_t ien_bk;
/* create the configuration - no chain transfer */
/* Source address addressing mode is FIXED
* Data size is 32 bits (long word)
* DTC transfer mode is Repeat mode & Source side is repeat area
 * Interrupt is raised after each single transfer
* Chain transfer is disabled
* /
td_cfg.src_addr_mode
                              = DTC SRC ADDR FIXED;
td_cfg.data_size
                              = DTC_DATA_SIZE_LWORD;
td_cfg.transfer_mode = DTC_TRANSFER_MODE_REPEAT;
td_cfg.dest_addr_mode = DTC_DES_ADDR_INCR;
td_cfg.repeat_block_side = DTC_REPEAT_BLOCK_SOURCE;
td_cfg.response_interrupt = DTC_INTERRUPT_PER_SINGLE_TRANSFER;
td cfg.chain transfer enable = DTC CHAIN TRANSFER DISABLE;
td_cfg.chain_transfer_mode = (dtc_chain_transfer_mode_t)0;
td_cfg.source_addr
                               = (uint32_t)&src;
td_cfg.dest_addr
                               = (uint32_t)des;
td_cfg.transfer_count
                               = 1;
td_cfg.block_size
                                = 3;
/* Disable Software interrupt request before calling R_DTC_Create() */
ien_bk = ICU.IER[3].BIT.IEN3 ; /* store old setting */
ICU.IER[3].BIT.IEN3 = 0;
/* Calling to R_DTC_Create() */
ret = R_DTC_Create(act_src, &transfer_data, &td_cfg, 0);
```

```
/* Restore the setting for Software interrupt request */
ICU.IER[3].BIT.IEN3 = ien_bk;
```

#### Case 2: In the case of ONE chain transfer

```
dtc_transfer_data_cfg_t td_cfg[2]; /* need 2 configuration sets */
dtc_activation_source_t act_src = DTCE_ICU_SWINT;
                       /* activation source is Software Interrupt */
uint32_t transfer_data[8];
        /* for 2 Transfer data; assume that DTC address mode is full mode */
dtc_err_t ret;
uint32_t src = 1234;
                         /* The destination for first Transfer data */
uint32_t des[3];
uint32_t des2[3];
                         /* The destination for second Transfer data */
uint8_t ien_bk;
/* create the configuration 1 - support chain transfer */
/* Source address addressing mode is FIXED
* Destination address addressing mode is INCREMENTED
* Data size is 32 bits (long word)
* DTC transfer mode is Normal mode
* Interrupt is raised after each single transfer
* Chain transfer is enabled
* Chain transfer is performed after when transfer counter is set to 0
* /
td_cfg[0].src_addr_mode
                         = DTC_SRC_ADDR_FIXED;
td_cfg[0].chain_transfer_enable = DTC_CHAIN_TRANSFER_ENABLE;
td_cfg[0].chain_transfer_mode = DTC_CHAIN_TRANSFER_NORMAL;
= 1;
td_cfg[0].transfer_count
td_cfg[0].block_size
                           = 3;
/* create the configuration 2 - no chain transfer */
/* Source address addressing mode is FIXED
 * Destination address addressing mode is INCREMENTED
* Data size is 32 bits (long word)
* DTC transfer mode is Normal mode
* Interrupt is raised after each single transfer
* Chain transfer is disabled
* /
td_cfg[1].src_addr_mode
                         = DTC SRC ADDR FIXED;
td_cfg[1].data_size
                         = DTC_DATA_SIZE_LWORD;
td_cfg[1].chain_transfer_enable = DTC_CHAIN_TRANSFER_DISABLE;
td_cfg[1].chain_transfer_mode = (dtc_chain_transfer_mode_t)0;
td_cfg[1].transfer_count = 1;
                           = 3;
td_cfg[1].block_size
/* Disable Software interrupt request before calling R_DTC_Create() */
```

```
ien_bk = ICU.IER[3].BIT.IEN3 ; /* store old setting */
ICU.IER[3].BIT.IEN3 = 0;

/* Call R_DTC_Create() */
ret = R_DTC_Create(act_src, transfer_data , td_cfg, 1); /* The fourth argument indicates that there's one chain transfer enabled in first Transfer data */

/* Restore the setting for Software interrupt request */
ICU.IER[3].BIT.IEN3 = ien_bk;
```

#### Case 3: In the case of multiple source registration

```
dtc_transfer_data_cfg_t td_cfg_sw;
dtc_transfer_data_cfg_t td_cfg_cmt;
dtc_activation_source_t act_src_sw = DTCE_ICU_SWINT;
                                /* activation source is Software Interrupt */
dtc_activation_source_t act_src_cmt = DTCE_CMT0_CMI0;
                                /* activation source is CMT Interrupt */
dtc_transfer_data_t transfer_data_sw;
                                /* assume that DTC address mode is full mode */
dtc_transfer_data_t transfer_data_cmt;
                                /* assume that DTC address mode is full mode */
dtc_err_t ret;
uint32_t src_sw = 1234;
uint32_t src_cmt = 5678;
uint32_t des_sw[3];
uint32_t des_cmt[3];
uint8_t ien_bk;
/* create the configuration - no chain transfer */
/* Source address addressing mode is FIXED
* Data size is 32 bits (long word)
* DTC transfer mode is Repeat mode & Source side is repeat area
* Interrupt is raised after each single transfer
* Chain transfer is disabled
* /
td_cfg_sw.src_addr_mode = DTC_SRC_ADDR_FIXED;
td_cfg_sw.data_size = DTC_DATA_SIZE_LWORD;
td_cfg_sw.transfer_mode = DTC_TRANSFER_MODE_REPEAT;
td_cfg_sw.dest_addr_mode = DTC_DES_ADDR_INCR;
td_cfg_sw.repeat_block_side = DTC_REPEAT_BLOCK_SOURCE;
td_cfg_sw.response_interrupt = DTC_INTERRUPT_PER_SINGLE_TRANSFER;
td cfg sw.chain transfer enable = DTC CHAIN TRANSFER DISABLE;
td_cfg_sw.chain_transfer_mode = (dtc_chain_transfer_mode_t)0;
td cfg sw.source addr = (uint32 t)&src sw;
td_cfg_sw.dest_addr = (uint32_t)des_sw;
td_cfg_sw.transfer_count = 1;
td_cfg_sw.block_size = 3;
/* Disable Software interrupt request before calling R_DTC_Create() */
ien_bk = ICU.IER[3].BIT.IEN3 ; /* store old setting */
ICU.IER[3].BIT.IEN3 = 0;
```

```
/* Calling to R DTC Create() */
ret = R_DTC_Create(act_src_sw, &transfer_data_sw, &td_cfg_sw, 0);
/* Restore the setting for Software interrupt request */
ICU.IER[3].BIT.IEN3 = ien_bk;
/* create the configuration - no chain transfer */
/* Source address addressing mode is FIXED
* Data size is 32 bits (long word)
* DTC transfer mode is Repeat mode & Source side is repeat area
* Interrupt is raised after each single transfer
* Chain transfer is disabled
td_cfg_cmt.src_addr_mode = DTC_SRC_ADDR_FIXED;
td_cfg_cmt.data_size = DTC_DATA_SIZE_LWORD;
td_cfg_cmt.transfer_mode = DTC_TRANSFER_MODE_REPEAT;
td_cfg_cmt.dest_addr_mode = DTC_DES_ADDR_INCR;
td_cfg_cmt.repeat_block_side = DTC_REPEAT_BLOCK_SOURCE;
td_cfg_cmt.response_interrupt = DTC_INTERRUPT_PER_SINGLE_TRANSFER;
td_cfg_cmt.chain_transfer_enable = DTC_CHAIN_TRANSFER_DISABLE;
td_cfg_cmt.chain_transfer_mode = (dtc_chain_transfer_mode_t)0;
td_cfg_cmt.source_addr = (uint32_t)&src_cmt;
td_cfg_cmt.dest_addr = (uint32_t)des_cmt;
td_cfg_cmt.transfer_count = 1;
td_cfg_cmt.block_size = 3;
/* Calling to R_DTC_Create() */
ret = R_DTC_Create(act_src_cmt, &transfer_data_cmt, &td_cfg_cmt, 0);
R_CMT_CreateOneShot(10000, &cmt_callback, &cmt_channel);
```

### **Special Notes:**

Before calling R\_DTC\_Create(), user must disable the current interrupt request (the interrupt source is passed to R\_DTC\_Create()) by clearing Interrupt Request Enable bit IERm.IENj:

```
ICU.IER[m].BIT.IENj = 0;
```

Then, enable the interrupt request disabled after R\_DTC\_Create() is ended.

The correspondence between IERm.IENj bit and interrupt source is described in Interrupt Vector Table, chapter Interrupt Controller (ICU) of User's Manual: Hardware.

## R\_DTC\_CreateSeq()

This function performs the setting of the DTC register used in the sequence transfer and the activation source.

#### **Format**

#### **Parameters**

act\_source

Activation source

\* p\_transfer\_data

Pointer to the start address in the transfer information area in RAM.

\* p\_data\_cfg

Pointer to the transfer information setting

Set the following structure members.

```
p_data_cfg->writeback_disable
p_data_cfg->sequence_end
p_data_cfg->refer_index_table_enable
p_data_cfg->disp_add_enable
```

sequence\_transfer\_nr

Transfer information counts per sequence transfer (0 - 4294967295)

| sequence_transfer_nr | Description                                                                                                                                                            |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                    | When transfer request for the sequence number (sequence_no) specified is generated, the setting is made to output CPU interrupt request without starting the sequence. |
| 1 - 4294967295       | When transfer request for the sequence number (sequence_no) specified is generated, the transfer information for the sequence transfer is set.                         |
|                      | Prepare transfer information about the number to be specified sequence_transfer_nr in advance, and set the start address of the transfer information to *p_data_cfg.   |

sequence\_no

Sequence number (0 - 255)

The type definition of the transfer information and the data structure are the same as R\_DTC\_Create(). Total of 256 ways of the sequence information can be set.

### **Return Values**

DTC\_SUCCESS /\* Successful operation \*/
DTC\_ERR\_NOT\_OPEN /\* DTC is not initialized yet. \*/
DTC\_ERR\_INVALID\_ARG /\* Arguments are invalid. \*/
DTC\_ERR\_NULL\_PTR /\* Argument pointers are NULL. \*/

### **Properties**

Prototype declarations are contained in r\_dtc\_rx\_if.h.

### **Description**

This function writes the setting information to the transfer information.

Start address of the transfer information for the sequence number is written to DTC index table.

### **Example**

Examples of asynchronous serial receiving by the sequence transfer based on the Receive FIFO Full Interrupt (RXI) as DTC activation source is explained as follows. SCI used is Channel 10. Sequence transfer is automatically started according to 1 bit data (cmnd) received first from external communication device.

#### Case 1:

After receiving cmnd= "00h" from external communication device, SCI10 receive FIFO threshold is changed to 4 bytes, then, 4 bytes data output from external communication device is received, and is stored in the RAM by DTC transfer.

Table 3-1 Transfer information specified in Case 1

| Member                   | Transfer information<br>1                                         | Transfer information 2                                            | Transfer information 3                                            |
|--------------------------|-------------------------------------------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------------|
| transfer_mode            | Normal transfer                                                   | Block transfer                                                    | Normal transfer                                                   |
| data_size                | 8 bits                                                            | 16 bits                                                           | 8 bits                                                            |
| src_addr_mode            | Fix source address                                                | Fix source address                                                | Fix source address                                                |
| chain_transfer_enable    | Disable chain transfer                                            | Enable chain transfer                                             | Disable chain transfer                                            |
| chain_transfer_mode      | Perform chain transfer continuously (setting disabled)            | Perform chain transfer continuously                               | Perform chain transfer continuously (setting disabled)            |
| response_interrupt       | Generate interrupt after the specified data transfer is complete. | Generate interrupt after the specified data transfer is complete. | Generate interrupt after the specified data transfer is complete. |
| repeat_block_side        | Destination is repeat or block area (setting disabled)            | Destination is repeat or block area                               | Destination is repeat or block area (setting disabled)            |
| dest_addr_mode           | Fix destination address                                           | Increment destination Address per transfer                        | Fix destination address                                           |
| source_addr              | ROM dtc_fcrh_data[0]<br>Address                                   | SCI10.FRDR register address                                       | ROM g_dtc_fcrh_cmnd address                                       |
| dest_addr                | SCI10.FCR.H register<br>Address                                   | RAM g_dtc_rx_buf0[0] address                                      | SCI10.FCR.H register address                                      |
| transfer_count           | 1                                                                 | 1                                                                 | 1                                                                 |
| block_size               | (Setting disabled)                                                | 4                                                                 | (Setting disabled)                                                |
| writeback_disable        | No write back                                                     | No write back                                                     | No write back                                                     |
| sequence_end             | Continue sequence transfer                                        | Continue sequence transfer                                        | End sequence transfer                                             |
| refer_index_table_enable | Not refer to                                                      | Not refer to                                                      | Not refer to                                                      |
|                          | index table                                                       | index table                                                       | index table                                                       |
| disp_add_enable          | Not add Displacement<br>value to the source<br>address            | Not add Displacement value to the source address                  | Not add Displacement value to the source address                  |

```
#include "platform.h"
#include "r_dtc_rx_if.h"
#define CMND0 RCV NUM (4)
#define CMND0_RCV_FIF0_TRG (4)
#define CMND0_FCRH_DATA ((uint8_t)(0xF0 | CMND0_RCV_FIF0_TRG))
#define CMND0_INFO_NUM (3)
dtc_transfer_data_cfg_t g_dtc_pre_seqinfo_cmnd0[CMND0_INFO_NUM];
dtc_transfer_data_t g_dtc_seqinfo_cmnd0[CMND0_INFO_NUM];
uint16_t g_dtc_rx_buf0[CMND0_RCV_NUM];
const uint8_t g_dtc_fcrh_cmnd = 0xF1;
static const uint8_t dtc_fcrh_data[] =
      CMND0_FCRH_DATA,
      CMND1_FCRH_DATA,
      CMND2_FCRH_DATA,
      CMND3_FCRH_DATA
};
void dtc_pre_seqinfo_cmnd0_init(void);
void main(void)
      dtc_err_t ret;
      dtc_activation_source_t act_source;
      uint32_t sequence_transfer_nr;
      uint8_t sequence_no;
      uint8_t ien_bk;
      /* ---- DTC sequence transfer information for Cmnd0 ---- */
      dtc_pre_seqinfo_cmnd0_init();
      act_source = DTCE_SCI10_RXI10;
      sequence_transfer_nr = CMND0_INFO_NUM;
      sequence_no = 0;
      ien_bk = IEN(SCI10,RXI10); /* IEN(x,x)->ICU.IER[z].BIT.IENz;*/
      IEN(SCI10,RXI10) = 0;
      ret = R_DTC_CreateSeq(act_source,
                             &g_dtc_seqinfo_cmnd0[0],
                             &g_dtc_pre_seqinfo_cmnd0[0],
                             sequence_transfer_nr,
                             sequence_no);
      IEN(SCI10,RXI10) = ien_bk;
void dtc_pre_seqinfo_cmnd0_init(void)
      /* [1st] Sequence transfer information -
               Changing the SCI10 Receive FIFO trigger */
      /* MRA */
      g_dtc_pre_seqinfo_cmnd0[0].transfer_mode = DTC_TRANSFER_MODE_NORMAL;
      g_dtc_pre_seqinfo_cmnd0[0].data_size = DTC_DATA_SIZE_BYTE;
      g_dtc_pre_seqinfo_cmnd0[0].src_addr_mode = DTC_SRC_ADDR_FIXED;
      g_dtc_pre_seqinfo_cmnd0[0].writeback_disable = DTC_WRITEBACK_DISABLE;
      /* MRB */
      g_dtc_pre_seqinfo_cmnd0[0].chain_transfer_enable =
                                          DTC_CHAIN_TRANSFER_DISABLE;
```

```
g_dtc_pre_seqinfo_cmnd0[0].chain_transfer_mode =
                                    DTC_CHAIN_TRANSFER_CONTINUOUSLY;
g_dtc_pre_seqinfo_cmnd0[0].response_interrupt =
                                    DTC_INTERRUPT_AFTER_ALL_COMPLETE;
g_dtc_pre_seqinfo_cmnd0[0].repeat_block_side =
                                    DTC_REPEAT_BLOCK_DESTINATION;
g_dtc_pre_seqinfo_cmnd0[0].dest_addr_mode = DTC_DES_ADDR_FIXED;
g_dtc_pre_seqinfo_cmnd0[0].refer_index_table_enable =
                                    DTC_REFER_INDEX_TABLE_DISABLE;
g_dtc_pre_seqinfo_cmnd0[0].sequence_end =
                                    DTC_SEQUENCE_TRANSFER_CONTINUE;
/* MRC */
g_dtc_pre_seqinfo_cmnd0[0].disp_add_enable =
                                    DTC_SRC_ADDR_DISP_ADD_DISABLE;
/* SAR */
g_dtc_pre_seqinfo_cmnd0[0].source_addr = (uint32_t)&dtc_fcrh_data[0];
/* DAR */
g_dtc_pre_seqinfo_cmnd0[0].dest_addr = (uint32_t)&SCI10.FCR.BYTE.H;
/* CRA, CRB */
g_dtc_pre_seqinfo_cmnd0[0].transfer_count = 1;
/* [2nd] Sequence transfer information -
         transfers the received data from SCI10.FRDR to RAM */
/* MRA */
g_dtc_pre_seqinfo_cmnd0[1].transfer_mode = DTC_TRANSFER_MODE_BLOCK;
g_dtc_pre_seqinfo_cmnd0[1].data_size = DTC_DATA_SIZE_WORD;
g_dtc_pre_seqinfo_cmnd0[1].src_addr_mode = DTC_SRC_ADDR_FIXED;
g_dtc_pre_seqinfo_cmnd0[1].writeback_disable = DTC_WRITEBACK_DISABLE;
/* MRB */
g_dtc_pre_seqinfo_cmnd0[1].chain_transfer_enable =
                                      DTC_CHAIN_TRANSFER_ENABLE;
g_dtc_pre_seqinfo_cmnd0[1].chain_transfer_mode =
                                      DTC_CHAIN_TRANSFER_CONTINUOUSLY;
g_dtc_pre_seqinfo_cmnd0[1].response_interrupt =
                                      DTC_INTERRUPT_AFTER_ALL_COMPLETE;
g_dtc_pre_seqinfo_cmnd0[1].repeat_block_side =
                                      DTC_REPEAT_BLOCK_DESTINATION;
g_dtc_pre_seqinfo_cmnd0[1].dest_addr_mode = DTC_DES_ADDR_INCR;
g_dtc_pre_seqinfo_cmnd0[1].refer_index_table_enable =
                                      DTC_REFER_INDEX_TABLE_DISABLE;
g_dtc_pre_seqinfo_cmnd0[1].sequence_end =
                                      DTC_SEQUENCE_TRANSFER_CONTINUE;
/* MRC */
g_dtc_pre_seqinfo_cmnd0[1].disp_add_enable =DTC_SRC_ADDR_DISP_ADD_DISABLE;
/* SAR */
g_dtc_pre_seqinfo_cmnd0[1].source_addr = (uint32_t)&SCI10.FRDR.WORD;
/* DAR */
g_dtc_pre_seqinfo_cmnd0[1].dest_addr = (uint32_t)&g_dtc_rx_buf0[0];
/* CRA, CRB */
g_dtc_pre_seqinfo_cmnd0[1].transfer_count = 1;
g_dtc_pre_seqinfo_cmnd0[1].block_size = CMND0_RCV_FIF0_TRG;
/* [3rd] Sequence transfer information -
         Changing the SCI10 Receive FIFO trigger to 1 */
/* MRA */
g_dtc_pre_seqinfo_cmnd0[2].transfer_mode = DTC_TRANSFER_MODE_NORMAL;
g_dtc_pre_seqinfo_cmnd0[2].data_size = DTC_DATA_SIZE_BYTE;
g_dtc_pre_seqinfo_cmnd0[2].src_addr_mode = DTC_SRC_ADDR_FIXED;
g_dtc_pre_seqinfo_cmnd0[2].writeback_disable = DTC_WRITEBACK_DISABLE;
/* MRB */
```

```
g_dtc_pre_seqinfo_cmnd0[2].chain_transfer_enable =
                                             DTC_CHAIN_TRANSFER_DISABLE;
     g_dtc_pre_seqinfo_cmnd0[2].chain_transfer_mode =
                                             DTC_CHAIN_TRANSFER_CONTINUOUSLY;
     g_dtc_pre_seqinfo_cmnd0[2].response_interrupt =
                                             DTC_INTERRUPT_AFTER_ALL_COMPLETE;
     g_dtc_pre_seqinfo_cmnd0[2].repeat_block_side =
                                             DTC_REPEAT_BLOCK_DESTINATION;
     g_dtc_pre_seqinfo_cmnd0[2].dest_addr_mode = DTC_DES_ADDR_FIXED;
     g_dtc_pre_seqinfo_cmnd0[2].refer_index_table_enable=
                                             DTC_REFER_INDEX_TABLE_DISABLE;
     g_dtc_pre_seqinfo_cmnd0[2].sequence_end = DTC_SEQUENCE_TRANSFER_END;
      /* MRC */
     g_dtc_pre_seqinfo_cmnd0[2].disp_add_enable =DTC_SRC_ADDR_DISP_ADD_DISABLE;
      /* SAR */
     g_dtc_pre_seqinfo_cmnd0[2].source_addr = (uint32_t)&g_dtc_fcrh_cmnd;
      /* DAR */
     g_dtc_pre_seqinfo_cmnd0[2].dest_addr = (uint32_t)&SCI10.FCR.BYTE.H;
      /* CRA, CRB */
     g_dtc_pre_seqinfo_cmnd0[2].transfer_count = 1;
}
```

#### Case 2:

When receiving cmnd >= "04h" from external communication device, generate the interrupt to CPU without sequence transfer.

```
#include "platform.h"
#include "r_dtc_rx_if.h"
void main(void)
      dtc_err_t ret;
      dtc_activation_source_t act_source;
      uint32_t sequence_transfer_nr;
      uint8_t sequence_no;
      uint8_t ien_bk;
      uint16_t i;
      /* ---- DTC sequence transfer information for Cmnd4-Cmnd255 ---- */
      for (i = 4; i < 256; i++)
             act_source = DTCE_SCI10_RXI10;
             sequence_transfer_nr = 0;
             sequence_no = i;
             ien_bk = IEN(SCI10,RXI10); /* IEN(x,x)->ICU.IER[z].BIT.IENz;*/
             IEN(SCI10,RXI10) = 0;
             ret = R_DTC_CreateSeq(act_source,
                                   NULL,
                                   NULL,
                                   sequence_transfer_nr,
                                   sequence_no);
             IEN(SCI10,RXI10) = ien_bk;
      }
```

### **Special Notes:**

Before calling  $R\_DTC\_CreateSeq()$ , user must disable the current interrupt request (the interrupt source is passed to  $R\_DTC\_CreateSeq()$ ) by clearing Interrupt Request Enable bit (IERm.IENj):

```
ICU.IER[m].BIT.IENj = 0;
```

Then, enable the interrupt request disabled after R\_DTC\_CreateSeq() is ended.

The correspondence between IERm.IENj bit and interrupt source is described in Interrupt Vector Table, chapter Interrupt Controller (ICU) of User's Manual: Hardware.

## R\_DTC\_Control()

This function controls the operation of the DTC.

#### **Format**

#### **Parameters**

dtc\_command\_t command
DTC control command

dtc\_stat\_t \* p\_stat

Pointer to the status when command is DTC\_CMD\_STATUS\_GET.

#### Member of dtc\_stat\_t Structure

| Member      | Short<br>Description            | Setting Value               | Setting Details                                                                                             |
|-------------|---------------------------------|-----------------------------|-------------------------------------------------------------------------------------------------------------|
| vect_nr     | DTC-Activating<br>Vector Number | Vector Number<br>Monitoring | The value is only valid when DTC transfer is in progress (the value of the DTC Active Flag is 1).           |
| in_progress | DTC Active Flag                 | - false<br>- true           | <ul><li>DTC transfer operation is not in progress.</li><li>DTC transfer operation is in progress.</li></ul> |

dtc\_cmd\_arg\_t \* p\_args

Pointer to the argument structure when command is *DTC\_CMD\_ACT\_SRC\_ENABLE*, DTC\_CMD\_ACT\_SRC\_DISABLE, DTC\_CMD\_CHAIN\_TRANSFER\_ABORT, DTC\_CMD\_SEQUENCE\_TRANSFER\_ENABLE, or DTC\_CMD\_CHANGING\_DATA\_FORCIBLY\_SET.

#### Members of dtc\_cmd\_arg\_t Structure

| Member                                     | Short Description        | Setting Details                                           |
|--------------------------------------------|--------------------------|-----------------------------------------------------------|
| act_src                                    | DTC-Activating Vector    | The value is only valid when command is                   |
|                                            | Number                   | DTC_CMD_ACT_SRC_ENABLE or                                 |
|                                            |                          | DTC_CMD_ACT_SRC_DISABLE or                                |
|                                            |                          | DTC_CMD_SEQUENCE_TRANSFER_ENABLE or                       |
|                                            |                          | DTC_CMD_CHANGING_DATA_FORCIBLY_SET                        |
| chain_transfer_nr Number of chain transfer |                          | The value is only valid when command is                   |
|                                            | (Note)                   | DTC_CMD_CHAIN_TRANSFER_ABORT or                           |
|                                            |                          | DTC_CMD_CHANGING_DATA_FORCIBLY_SET.                       |
| *p_transfer_data                           | Pointer to start address | The value is only valid when command is                   |
|                                            | of Transfer data area on | DTC_CMD_CHANGING_DATA_FORCIBLY_SET.                       |
|                                            | RAM                      |                                                           |
| *p_data_cfg                                | Pointer to settings for  | The value is only valid when command is                   |
|                                            | Transfer data            | DTC_CMD_CHANGING_DATA_FORCIBLY_SET.                       |
| XX                                         |                          | 11. D. D. T. G. G. A. |

Note: Set the value as same as the argument chain\_transfer\_nr when user call R\_DTC\_Create() before.

### **Return Values**

[DTC\_SUCCESS] /\* Successful operation \*/
[DTC\_ERR\_NOT\_OPEN] /\* DTC is not initialized yet. \*/

[DTC\_ERR\_INVALID\_COMMAND] /\* Command parameters are invalid or

DTC\_CMD\_CHANGING\_DATA\_FORCIBLY\_SET command error. \*/

[DTC\_ERR\_NULL\_PTR] /\* Argument pointers are NULL. \*/
[DTC\_ERR\_ACT] /\* Data transfer is in progress. \*/

### **Properties**

Prototype declarations are contained in r\_dtc\_rx\_if.h.

### **Description**

Processing is performed depending on the command.

| Command                                    | Arguments                                      | Arguments                                                                                     | Description                                                                                                                   |
|--------------------------------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
|                                            | dtc_stat_t *                                   | dtc_cmd_arg_t *                                                                               |                                                                                                                               |
| DTC_CMD_DTC_ST<br>ART                      | NULL                                           | NULL                                                                                          | Starts DTC module using DTC Module Start (DTCST) bit.                                                                         |
| DTC_CMD_DTC_ST<br>OP                       | NULL                                           | NULL                                                                                          | Stops DTC module using DTC Module Start (DTCST) bit.                                                                          |
| DTC_CMD_DATA_R<br>EAD_SKIP_ENABLE          | NULL                                           | NULL                                                                                          | Enables Transfer Data Read Skip using DTC Transfer Information Read Skip Enable (RRS) bit.                                    |
| DTC_CMD_DATA_R<br>EAD_SKIP_DISABLE         | NULL                                           | NULL                                                                                          | Disables Transfer Data Read Skip using DTC Transfer Information Read Skip Enable (RRS) bit.                                   |
| DTC_CMD_ACT_SR<br>C_ENABLE                 | NULL                                           | p_args->act_src                                                                               | Sets an interrupt source using DTC Start Enable (DTCE) bit.                                                                   |
| DTC_CMD_ACT_SR<br>C_DISABLE                | NULL                                           | p_args->act_src                                                                               | Clears an interrupt source using DTC Start Enable (DTCE) bit.                                                                 |
| DTC_CMD_STATUS<br>_GET                     | p_stat-<br>>in_progress<br>p_stat-<br>>vect_nr | NULL                                                                                          | Gets a DTC Active Flag (ACT) and vector number (VECN[7:0]) using DTC Status Register (DTCSTS).                                |
| DTC_CMD_CHAIN_T<br>RANSFER_ABORT           | NULL                                           | p_args-><br>chain_transfer_nr                                                                 | Aborts the current active chain transfer.                                                                                     |
| DTC_CMD_SEQUEN<br>CE_TRANSFER_EN<br>ABLE   | NULL                                           | p_args->act_src                                                                               | Specifies Sequence Transfer Vector number and enables Sequence transfer using DTC Sequence Transfer Enable Register (DTCSEQ). |
| DTC_CMD_SEQUEN<br>CE_TRANSFER_DIS<br>ABLE  | NULL                                           | NULL                                                                                          | Disables Sequence Transfer using DTC Sequence Transfer Enable Register (DTCSEQ).                                              |
| DTC_CMD_SEQUEN<br>CE_TRANSFER_AB<br>ORT    | NULL                                           | NULL                                                                                          | Aborts Sequence Transfer using Sequence Transfer End bit (SQTFRL).                                                            |
| DTC_CMD_CHANGI<br>NG_DATA_FORCIBL<br>Y_SET | NULL                                           | p_args->act_src<br>p_args->chain_transfer_nr<br>p_args->p_transfer_data<br>p_args->p_data_cfg | Changes the value set by R_DTC_Create(). It is a valid process for changing parameters*1 forcibly set by R_DTC_Create().      |

Note: 1. writeback\_disable, sequence\_end, refer\_index\_table\_enable, and disp\_add\_enable

### **Example**

#### Case 1: Start DTC module

```
dtc_err_t ret;
/* Start DTC module */
ret = R_DTC_Control(DTC_CMD_DTC_START, NULL, NULL);
```

#### Case 2: Stop DTC module

```
dtc_err_t ret;
/* Stop DTC module */
ret = R_DTC_Control(DTC_CMD_DTC_STOP, NULL, NULL);
```

#### Case 3: Enable transfer information read skip

```
dtc_err_t ret;
/* Enable transfer information read skip */
ret = R_DTC_Control(DTC_CMD_DATA_READ_SKIP_ENABLE, NULL, NULL);
```

#### Case 4: Disable transfer information read skip

```
dtc_err_t ret;
/* Disable transfer information read skip */
ret = R_DTC_Control(DTC_CMD_DATA_READ_SKIP_DISABLE, NULL, NULL);
```

### Case 5: Using the DTCE, set the interrupt used for DTC activation source

```
dtc_err_t ret;
dtc_cmd_arg_t args;

/* Disable DTC transfer request by SCI10 receive data full interrupt */
IEN(SCI10, RXI10) = 0;

/* Set SCI10 receive data full interrupt as DTC activation source*/
args.act_src = DTCE_SCI10_RXI10;

/* Set the interrupt used for DTC activation source */
ret = R_DTC_Control(DTC_CMD_ACT_SRC_ENABLE, NULL, &args);
```

#### Case 6: Using the DTCE, clear the interrupt used for DTC activation source

```
dtc_err_t ret;
dtc_cmd_arg_t args;

/* Disable DTC trasnfer request by SCI10 receive data full interrupt */
IEN(SCI10, RXI10) = 0;

/* Set SCI10 receive data full interrupt as DTC activation source */
args.act_src = DTCE_SCI10_RXI10;

/* Delete the interrupt used for DTC activation source */
ret = R_DTC_Control(DTC_CMD_ACT_SRC_DISABLE, NULL, &args);
```

### Case 7: Get DTC Active Flag (ACT) and Vector number (VECN[7:0]) in progress

```
dtc_err_t ret;
dtc_stat_t stat;
uint8_t interrupt_number;

/* Get DTC Active Flag (ACT) and Vector number(VECN[7:0])in progress */
ret = R_DTC_Control(DTC_CMD_STATUS_GET, stat, NULL);

if (true == stat.in_progress)
{
    /* Vector number is valid */
interrupt_number = stat.vect_nr;
}
else
{
    /* Vector number is inbalid */
}
```

#### Case 8: Abort the chain transfer in process

```
dtc_err_t ret;
dtc_cmd_arg_t args;

/* No. Of chain transfer = 5 */
args. chain_transfer_nr = 5;

/* Abort the chain transfer in process */
ret = R_DTC_Control(DTC_CMD_STATUS_GET, NULL, &args);
```

### **Case 9 : Enable the sequence transfer**

```
dtc_err_t ret;
dtc_cmd_arg_t args;

/* Set SCI10 receive data full interrupt as sequence transfger activation source
*/
args.act_src = DTCE_SCI10_RXI10;

/* Enable sequence transfer */
ret = R_DTC_Control(DTC_CMD_SEQUENCE_TRANSFER_ENABLE, NULL, &args);
```

### Case 10: Disable the sequence transfer

```
dtc_err_t ret;

/* Disable sequence transfer */
ret = R_DTC_Control(DTC_CMD_SEQUENCE_TRANSFER_DISABLE, NULL, NULL);
```

#### Case 11: Abort the sequence transfer

```
dtc_err_t ret;

/* Disable DTC transfer request by SCI10 receive data full interrupt */
IEN(SCI10, RXI10) = 0;

/* Issue command repeatedly until sequence transfer can be aborted */
do
{
ret = R_DTC_Control(DTC_CMD_SEQUENCE_TRANSFER_ABORT, NULL, NULL);
} while (DTC_ERR_ACT == ret);
```

### Case 12: Changes the value set by R\_DTC\_Create()

```
dtc activation source t act source;
uint32_t chain_transfer_nr;
act_source = DTCE_SCI10_RXI10;
chain_transfer_nr = 0;
if (R_DTC_Create(act_source,
                     &g_dtc_info_sqnum,
                     &g_dtc_pre_info_sqnum,
                     chain_transfer_nr) != DTC_SUCCESS)
{
    /* Error */
g_dtc_pre_info_sqnum.writeback_disable
                                             = DTC_WRITEBACK_DISABLE;
g_dtc_pre_info_sqnum.sequence_end
                                              = DTC_SEQUENCE_TRANSFER_CONTINUE;
g_dtc_pre_info_sqnum.refer_index_table_enable = DTC_REFER_INDEX_TABLE_ENABLE;
q dtc pre info sqnum.disp add enable
                                              = DTC SRC ADDR DISP ADD DISABLE;
args.act src = DTCE SCI10 RXI10;
args.chain transfer nr = 0;
args.p_transfer_data = &g_dtc_info_sqnum;
args.p_data_cfg = &g_dtc_pre_info_sqnum;
if (R_DTC_Control(DTC_CMD_CHANGING_DATA_FORCIBLY_SET, NULL, &args) !=
DTC SUCCESS)
    /* Error */
```

#### **Special Notes:**

When the command is DTC\_CMD\_GET\_STATUS, the vector number is valid if only the DTC is in the progress (p\_stat->in\_progress is true).

With command DTC\_CMD\_ENABLE\_ACT\_SRC, DTC\_CMD\_DISABLE\_ACT\_SRC or DTC\_CMD\_SEQUENCE\_TRANSFER\_ABORT, before calling R\_DTC\_Control(), user must disable the current interrupt request (the interrupt source is passed to R\_DTC\_Control()) by clearing Interrupt Request Enable bit (IERm.IENj);

```
ICU.IER[m].BIT.IENj = 0;
```

After processing of R DTC Control() is ended, the interrupt request disabled is enabled.

The correspondence between IERm.IENj bit and interrupt source is described in Interrupt Vector Table, chapter Interrupt Controller (ICU) of User's Manual: Hardware.

With abort processing, user must re-create the Chain transfer data after the transfer is aborted because the old Transfer data are destroyed.

If an invalid value is attempted to set with DTC\_CMD\_CHANGING\_DATA\_FORCIBLY\_SET, R\_DTC\_Control() returns DTC\_ERR\_INVALID\_COMMAND

R\_DTC\_Control() may already update some registers before the invalid value is detected. This occurs only when users try to change FORCIBLY DTC with Invalid Value.

### **R\_DTC\_GetVersion()**

This function is used to get the driver version information.

### **Format**

uint32\_t R\_DTC\_GetVersion (void)

### **Parameters**

None.

### **Return Values**

Version number

Upper 2 bytes: major version, lower 2 bytes: minor version

### **Properties**

Prototype declarations are contained in r\_dtc\_rx\_if.h.

### **Description**

Returns the version information.

### Example

uint32\_t version; version = R\_DTC\_GetVersion();

### **Special Notes:**

None.

# 4. Pin Setting

DTC FIT module don't use pin setting.

# 5. Appendices

### 5.1 Confirmed Operation Environment

This section describes confirmed operation environment for the DTC FIT module.

Table 5.1 Confirmed Operation Environment (Rev.2.20)

| Item                               | Contents                                                                                                                      |  |
|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--|
| Integrated development environment | Renesas Electronics e2 studio V7.3.0                                                                                          |  |
| C compiler                         | Renesas Electronics C/C++ compiler for RX Family V3.01.00                                                                     |  |
|                                    | Compiler options: The integrated development environment default settings are used, with the following option addedlang = c99 |  |
| Endian order                       | Big-endian/Little-endian                                                                                                      |  |
| Module version                     | Ver.2.20                                                                                                                      |  |
| Board used                         | Renesas Starter Kit for RX72T (product No.: RTK5572TKCCxxxxxBE)                                                               |  |

Table 5.2 Confirmed Operation Environment (Rev.2.10)

| Item                               | Contents                                                                  |
|------------------------------------|---------------------------------------------------------------------------|
| Integrated development environment | Renesas Electronics e2 studio V7.0.0                                      |
| C compiler                         | Renesas Electronics C/C++ compiler for RX Family V3.00.00                 |
|                                    | Compiler options: The integrated development environment default settings |
|                                    | are used, with the following option added.                                |
|                                    | -lang = c99                                                               |
| Endian order                       | Big-endian/Little-endian                                                  |
| Module version                     | Ver.2.10                                                                  |
| Board used                         | Renesas Starter Kit for RX111 (product No.: R0K505111SxxxBE)              |
|                                    | Renesas Starter Kit for RX113 (product No.: R0K505113SxxxBE)              |
|                                    | Renesas Starter Kit for RX130 (product No.: RTK5005130SxxxxxBE)           |
|                                    | Renesas Starter Kit for RX130-512KB (product No.: RTK5051308SxxxxxBE)     |
|                                    | Renesas Starter Kit for RX231 (product No.: R0K505231SxxxBE)              |
|                                    | Renesas Starter Kit for RX23T (product No.: RTK500523TSxxxxxBE)           |
|                                    | Renesas Starter Kit for RX24T (product No.: RTK500524TSxxxxxBE)           |
|                                    | Renesas Starter Kit for RX24U (product No.: RTK500524USxxxxxBE)           |
|                                    | Renesas Starter Kit for RX64M (product No.: R0K50564MSxxxBE)              |
|                                    | Renesas Starter Kit for RX71M (product No.: R0K50571MSxxxBE)              |
|                                    | Renesas Starter Kit for RX65N (product No.: RTK500565NSxxxxxBE)           |
|                                    | Renesas Starter Kit for RX65N-2MB (product No.: RTK50565N2SxxxxxBE)       |
|                                    | Renesas Starter Kit for RX66T (product No.: RTK50566T0SxxxxxBE)           |

Table 5.3 Confirmed Operation Environment (Rev.2.08)

| Item                               | Contents                                                                                                             |
|------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| Integrated development environment | Renesas Electronics e2 studio V6.0.0                                                                                 |
| C compiler                         | Renesas Electronics C/C++ compiler for RX Family V.2.07.00                                                           |
|                                    | Compiler options: The integrated development environment default settings are used, with the following option added. |
|                                    | -lang = c99                                                                                                          |
| Endian order                       | Big-endian/Little-endian                                                                                             |
| Module version                     | Ver.2.08                                                                                                             |
| Board used                         | Renesas Starter Kit for RX111 (product No.: R0K505111SxxxBE)                                                         |
|                                    | Renesas Starter Kit for RX113 (product No.: R0K505113SxxxBE)                                                         |
|                                    | Renesas Starter Kit for RX130 (product No.: RTK5005130SxxxxxBE)                                                      |
|                                    | Renesas Starter Kit for RX130-512KB (product No.: RTK5051308SxxxxxBE)                                                |
|                                    | Renesas Starter Kit for RX231 (product No.: R0K505231SxxxBE)                                                         |
|                                    | Renesas Starter Kit for RX23T (product No.: RTK500523TSxxxxxBE)                                                      |
|                                    | Renesas Starter Kit for RX24T (product No.: RTK500524TSxxxxxBE)                                                      |
|                                    | Renesas Starter Kit for RX24U (product No.: RTK500524USxxxxxBE)                                                      |
|                                    | Renesas Starter Kit for RX64M (product No.: R0K50564MSxxxBE)                                                         |
|                                    | Renesas Starter Kit for RX71M (product No.: R0K50571MSxxxBE)                                                         |
|                                    | Renesas Starter Kit for RX65N (product No.: RTK500565NSxxxxxBE)                                                      |
|                                    | Renesas Starter Kit for RX65N-2MB (product No.: RTK50565N2SxxxxxBE)                                                  |

### 5.2 Troubleshooting

(1) Q: I have added the FIT module to the project and built it. Then I got the error: Could not open source file "platform.h".

A: The FIT module may not be added to the project properly. Check if the method for adding FIT modules is correct with the following documents:

• Using CS+:

Application note "Adding Firmware Integration Technology Modules to CS+ Projects (R01AN1826)"

• Using e<sup>2</sup> studio:

Application note "Adding Firmware Integration Technology Modules to Projects (R01AN1723)"

When using this FIT module, the board support package FIT module (BSP module) must also be added to the project. Refer to the application note "Board Support Package Module Using Firmware Integration Technology (R01AN1685)".

- (2) Q: I have added the FIT module to the project and built it. Then I got the error: This MCU is not supported by the current r\_dtc\_rx module.
  - A: The FIT module you added may not support the target device chosen in your project. Check the supported devices of added FIT modules.

### 6. Reference Documents

User's Manual: Hardware

The latest versions can be downloaded from the Renesas Electronics website.

Technical Update/Technical News

The latest information can be downloaded from the Renesas Electronics website.

User's Manual: Development Tools

RX Family C/C++ Compiler CC-RX User's Manual (R20UT3248)

The latest version can be downloaded from the Renesas Electronics website.

## **Related Technical Updates**

Not applicable technical update for this module.

## **Website and Support**

Renesas Electronics Website

http://www.renesas.com/

Inquiries

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

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

|      | ion History                           | Descript                    | ion                                                           |
|------|---------------------------------------|-----------------------------|---------------------------------------------------------------|
| Rev. | Date                                  | Page                        | Summary                                                       |
| 2.02 | Apr 1, 2015                           | <u> </u>                    | First edition issued                                          |
| 2.03 | Jun 15, 2015                          | 1                           | Added RX230 Group and RX231 Group In Target Device            |
|      | · · · · · · · · · · · · · · · · · · · | 9                           | 1.2.2 Operating Environment and Memory Size                   |
|      |                                       |                             | Added (5)RX231                                                |
|      |                                       | 18                          | 3.2 R_DTC_Close() Description                                 |
|      |                                       |                             | Changed "If all DMAC channels are unlocked," to "If all DMAC  |
|      |                                       |                             | channels have been unlocked,"                                 |
|      |                                       | 27                          | 3.3 R_DTC_Create()                                            |
|      |                                       |                             | Added Case 3: In the case of multiple source registration to  |
|      |                                       |                             | Example                                                       |
| 2.04 | Dec 29,2015                           | 1                           | Added RX130 Group, RX23T Group, and RX24T Group In            |
|      |                                       |                             | Target Device                                                 |
|      |                                       | 2                           | Changed the explanation of 1. Overviews;                      |
|      |                                       |                             | "The DTC is activated by interruptstart the transfer."        |
|      |                                       | 13                          | 2.6 Compile Settings #define                                  |
|      |                                       |                             | DTC_CFG_SHORT_ADDRESS_MODE                                    |
|      |                                       | 4.4                         | Changed from "ADDRRESS"                                       |
|      |                                       | 14                          | 2.7 Arguments                                                 |
|      |                                       | 16                          | Added /* Short-address mode */ and /* Full-address mode */    |
|      |                                       | 16                          | Updated 2.9 Adding Driver to Your Project                     |
|      |                                       | 20                          | 3.3 R_DTC_Create() Parameters                                 |
|      |                                       |                             | #if (1 == DTC_CFG_SHORT_ADDRESS_MODE) Changed from "ADDRRESS" |
|      |                                       | 25                          | 3.3 R_DTC_Create() Example Case 1                             |
|      |                                       | 25                          | Added uint8_t ien_bk;                                         |
|      |                                       |                             | Changed from dest_addr to des_addr                            |
|      |                                       | 26                          | 3.3 R_DTC_Create() Example Case 2                             |
|      |                                       | 20                          | Changed from uint32 transfer_data[8] to uint32_t              |
|      |                                       |                             | transfer_data[8]                                              |
|      |                                       |                             | Added uint8_t ien_bk;                                         |
|      |                                       | 26                          | 3.3 R_DTC_Create() Example Case 2                             |
|      |                                       |                             | Changed from dest_addr to des_addr (2 places)                 |
|      |                                       | 27                          | 3.3 R_DTC_Create() Example Case 3                             |
|      |                                       |                             | Added uint8_t ien_bk;                                         |
|      |                                       |                             | Changed from dest_addr to des_addr                            |
|      |                                       | 27                          | 3.3 R_DTC_Create() Example Case 3                             |
|      |                                       |                             | Changed from dest_addr to des_addr :                          |
|      |                                       | 3.4 R_DTC_Control() Example |                                                               |
|      |                                       |                             | Added uint8_t interrupt_number;                               |
| 2.05 | Sep 30, 2016                          | 1                           | Added RX65N Group In Target Device                            |
|      |                                       | 2-3                         | Added the contents of sequence transfer to 1. Overview        |
|      |                                       | 4                           | 1.2.1 Overview of API                                         |
|      |                                       |                             | Added "R_DTC_CreateSeq()" to Table 1.1                        |
|      |                                       | 10                          | 1.2.2 Operating Environment and Memory Size                   |
|      |                                       |                             | Added (6)RX65N                                                |
|      |                                       | 12                          | 2.1 Hardware Requirements                                     |
|      |                                       |                             | Added DTCb                                                    |

| 2.05 | Sep 30, 2016 | 13            | 2.6 Compile Settings                                                                          |
|------|--------------|---------------|-----------------------------------------------------------------------------------------------|
|      |              |               | Added "#define DTC_CFG_USE_SEQUENCE_TRANSFER to                                               |
|      |              |               | the table                                                                                     |
|      |              | 14            | 2.7 Arguments                                                                                 |
|      |              |               | Added r_dtc_rx_target_if.h                                                                    |
|      |              | 14-15         | Divided the contents of 2.7 Arguments into 2.7.1 r_dtc_rx_if.h and 2.7.2 r_dtc_rx_target_if.h |
|      |              | 15            | 2.7.1 r_dtc_rx_if.h                                                                           |
|      |              |               | Added Structure dtc_command_t to the followings;                                              |
|      |              |               | DTC_CMD_SEQUENCE_TRANSFER_ENABLE                                                              |
|      |              |               | DTC_CMD_SEQUENCE_TRANSFER_DISABLE                                                             |
|      |              |               | DTC_CMD_SEQUENCE_TRANSFER_ABORT                                                               |
|      |              | 16            | 2.8 Return Values                                                                             |
|      |              |               | Added DTC_ERR_ACT                                                                             |
|      |              | 16            | 2.9 Adding FIT Module to Your Project                                                         |
|      |              |               | Changed the title from Adding Driver to Your Project                                          |
|      |              | 17            | 3.1 R_DTC_Open()                                                                              |
|      |              |               | Added the contents of Description DTC Index table                                             |
|      |              | 21            | 3.3 R_DTC_Create()                                                                            |
|      |              |               | Added the contents of DTCb to Data structure                                                  |
|      |              |               | dtc_transfer_data_cfg_t                                                                       |
|      |              | 23            | 3.3 R_DTC_Create()                                                                            |
|      |              |               | Added the following data structure;                                                           |
|      |              |               | dtc_write_back_t, dtc_sequence_end_t,                                                         |
|      |              | 20 24         | dtc_refer_index_table_t, dtc_disp_add_t                                                       |
|      |              | 29 - 34<br>35 | Added 3.4 R_DTC_CreateSeq()                                                                   |
|      |              | 33            | 3.5 R_DTC_Control() Return Values Added DTC_ERR_ACT                                           |
|      |              | 36            | 3.5 R_DTC_Control() Description                                                               |
|      |              | 30            | Added the table                                                                               |
|      |              | 37 -39        | 3.5 R_DTC_Control()                                                                           |
|      |              | 37 -39        | Revised the contents of Example                                                               |
| 2.06 | Jan 31, 2017 | 10            | 1.2.2 Operating Environment and Memory Size                                                   |
| 00   | 0an 01, 2017 | 10            | Updated Table 1.12 and Table 1.13.                                                            |
|      |              | 20 - 21       | 3.3 R_DTC_Create() Parameters                                                                 |
|      |              | 20 21         | Added the explanation.                                                                        |
|      |              | 29            | 3.4 R_DTC_CreateSeq() Parameters                                                              |
|      |              | 20            | Added the explanation.                                                                        |
| 2.07 | Mar 31, 2017 |               | Changed the following chapter number.                                                         |
| 07   | Mai 01, 2017 |               | Moved 1.2.2 Operating Environment and Memory Sizes to 2.3                                     |
|      |              |               | Operating Environment, 2.8 Code Size and 4.1 Details of                                       |
|      |              |               | Operating Environment.                                                                        |
|      |              | 1             | Added RX24U Group in Target Device                                                            |
|      |              | 4             | Added 1.3. DTC IP Version.                                                                    |
|      |              | 5             | 1.4 Related Application Note                                                                  |
|      |              |               | Revised the contents                                                                          |
|      |              | 37            | Added 4. Appendix                                                                             |

| 0.00 | 1.1.04.0047  |         | Marrad tha fallarida a abantan agustanta                |
|------|--------------|---------|---------------------------------------------------------|
| 2.08 | Jul 31, 2017 | -       | Moved the following chapter contents.                   |
|      |              |         | Moved from 1. Overview to 1.2 Overview of APIs          |
|      |              |         | Changed the following chapter number.                   |
|      |              |         | Changed form 2.3 Operating Environment to 5.1 Operating |
|      |              |         | Confirmation environment                                |
|      |              |         | Changed form 4. Appendix to 5. Appendices               |
|      |              |         | Changed form 5. Reference Documents to 6. Reference     |
|      |              |         | Documents                                               |
|      |              |         | Added the following chapter.                            |
|      |              |         | Added 2.4 Interrupt vector usage                        |
|      |              |         | Added 2.12 Adding FIT Module to your Project            |
|      |              |         | Added 5.2 Troubleshooting                               |
|      |              | 1       | Added RX651 Group in Target Device                      |
|      |              | 7       | Deleted "r_cgc_rx" of 2.2 Software Requirements.        |
|      |              | 31 - 35 | 3.5 R_DTC_Control()                                     |
|      |              |         | Added new command                                       |
|      |              |         | "DTC_CMD_CHANGING_DATA_FORCIBLY_SET".                   |
| 2.10 | Sep 28, 2018 | 1,5     | Added support for RX66T.                                |
|      |              | 8       | Added code size corresponding to RX66T                  |
|      |              | 40      | 5.1 Confirmed Operation Environment:                    |
|      |              |         | Added Table for Rev.2.10                                |
| 2.20 | Feb 01, 2019 | 1       | Added RX72T Group in Target Device                      |
|      |              | 5       | Added RX72T Group to DTC IP version section             |
|      |              | 9       | Added code size corresponding to RX72T                  |
|      |              | 16-39   | Removed 'Reentrant' description in each API function.   |
|      |              | 38      | Updated Special notes of R_DTC_Control() function       |
|      |              | 41      | Changed Renesas Starter Kit for RX66T Product No        |
|      |              | 41      | 6.1 Confirmed Operation Environment:                    |
|      |              |         | Added Table for Rev.2.20                                |

### General Precautions in the Handling of Microprocessing Unit and Microcontroller Unit Products

The following usage notes are applicable to all Microprocessing unit and Microcontroller unit products from Renesas. For detailed usage notes on the products covered by this document, refer to the relevant sections of the document as well as any technical updates that have been issued for the products.

#### 1. Handling of Unused Pins

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

— The input pins of CMOS products are generally in the high-impedance state. In operation with an unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of LSI, an associated shoot-through current flows internally, and malfunctions occur due to the false recognition of the pin state as an input signal become possible. Unused pins should be handled as described under Handling of Unused Pins in the manual.

#### 2. Processing at Power-on

The state of the product is undefined at the moment when power is supplied.

- The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the moment when power is supplied.
   In a finished product where the reset signal is applied to the external reset pin, the states of pins are not guaranteed from the moment when power is supplied until the reset process is completed.
   In a similar way, the states of pins in a product that is reset by an on-chip power-on reset function are not guaranteed from the moment when power is supplied until the power reaches the level at which resetting has been specified.
- 3. Prohibition of Access to Reserved Addresses

Access to reserved addresses is prohibited.

— The reserved addresses are provided for the possible future expansion of functions. Do not access these addresses; the correct operation of LSI is not guaranteed if they are accessed.

#### 4. Clock Signals

After applying a reset, only release the reset line after the operating clock signal has become stable. When switching the clock signal during program execution, wait until the target clock signal has stabilized.

— When the clock signal is generated with an external resonator (or from an external oscillator) during a reset, ensure that the reset line is only released after full stabilization of the clock signal. Moreover, when switching to a clock signal produced with an external resonator (or by an external oscillator) while program execution is in progress, wait until the target clock signal is stable.

### 5. Differences between Products

Before changing from one product to another, i.e. to a product with a different part number, confirm that the change will not lead to problems.

— The characteristics of Microprocessing unit or Microcontroller unit products in the same group but having a different part number may differ in terms of the internal memory capacity, layout pattern, and other factors, which can affect the ranges of electrical characteristics, such as characteristic values, operating margins, immunity to noise, and amount of radiated noise. When changing to a product with a different part number, implement a system-evaluation test for the given product.

#### Notice

- criptions 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 resp the incorporation or any other use of the circuits, software, and information in the design of your product or system. Renesas Electronics disclaims any and all liability for any losses and damages incurred by you or third parties arising from the use of these circuits, software, or information
- 2. Renesas Electronics hereby expressly disclaims any warranties against and liability for infringement or any other claims involving 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, including but not limited to, the product data, drawings, charts, programs, algorithms, and application
- 3. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 4. You shall not alter, modify, copy, or reverse engineer any Renesas Electronics product, whether in whole or in part. Renesas Electronics disclaims any and all liability for any losses or damages incurred by you or third parties arising from such alteration, modification, copying or reverse engineering.
- 5. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The intended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below.
  - Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment: industrial robots: etc.

"High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control (traffic lights); large-scale communication equipment; key financial terminal systems; safety control equipment; etc. Unless expressly designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not intended or authorized for use in products or systems that may pose a direct threat to human life or bodily injury (artificial life support devices or systems; surgical implantations; etc.), or may cause serious property damage (space system; undersea repeaters; nuclear power control systems; aircraft control systems; key plant systems; military equipment; etc.). Renesas Electronics disclaims any and all liability for any damages or losses incurred by you or any third parties arising from the use of any Renesas Electronics product that is inconsistent with any Renesas Electronics data sheet, user's manual or other Renesas Electronics document.

- 6. When using Renesas Electronics products, refer to the latest product information (data sheets, user's manuals, application notes, "General Notes for Handling and Using Semiconductor Devices" in the reliability handbook, etc.), and ensure that usage conditions are within the ranges specified by Renesas Electronics with respect to maximum ratings, operating power supply voltage range, heat dissipation characteristics, installation, etc. Renesas Electronics disclaims any and all liability for any malfunctions, failure or accident arising out of the use of Renesas Electronics products outside of such specified
- 7. Although Renesas Electronics endeavors to improve the quality and reliability of Renesas Electronics products, semiconductor products have specific characteristics, such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Unless designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not subject to radiation resistance design. You are responsible for implementing safety measures to guard against the possibility of bodily injury, injury or damage caused by fire, and/or danger to the public in the event of a failure or malfunction of Renesas Electronics products, 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 and impractical, you are responsible for evaluating the safety of the final products or systems manufactured by you.
- 8. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. You are responsible for carefully and sufficiently investigating applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive, and using Renesas Electronics products in compliance with all these applicable laws and regulations. Renesas Electronics disclaims any and all liability for damages or losses occurring as a result of your noncompliance with applicable aws and regulations
- 9. Renesas Electronics products and technologies shall not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations. You shall comply with any applicable export control laws and regulations promulgated and administered by the governments of any countries asserting jurisdiction over the parties or transactions.
- 10. It is the responsibility of the buyer or distributor of Renesas Electronics products, or any other party who distributes, disposes of, or otherwise sells or transfers the product to a third party, to notify such third earty in advance of the contents and conditions set forth in this document
- 11. This document shall not be reprinted, 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
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its directly or indirectly controlled subsidiaries.

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

(Rev.4.0-1 November 2017)



#### SALES OFFICES

### Renesas Electronics Corporation

http://www.renesas.com

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

Renesas Electronics Corporation TOYOSU FORESIA, 3-2-24 Toyosu, Koto-ku, Tokyo 135-0061, Japan

Renesas Electronics America Inc. 1001 Murphy Ranch Road, Milpitas, CA 95035, U.S.A. Tel: +1-408-432-8888, Fax: +1-408-434-5351

Renesas Electronics Canada Limited 9251 Yonge Street, Suite 8309 Richmond Hill, Ontario Canada L4C 9T3 Tel: +1-905-237-2004

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

Renesas Electronics Europe GmbH

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

Renesas Electronics (China) Co., Ltd.
Room 1709 Quantum Plaza, No.27 ZhichunLu, Haidian District, Beijing, 100191 P. R. China Tel: +86-10-8235-1155, Fax: +86-10-8235-7679

Renesas Electronics (Shanghai) Co., Ltd. Unit 301, Tower A, Central Towers, 555 Langae Road, Putuo District, Shanghai, 200333 P. R. China Tel: +86-21-2226-0888, Fax: +86-21-2226-0999

Renesas Electronics Hong Kong Limited

Unit 1601-1611, 16IF., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong Tel: +852-2265-6688, Fax: +852 2886-9022

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

Renesas Electronics Singapore Pte. Ltd.
80 Bendemeer Road, Unit #06-02 Hyflux Innovation Centre, Singapore 339949
Tel: +65-6213-0200, Fax: +65-6213-0300

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

Renesas Electronics India Pvt. Ltd. No.777C, 100 Feet Road, HAL 2nd Stage, Ind Tel: +91-80-67208700, Fax: +91-80-67208777 Indiranagar, Bangalore 560 038, India

Renesas Electronics Korea Co., Ltd. 17F, KAMCO Yangjae Tower, 262, Gangnam-daero, Gangnam-gu, Seoul, 06265 Korea Tel: +82-2-558-3737, Fax: +82-2-558-5338