最近用到了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路。
本文探讨了在使用RA6M芯片的DTC功能时遇到的串口数据持续发送问题,原因在于硬件接收脚的实际电平不匹配。作者揭示了DTC与DMA的区别,并详细解释了DTC的工作原理,特别是它如何通过RAM区域进行数据传输。博客还重点介绍了DTC寄存器的配置实例,包括SM、SAR和DAR地址。
2694

被折叠的 条评论
为什么被折叠?



