OpenEdv-开源电子网

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

问一个SPI的NSS硬件模式下的问题

[复制链接]

22

主题

73

帖子

0

精华

初级会员

Rank: 2

积分
164
金钱
164
注册时间
2017-9-18
在线时间
42 小时
发表于 2018-4-7 17:54:57 | 显示全部楼层 |阅读模式
5金钱
我在学习的过程中总结出了以下三点:
1.正常通信时要求,主机NSS内部电平为高,从机NSS内部电平为低
2.硬件模式下,内部电平由外部电平决定
3.当SPI_CR2寄存器的SSOE位为1时,NSS输出被使能,处于主模式下的SPI的NSS输出低电平

我的疑问是,结合以上三点,在硬件模式下NSS输出被使能时,主机的内部电平不就是低电平了吗?这与第一点岂不产生了冲突?

最佳答案

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

是的,NSS输出被关闭:允许操作于多主环境。多主模式下,他是去拉别人的NSS,或者被别人拉,看谁更快,谁快谁先占。
普通人要怎么努力,才能超越勤奋的天才啊
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

4

主题

346

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3657
金钱
3657
注册时间
2016-2-21
在线时间
542 小时
发表于 2018-4-7 17:54:58 | 显示全部楼层
aswsd 发表于 2018-4-8 10:28
的确,NSS引脚使能输出(SSOE=1)时无法工作在多主模式
您的意思是不是硬件模式下主机使能NSS输出,内外 ...

是的,NSS输出被关闭:允许操作于多主环境。多主模式下,他是去拉别人的NSS,或者被别人拉,看谁更快,谁快谁先占。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2018-4-8 02:04:44 | 显示全部楼层
没用硬件NSS,你再翻翻手册吧。
回复

使用道具 举报

4

主题

346

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3657
金钱
3657
注册时间
2016-2-21
在线时间
542 小时
发表于 2018-4-8 09:04:22 | 显示全部楼层
你说的第二句是用来做从机的情况。1和3是做主机的情况。做主机的时候最重要的是,他给信号给别人。做从机的时候要的是别人给信号给他。这个应该不算太绕吧。
回复

使用道具 举报

4

主题

346

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3657
金钱
3657
注册时间
2016-2-21
在线时间
542 小时
发表于 2018-4-8 09:05:42 | 显示全部楼层
因为STM32 的SPI支持多主机组网的情况,此时NSS信号会被作为仲裁信号的存在,如果你仔细读手册就会发现,当SPI工作在多主模式下时,NSS先被拉下去的一方就会被禁止发送,谁先获得发言权,谁就先说话。
回复

使用道具 举报

22

主题

73

帖子

0

精华

初级会员

Rank: 2

积分
164
金钱
164
注册时间
2017-9-18
在线时间
42 小时
 楼主| 发表于 2018-4-8 09:11:35 | 显示全部楼层
shikihane 发表于 2018-4-8 09:05
因为STM32 的SPI支持多主机组网的情况,此时NSS信号会被作为仲裁信号的存在,如果你仔细读手册就会发现,当 ...

看了下您的回复,还是不太明白
我想问的情况是 主机NSS工作在硬件模式时,它既需要保持内部电平为高,又需要输出低电平给从机,而在硬件模式下NSS内外电平相同,这不就冲突了吗?
普通人要怎么努力,才能超越勤奋的天才啊
回复

使用道具 举报

4

主题

346

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3657
金钱
3657
注册时间
2016-2-21
在线时间
542 小时
发表于 2018-4-8 09:45:14 | 显示全部楼层
aswsd 发表于 2018-4-8 09:11
看了下您的回复,还是不太明白
我想问的情况是 主机NSS工作在硬件模式时,它既需要保持内部电平为高,又 ...

他们处在不同的工作模式,而且一般这种信号都是做成弱上拉的,可以被更强的低电平拉下去。
回复

使用道具 举报

4

主题

346

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3657
金钱
3657
注册时间
2016-2-21
在线时间
542 小时
发表于 2018-4-8 09:45:55 | 显示全部楼层
aswsd 发表于 2018-4-8 09:11
看了下您的回复,还是不太明白
我想问的情况是 主机NSS工作在硬件模式时,它既需要保持内部电平为高,又 ...

NSS 被拉下,禁止发送,这个功能只会在多主模式下出现。一主一从不存在这个问题。
回复

使用道具 举报

22

主题

73

帖子

0

精华

初级会员

Rank: 2

积分
164
金钱
164
注册时间
2017-9-18
在线时间
42 小时
 楼主| 发表于 2018-4-8 10:28:59 | 显示全部楼层
shikihane 发表于 2018-4-8 09:45
NSS 被拉下,禁止发送,这个功能只会在多主模式下出现。一主一从不存在这个问题。

的确,NSS引脚使能输出(SSOE=1)时无法工作在多主模式
您的意思是不是硬件模式下主机使能NSS输出,内外引脚都低了,它仍然可以保持主机模式?
普通人要怎么努力,才能超越勤奋的天才啊
回复

使用道具 举报

22

主题

73

帖子

0

精华

初级会员

Rank: 2

积分
164
金钱
164
注册时间
2017-9-18
在线时间
42 小时
 楼主| 发表于 2018-4-8 10:32:23 | 显示全部楼层
普通人要怎么努力,才能超越勤奋的天才啊
回复

使用道具 举报

22

主题

73

帖子

0

精华

初级会员

Rank: 2

积分
164
金钱
164
注册时间
2017-9-18
在线时间
42 小时
 楼主| 发表于 2018-4-8 10:33:28 | 显示全部楼层
您看第6条,这与“NSS引脚使能输出(SSOE=1)时输出低电平”不矛盾吗?无法保持主机状态啊
普通人要怎么努力,才能超越勤奋的天才啊
回复

使用道具 举报

22

主题

73

帖子

0

精华

初级会员

Rank: 2

积分
164
金钱
164
注册时间
2017-9-18
在线时间
42 小时
 楼主| 发表于 2018-4-8 11:29:45 | 显示全部楼层
明白了,谢谢!
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-9 13:48

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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