OpenEdv-开源电子网

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

请问有什么办法可以在SPI1的DMA方式下,每发一个byte前拉低NSS,发完这个byte之后又拉高吗?

[复制链接]

3

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
62
金钱
62
注册时间
2015-12-21
在线时间
20 小时
发表于 2015-12-22 10:26:35 | 显示全部楼层 |阅读模式
5金钱
我试过每次只让DMA发一个数据,然后发N次,但是这样速度会降低很多,因为要不停地重新赋值和打开、关闭DMA通道。请问各位有没有什么办法可以实现标题问到的办法?谢谢!

最佳答案

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

谢谢三位的意见,我决定不用这种每个字节都拉NSS的方法了,确实严重影响速度。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

3

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
62
金钱
62
注册时间
2015-12-21
在线时间
20 小时
 楼主| 发表于 2015-12-22 10:26:36 | 显示全部楼层
谢谢三位的意见,我决定不用这种每个字节都拉NSS的方法了,确实严重影响速度。
回复

使用道具 举报

58

主题

6294

帖子

1

精华

资深版主

Rank: 8Rank: 8

积分
11555
金钱
11555
注册时间
2014-4-1
在线时间
1317 小时
发表于 2015-12-22 11:00:15 | 显示全部楼层
这就是“总体设计”,需要统筹考虑。

TIMER  ->  DMA  ->  SPI  ->  CS脚自动拉低
方法之一吧。
回复

使用道具 举报

3

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
62
金钱
62
注册时间
2015-12-21
在线时间
20 小时
 楼主| 发表于 2015-12-22 11:15:33 | 显示全部楼层
[mw_shl_code=c,true]for(i=0;i<len;i++) { SPI1_TX_Buff[0] = *(pt+47+i); GPIOA->BRR|=0x10;//片选有效 DMA1_Channel3->CNDTR = 1 ;//每次只传输一个byte DMA1->IFCR = 0xF00 ;//清除标志位 DMA1_Channel3->CCR |= 1 ;//开启DMA通道 while( ( DMA1->ISR & 0x200 ) == 0 );//等待传输完成 DMA1_Channel3->CCR &= 0xFFFFFFFE ;//关闭DMA通道 GPIOA->BSRR|=0x10;//片选无效 }[/mw_shl_code]

就是这样,每个字节都损耗1us多一点。初学者,希望大家多多指点,不胜感激!
回复

使用道具 举报

14

主题

96

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
412
金钱
412
注册时间
2013-6-23
在线时间
59 小时
发表于 2015-12-22 12:40:51 | 显示全部楼层
用DMA每次只发一个字节,那还不如不用DMA
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-22 06:56

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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