当前位置:首页 > 半导体 > ADI
[导读]能否用MCU访问非标准SPI接口?

问题:能否用MCU访问非标准SPI接口?

raq-issue-172.jpg

答案:可以,但可能需要做一些额外的努力。

简介

当前许多精密模数转换器(ADC)具有串行外设接口(SPI)或某种串行接口,用以与包括微控制器单元(MCU)、DSP和FPGA在内的控制器进行通信。控制器写入或读取ADC内部寄存器并读取转换码。SPI的印刷电路板(PCB)布线简单,并且有比并行接口更快的时钟速率,因而越来越受欢迎。而且,使用标准SPI很容易将ADC连接到控制器。

一些新型ADC具有SPI,但有些ADC具有非标准的3线或4线SPI作为从机,因为它们希望实现更快的吞吐速率。例如,AD7616、AD7606和AD7606B系列有两条或四条SDO线,在串行模式下可提供更快的吞吐速率。AD7768、AD7779和AD7134系列有多条SDO线,用作SPI主机。用户在设计微控制器SPI以配置ADC和读取代码时往往会遇到困难。

raq-issue-172-fig-01.jpg

图1.AD7768用作串行主机,具有两个数据输出引脚(14001-193)。

与ADC的标准MCU SPI连接

SPI是一种同步、全双工、主从式接口。来自主机或从机的数据在时钟上升沿或下降沿同步。主机和从机可以同时传输数据。图2显示了典型的4线MCU SPI接口连接。

raq-issue-172-fig-02.jpg

图2.与ADC从机的标准MCU SPI连接

要开始SPI通信,控制器必须发送时钟信号,并通过使能信号(通常是低电平有效信号)来选择ADC。SPI是全双工接口,因此控制器和ADC可以分别通过MOSI/DIN和MISO/DOUT线同时输出数据。控制器SPI接口允许用户灵活选择时钟的上升沿或下降沿来采样和/或移位数据。为了在主机和从机之间进行可靠的通信,用户必须遵守微控制器和ADC芯片的数字接口时序规范。

如果微控制器SPI和ADC串行接口具有标准SPI时序模式,那么用户设计PCB布线和开发驱动器固件不成问题。但是,有些新型ADC的串行接口端口不是典型的SPI时序模式。MCU或DSP似乎不可能通过AD7768串行端口(一种非标准时序SPI端口)读取数据,如图4所示。

本文将介绍操纵标准微控制器SPI以便与具有非标准SPI端口的ADC接口的方法。

本文会给出四种通过串行接口读取ADC码的解决方案:

·解决方案1:MCU作为SPI从机,通过一条DOUT线与作为SPI主机的ADC接口。

·解决方案2:MCU作为SPI从机,通过两条DOUT线与作为SPI主机的ADC接口。

·解决方案3:MCU作为SPI从机,通过DMA与作为SPI主机的ADC接口。

·解决方案4:MCU作为SPI主机和SPI从机,通过两条DOUT线读取数据。

raq-issue-172-fig-03.jpg

图3.SPI数据时钟时序图示例

raq-issue-172-fig-04.jpg

图4.AD7768FORMATx=1×时序图,仅通过DOUT0输出。

STM32F429微控制器SPI通过一条DOUT线读取AD7768代码

如图4所示,当FORMATx=11或10时,通道0至通道7仅通过DOUT0输出数据。在标准工作模式下,AD7768/AD7768-4作为主机工作,数据流入MCU、DSP或FPGA。AD7768/AD7768-4向从机提供数据、数据时钟(DCLK)和下降沿帧使能信号(DRDY)。

STM32Fxxx系列微控制器广泛用于很多不同的应用中。该MCU有多个SPI端口,可以使用典型的SPI时序模式将其配置为SPI主机或从机。下文中介绍的方法也可应用于其他具有8位、16位或32位帧的微控制器。

AD7768/AD7768-4分别为8通道和4通道同步采样Σ-Δ型ADC,每通道均有Σ-Δ型调制器和数字滤波器,支持交流和直流信号的同步采样。这些器件在110.8kHz的最大输入带宽下实现了108dB动态范围,具备±2ppm INL、±50µV偏置误差和±30ppm增益误差的典型性能。AD7768/AD7768-4用户可在输入带宽、输出数据速率和功耗之间进行权衡,并选择三种功耗模式之一以优化噪声目标和功耗。AD7768/AD7768-4的灵活性使其成为适合低功耗直流和高性能交流测量模块的可重复使用平台。遗憾的是,AD7768的串行接口不是典型SPI时序模式,而且AD7768充当串行接口主机。一般而言,用户必须使用FPGA/CPLD作为其控制器,

例如,使用32F429IDISCOVERY和AD7768评估板。变通SPI线的连接如图5所示。在这种设置下,AD7768的所有八通道数据仅通过DOUT0输出。

raq-issue-172-fig-05.jpg

图5.AD7768通过DOUT0将数据输出到STM32F429MCU SPI连接

需要解决的问题:

