# M4G Group (1) Application Note High-Speed DMA Controller (HDMAC-A) Memory to Memory

## **Outlines**

This application note is a reference material for developing products that the function of transferring data from the memory to the memory using the high speed DMA controller (HDMAC) of the M4G group (1). This document helps the user check operation of the product and develop its program.

Target sample program: HDMA\_MEM\_MEM



# **Table of Contents**

| Outlines                                    | 1  |
|---------------------------------------------|----|
| Table of Contents                           | 2  |
| 1. Preface                                  | 3  |
| 2. Reference Document                       | 4  |
| 3. Function to Use                          | 4  |
| 4. Target Device                            | 4  |
| 5. Operation Confirmation Condition         | 5  |
| 6. Evaluation Board Setting                 | 6  |
| 7. Operation of Evaluation Board            | 6  |
| 8. Outline of HDMAC function                | 7  |
| 9. Sample Program                           | 8  |
| 9.1. Initialization                         | 8  |
| 9.2. Sample Program Main Operation          | 8  |
| 9.3. HDMA_MEM_MEM Setting                   | 8  |
| 9.4. Output Example of Sample Program       | 9  |
| 9.4.1. Setting Example of Terminal Software | 9  |
| 9.5. Operating Flow of Sample Program       | 10 |
| 10. Precaution                              | 25 |
| 11. Revision History                        | 25 |
| RESTRICTIONS ON PRODUCT USE                 | 26 |

## 1. Preface

This sample program is used to check the operation of the HDMAC function which transfers data between memories.

The program transfers reception data directly between a memory and another memory. The CPU is not used for the data transfer.

Structure diagram of Sample program





## 2. Reference Document

Datasheet

TMPM4G Group (1) datasheet Rev1.0 (Japanese edition)

Reference manual

High Speed DMA Controller (HDMAC-A) Rev1.0 (Japanese edition)

Asynchronous Serial Communication Circuit (UART-C) Rev3.0 (Japanese edition)

Application Note

M4G Group (1) Application Note Startup (CMSIS System & Clock Configuration) Rev1.0

Other reference document

TMPM4G(1) Group Peripheral Driver User Manual (Doxygen)

## 3. Function to Use

| IP                    | Channel        | Port          | Function/Operation mode        |
|-----------------------|----------------|---------------|--------------------------------|
| High Speed DMA        | ch0 (transfer) | -             | Data transfer between memories |
| Controller            | ch0 (request)  |               | Single transfer                |
| Asynchronous Serial   | ch0            | PE2 (UT0RXD)  | UART mode                      |
| Communication Circuit |                | PE3 (UT0TXDA) |                                |

# 4. Target Device

The target devices of this application note are as follows;

| TMPM4G9F15FG  | TMPM4G9F10FG  | TMPM4G9FEFG  | TMPM4G9FDFG  |
|---------------|---------------|--------------|--------------|
| TMPM4G9F15XBG | TMPM4G9F10XBG | TMPM4G9FEXBG | TMPM4G9FDXBG |
| TMPM4G8F15FG  | TMPM4G8F10FG  | TMPM4G8FEFG  | TMPM4G8FDFG  |
| TMPM4G8F15XBG | TMPM4G8F10XBG | TMPM4G8FEXBG | TMPM4G8FDXBG |
|               | TMPM4G7F10FG  | TMPM4G7FEFG  | TMPM4G7FDFG  |
|               | TMPM4G6F10FG  | TMPM4G6FEFG  | TMPM4G6FDFG  |

<sup>\*</sup>This sample program operates on the evaluation board of TMPM4G9F15FG.

If other function than the TMPM4G9F15 one is checked, it is necessary that CMSIS Core related files (C startup file and I/O header file) should be changed properly.

The BSP related file is dedicated to the evaluation board (TMPM4G9F15). If other function than the TMPM4G9F15 one is checked, the BSP related file should be changed properly.

2018-11-30 **4 / 26** Rev 1.0



# 5. Operation Confirmation Condition

Used microcontroller Used board Unified development environment Unified development environment Terminal software Sample program TMPM4G9F15FG
TMPM4G9F15FG Evaluation Board by Sensyst
IAR Embedded Workbench for ARM 8.11.2.13606
µVision MDK Version 5.24.2.0
Tera Term V4.96
V1000

Evaluation board (TMPM4G9F15FG Evaluation Board) Top view



# 6. Evaluation Board Setting

The following pin connections should be done on the evaluation board.

|                     | CN5              |                  |
|---------------------|------------------|------------------|
| Board function      | Through-hole No. | Through-hole No. |
| USB UART conversion | 1: USB_UT_RX     | 2: PE2           |
| USB UART conversion | 3: USB_UT_TX     | 4: PE3           |



# 7. Operation of Evaluation Board

PC and the USB\_UART are connected for communication with the terminal software. An arbitrary character should be input to the terminal software.

After the input data is transferred from a memory to another memory, it is output to the terminal software through the UART interface.



