当前位置:首页 > 单片机 > 单片机
[导读]以Ez—USB FX2作为USB接口芯片设计一种数据采集系统。该系统应用EZ—USB FX2芯片构建单片机和主机的数据管道,接口符合USB2.0协议。详细介绍该系统的硬件组成和软件设计,包括FX2的固件设计和主机用户程序。EZ—USB FX2芯片工作在从属FIFO方式下,通过适当的配置可与单片机方便地进行连接,单片机可以像访问外部存储器一样访问FX2的端点。主机应用程序通过USB接口向设备发送相应的命令来控制采样过程。该系统硬件扩展方便、编程简单。

 在工业生产和科学技术研究中,常利用PC或工控机对各种数据进行采集,以获得所需要的控制信息和实验数据。传统的数据采集系统多以ISA,EISA或PCI插卡的形式完成数据传输,这种方式存在安装麻烦,受计算机插槽数量、地址、中断资源限制,可扩展性差等缺点。由于通用串行总线(Universal Serial Bus.USB)具有自动被系统识别.自动安装驱动程序、自行进行系统配置,以及支持不同速率的同步和异步传输方式,支持热插拔和即插即用(Plug and Play,PNP)等优点,已逐渐成为现代数据传输的发展趋势。目前实现USB数据传送多采用专用的USB接口芯片,文献采用的PDIUSBDl2可支持USBl.1协议,文献E37采用的接口芯片为USBl00也仅支持USBl.1协议,文献采用CP2102符合USB2.0协议,其通用的驱动程序可将设备作为虚拟的COM端口设备进行操作,文献采用Philips公司ISPl581芯片作为USB2.0的接VI芯片’。这里采用Cypress公司的CY7C68013作为USB接口芯片,设计实现了基于单片机和USB2.0的数据采集系统。该系统可实现单通道模拟信号的采集,主机应用程序负责启动和停止采样,采样间隔时间由主机应用程序设置调整,采样数据传给主机应用程序显示并保存。

1 系统硬件设计
1.1 系统硬件组成

    整个系统的硬件结构如图l所示。AT89C52为主控单片机,负责控制A/D转换、上传采集数据、接收并执行主机的命令。CY7C68013为USB接口芯片。A/D转换芯片采用TI公司生产的TLC549,AD780是一款高精度参考电压芯片,可为TLC549提供2.5 V或 者3.0 V的参考电压。系统+5 V电源由主机的USB 接口提供,CY7C68013所需的电源为+3.3 V,由+5 v 电源接稳压芯片APlll7提供,图中没有画出。

1.2 TLC549
    TLC549是以8位开关电容逐次逼近A/D转换器为基础而构造的CMOS A/D转换器,将其设计成能通过三态输出与微处理器或外围设备串行接VI。TLC549用输入/输出时钟(I/O CLOCK)和芯片选择(CS)输入作数据控制,转换结果由DATAOUT引脚输出。I/o CLOCK端的最高频率可达1.1 MHz。TLC一549片内系统时钟工作在4 MHz(不需要外部时钟)。片内系统时钟使内部器件的操作独立于串行输入/输出时序并允许TLC549像许多软件和硬件所要求的那样工作。I/O CLOCK和内部系统时钟可以实现高速数据传送,使得TLc549可实现40 kHz的采样频率。TLC549具有通用控制逻辑及自动工作或在微处理器控制下工作的片内采样/保持电路,差分高阻抗基准电压输入端,易于实现比例转换的高速转换器,定标及隔离电路。整个开关电容逐次逼近转换器电路的设计允许在小于17μs的时间内,以最大误差±0.5为最低有效位的精度实现转换。
