Skip to main content
Visitor II
April 24, 2025
Question

about gpdma transmission size

  • April 24, 2025
  • 3 replies
  • 716 views

I am porting code from G473 to U575 because I need more flash and ram.

Then I meet some issues on gpdma transmission size.

For G473, I use dma to transfer data to timer ARR likes:

uint16_t buf[65536] = { ..... };

HAL_TIM_Base_Start_DMA(&htim1, (uint32_t *)buf, 65536);

For U575, the code doesn't work because the size have to be 65536 * sizeof(uint16_t), not the number of buf.

Is there any way to figure it out?

    This topic has been closed for replies.

    3 replies

    Super User
    April 24, 2025

    The code presented cannot work, either at 65536 or at 65536 * sizeof(uint16_t).

     

    The CNDT register field is 16 bits and accept a maximum value of 65535.

    The HAL_TIM_Base_Start_DMA also accept a max value of 65535.

    /**
     * @brief Starts the TIM Base generation in DMA mode.
     * @PAram htim TIM Base handle
     * @PAram pData The source Buffer address.
     * @PAram Length The length of data to be transferred from memory to peripheral.
     * @retval HAL status
     */
    HAL_StatusTypeDef HAL_TIM_Base_Start_DMA(TIM_HandleTypeDef *htim, const uint32_t *pData, uint16_t Length)
    {

     

     

    dh_leslieAuthor
    Visitor II
    April 24, 2025

    Yes, you are right.

    Currently, I only use 16384 in G473. But I want to port code to U575 and use more buf in DMA.

    And I found the definition is different between G4 and U5 in DMA size.

    dh_leslieAuthor
    Visitor II
    April 25, 2025

    New question: How to configure linked list DMA to update TIM->ARR each time when Update Event generated?

    /**
     * @brief DMA Linked-list xFreqList configuration
     * None
     * @retval None
     */
    HAL_StatusTypeDef MX_xFreqList_Config(void)
    {
     HAL_StatusTypeDef ret = HAL_OK;
     /* DMA node configuration declaration */
     DMA_NodeConfTypeDef pNodeConfig;
    
     /* Set node configuration ################################################*/
     pNodeConfig.NodeType = DMA_GPDMA_LINEAR_NODE;
     pNodeConfig.Init.Request = GPDMA1_REQUEST_TIM15_UP;
     pNodeConfig.Init.BlkHWRequest = DMA_BREQ_SINGLE_BURST;
     pNodeConfig.Init.Direction = DMA_MEMORY_TO_PERIPH;
     pNodeConfig.Init.SrcInc = DMA_SINC_INCREMENTED;
     pNodeConfig.Init.DestInc = DMA_DINC_FIXED;
     pNodeConfig.Init.SrcDataWidth = DMA_SRC_DATAWIDTH_HALFWORD;
     pNodeConfig.Init.DestDataWidth = DMA_DEST_DATAWIDTH_HALFWORD;
     pNodeConfig.Init.SrcBurstLength = 1;
     pNodeConfig.Init.DestBurstLength = 1;
     pNodeConfig.Init.TransferAllocatedPort = DMA_SRC_ALLOCATED_PORT0|DMA_DEST_ALLOCATED_PORT1;
     pNodeConfig.Init.TransferEventMode = DMA_TCEM_BLOCK_TRANSFER;
     pNodeConfig.TriggerConfig.TriggerPolarity = DMA_TRIG_POLARITY_MASKED;
     pNodeConfig.DataHandlingConfig.DataExchange = DMA_EXCHANGE_NONE;
     pNodeConfig.DataHandlingConfig.DataAlignment = DMA_DATA_RIGHTALIGN_ZEROPADDED;
     pNodeConfig.SrcAddress = (uint32_t)TimerTable;
     pNodeConfig.DstAddress = (uint32_t)&(TIM15->ARR);
     pNodeConfig.DataSize = 4*2;
    
     /* Build FreqTimerTable1 Node */
     ret |= HAL_DMAEx_List_BuildNode(&pNodeConfig, &FreqTimerTable1);
    
     /* Insert FreqTimerTable1 to Queue */
     ret |= HAL_DMAEx_List_InsertNode_Tail(&xFreqList, &FreqTimerTable1);
    
     ret |= HAL_DMAEx_List_SetCircularMode(&xFreqList);
    
     return ret;
    }
     MX_xFreqList_Config();
     HAL_DMAEx_List_LinkQ(&handle_GPDMA1_Channel0, &xFreqList);
     HAL_DMAEx_List_Start(&handle_GPDMA1_Channel0);
     HAL_TIM_Base_Start(&htim15);

     

    Visitor II
    April 25, 2025

    Follow this ST video as a guide: https://youtu.be/jKOhRfb3gvk?si=xX4p7RoMXyTvPXEC

    dh_leslieAuthor
    Visitor II
    April 25, 2025

    I tried the code in the video. It works on ADC but not on Timer.

    Also I tried standard request mode dma with HAL_TIM_Base_Start_DMA. ARR was being updated.

    I am confused why it does not work with linked-list mode dma.

    dh_leslieAuthor
    Visitor II
    April 25, 2025
     uint16_t StartTable = 1;
     MX_xFreqQ_Config();
     HAL_DMAEx_List_LinkQ(&handle_GPDMA1_Channel0, &xFreqList);
     HAL_DMAEx_List_Start(&handle_GPDMA1_Channel0);
     HAL_TIM_Base_Start_DMA(&htim15, (uint32_t *)&StartTable, 2);

    Things are weird.

    I opened an other standard request mode dma for the same timer, and ran HAL_TIM_Base_Start_DMA. 

    Then the linked-list dma started working.

    I think maybe I need to set bit TIMx_EGR.UG to force ARR update, but it's not the key.

    Why? very confused.