微波EDA网,见证研发工程师的成长!
首页 > 测试测量 > 测试测量技术文库 > 混和信号数字示波器在通用串行总线开发中的应用

混和信号数字示波器在通用串行总线开发中的应用

时间:08-21 来源:互联网 点击:
在嵌入式系统的开发过程中,串行总线的协议分析一直是一件令工程师头疼的工作。在有逻辑分析仪的情况下,工程师需要进行复杂的触发条件设定,才能捕获到需要的数据,这样既需要昂贵的设备投资也要花费大量的时间进行仪器设置;随着示波器技术的不断发展,串行总线触发和分析功能在一些高端示波器中出现,并受到嵌入式工程师的欢迎。但不同厂家的示波器在串行总线分析方面的功能和性能是有很大区别的。

  使用示波器进行串行总线触发

  使用普通示波器只能进行一般的边沿触发和脉宽触发,很难捕捉到复杂的串行总线波形。而使用带有串行总线触发功能的示波器可以方便地捕获到需要的串行数据。横河公司的DLM2000系列数字示波器支持多种常用串行总线的触发,包括CAN/LIN/I2C/SPI/UART,甚至可以对用户自己定义的非标准串行总线进行触发。根据每种总线结构的不同,可以设置多种触发模式。触发模式越多,捕获数据的能力就越强。

  在嵌入式系统中,往往同时存在两种甚至两种以上的串行总线结构,例如汽车电子中CAN和LIN总线经常同时被使用,也经常需要分析两种总线的通讯配合是否出现问题。而多数带串行总线触发功能的示波器同时只能触发一种总线,要实现CAN和LIN总线同时触发,只能使用两台示波器,而两台示波器的同步问题也很难解决。DLM2000系列示波器的双总线触发功能则可以轻松实现任意两种串行总线的组合触发。

  使用示波器进行串行总线解码分析

  触发到需要的串行数据后,工程师面对的仍然是数据的原始波形,要想进行高效的总线分析,需要对波形进行解码。目前,数字示波器中所用的解码技术包括软件解码和硬件解码。软件解码是将波形数据通过示波器中的软件进行运算获得解码结果,虽然可以降低硬件成本,但对CPU的运算速度要求很高。在实际应用中,采用软件解码的示波器解码一次需要几秒甚至十几秒的时间。这样的解码速度已经失去了实时分析的意义,因为大多数数据已经在等待解码中丢失了。少数高端示波器采用了硬件解码技术解决了这一问题,使实时解码分析成为可能。

  在显示解码结果的同时,还可以显示所有捕获帧的解码列表,非常便于波形与解码结果的对应观测。

  要获得正确的解码结果,需要根据不同的总线参数对示波器进行设置。以CAN总线分析为例,需要指定总线类型为CAN,设置CAN信号对应的通道,通过调节触发电平和时间轴对CAN总线进行触发,然后调节比特率,设置隐形电平等,如果是SPI总线,还要指定3线制或4线制,指定时钟信号,片选信号。这个设置过程需要非常仔细,其中任何一项设置得不合适,解码结果都有可能出不来。尤其是比特率设置,稍有误差,得到的解码结果有可能就是错的。



  复杂的设置过程浪费了一部分调试时间,没有充分发挥示波器提高开发效率的作用。而DLM2000示波器实现了串行总线触发和解码分析的自动设置,用户只需要设置好总线类型和信号源通道,系统便可以自动调整比特率,触发电平,隐形电平等其他设置,在短短两秒钟内就可以将触发波形和解码结果同步显示出来。这一功能使繁琐的串行总线设置变得非常方便,大大提高了工程师的开发效率。

  下面就几种常用的串行总线介绍一下使用示波器进行串行总线分析的技巧。

  CAN总线控制过程的记录和分析

  在进行CAN总线分析时,工程师通常希望示波器能够捕获某个完整的控制过程,比如车窗的开启或关闭过程。这些过程通常会持续几秒钟或十几秒钟时间,记录这么长时间的数据要求示波器有很大的存储深度。而目前200MHz~500MHz带宽的示波器一般每个通道的存储深度只有10Mpoints以下,想记录几秒钟的CAN总线波形是很难做到的。DLM2000可以扩充到单通道125Mpoints,这样就可以完整地记录一个十几秒甚至更长的控制过程。

  对于一个过程的分析,最重要的就是这个过程的开始阶段和结束阶段。当捕获到一个控制过程之后,用户可以打开一个放大窗口,移动到过程的起始点,观测起始点的细节情况。如果想同时观测结束点的细节,一般示波器就无能为力了,而DLM2000继承了横河DL系列示波器的双窗口放大的独特功能,可以同时观测两个位置的波形细节,并独立调节缩放比例。



  偶发异常信号的捕获

  在将时基Time/Div调节到比较小用来观测波形细节时,有可能会有一些偶发的异常信号或者错误帧,当用户想抓住这些波形时已经来不及了,如果使用历史存储功能(也被称为分段存储技术)就可以解决这一问题。DLM2000可以将大内存平均分割成若干块,捕获到的一屏屏波形没有被马上覆盖掉,而被存入了历史内存中。这样的话,即使发现异常信号没有被锁定在屏幕上,只要用户及时按下了采集停止键,异常信号很容易在历史内存中被检索出来。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top