
作者Email: violit@netease.com
摘要:本文介绍一款USB接口的虚拟示波器的设计方案,重点介绍了USB总线接口芯片CH371的原理及应用,降低了USB系统研发的门槛,并达到令人满意的效果。
关键词:USB接口,虚拟示波器,CH371,高速数据采集
一、引言
对于学校教学实验连同某些特定需求来说,现在市场上的模拟及数字示波器也许并不适用,价格高昂、体积较大且很多专业功能并不实用。而现在电脑的普及程度也达到了相当的规模,利用电脑连同附加的数采模块实现一个灵活便捷的虚拟示波器能够满足大多数的工作、学习和研发需要,并且能够通过较低代价的硬件和软件升级实现相当复杂的信号处理功能,能够以较低的成本、较小的体积实现配置灵活的智能仪器组合;完万能够和便携电脑结合,构成便携式检测维修工作站。现在已有电脑并口通信的数据采集器,但是USB的应用日趋广泛和深入,假如将USB功能融合在里面则能够实现更高的数据传输率、更方便的使用方式,更为优越的体现出虚拟仪器的性能。
二、硬件设计
此虚拟示波器的数据采集器由以下功能模块组成:前端信号变换模块、高速模数转换模块、高速数据缓冲模块、单片机控制模块、USB接口模块和电源模块。前端信号变换、高速数据采集有成熟的方案并且可根据需要的指标,譬如采样率、量程控制、采样深度等进行设计,我们这里主要讨论USB接口部分的研发。

USB接口的研发以往都是个令人头痛的问题,尽管很多设计者向往USB接口高速传输、自主供电、即插即用的长处,但较难逾越他的协议固件研发和驱动程式研发的障碍。在这个方案里,笔者选用了一款无需研发协议固件和驱动程式的USB总线接口芯片。
南京沁恒公司(www.winchiphead.com)推出的CH371是个USB总线的通用接口芯片,他利用硬件逻辑屏蔽了USB 通讯中的任何协议,在电脑应用层和本地端控制器之间提供端对端的连接。基于CH371,设计者无需了解任何USB协议、固件程式连同驱动程式,能够轻松地将原来的并口、串口的产品升级到USB接口,以较低的风险和成本享用USB接口带来的优越性。
使用时在本地端,CH371具备8位数据总线和读、写、片选控制线连同中断输出,就像操作一般外设芯片相同方便地挂接到DSP、MCU等控制器的系统总线上;在电脑端,CH371的配套软件包括通用驱动程式连同应用软件包,提供了简洁易用的操作接口,和本地端的单片机通讯就如同读写硬盘中的文档相同简单,研发者能够使用VB、VC、C++Builder等高级语言进行研发。一般情况下,基于CH371设计USB产品不必考虑USB通讯协议、固件程式、驱动程式、配置过程、底层数据传输过程。设计者所要做的工作和设计并口、串口的产品相同,包括两件事:一是从电脑的应用层发出数据传输请求并接收应答;二是当USB 产品的控制器被通知有数据传输请求时,作出应答。
同时,CH371在提供了透明的USB协议的基础上还提供了I2C器件的直接管理、16个地址的直接读写连同复位、看门狗等功能,本地端甚至不使用单片机就可完成简单的控制功能,因此具备较强的功能适应性,能够满足不同场合的需要,有效的降低系统成本。
在本系统中使用的是SOP28封装的产品,他的管脚定义如下表:

根据不同的工作方式,芯片的接口类型能够有以下几种:被动并行接口、I2C主接口、主控方式接口。其中被动并行接口是最常用的方式,他提供单片机和电脑的连接,CH371作为单片机的一个被动外设;I2C主接口是CH371在电脑端程式的控制下不经过单片机直接读写一个EEPROM器件(譬如24C04等),经常用于USB外设的产品信息纪录;主控方式接口是不使用单片机,由电脑端程式直接控制CH371提供的16个地址的8位数据读写或是十几根IO口线,此方式主要用于完成相对简单的外部控制任务。这几种接口方式并非完全对立的,能够根据需要灵活配置。在此虚拟示波器中则将其使用为单片机的一个外设器件,同时将A3~A0用于主控方式由电脑控制四只LED。
单片机对于CH371的控制依靠对其内部的16个寄存器的操作来实现。这16个寄存器的地址有两种定义方式。一种是上电复位后默认为直接地址方式,A3~A0四个管脚为寄存器地址,这种方式较为简单,但是需要使用单片机较多的IO口资源;另一种是当CH371检测到ALE脚上的上升沿信号后,转换到复用地址方式,寄存器地址由数据总线的D3~D0来控制,根据ALE的跳变来判断是寄存器操作还是数据读写。在此设计中由于大容量数据缓冲需要使用到74373作为地址锁存,所以即使使用直接地址方式也无需多占用单片机资源,但是为了将A3~A0节省出来驱动LED所以选用复用地址方式。
根据系统的需要我们设计硬件如下。
USB接口提供数据交换及电源供给(经适当变换后供高速AD使用),CH371在12M晶振下倍频工作,提供和单片机接口的同时提供看门狗复位输出功能,I2C主控功能没有使用,A3~A0能够由计算控制驱动4只LED作为工作显示信号。单片机89C52的P1口组用于控制数据采集模块,包括量程转换控制、AD触发信号、采集数据溢出信号等;高速缓存62256通过低功耗的CPLD控制存放高速AD采集的结果,单片机定时将其中数据读出经CH371传送到电脑的数据显示和分析软件,实现虚拟示波器功能。单片机、CH371和RAM部分原理图如下:

