This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

[参考译文] TMS570LC4357:DMA 实现(存储器外设)

Guru**** 2693225 points

Other Parts Discussed in Thread: TMS570LC4357

请注意,本文内容源自机器翻译,可能存在语法或其它翻译错误,仅供参考。如需获取准确内容,请参阅链接中的英语原文或自行翻译。

https://e2e.ti.com/support/microcontrollers/arm-based-microcontrollers-group/arm-based-microcontrollers/f/arm-based-microcontrollers-forum/1596244/tms570lc4357-dma-implmentation-memory-pheripheral

器件型号: TMS570LC4357

请为 TMS570LC4357 中的存储器外设 (SCI3 TX) DMA 限制建议可配置输入

下面是我编写的所附示例代码

#if ((__little_endian _= 1)||(__little_ENDIAN__= 1))
#define SCI3_TX_ADDR ((uint32_t)(&(sciREG3->td))
#define SCI3_RX_ADDR ((uint32_t)(&(sciREG3->RD))
#define SCI4_TX_ADDR ((uint32_t)(&(sciREG4->td))
#define SCI4_RX_ADDR ((uint32_t)(&(sciREG4->RD))
#else
#define SCI3_TX_ADDR ((uint32_t)(&(sciREG3->td))+ 3)  // 0xFFF7E538 调试发送
#define SCI3_RX_ADDR ((uint32_t)(&(sciREG3->RD))+ 3)
#define SCI4_TX_ADDR ((uint32_t)(&(sciREG4->td))+ 3)
#define SCI4_RX_ADDR ((uint32_t)(&(sciREG4->RD))+ 3)
#endif

#define DMA_SCI3_TX DMA_REQ31  
#define DMA_SCI3_RX DMA_REQ30  
#define DMA_SCI4_TX DMA_REQ43  
#define DMA_SCI4_RX DMA_REQ42  

#define SCI_SET_TX_DMA   (1<<16)
#define SCI_SET_RX_DMA   (1<<17)
#define SCI_SET_RX_DMA_ALL (1<18)

 

 

void main()

  gioInit();                                   // GPIO 初始化
  rtiInit();                                   //计时器初始化
  hetInit();                                   //HET 初始化
  sciInit();                                   //串行初始化
  spiInit();                                   //该函数初始化 SPI 模块 — SPI4 用于通信//

 

    g_dmaCTRL ctrlPacket;

    /*加载源数据*/
    对于 (I=0;I<128;I++)
    {
      srcBuffer[i]= i;
    }

    ctrlPacket.Sadd  =(uint32) srcBuffer;    //源地址
    ctrlPacket.DADD  =(Uint32) SCI3_TX_ADDR;    //目标地址
    CtrlPacket.RDSIZE = ACCESS_32_BIT;       //读取大小
    CtrlPacket.WRSIZE = ACCESS_32_BIT;       //写入大小
    CtrlPacket.ADDMODERD= ADDR_INC1;         //递增源
    CtrlPacket.ADDMODEWR= ADDR_INC1;         //递增 Dest
    CtrlPacket.ELCNT  = 128;            // 128 个元素
    CtrlPacket.FRCNT  = 1;             // 1 帧
    ctrlPacket.tType  = frame_transfer;      //内存→内存
    CtrlPacket.PORTASGN = Porta_READ_PORTB_WRITE; //数据端口

    dmaSetCtrlPacket (DMA_CH0、ctrlPacket);
    dmaReqAssign (DMA_CH0、DMA_SCI3_TX);
    dmaSetChEnable (DMA_CH0、DMA_SW);

//    dmaEnable ();
//
    sciREG3->SETINT |= SCI_SET_TX_DMA;
    sciREG1->GCR1 |= 0x01;      //启用 SCI

 

}