·AD7768用作SPI主机,故必须将STM32F429I SPI配置为SPI从机。

·高电平脉冲只持续一个DCLK周期,这不是典型的。

·完成所有通道数据位的输出之后,DCLK继续输出,为低电平。

解决方案1:MCU SPI作为从机,通过一条DOUT线与SPI主机ADC接口

·将STM32F429的一个SPI端口(如SPI4)配置为从机,以DCLK速率接收MOSI上的数据位。

·将AD7768连接到STM32F429外部中断输入引脚EXTI0和NSS(SPI)引脚。的上升沿将触发EXTI0处理例程,以使SPI从机能够在变为低电平之后的第一个DCLK下降沿开始接收数据位。时序设计在这里至关重要。

·接收到通道0至通道7的所有数据后,应禁用SPI以防止读取额外的无效数据,因为会使SPI从机变为低电平,并且DCLK保持切换。

raq-issue-172-fig-06.jpg

图6.时序解决方案中的AD7768数据位读取

MCU固件开发注意事项

当软件处于中断模式时,DCLK运行速率可以高达4MHz,实现8kSPS的ODR。软件应进入中断处理程序,在一个半DCLK周期(375ns)内启动SPI。为使软件更轻松地进入中断例程,MCU可以在DCLK上升沿读取数据,从而提供额外的半个DCLK周期时间。但是,t5DCLK上升到DOUTx无效最小值为–3ns(IOVDD=1.8V时为–4ns),因此DOUTx上的传播延迟(>|t5|+MCU保持时间)应通过PCB布线或缓冲增加。

raq-issue-172-fig-07.jpg

图7.配置SPI4外设

解决方案2:MCU SPI作为从机,通过两条DOUT线与SPI主机ADC接口

在第一种解决方案中,仅使用DOUT0来输出所有8通道数据。因此,数据读取将ADC吞吐速率限制为8kSPS。如图1所示,在DOUT0上输出通道0至通道3,在DOUT1上输出通道4至通道7,可以减少数据传输时间。串行线的连接如图7所示。通过这种改进,在DCLK为4MHz时,ODR可以轻松达到16kSPS。

raq-issue-172-fig-08.jpg

图8.AD7768通过DOUT0和DOUT1将数据输出到STM32F429MCU SPI连接

固件可以不使用中断模式,而使用轮询模式,以减少从上升沿触发到使能SPI接收数据的时间延迟。这样可以在DCLK为8MHz时实现32kSPS的ODR。

解决方案3:MCU SPI作为从机,通过DMA与SPI主机ADC接口

直接存储器访问(DMA)用于在外设与存储器之间以及存储器与存储器之间提供高速数据传输。DMA可以迅速移动数据而不需要任何MCU操作,这样可以腾出MCU资源用于执行其他操作。下面是MCU SPI用作从机通过DMA接收数据的设计说明。

解决方案4:MCU SPI作为主机和从机,通过两条DOUT线读取数据

高吞吐量或多通道精密ADC为SPI端口提供两条、四条甚至八条SDO线,以在串行模式下更快地读取代码。对于具有两个或更多个SPI端口的微控制器,这些SPI端口可以同时运行以加快代码的读取。

raq-issue-172-fig-09.jpg

图9.EXTI0处于轮询模式,SPI4和SPI5通过DOUT0和DOUT1接收AD7768数据位。

raq-issue-172-fig-10.jpg

图10.EXTI0处于轮询模式,SPI4DMA通过DOUT0接收AD7768数据位。

在以下使用案例中,32F429IDISCOVERY使用SPI4作为SPI主机,SPI5作为SPI从机,通过DOUTA和DOUTB接收EVAL-AD7606B-FMCZ数据,如图8所示。

AD7606B是一款16位同步采样模数转换数据采集系统(DAS),具有八个通道,每个通道均包含模拟输入箝位保护、可编程增益放大器(PGA)、低通滤波器和16位逐次逼近寄存器(SAR)型ADC。AD7606B还内置灵活的数字滤波器、低漂移2.5V精密基准电压源和基准电压缓冲器,可驱动ADC及灵活的并行和串行接口。AD7606B采用5V单电源供电,支持±10V、±5V和±2.5V真双极性输入范围,所有通道均能以800kSPS的吞吐速率采样。

raq-issue-172-fig-11.jpg

图11.在主从模式下使用MCU SPI通过DOUTA和DOUTB接收数据

raq-issue-172-fig-12.jpg

图12.SPI4配置为主机,SPI5配置为从机。

图13显示了AD7606B以240kSPS运行时BUSY、SCLK、DOUTA和DOUB的数字接口截图。

raq-issue-172-fig-13.jpg

图13.AD7606B BUSY、SCLK以及DOUTA和DOUTB上的数据的示波器截图

结论

本文讨论了使用微控制器SPI访问具有非标准SPI接口的ADC的方法。这些方法可以直接使用,也可以稍加调整即可控制ADC SPI;其可作为SPI主机使用,也可以与多条DOUT线配合使用以提高吞吐速率。


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