图三 单片机、CH371和RAM部分原理图
三、软件设计
单片机端软件:
单片机端软件主要完成数据采集控制、数据报告这两个功能。其中数据采集控制根据电脑端软件设定的增益、时基、触发等参数控制数据采集模块,这里面要用到电脑向单片机发送少量的控制信息;数据报告功能则需要单片机将缓存中的一个采集周期的任何数据传送给电脑端软件,这属于大批量数据的传输。我们把介绍的重点放在单片机和电脑的通信上面。
单片机和电脑通信是通过对CH371的寄存器操作实现的,有关其寄存器定义的具体情况请参考数据手册。
在应用中需要注意的是,CH371提供的单片机接收缓冲区为8个字节,多于8个字节的电脑下传数据被切分;而单片机的发送缓冲区也是8个字节,多于8个字节的上传数据需要分多次上传。另外,CH371的中断包括了上传及接受成功,中断发生后具体的情况需要由传输状态寄存器来辨别;同时其中断电平是单稳态的,一个事件发生后中断信号跳变,但仅维持一个短暂的脉冲便恢复,这是为了配合不同速度的处理器而作的处理。
单片机和电脑的USB通信主要功能子程式示例如下:(请在使用时加入CH371的相应寄存器的地址定义) file://********** CH371初始化程式****************************** void ch371_init() { CH371_INT_SET=0; file://CH371中断数据设定寄存器的地址偏移 CH371_LENGTH=0X0F; file://置上传数据长度寄存器为15,表示暂时没有数据上传 save_length=0; file://保存下传数据长度 IT0=1; file://外部信号为下降沿触发 IE0=0; file://清中断标志 PX0=1; file://置高优先级 EX0=1; file://允许中断 } file://***********上传数据子程式******************************** void ch371_upload(unsigned char len) file://参数传入数据长度 { unsigned char i; unsigned char *up_buf; unsigned char *ch371_buf; if(len!=0) { up_buf=&ret_buffer; file://指向数据的地址 ch371_buf=&CH371_BUFFER; file://指向数据缓冲区 for(i=0;i{ *ch371_buf=*up_buf; file://写入上传数据缓冲区 ch371_buf++; up_buf++; } } CH371_LENGTH=len; file://写入本次数据的长度 } file://********中断子程式 使用中断0 寄存器组2******** void ch371_inter() interrupt 0 using 2{ unsigned char *down_buf; unsigned char *ch371_buf; unsigned char i; IE0=0; file://清中断标志 if( (CH371_STATUS&0x01) ==0 ){ file://读取状态信息寄存器,判断数据传输状态 save_length=CH371_LENGTH; file://保持下传数据长度 down_buf=&save_buffer; ch371_buf=&CH371_BUFFER; for(i=0;i{ *down_buf=*ch371_buf; file://读取一字节的下传数据 down_buf++; ch371_buf++; } } else CH371_LENGTH=0x0f; file://置上传数据长度寄存器为15 }
电脑端软件:
电脑端软件主要功能是模拟一个示波器的界面,实现数据的显示连同满足不同需要的分析功能,同时完成对数据采集硬件的参数设定。在这个设计中已实现了基本的功能,虚拟示波器的界面如下图。进一步研发后能够实现量程的自动转换、数据的深度分析(譬如波形测量、频谱分析等),甚至能够结合硬件的升级实现波形发生器、逻辑分析仪、扫频仪、网络分析仪等功能。

图四 虚拟仪器电脑软件面板图
电脑端有关USB通信的研发无需了解USB底层驱动,并且芯片生产商已以动态链接库的形式封装好了面向功能应用的API函数,研发者能够在多种高级语言中调用,功能强大且灵活方便。CH371动态链接库提供的API函数主要包括:设备管理API、数据传输API、中断查询API、I2C 操作API和直接控制API。
其中设备管理API对于一般产品研发无需用到;数据传输API是最重要最常用的一组函数,他提供了多种数据传输模式;中断查询API一般用于USB设备使用到中断传输的场合,我们这里没有用到;I2C 操作API用于对CH371控制的I2C器件进行读写,一般用于存放产品信息,我们这里也没有用到;直接控制API是用于CH371直接输入输出信号,包括配置、输入和输出三部分组成,我们使用这一组API实现对LED进行控制。 在实际应用中笔者使用VB6作为电脑端应用软件的研发平台,首先要将沁恒公司提供的驱动程式、动态链接库拷贝到电脑中,再将动态链接库的访问入口及函数定义入口添加至VB6项目中,就是将提供的VB6实例程式中的module功能模块添加到自己的工程项目下即可。此时对USB设备的通信编程就几乎和访问本地硬盘中的文档差不多了,具体差别能够通过分析实例程式的句法来解决。下面给出电脑接收和发送数据的相关程式。
Option Explicit ’ 变量定义 Dim myReq As DEMO_REQ Dim mOpen As Integer
Private Sub Form_Load( ) ’ 窗口加载事件 Dim mLength As Long mIndex = 0 mOpen = CH371OpenDevice(mIndex) ’ 窗体加载时打开设备 If mOpen = -1 Then MsgBox "无法打开CH371设备" ’ 加载失败提示 End If
myReq.mCommand = &HFF ’ 用户定义命令 myReq.mBuffer(0) = &H11 ’ 用户定义数据 myReq.mBuffer(1) = &H22 ’ 用户定义数据 mLength = Len(myReq) CH371WriteData(mIndex, myReq, mLength) ’ 通过CH371发送命令数据 …… CH371ReadData(mIndex, myReq, mLength) ’ 通过CH371接收应答数据 …… End Sub
四、结束语
使用CH371设计的USB接口的虚拟示波器现在已完成基本功能的验证,正在后期完善中,而且能够推出面向多种应用的不同级别的系列产品。实践表明其技术性能良好,功能强大、体积小巧、使用简便、价格低廉,是广大电子爱好者、研发者的有力助手。
|