OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3869|回复: 6

SPI + DMA 使用DMA传输完成中断拉高CS,导致CS提前拉高

[复制链接]

16

主题

75

帖子

0

精华

高级会员

Rank: 4

积分
572
金钱
572
注册时间
2018-4-16
在线时间
77 小时
发表于 2020-8-16 10:51:14 | 显示全部楼层 |阅读模式
1金钱
我想用 DMA传输SPI发送控制一块IPS屏幕, 我在启动dma传输前拉低CS,启动DMA后等待DMA传输完成中断,在中断中回调设置CS拉高。实测发现CS总是提前拉高,如果在中断中CS拉高前延时一段时间则能正常发送,可是,中断中延时在时效上是致命的。。初步推测原因是由于DMA搬运完成后SPI外设并没有及时把数据发送出去,dma传输完成和spi发送完成并不是同时的,然后进一步我就想 使用spi发送完成中断,可是我并没有找到spi发送完成中断标志,倒是发现了发送缓冲区空标志位,经过试验发现发送缓冲区空也不能代表发送完成,也有可能数据还在移位寄存器中就把CS拉高了。。大佬们有什么解决办法吗???能够判断SPI发送完成的办法
1597545481(1).jpg
1597545436(1).jpg

最佳答案

查看完整内容[请看2#楼]

实测总是会丢掉最后一个字节数据,初步推测是因为 数据寄存器将数据送到移位寄存器中准备发送,同时产生发送缓冲区空中断,这时,数据确实不在数据寄存器中,被放到了移位寄存器,由于CPU执行速度要比SPI外设快,一产生发送缓冲区空中断,CPU就把CS拉高了,然后最后一字节数据在CS高的情况下发送了出去,导致从机不认最后一字节
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

16

主题

75

帖子

0

精华

高级会员

Rank: 4

积分
572
金钱
572
注册时间
2018-4-16
在线时间
77 小时
 楼主| 发表于 2020-8-16 10:51:15 | 显示全部楼层
awsawzj 发表于 2020-8-17 10:23
发送区空就会产生发送完成中断

实测总是会丢掉最后一个字节数据,初步推测是因为 数据寄存器将数据送到移位寄存器中准备发送,同时产生发送缓冲区空中断,这时,数据确实不在数据寄存器中,被放到了移位寄存器,由于CPU执行速度要比SPI外设快,一产生发送缓冲区空中断,CPU就把CS拉高了,然后最后一字节数据在CS高的情况下发送了出去,导致从机不认最后一字节
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165475
金钱
165475
注册时间
2010-12-1
在线时间
2115 小时
发表于 2020-8-17 01:35:59 | 显示全部楼层
这完全可以用软件CS,不要用硬件NSS
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

0

主题

47

帖子

0

精华

初级会员

Rank: 2

积分
155
金钱
155
注册时间
2019-12-31
在线时间
29 小时
发表于 2020-8-17 10:17:12 | 显示全部楼层
正点原子 发表于 2020-8-17 01:35
这完全可以用软件CS,不要用硬件NSS

·楼主说的好像就是软件控制cs
回复

使用道具 举报

2

主题

582

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2690
金钱
2690
注册时间
2014-5-23
在线时间
188 小时
发表于 2020-8-17 10:23:28 | 显示全部楼层
发送区空就会产生发送完成中断
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165475
金钱
165475
注册时间
2010-12-1
在线时间
2115 小时
发表于 2020-8-18 00:56:09 | 显示全部楼层
caoenq 发表于 2020-8-17 10:17
·楼主说的好像就是软件控制cs

那就不存在拉高不拉高,都是你程序控制了。拉高就说明你代码哪里拉高了,找到代码即可。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

16

主题

75

帖子

0

精华

高级会员

Rank: 4

积分
572
金钱
572
注册时间
2018-4-16
在线时间
77 小时
 楼主| 发表于 2020-8-21 08:46:10 | 显示全部楼层
正点原子 发表于 2020-8-18 00:56
那就不存在拉高不拉高,都是你程序控制了。拉高就说明你代码哪里拉高了,找到代码即可。

是的确实是软件控制的,,拉低我是先拉低了,然后开始dma发送这没什么问题,拉高我是放在一个回调函数中,由dma发送完成中断来回调,可是实测发现dma发送完成后产生中断拉高CS的时候,CLK还没有发完,就是逻辑分析仪抓到的样子,0号通道是clk,2号通道是CS,CS在芯片复位状态下是低电平,芯片启动后初始化成高电平,延时50us后拉低开始发送,时钟还没走完就被dma完成中断拉高了。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-4-30 15:46

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表