# 8. Outline of HDMAC function

The functions of HDMAC per unit are shown in the following table.

| Function category | Function                                   | Description                                                                                                                                                                                                                       |  |
|-------------------|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Transfer request  | Peripheral function                        | Transfer request from a peripheral device (Single transfer request/Burst transfer request)                                                                                                                                        |  |
|                   | Software                                   | Transfer request by software (Single transfer request/Burst transfer request)                                                                                                                                                     |  |
|                   | Request channel                            | 16 channels (Transfer request count by peripheral devices)                                                                                                                                                                        |  |
|                   | Single transfer                            | Data transfer is executed once.                                                                                                                                                                                                   |  |
| Transfer<br>mode  | Burst transfer                             | Data transfer is executed once or multiple times Burst size: 1, 4, 8, 16, 32, 64, 128, and 256 beats Continuous data transfer of the specified burst count is possible without releasing the bus using the lock transfer setting. |  |
|                   | Chain transfer                             | Continuous data transfer is possible using discontinuous addresses according to Linked List Item (LLI).                                                                                                                           |  |
| Transfer type     | Transfer source -><br>Transfer destination | Peripheral device (Register) -> Memory Peripheral device (Register) -> Peripheral device (Register) Memory -> Peripheral device (Register) Memory -> Memory (start up by only software)                                           |  |
|                   | Transfer channel                           | 2 channels (ch 0 and ch 1)                                                                                                                                                                                                        |  |
|                   | Transfer address                           | Addresses of the transfer source and destination are set. Selection of the increment of the address or fixed address for either the transfer source or destination.                                                               |  |
| Transfer control  | Transfer data size                         | 8 bits, 16 bits, or 32 bits The sizes of the transfer source and destination can be set independently.                                                                                                                            |  |
|                   | Priority                                   | ch 0 > ch 1 (Fixed in the unit.) Unit A > Unit B (For the integrated units, refer to "Product Information".)                                                                                                                      |  |
|                   | FIFO                                       | 4 Words x 2 ch (1 Word = 32 bits)                                                                                                                                                                                                 |  |
| Transfer count    | Transfer count                             | 4095 at maximum Infinite count transfers can be done using LLI.                                                                                                                                                                   |  |
| Endian            | Little endian                              | -                                                                                                                                                                                                                                 |  |
| Interrupt         | Transfer completion interrupt              | Transfer completion interrupt (INTHDMACxTC) is generated when a transfer completes.                                                                                                                                               |  |
|                   | Error interrupt                            | Error interrupt (INTHDMACxERR) is generated when a bus error or a memory protection error is detected during data transfer.                                                                                                       |  |



## 9. Sample Program

The data received from the terminal software is transferred from a memory to another memory using the HDMAC.

The transferred data is output to the terminal software through the UART interface.

#### 9.1. Initialization

The following initialization is done after power is supplied.

The initialization of each clock setting and the setting of the watchdog timer are done.

## 9.2. Sample Program Main Operation

BSP initialization is done.

Driver initialization is done.

Application initialization is done.

HDMA setting is done.

The HDMA transfer end interrupt and the HDMA transfer error interrupt are enabled.

The message which requests a user to input appropriate data to the terminal software is issued.

The sample program waits for data transmitted by the terminal software.

When a character is input to the terminal software, the input data is received through the UART interface.

The received data is stored in a memory and it is copied to another memory. Then the data is output to the terminal software through the UART interface.

If the input character exceeds 32 byte (including a line feed code), an input error is output to the terminal software.

## 9.3. HDMA\_MEM\_MEM Setting

The transfer channel in the sample program can be changed using the following parameter; CFG\_DMA\_CH in "main.c" should be modified.

The priority of the transfer control is ch 0 > ch 1.

When transferring a lot of data in "memory to memory", we recommend using a transfer channel with low priority. If you use a transfer channel with a higher priority, you can not start transferring a transfer channel with a lower priority until the transfer ends.



## 9.4. Output Example of Sample Program

When the sample program is executed, the transfer result done by the HDMAC is output shown as follows;



## 9.4.1. Setting Example of Terminal Software

The operation of the terminal software (Tera Term) has been checked with the following settings.





# 9.5. Operating Flow of Sample Program

The basic operating flows of the sample program are shown in the following;







The 32-bit timer event counter of TMPM4G9 is running, but processing using timer count is not performed.















































# 10. Precaution

When using the sample program with CPU other than TMPM4G9F15, please check operation sufficiently.

# 11. Revision History

| Rev | Date       | Description   |
|-----|------------|---------------|
| 1.0 | 2018-11-30 | First release |



#### **RESTRICTIONS ON PRODUCT USE**

Toshiba Corporation and its subsidiaries and affiliates are collectively referred to as "TOSHIBA". Hardware, software and systems described in this document are collectively referred to as "Product".

