找回密码
 立即注册

QQ登录

只需一步,快速开始

打印 上一主题 下一主题
开启左侧

NUC972 UART RX DMA 问题

[复制链接]
跳转到指定楼层
楼主
匿名  发表于 2021-5-27 23:09:35 回帖奖励 |倒序浏览 |阅读模式
目的: 用DMA 把串口9的接收数据放到一个数组代码:
                        CHAR buf[]={0x03,0x03,0x9C,0x4B,0x00,0x01};

                        outpw(REG_GDMA_CTL0, 0x0);
                        outpw(REG_GDMA_SRCB0,REG_UART9_RBR);//source
                        outpw(REG_GDMA_DSTB0,(uint32_t)DMARecBuf);//destination
                        outpw(REG_GDMA_TCNT0,7);

                        outpw(REG_GDMA_CTL0,(1<<7)  | (1<<16));
                        outpw(REG_GDMA_CTL0,inpw(REG_GDMA_CTL0)|1);

                        comSend(buf,6);
                       
                        while(!(inpw(REG_GDMA_INTCS) & 0x100));
                        outpw(REG_GDMA_INTCS,0x100);
问题点                bug = DMARecBuf[0]; //如果增加这一句代码后,就没有接收数据到DMARecBuf


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 顶 踩
回复

使用道具

沙发
arthur 发表于 2021-6-1 10:54:38 | 只看该作者
是楼主的 typo 吗?从上面看 GDMA使用的是 Channel 0, 最后却是 REG_GDMA_INTCS: 0x100 设置的是 Channel 1的中断?
回复 支持 反对

使用道具 举报

板凳
匿名  发表于 2021-6-2 20:38:57
Publication Release Date: Dec. 15, 2015
- 321 - Revision V1.30
NUC970 TECHNICAL REFERENCE MANUAL
[8] TC0F
Channel 0 Terminal Count
0 = Channel does not expire.
1 = Channel expires; this bit is set only by GDMA hardware, and clear by software to
write logic 1.
TC0 is the GDMA interrupt flag. TC0 or GDMATERR0 will generate interrupt
回复 支持 反对

使用道具

地板
arthur 发表于 2021-6-11 13:07:49 | 只看该作者
参考现有的BSP代码:
NUC980_NonOS_BSP\SampleCode\UART_PDMA
回复 支持 反对

使用道具 举报

高级模式
B Color Image Link Quote Code Smilies |上传

本版积分规则

新唐MCU