1.3 CY7(368013及其固件程序
    EZ—USB FX2系列芯片CY7C68013是业界第一个支持USB2.0,同时向下兼容USBl.1规范的单片机,为描述方便以下简称该芯片为FX2。FX2支持全速传输(12 Mb/s)和高速传输(480 Mb/s),该芯片将USB2.O收发器、串行接口引擎SIE、增强的8051内核、GPIF等集成于一体。FX2内含4 KB的端点缓冲区F1FO,可以被配置为具有不同大小缓冲区的IN或OUT端点(EP2,EP4,EP6,EP8),具有USB协议所规定的4种传输方式,即控制方式、中断方式、批量传输、和同步传输方式。Cypress公司为FX2提供了完善的软件开发工具包,降低了开难度,加快了开发进度。
    FX2可以工作在3种不同的模式下完成USB数据的传输,即:Ports模式、GPIF模式和Slave FIFO模式。Ports模式下其uSB数据的传输主要在FX2的8051内核参与下完成,数据传输通过执行指令实现,因此数据的传输率比较低,对大批量数据传输一般采用后两种方式。GPIF方式,称为通用可编程接口方式,在此模式下,FX2的FIFO是由内部的GPIF控制的,FX2利用由软件编程输出读写控制波形读取FIFO标志,控制FIFO的选通,并且对外部设备提供了用户专用接口,可以对许多通用总线接口进行访问,如ASIC,DSP和存储器等。文献利用FX2的GPIF方式构建了LISB数据传输通道。Slave FIFO方式是将FX2的FIFO作为外部控制器(如FPGA或单片机)的从属FIFO,外部控制器可像普通FIFO操作一样对FX2的FIFO进行读写,而不考虑该包的大小,传输速率可明显提高,文中FX2在Slave FIFO模式下工作。FX2有3种封装形式:128引脚、100引脚和56引脚,这里选用FX2的56引脚的封装形式。
    FX2芯片在使用时必须先下载固件程序,固件程序主要负责完成芯片初始化,对芯片进行必要的配置、处理设备请求、进行数据传输等相应工作。用户通过编写适当的固件程序完成对FX2的设置。Cypress公司提供了一个固件程序开发框架可以大大简化FX2芯片固件程序的开发难度。通过编写用户初始化函数TD_Init(),用户可以规定各种端点资源的使用以及配置外围接口的输入/输出等。其主要配置语句如下:

   
    固件程序将FX2配置为异步Slave FIFl0模式,总线宽度8位,在4个端点中,EP4和:EP8未被使用,EP2和EP6的配置如表1所示。由于采用自动输入/输出模式,主机和单片机通过旁路FX2的CPU直接连接,所有数据被直接通过FIFO管道提交,不需固件程序干预。在FX2的slave FIF0模式下,FIFOADR[1:0]引脚作为地址线选择某个端点,SLCS相当于片选信号,SLwR(写)与单片机的wR引脚相连,SLRD(读)和SLOE(输出使能)与单片机的RD引脚相连。单片机通过访问地址为0x00的外部存储器的方式就可以实现对EP2的访问,同理可访问EP6端点。

    单片机通过FX2的3个标志引脚(FALGA,FLAGB,FLAGC)来全面掌握FX2的各端点FIFO的状况。FLAGA定义为输入端点EP6的满标志,当输入数据满时该引脚为低电平;FLAGB被定义为输出端点EP2的空标志,当主机传来的数据被读空时该引脚为低电平;FLAGC定义为当EP2端点整个FIF0中的字节数大于等于1时为低电平。假设当前主机没有传送命令,则FLAGC为高电平,当主机发送命令后,EP2的字节数大于等于1,则FLAGC变为低电平。这样在FALGC引脚上产生了一个下降沿,将此引脚与单片机的INTO引脚相连,则当主机发送命令后单片机会触发INT0中断,在INTO的中断处理程序中单片机读取并执行传来的命令。

2 系统软件设计
2.1 驱动程序
   
在EZ—USB FX2开发包中,提供有通用的驱动程序包,对该程序包稍加修改就可生成一个具有下载固件并完成设备重枚举功能的设备驱动程序。文献对驱动程序的开发步骤有详细的记述,这里采用的就是这个通用驱动程序(GPD)。
2.2 主机应用程序
    主机应用程序主要实现向设备发送命令数据包,接收设备传送的数据并进行显示,主机应用程序通过通用驱动程序来完成对设备的控制和通信。应用程序采用VC6.O编写,与设备通信时,首先通过调用win32函数CreateFile()来取得访问设备驱动程序的句柄。该函数的语句实例如下:


    用户得到设备句柄后,就可以使用win32函数DevicelontroI()来向设备提交相应的IOCTL控制码,进行读写和控制操作,完成相应操作后应用程序通过Win32函数CloseHandle()关闭设备句柄结束1次操作。以下是部分操作的代码实例:


    应用程序中有两个线程,辅助线程为采样线程,采样线程的流程如图2所示。

    采样线程负责从设备读取数据,并通过消息传送机制与主线程通信;主线程负责采样数据的显示、存盘,向设备发送命令数据包,以及启动/停止采样线程。当执行启动采样命令时,主线程先向设备发送启动命令数据包,然后启动采样线程准备接收数据;当执行停止采样命令时,主线程先向设备发送停止命令数据包,然后停止采样线程结束数据的接收。命令数据包大小为4 B.包含有命令字和采样间隔时间参数等信息。
2.3 单片机程序
   
如上所述,单片机的INTO中断一旦触发,表示主机有命令数据包传送到。在INTO的中断处理程序中,单片机读取EP2端点的数据直到EP2端点为空(FLAGB为低电平),获得上位机发送的命令数据包。若接收到启动命令,则根据命令数据包的采样间隔时间参数来设置计数变量和定时器T0的初值并启动T0;若接收到的命令为停止命令,则停止定时器TO。在TO的中断处理程序中若相应的计数变量达到设定值,则完成A/D转换、读取数据以及将数据写入EP6端点的操作。计数变量和TO的初值均根据命令数据包的参数进行设置,因此设备的采样间隔时间可以由主机程序进行调整。

3 结 语
    工作于Slave FIFo方式下的FX2相当于在外部控制和主机之间构造了一个的数据管道。通过对FX2的FIFO标志引脚FLAGA,FALGB,FLAGc的配置,使该芯片可以方便地与单片机进行连接,单片机通过外部中断获知主机数据的到达,通过其他标志引脚获得端点FIFO的信息,单片机和主机通信时,感觉不到FX2的存在。基于单片机和Fx2的数据采集系统扩展方便、编程简单、无需外接电源、采样间隔时间由主机调整,实现了数据采集系统的小型化和便携化,在现场信号采集,教学实验,仪器仪表等领域具有一定的应用前景。

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

大家好,我是鲏。认识我的朋友都知道,我是一个实践派,相比研究枯燥的理论知识,我更喜欢做自己想做的项目,用技术来实现自己的想法的感觉真的很棒。所以从大学期间一直到现在,除了工作中的项目外,我依然保持着自己做项目的习惯,有坚...

关键字: 系统设计 技术选型 需求分析

(全球TMT2022年8月30日讯)近日,在2022英特尔中国数据中心合作伙伴技术峰会上,英特尔与浪潮信息等产业生态伙伴联合发布了《绿色数据中心创新实践 -- 冷板液冷系统设计参考》白皮书,分享冷板液冷技术关键部件的最...

关键字: 系统设计 英特尔 数据中心 生态系统

北京2022年8月30日 /美通社/ -- 近日,在2022英特尔中国数据中心合作伙伴技术峰会上,英特尔与浪潮信息等产业生态伙伴联合发布了《绿色数据中心创新实践 -- 冷板液冷系统设计参考》白皮书,分享冷板液冷技术关键部...

关键字: 系统设计 英特尔 数据中心 电量

摘要:近年来,受人类活动的影响,各大水域的水质污染问题越来越严重,大部分水资源受到严重污染,水质处理问题亟需解决。分析水体污染情况对改进水质有着重要意义,目前水质监测主要采用人工或无人船的方式。人工监测方式工作量大,影响...

关键字: 水质监测 无人机 系统设计

摘要:根据饶平县高堂水闸重建工程建设实际需求,对高堂水闸运行管理进行实时在线式监控与监测,通过闸门控制、视频监控、水情测报、安全监测和网络通信等系统的设计,为高堂水闸的水工建筑物安全、防洪调度和自动化管理提供技术支持,以...

关键字: 管理信息系统 水利工程 系统设计

湖州2022年7月26日 /美通社/ -- 近日,浙江省科技创新大会在浙江省人民大会堂隆重举行。大会正式颁布2021年度浙江省科学技术进步奖,隆重表彰为浙江科技创新事业和经济社会发展做出突出贡献的科技工作者及团队。...

关键字: 电梯 检测技术 系统设计 零部件

摘要:简要介绍了柴油发电机组和重油发电机组的构成和主要特点,以某发电厂重柴油发电机组系统设计为例,重点分析了重油发电机组燃油系统、润滑油系统、循环冷却水系统、压缩空气系统的设计要点,以提高柴油、重油发电机组的运行效率和运...

关键字: 重油发电机组 特性 系统设计

摘要:针对一种小型消费级水下机器人,分析了其系统总体设计及各关键子系统(推进系统、通信系统、控制系统及其他系统等)设计的要点和方法,举例介绍了一种五推进器小型消费级水下机器人。经验证,该设计方法可以用于同类型水下机器人的...

关键字: 推进器 系统设计 五推进器

提供全面高效的电源管理建模,适用于汽车和工业应用领域 加州山景城2022年5月24日 /美通社/ -- 新思科技(纳斯达克股票代码:SNPS)和Analog Devices, Inc. 近日宣布达成合作,通过...

关键字: ADI 电源系统 系统设计 新思科技

摘要:PLC以其体积小、占用空间小、辅助设施投入少、工作可靠和维修简单等优点,被广泛应用于各个领域。现介绍了一款可对铁、铝及颜色进行材料分拣的装置,分析了该分拣装置的总体结构设计、硬件设计和软件系统设计要点。该分拣装置成...

关键字: 自动分拣 PLC 系统设计

单片机

21600 篇文章

关注

发布文章

编辑精选

技术子站

关闭