- · TOSHIBA reserves the right to make changes to the information in this document and related Product without notice.
- This document and any information herein may not be reproduced without prior written permission from TOSHIBA. Even with TOSHIBA's written permission, reproduction is permissible only if reproduction is without alteration/omission.
- Though TOSHIBA works continually to improve Product's quality and reliability, Product can malfunction or fail. Customers are responsible for complying with safety standards and for providing adequate designs and safeguards for their hardware, software and systems which minimize risk and avoid situations in which a malfunction or failure of Product could cause loss of human life, bodily injury or damage to property, including data loss or corruption. Before customers use the Product, create designs including the Product, or incorporate the Product into their own applications, customers must also refer to and comply with (a) the latest versions of all relevant TOSHIBA information, including without limitation, this document, the specifications, the data sheets and application notes for Product and the precautions and conditions set forth in the "TOSHIBA Semiconductor Reliability Handbook" and (b) the instructions for the application with which the Product will be used with or for. Customers are solely responsible for all aspects of their own product design or applications, including but not limited to (a) determining the appropriateness of the use of this Product in such design or applications; (b) evaluating and determining the applicability of any information contained in this document, or in charts, diagrams, programs, algorithms, sample application circuits, or any other referenced documents; and (c) validating all operating parameters for such designs and applications. TOSHIBA ASSUMES NO LIABILITY FOR CUSTOMERS' PRODUCT DESIGN OR APPLICATIONS.
- PRODUCT IS NEITHER INTENDED NOR WARRANTED FOR USE IN EQUIPMENTS OR SYSTEMS THAT REQUIRE EXTRAORDINARILY
  HIGH LEVELS OF QUALITY AND/OR RELIABILITY, AND/OR A MALFUNCTION OR FAILURE OF WHICH MAY CAUSE LOSS OF
  HUMAN LIFE, BODILY INJURY, SERIOUS PROPERTY DAMAGE AND/OR SERIOUS PUBLIC IMPACT ("UNINTENDED USE"). Except for
  specific applications as expressly stated in this document, Unintended Use includes, without limitation, equipment used in nuclear facilities,
  equipment used in the aerospace industry, lifesaving and/or life supporting medical equipment, equipment used for automobiles, trains, ships
  and other transportation, traffic signaling equipment, equipment used to control combustions or explosions, safety devices, elevators and
  escalators, and devices related to power plant. IF YOU USE PRODUCT FOR UNINTENDED USE, TOSHIBA ASSUMES NO LIABILITY FOR
  PRODUCT. For details, please contact your TOSHIBA sales representative or contact us via our website.
- Product shall not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable laws or regulations.
- The information contained herein is presented only as guidance for Product use. No responsibility is assumed by TOSHIBA for any
  infringement of patents or any other intellectual property rights of third parties that may result from the use of Product. No license to any
  intellectual property right is granted by this document, whether express or implied, by estoppel or otherwise.
- ABSENT A WRITTEN SIGNED AGREEMENT, EXCEPT AS PROVIDED IN THE RELEVANT TERMS AND CONDITIONS OF SALE FOR
  PRODUCT, AND TO THE MAXIMUM EXTENT ALLOWABLE BY LAW, TOSHIBA (1) ASSUMES NO LIABILITY WHATSOEVER,
  INCLUDING WITHOUT LIMITATION, INDIRECT, CONSEQUENTIAL, SPECIAL, OR INCIDENTAL DAMAGES OR LOSS, INCLUDING
  WITHOUT LIMITATION, LOSS OF PROFITS, LOSS OF OPPORTUNITIES, BUSINESS INTERRUPTION AND LOSS OF DATA, AND (2)
  DISCLAIMS ANY AND ALL EXPRESS OR IMPLIED WARRANTIES AND CONDITIONS RELATED TO SALE, USE OF PRODUCT, OR
  INFORMATION, INCLUDING WARRANTIES OR CONDITIONS OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE,
  ACCURACY OF INFORMATION, OR NONINFRINGEMENT.
- Do not use or otherwise make available Product or related software or technology for any military purposes, including without limitation, for the
  design, development, use, stockpiling or manufacturing of nuclear, chemical, or biological weapons or missile technology products (mass
  destruction weapons). Product and related software and technology may be controlled under the applicable export laws and regulations
  including, without limitation, the Japanese Foreign Exchange and Foreign Trade Law and the U.S. Export Administration Regulations. Export
  and re-export of Product or related software or technology are strictly prohibited except in compliance with all applicable export laws and
  regulations.
- Please contact your TOSHIBA sales representative for details as to environmental matters such as the RoHS compatibility of Product. Please
  use Product in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without
  limitation, the EU RoHS Directive. TOSHIBA ASSUMES NO LIABILITY FOR DAMAGES OR LOSSES OCCURRING AS A RESULT OF
  NONCOMPLIANCE WITH APPLICABLE LAWS AND REGULATIONS.

## TOSHIBA ELECTRONIC DEVICES & STORAGE CORPORATION

https://toshiba.semicon-storage.com/

2018-11-30 **26 / 26** Rev 1.0