# Customer training workshop: Device Configurator\_DMA TRAVEO<sup>™</sup> T2G CYT4BF series Microcontroller Training V1.0.0 2022-12 # Scope of work - This document helps application developers understand how to use the Device Configurator DMA as part of creating a ModusToolbox™ (MTB) application - The Device Configurator DMA is part of a collection of tools included with the MTB software. It provides configuration of the DMA channel and transaction descriptors. - › ModusToolbox™ tools package version: 3.0.0 - Device Configurator version: 4.0 - Device - The TRAVEO<sup>™</sup> T2G CYT4BFBCH device is used in this code example. - Board - The TRAVEO<sup>™</sup> T2G KIT\_T2G-B-H\_EVK board is used for testing. ## Introduction # → TRAVEO™ T2G has two types of DMA : - Peripheral DMA (P-DMA) - Memory DMA (M-DMA) # > P-DMA has the following features: - Focuses on achieving low latency for a large number of channels. - Focuses on peripheral-to-memory and memory-to-peripheral data transfers (but it can also perform memory-to-memory data transfers). - Uses a single data transfer engine that is shared by all channels. - A descriptor specifies the following data transfer specifications: - The source and destination address locations and the size of the transfer. - The actions of a channel; for example, generation of output triggers and interrupts. - Data transfer types: single, 1D, 2D, or CRC as defined in the descriptor structure. These types essentially define the address sequences generated for source and destination - It is called DMA DataWire in this document # Introduction (contd.) # M-DMA has the following features: - Focuses on achieving high memory bandwidth for a small number of channels. - Focuses on memory-to-memory data transfers (but it can also perform peripheral-to-memory and memory-to-peripheral data transfers). - Uses a dedicated data transfer engine for each channel. - A descriptor specifies the following data transfer specifications: - The source and destination address locations and the size of the transfer. - The actions of a channel; for example, generation of output triggers and interrupts. - Data transfer types can be single, 1D, or 2D as defined in the descriptor structure. These types essentially define the address sequences generated for source and destination. 1D and 2D transfers are used for "scatter gather" and other useful transfer operations. - It is called DMA Controller in this document # From Eclipse IDE - You can launch the Device Configurator by either method a) or b) - a) Right-click on the project in the Project Explorer and select ModusToolbox™ > Device Configurator <version> b) Click the Device Configurator link in the Quick Panel # Device Configurator DMA On the DMA tab, you can select and configure each DMA channel ## Quick start # To use the DMA Device Configurator for DMA setting - Launch the Device Configurator. - Check the DMA channels to use - Select the parameter from the various pull-down menus to configure signals. - The DMA Device Configurator generates code into a "GeneratedSource" directory in your Eclipse IDE application, or in the same location you saved the \*.modus file for non-IDE applications. That directory contains the necessary source (.c) and header (.h) files for the generated firmware, which uses the relevant driver APIs to configure the hardware. - Use the generated structures as input parameters for DMA functions in your application. ## Use case - This use case uses two DMA channels: txDma and rxDma - txDma initiates transfer by a SCB2 transmit request event, and rxDma initiates transfer by a SCB8 receive event - txDma - DMA DataWire#1 channel 20 - In the first event, data of tx\_buff (A) in RAM is transferred to the SCB2 Tx FIFO. In the second event, data of tx\_buff (B) in RAM is transferred to the SCB2 Tx FIFO. In the third event, data of tx\_buff (A) in RAM is transferred again. - Transfer size: Source byte / Destination word - Descriptor type: 1D transfer - Transfer count: 12 - rxDma - DMA DataWire#1 channel 33 - In first receive event, data of SCB8 RX FIFO is transferred to the rx\_buff (A) in RAM. In second event, data of SCB8 RX FIFO is transferred to the data of rx\_buff (B) in RAM. In the third event, the data is transferred to rx\_buff (A) in RAM again. - Transfer size: Source word / Destination byte - Descriptor type: 1D transfer - Transfer count: 12 - See the SCB\_SPI\_Master\_DMA application for operation # DMA configuration # Create project Click New Application in Quick Panel and open the Choose Board Support Package (BSP) window - 2) Select TRAVEO™ BSPs and KIT\_T2G-B-H\_EVK - 3) Click the **Next** button and open the Application window - 4) Check the Empty App option. In this use case, change the application name to DMA\_training. - 5) Click the **Create** button to start application creation # > Launch the Device Configurator - 1) Select the **DMA\_training** project. - 2) Click the Device Configurator in the Quick Panel - 3) Then, open the Device configurator window # Configure txDMA # Configure rxDMA # Configure peripheral for DMA trigger When the trigger is selected from the peripheral, it is automatically linked to the target peripheral When the input trigger is set in the DMA configuration, peripheral configuration is required. If the peripheral is not valid, it will be displayed as follows. # DMA configuration (contd.) # Confirm configuration result You can check the configuration result in the "Code Preview" tab of the Device Configurator #### txDma #### Code Preview Enter search text #define txDma HW DW1 #define txDma CHANNEL 20U #define txDma IRQ cpuss interrupts dw1 20 IRQn const cy stc dma descriptor config t txDma Descriptor 0 config = .retrigger = CY DMA RETRIG 4CYC, .interruptType = CY DMA DESCR, .triggerOutType = CY DMA 1ELEMENT, .channelState = CY DMA CHANNEL DISABLED. .triggerInType = CY DMA 1ELEMENT, .dataSize = CY DMA BYTE, .srcTransferSize = CY DMA TRANSFER SIZE DATA, .dstTransferSize = CY DMA TRANSFER SIZE WORD, .descriptorType = CY DMA 1D TRANSFER, .srcAddress = NULL. .dstAddress = NULL. .srcXincrement = 1. .dstXincrement = 0. .xCount = 12. .srcYincrement = 0. .dstYincrement = 0, .yCount = 1, .nextDescriptor = &txDma Descriptor 0, CY\_ALIGN(32) cy\_stc\_dma\_descriptor\_t txDma Descriptor 0 = .src = OUL, .dst = OUL. .xCtl = OUL, .yCtl = OUL, .nextPtr = OUL, const cy stc dma channel config t txDma channelConfig = descriptor = EtyDms Descriptor A DMA DataWire 1: Channel 20 (txDma) - Parameters Code Preview #### <u>rxDma</u> ``` Code Preview Enter search text. #define rxDma HW DW1 #define rxDma CHANNEL 33U #define rxDma IRQ cpuss interrupts dw1 33 IRQn const cy stc dma descriptor config t rxDma Descriptor 0 config = .retrigger = CY DMA RETRIG IM, .interruptType = CY DMA DESCR, .triggerOutType = CY DMA 1ELEMENT, .channelState = CY DMA CHANNEL DISABLED, .triggerInType = CY_DMA_1ELEMENT, .dataSize = CY_DMA_BYTE, .srcTransferSize = CY DMA TRANSFER SIZE WORD, .dstTransferSize = CY DMA TRANSFER SIZE DATA, .descriptorType = CY DMA 1D TRANSFER, .srcAddress = NULL. .dstAddress = NULL. .srcXincrement = 0. .dstXincrement = 1. .xCount = 12. .srcYincrement = 0. .dstYincrement = 0, .yCount = 1, .nextDescriptor = &rxDma Descriptor 0, CY_ALIGN(32) cy_stc_dma_descriptor_t rxDma_Descriptor_0 = .ctl = OUL. .src = OUL, .dst = OUL, .xCtl = OUL. .vCtl = OUL. .nextPtr = OUL. const cy stc dma channel config t rxDma channelConfig = descriptor = EryDma Descriptor DMA DataWire 1: Channel 33 (rxDma) - Paramete Code Preview Code preview tab ``` 14 ## Close Device configurator Click the Save button after completing all the settings, then close the Device configurator If an Errors/Tasks message appears, it should be resolved according to the instructions # DMA configuration (contd.) # Configuration file The DMA Configurator generates code into a "GeneratedSource" directory in your Eclipse IDE application, or in the same location you saved the \*.modus file for non-IDE applications. This example has the following code: ``` #include "cycfg dmas.h"↓ const cy stc dma descriptor config t txDma Descriptor O config = 1 .retrigger = CY DMA RETRIG 4CYC,↓ .interruptType = CY DMA DESCR, J .triggerOutType = C7 DMA IELEMENT,↓ .channelState = CY DMA CHANNEL DISABLED.↓ .triggerInType = CY DMA 1ELEMENT, .dataSize = CY DMA BYTE. ↓ .srcTransferSize = CY DMA TRANSFER SIZE DATA. J .dstTransferSize = CYTDMATRANSFERTSIZETWORD. .descriptorType = CY DMA TD TRANSFER.↓ .srcAddress = NULL.↓ .dstAddress = NULL .srcXincrement #if !defined(CYCFG DMAS H) \ .dstXincrement #define CYCFG DMAS H↓ .xCount = 12.↓ .srcYincrement #include "cycfg notices.h"↓ .dstYincrement #include "cy_dma.h"↓ #if defined (CY USING HAL)↓ .yCount = 1,↓ .nextDescriptor #include "cyhal hwmgr.h"↓ #endif //defined (CY USING HAL) + ALIGN(32) cy stc #if defined( cplusplus)↓ .ctl = OUL.↓ extern "C" {↓ .dst = OUL.↓ #endif↓ .xCtl = OUĹ.↓ .vCtl = OUL.↓ #define t×Dma ENABLED 1U↓ .nextPtr = OUL. #define t×Dma HW DW1↓ #define txDma CHANNEL 20U1 #define txDma_IRQ cpuss_interrupts_dw1_20_IRQn↓ #define r×Dma ENABLED 1Ū↓ #define r×Dma HW DW1↓ #define rxDma CHANNEL 33U+ #define rxDma_IRQ cpuss_interrupts_dw1_33_IRQn↓ ``` The structure generated by the Device Configurator can be used by implementing the following function in your application code. Add DMA initialization and enable function There is structure to configure TxDMA in the cycfg\_dmas.c file ``` main.c main.c ■ spi dma.c 🗵 Add Cy_DMA_Descriptor_Init() function /* Initialize descriptor dma init status = Cy DMA Descriptor Init(&txDma Descriptor 0, &txDma Descriptor 0 config) if (dma init_status!=CY_DMA_SUCCESS) return INIT_FAILURE; AddCy DMA Channel Init() function dma_init_status = Cy_DMA_Channel_Init(txDma_HW, txDma CHANNEL, &txDma channelConfig): if (dma init status:=CY DMA SUCCESS) Add Cy_DMA_Descriptor_SetSrcAddress() function return INIT_FAILURE; Add Cv DMA Descriptor SetDstAddress() function Cy DMA Descriptor SetSrcAddress(&txDma Descriptor 0, (uint8 t *)tx buffer); Cv DMA Descriptor SetDstAddress(&txDma Descriptor 0. (void *)&mSPI HW->TX FIFO WR): /* Initialize and enable the interrupt from TxDma */ Cy SysInt Init(&intTxDma cfg, &tx dma complete); NVIC EnableIRO((IROn Type) NvicMux2 IROn): Add Cv DMA Enable() function /* Enable DMA interrupt so Cy DMA Channel SetInterruptMask(txDma HW, txDma CHANNEL, CY DMA INTR MASK); /* Enable DMA block to start descriptor execution process */ Cy_DMA_Enable(txDma_HW); return INIT SUCCESS; ``` ``` #include "cycfg dmas.h"↓ const cy sto dma descriptor config txDma Descriptor O config .retrigger = CY DMA RETRIG 4CYC,↓ .interruptType = CY_DMA_DESCR,↓ .triggerOutType = C₹ DMĀ 1ELEMENT.↓ .channelState = CY DMA CHANNEL DISABLED.↓ .triggerInTvpe = CY DMA 1ELEMENT.↓ .dataSize = CY DMA BYTE,↓ .srcTransferSize = CY DMA TRANSFER SIZE DATA, J .dstTransferSize = CYDMATRANSFERSIZE WORD, J .descriptorType = CY DMA TD TRANSFER,↓ .srcAddress = NULL.↓ .dstAddress = NULL.↓ .srcXincrement = 1.↓ .dstXincrement = 0.↓ .xCount = 12.↓ .srcYincrement = 0.↓ .dstYincrement = 0.↓ .vCount = 1.↓ .nextDescriptor = &txDma Descriptor 0,↓ ``` #### **DMA** initialization - > Call the <a href="Cy\_DMA\_Descriptor\_Init(">Cy\_DMA\_Descriptor\_Init()</a> function to initialize the DMA descriptor - Configure DMA with the parameters in txDma\_Descriptor\_0 and txDma\_Descriptor\_0\_config structure for txDma - Configure DMA with the parameters in rxDma\_Descriptor\_0 and rxDma\_Descriptor\_0\_config structure for rxDma - > Call the <u>Cy\_DMA\_Channel\_Init()</u> function to initialize the DMA channel - Configure DMA with the parameters in txDma\_channelConfig structure for txDma - Configure DMA with the parameters in rxDma\_channelConfig structure for rxDma - Call the <u>Cy\_DMA\_Descriptor\_SetSrcAddress()</u> and <u>Cy\_DMA\_Descriptor\_SetDstAddress()</u> function to set the source and destination address of the DMA transfer - Source address sets to RAM (tx\_buffer), and destination address sets to TX FIFO of SCB2 - Source address sets to RX FIFO of SCB8, and destination address sets to RAM (rx\_buffer) #### DMA enable: Call the <u>Cy DMA Enable()</u> function to enable DMA #### Data transfer > Data transfer is initiated by serial communication send and receive events ## References #### **Datasheet** > CYT4BF datasheet 32-bit Arm® Cortex®-M7 microcontroller TRAVEO™ T2G family #### **Architecture Technical reference manual** > TRAVEO™ T2G automotive body controller high family architecture technical reference manual # **Registers Technical reference manual** > TRAVEO™ T2G Automotive body controller high registers technical reference manual ### PDL/HAL - > PDL - > HAL # **Training** > TRAVEO™ T2G Training | Revision | ECN | Submission Date | Description of Change | |----------|---------|-----------------|-----------------------| | ** | 7847414 | 2022/12/13 | Initial release | # Important notice and warnings All referenced product or service names and trademarks are the property of their respective owners. Edition 2022-12 Published by Infineon Technologies AG 81726 Munich, Germany © 2022 Infineon Technologies AG. All Rights Reserved. Do you have a question about this document? Go to: www.infineon.com/support Document reference 002-36715 Rev. \*\* #### IMPORTANT NOTICE The information given in this document shall in no event be regarded as a guarantee of conditions or characteristics ("Beschaffenheitsgarantie"). With respect to any examples, hints or any typical values stated herein and/or any information regarding the application of the product, Infineon Technologies hereby disclaims any and all warranties and liabilities of any kind, including without limitation warranties of non-infringement of intellectual property rights of any third party. In addition, any information given in this document is subject to customer's compliance with its obligations stated in this document and any applicable legal requirements, norms and standards concerning customer's products and any use of the product of Infineon Technologies in customer's applications. The data contained in this document is exclusively intended for technically trained staff. It is the responsibility of customer's technical departments to evaluate the suitability of the product for the intended application and the completeness of the product information given in this document with respect to such application. For further information on the product, technology, delivery terms and conditions and prices please contact your nearest Infineon Technologies office (www.infineon.com). #### WARNINGS Due to technical requirements products may contain dangerous substances. For information on the types in question please contact your nearest Infineon Technologies office. Except as otherwise explicitly approved by Infineon Technologies in a written document signed by authorized representatives of Infineon Technologies, Infineon Technologies' products may not be used in any applications where a failure of the product or any consequences of the use thereof can reasonably be expected to result in personal injury.