完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
STM32L476RG 到 ti CC1200 SPI 的接口。将 MCU 寄存器与 NSS 一起使用会产生短的可接受的 CSN 到时钟启动间隔,但我无法消除导致 CC1200 发生故障的帧之间的高脉冲。手动配置和切换 CSN GPIO 在 CSN 低电平开始和 SPI 时钟脉冲开始之间产生不可接受的长延迟,但交易工作。我的项目需要优化 SPI 事务速度,因为有许多单独的 2 字节事务需要在尽可能短的时间内发生。将 CSN 切换插入 HAL_SPI_TransmitReceive_IT 或 HAL_SPI_TransmitReceive 函数可缩短 CSN 时钟之间的持续时间,反之亦然,但仍会增加比 HAL NSS 硬件输出更长的间隔。2 字节事务明显比必要的长。
HAL STM32l476 用户手册第 42.4.5 节规定如下 - “硬件 NSS 管理(SSM = 0):在这种情况下,有两种可能的配置。使用的配置取决于 NSS 输出配置(寄存器 SPIx_CR1 中的 SSOE 位)。 – NSS 输出使能(SSM=0,SSOE = 1):此配置仅在 MCU 设置为主机时使用。NSS 引脚由硬件管理。一旦 SPI 在主机模式下启用 (SPE=1),NSS 信号就会被驱动为低电平,并保持低电平直到 SPI 被禁用 (SPE=0)。如果激活 NSS 脉冲模式 (NSSP=1),则可以在连续通信之间产生一个脉冲。SPI 无法在具有此 NSS 设置的多主机配置中工作。 – NSS 输出禁用(SSM=0,SSOE = 0):如果微控制器充当总线上的主机,则此配置允许多主机功能。如果 NSS 引脚在此模式下被拉低,则 SPI 进入主机模式故障状态并且设备自动重新配置为从机模式。在从机模式下,NSS 引脚用作标准的“芯片选择”输入,当 NSS 线处于低电平时选择从机。” 上面暗示下面的初始化将产生一个 NSS/CSN 低电平,帧之间有一个脉冲。它是做什么的。 hspi2.Instance = SPI2; hspi2.Init.Mode = SPI_MODE_MASTER; hspi2.Init.Direction = SPI_DIRECTION_2LINES; hspi2.Init.DataSize = SPI_DATASIZE_8BIT; hspi2.Init.CLKPolarity = SPI_POLARITY_LOW; hspi2.Init.CLKPhase = SPI_PHASE_1EDGE; hspi2.Init.NSS = SPI_NSS_HARD_OUTPUT; hspi2.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_8; hspi2.Init.FirstBit = SPI_FIRSTBIT_MSB; hspi2.Init.TIMode = SPI_TIMODE_DISABLE; hspi2.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE; hspi2.Init.CRCPolynomial = 7; hspi2.Init.CRCLength = SPI_CRC_LENGTH_DATASIZE; hspi2.Init.NSSPMode = SPI_NSS_PULSE_ENABLED; Init后注册: CR1=0x11c CR2=0x170c 启用 NSSP 的 NSS 硬件输出 并暗示下面的初始化将产生一个 NSS/CSN 低电平,而帧之间没有脉冲。它没有。 hspi2.Instance = SPI2; hspi2.Init.Mode = SPI_MODE_MASTER; hspi2.Init.Direction = SPI_DIRECTION_2LINES; hspi2.Init.DataSize = SPI_DATASIZE_8BIT; hspi2.Init.CLKPolarity = SPI_POLARITY_LOW; hspi2.Init.CLKPhase = SPI_PHASE_1EDGE; hspi2.Init.NSS = SPI_NSS_HARD_OUTPUT; hspi2.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_8; hspi2.Init.FirstBit = SPI_FIRSTBIT_MSB; hspi2.Init.TIMode = SPI_TIMODE_DISABLE; hspi2.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE; hspi2.Init.CRCPolynomial = 7; hspi2.Init.CRCLength = SPI_CRC_LENGTH_DATASIZE; hspi2.Init.NSSPMode = SPI_NSS_PULSE_DISABLED; Init后注册: CR1=0x11c CR2=0x1704 禁用 NSSP 的 NSS 硬件输出 手动切换 |
|
相关推荐
1个回答
|
|
明确地说,我想你是说我是否使用 SPI_transmit_receive 函数中的代码来手动配置和切换 CS GPIO 或启用/禁用外围设备 - CS 低/高和时钟脉冲启动/停止之间的间隔可能会结束起来~一样。因此不妨单独使用 SPE,禁用 NSS 并使用手动 GPIO 输出。
|
|
|
|
只有小组成员才能发言,加入小组>>
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
2642 浏览 1 评论
3208 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
1783 浏览 1 评论
3611 浏览 6 评论
5989 浏览 21 评论
939浏览 4评论
1316浏览 4评论
在Linux上安装Atollic TRUEStudio的步骤有哪些呢?
584浏览 3评论
使用DMA激活某些外设会以导致外设无法工作的方式生成代码是怎么回事
1303浏览 3评论
1361浏览 3评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-25 00:14 , Processed in 1.165503 second(s), Total 77, Slave 60 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号