最近用到了RA6M芯片的DTC功能,调试时发现串口 一直再发数据,反复确认配置的生成的代码没有问题,最终发现是硬件上的接收脚上拉电平的问题,原本应为3.3v,实际上拉为1.8V。将其飞线到3.3V问题解决。至于硬件上为什么会影响到DTC的功能,留待后续深入。
另外,DTC和DMA很类似,都不需要CPU参与处理,由硬件自动完成。区别:DTC的寄存器映射到一片RAM区,CPU无法直接访问,只能通过这片ram间接操作。
比如串口7的发送信息句柄transfor7info(0X1FFE0204)存储在DTC的RAM区0x1ffe0000上,
地址 -----------------值
0x1ffe0204的值为0x08000000对应 MRA.SM为2
ox1ffe0208-------- 0x1ffe13ac 对应 SAR 源发送数据的起始地址
0x1ffe020c--------0x400700ef对应DAR目标发送地址(其实是串口7发送寄存器地址)
每一路DTC占16个BYTE。共96路。