基于ISP1581的USB数据采集系统的实现

发布者:码梦小子最新更新时间:2013-09-11 来源: dzsc关键字:ISP1581  USB  数据采集系统 手机看文章 扫描二维码
随时随地手机看文章

  数据采集广泛应用于信号检测、信号处理、仪器仪表等领域。目前,有各种数据采集卡或采集系统可供选择,但由于数据源以及用户需求的多样性,有时并不能满足要求。特别是在某些应用中,需要同时高速采集多个通道的数据,而且为了分析比较各通道信号间的相互关系,常常要求所有通道的采集必须同步。目前常用的数据采集卡是具有ISA总线、PCI总线等接口形式的A/D采集卡,虽然数据传输率很高,但是还存在整个系统笨重,缺乏灵活性,不能实现即插即用,不适合小型、便携设备应用等缺点。通用串行总线(USB)是为了解决日益增加的PC机外设与有限的主板插槽和端口之间的矛盾而制定的一种串行通信标准。USB的出现很好地解决了以上问题。USB不仅具有快速的传输性能,而且USB协议本身具有其纠错能力,它的即插即用模式和易扩展性能都具有很强的发展前途和应用价值。根据项目实际需求,本文设计了一种基于ISP1581的高速USB多通道数据采集系统,系统最高采样率每通道可达500 K字,并且具有增益控制调节、外触发同步采集等功能,目前该系统已成功地应用于某水下定位系统。

  1 系统硬件组成

  如图1所示,系统由信号调理电路模块、A/D采集模块、USB数据传输模块三个部分组成。


  1.1 信号调理电路模块

  由于从传感器进来的信号一般都比较小(大约在微伏量级),A/D无法直接对这些信号进行采集,需要通过信号调理电路模块对其进行放大,以满足A/D采集的量程范围。另外,由于信号容易受到外界噪声以及电噪声的干扰,通过信号调理电路所具有的滤波功能,可以滤除信号频带外的噪声。

  1.2 A/D采集模块

  A/D采集模块由1片FPGA和2片A/D组成,完成4路信号的模/数转换。模数转换器选择的是AD7655芯片。AD7655是一款高速、低功耗4通道16位模数转换器,采用5 V单电源供电,模拟输入信号范围为0 V~5 V;高输入阻抗,可对4路模拟输入同时高速采样并进行数字化转换,采样速率最高可达1 MS/s,支持并行或串行接口。由于本采集系统要求对各路信号的相位严格一致,而AD7655只能同时对4个通道中的2路信号同时进行采样,因此,1片A/D仅连接了2路模拟信号。另外,为了保证所有通道信号的相位一致性,2片A/D需要使用同一个转换信号来控制转换的进行,故在电路连接时,把每个A/D芯片的转换信号(CNVST)管脚连接在一起,然后连接到FPGA上的转换信号输出管脚上,由FPGA输出的转换信号驱动。FPGA与A/D之间的数据读取采用总线的方式,将每一片A/D的读控制信号都独立连接到FPGA上,由FPGA控制各路采样数据的读取。采集电路连接如图2所示。


  1.3 USB数据传输模块

  USB数据传输模块是本系统的核心。要开发USB功能设备,首先需要对设计产品的功能进行全面了解,包括数据传输速率、传输类型、所需要的硬件资源等。在充分了解设计的产品后,要选择合适的USB接口芯片,如果选择得好,可以大大节省开发时间和费用。

  USB接口芯片是一种集成了USB协议的微处理器,能自动对各种USB事件作出响应,以处理USB总线上的数据传输。所有的主机和设备上都至少含有1块实现其功能的USB接口芯片。按照不同的标准,USB接口芯片有如下几种分类方式,以功能分类则可以分为:主控制器芯片、集线器芯片、功能设备芯片;以使用方式进行分类则可以分为:带USB接口的专用MCU、带USB接口的通用MCU、纯粹的USB接口芯片。[page]

  本设计中选用了Philips公司的USB2.0接口芯片ISP1581,该芯片属于纯粹的USB接口芯片。这类USB接口芯片价格较低,接口方便,灵活性高,针对不同的硬件环境可以配合多种MCU使用,如单片机、DSP、FPGA。ISP1581支持2种工作模式:通用处理器模式和断开总线模式。本设计中采用DSP来控制ISP1581,连接方式选用通用处理器模式,原理图如图3所示。


  2 USB接口软件开发

  软件分为USB固件程序开发和USB设备驱动程序开发两大部分。

  2.1 USB固件程序开发

  所有基于微处理器及其外围电路的功能设备的正常工作都离不开固件的参与,固件的作用就是辅助硬件,即控制硬件来完成预期的功能,如没有固件的参与和控制,硬件设备只是芯片简单的堆砌,无法实现预期的功能,如同一台没有安装操作系统的计算机,无法正常工作。因此,用户必须编写固件程序来辅助硬件完成USB通信任务。具体如下:

  (1)初始化。主要是设置一些特殊寄存器的初值,以实现所需的设备属性或功能,例如开中断、使能端点、配置端口等。

  (2)辅助硬件完成设备的重新枚举(ReNumeration)过程。包括模拟设备的断开与重新连接,对收到的设置包进行分析判断,从而对主设备请求做出适当的响应,完成对设备的配置任务。

  (3)对中断的处理。

  (4)数据的接收和发送。

  (5)外围电路的控制。

  固件程序设计成中断驱动模式,采用模块化设计,其总体结构如图4所示。


  各模块的主要功能如下:

  (1)主程序:完成DSP及USB接口芯片的初始化、数据发送/接收标志位的判断及中断请求等待。

  (2)中断服务程序:中断服务程序是整个固件程序设计的重点。首先通过读取ISP1581中断寄存器的值判断所发生中断的类型,然后根据具体的中断类型进入相应的处理子程序或设置相应的标志位。中断服务程序中需要处理的有总线复位中断、高速状态变化中断、SETUP中断及端点的IN/OUT中断。在所有的中断处理程序中,EP0SETUP中断处理是最重要的,它是USB设备与PC机间建立通信链路的基础。

  (3)请求处理程序:USB标准请求处理程序负责处理枚举阶段主机发给设备的标准请求,以及正常工作时主机发送的厂商请求。USB2.0协议中规定了11种USB标准请求,对这11种标准请求作出正确的响应是设备成功枚举的重中之重。当固件接收到第1个SETUP中断后,就进入USB枚举过程,其过程是由主机发出一系列USB标准设备请求并要求及时得到设备响应,如果不需要进行操作,也必须指示一个空响应,使主机能为该设备准备其所请求的资源,建立好两者之间的信息沟通机制。

  (4)数据接收/发送程序:当用户通过主机端应用程序向设备索要数据或向设备发送数据时,DSP调用数据发送/接收子程序完成数据的发送/接收。数据的发送和接收过程如下:

  发送数据:选择端点索引→写发送缓冲区长度寄存器→写发送数据到数据端口寄存器→等待发送完毕标志。

  接收数据:选择端点索引→读接收缓冲区长度寄存器→从数据端口寄存器读取接收到的数据。

  (5)硬件接口访问程序:硬件接口程序负责完成DSP对ISP1581的读写操作,它是整个固件程序中最底层也是使用最频繁的部分,在这里主要定义了2种类型的函数:ISP1581常用寄存器访问函数和数据端口寄存器访问函数。

  常用寄存器访问函数:

  void outport(unsigned int *reg_addr, unsigned short value);

  unsigned short inport(unsigned int *reg_addr);

  数据端口寄存器访问函数:

  void write_ep(unsigned short *addr, unsigned short size);

  unsigned short read_ep(unsigned short *addr);

  write_ep为写端点发送缓冲区函数,其中参数*addr为指向待发送缓冲区的起始地址指针,参数size为要发送数据的字节数;read_ep为读端点接收缓冲区函数,参数含义与write_ep函数相同,返回值为接收数据的字节数。[page]

  2.2 驱动程序开发

  Windows环境下驱动程序有3种模型:VxD模型、KMD模型、WDM模型。WDM模型是微软力推的全新驱动程序模型,现在主流的操作系统都是采用基于WDM模型的驱动程序,因此本采集系统也采用WDM驱动程序模型来开发USB设备的驱动程序。

  对于USB设备,其WDM驱动程序分为USB底层(总线)驱动程序和USB功能(设备)驱动程序。USB底层驱动程序由操作系统提供,负责与实际的硬件打交道,实现底层通信。USB功能驱动程序由设备开发者编写,不对实际的硬件进行操作,而是通过向USB底层驱动程序发送包含请求块URB(USB Request Block)的IRP,以实现对USB设备信息的发送和接收。

  目前,WDM驱动程序开发工具有3种:Microsoft公司的DDK、Numega公司的DriverStudio和Jungo公司的WinDriver。其中,DDK的开发难度较大,开发者需要对整个体系结构和WDM规范有很好的理解和把握,还要熟悉上千个DDK函数的功能和使用场合,且测试流程繁琐;DriverStudio的开发难度低一些,它将DDK函数按照逻辑功能进行组织,把很多常用功能封装成类,建立了一个基于C++语言的面向对象的编程环境,开发者面对的不再是上千个复杂凌乱的DDK函数,而是逻辑清晰的类库;WinDriver的开发几乎没有难度,开发者所编写的只是定制和调用它提供的通用驱动,开发周期较短,特别适合于驱动程序初学者使用。

  利用WinDriver开发设备驱动程序,有2种方法:(1)用Wizard自动生成驱动程序的框架代码,根据实际要求修改代码,加入定制的功能,再在用户态执行和调试代码,并将性能要求苛刻的部分插入到核心态,从而完成整个驱动程序的编写。在使用这种方法时,WinDriver已经完成了驱动程序编写的大部分工作,减少了工作量,使编写驱动成为相对较简单。但此方法生成的设备驱动程序,其通用性和可移植性较差;(2)完全用WinDriver提供的API函数来写驱动程序。这样要比修改由Wizard生成的框架代码灵活得多,并且编写的程序更简短。但这要求开发者熟悉驱动程序的框架,能熟练运用WinDriver API函数。

  为了缩短开发周期,在实际应用中选用了第1种方法生成驱动程序。具体步骤如下:

  (1) 启动Driver Wizard,检测连接的USB设备,生成inf文件,这个inf文件和WinDriver包含的windrvr6.sys一起,就是新开发USB设备的驱动程序。

  (2) 点击Next按钮,进入资源列表窗口,窗口中显示了管道(Pipe)的一些基本信息。此窗口还可以用于对外设进行读写,测试硬件资源的正确性,窗口中的Log部分即为测试结果。

  (3) 点击Next按钮,进入代码生成窗口,在窗口中选择生成C语言代码。之后Driver Wizard将自动生成针对ISP1581的样本程序和工程文件(包括代码文件、说明文件以及适用于VC++编译器的项目文件)。

  (4)重新安装这个USB设备的驱动程序,利用DriverWizard生成的文件,就可开发应用程序了。

  经过反复测试发现,在现有硬件上批量传输的速度在60 Mb/s左右,可以满足当前系统采样频率为500 kHz时的数据采集要求,即500K×4路×16=32 Mb/s。但与USB2.0规范的极限速度相比,现有的批量传输速度还不及其13%,分析其原因:

  (1) USB2.0规范定义的最大速度为480 Mb/s,但它是包含令牌包在内的传输,因此,若扣除通信协议中的令牌,实际传输速度要远低于480 Mb/s。

  (2) 从访问寄存器的时序参数可以看出,读/写周期最小为80 ns,即DSP对ISP1581读写的最高频率是12.5 MHz,由于每次读写操作的数据为2 B,所以DSP与接口芯片之间数据传输的最高速率是25 MB/s,最后的实际值应该小于此值。

  (3) 利用WinDriver开发驱动,事实上它只是定制和调用WinDriver提供的通用驱动而已,所以并非有针对性地对特定硬件编程,程序执行效率上也不免大打折扣。

  (4) 计算机与USB设备的通信中还包含对计算机硬盘的写操作,使用测试软件对所用机器硬盘进行写测试,测得平均速度在22~25 MB/s之间,因此硬盘的写速度也是影响USB数据传输速度的原因之一。

  因此若想在现有硬件平台上获得更高的速度可以在以下几个方面进行:采用端点的双缓冲模式、采用ISP1581的DMA模式、采用效率更高的驱动开发方式及优化固件程序以提高硬件的工作效率等。



 参考文献:

[1]. PCI datasheet http://www.dzsc.com/datasheet/PCI_1201469.html.
[2]. ISP1581 datasheet http://www.dzsc.com/datasheet/ISP1581_410269.html.
[3]. AD7655 datasheet http://www.dzsc.com/datasheet/AD7655_1131512.html.

关键字:ISP1581  USB  数据采集系统 引用地址:基于ISP1581的USB数据采集系统的实现

上一篇:基于CY7C68013A的USB控制系统设计研究
下一篇:基于PDIUSBD12芯片的USB应用开发

推荐阅读最新更新时间:2024-05-02 22:46

英飞凌推出 EPR 电子标记电缆组件控制器,为USB-C无源电缆提供高达54 V的过压保护
【 2023 年 10 月 31 日,德国慕尼黑讯】 USB-C之所以能够在产业领域迅速普及,主要归功于其超薄的设计、对用户友好的通用连接器使用体验,以及能够支持 USB4、Thunderbolt 和 HDMI 等多种数据协议,因而用途十分广泛的优势特性。 此外,USB-C可支持高达240 W的充电功率,这一特性使其成为各种应用的首选电源连接器。现代移动设备对可靠的端到端供电和数据传输能力的需求日益增长,为了满足这一需求,英飞凌科技股份公司(FSE代码:IFX / OTCQX代码:IFNNY)推出了功能更加强大的 USB-C电子标记电缆组件(EMCA)控制器 EZ-PD™ CMG2。该控制器旨在为支持EPR(Extend
[电源管理]
英飞凌推出 EPR 电子标记电缆组件控制器,为<font color='red'>USB</font>-C无源电缆提供高达54 V的过压保护
基于USB接口的激光陀螺惯导系统数据通讯
  激光陀螺作为捷联惯性导航系统的核心器件,其性能远优越于传统的机电陀螺,已广泛应用于海、陆、空、天等军用和民用导航领域。   在激光陀螺捷联惯导系统中,惯性仪表(激光陀螺和加速度计)直接“捆绑”在载体上,所承受的力学环境要比平台恶劣。在某些军用环境所要求承受的强烈振动条件下,由于惯性组合体在力和运动的激励下产生多项误差,系统姿态和位置误差增长较快。研究表明,这些误差项有一部分具有较好的补偿性,可以通过误差补偿减小或消除部分误差,从而提高系统在强振动下的精度。这就需要将惯性仪表在振动环境下的输出数据高速采集并保存下来,然后在PC机上进行离线仿真以确定和分离各项误差系数。由于数据量庞大,无法直接存储在导航计算机中:例如以8 kHz对惯
[嵌入式]
一款USB接口的锂离子电池充电电路设计方案
摘要: 个人电脑(PC机)已得到广泛应用,而 USB 接口也已成为PC机上的标准外设接口之一。另一方面,使用锂离子电池的手机、数码相机、MP3播放器等便携设备大量涌现。如何利用随处可见的电脑USB接口为这些设备所用的锂离子电池充电,是目前USB接口应用的一个热点。 锂离子电池及USB接口概述 锂离子(Li-ion)电池,简称 锂电池 ,是近年来逐渐普及使用的一种新型电池,具有体积小、重量轻、容量大(能量密度高)、自放电率低以及无记忆效应等优点,但同时它也有一些致命的缺陷:对充电、放电的要求比较苛刻,不能过充和过放,否则容易造成不可逆转性损坏,在短路、过充等极端情况下还有可能发生爆炸,产生危险。 一般锂电池单节标称电压为316
[电源管理]
一款<font color='red'>USB</font>接口的锂离子电池充电电路设计方案
[单片机][USB_HID] USB问题汇总
不同系统请求字符串次数(三个根节点) 系统 字符串2 字符串3 windos 8 2 linux 1 3 ios 2 2 单节点只会请求2次,以上现在属于正常。 windos枚举时,每个节点都会重新重新请求字符串2。 USB ERR 0xC0000012 Bus Hound 6.01 capture on Windows Vista Service Pack 1 (x86). Complements of 返回数据过大重启 USB ERR “babble” compatibility with the USB 1.0). babble 错误. 检测到设备返回了一个无意义的数据 babble 错误. 一个
[单片机]
[单片机][<font color='red'>USB</font>_HID] <font color='red'>USB</font>问题汇总
USB PD有望一统快充技术规范,PPS加速行业标准化
传言即将发布的iPhone8会支持USB Type-C接口和USB PD协议?9月1日,在2017 USB PD快充产业亚洲高峰论坛上,据业内人士透露,iPhone8支持USB PD协议将是大概率事件。 USB PD(Power Delivery)协议可以为快充技术带来更大的灵活性,支持的充电功率最高可达到100w,被业界认为是最有希望统一目前标准各立的快充技术规范。基于USB PD 3.0形成的PPS有望实现对高通QC4.0/3.0、联发科PE3.0/2.0、华为、OPPO等主流快充方案的收编。目前USB PD协议配合USB Type-C接口广泛应用于苹果新款MacBook系列笔记本、小米笔记本,以及市面众多品牌的旗舰手机上。
[手机便携]
基于无线USB技术的系统开发与应用
  由于USB技术在最近几年已成长为PC主流的技术标准,几乎所有的外设都可以借助USB接口轻易地与PC机相连。2004年,包括惠普、英特尔、微软、NEC、飞利浦半导体、三星电子在内的多家大公司成立了WUSB(无线USB)促进联盟,旨在将USB的使用变得更加简便——去掉电缆,实现无线USB技术。为了给用户提供一种低成本的WUSB射频系统解决方案,Cypress Semiconductor公司最近推出了低成本的芯片级远距离2.4 GHz射频系统——WirelessUSB LR(CYWUSB6935)方案。该方案可以在半径50 m甚至更大的范围内为用户提供在众多有线应用中快速实现无线连通的途径。与Zigbee和蓝牙等复杂且昂贵的无线网络方
[嵌入式]
USB芯片价格猛跌 惠荣拟与中芯国际合作生产
1月3日消息,据境外媒体消息,行业消息来源称,位于中国台湾的IC设计公司慧荣科技(Silicon Motion)正与中芯国际公司谈判USB闪存控制器集成电路的制造事宜。 行业消息来源说,USB控制器芯片价格下跌可能驱使更多的IC设计公司将产品外包给中国大陆企业。 消息来源指出, 在UCB控制器集成电路方面,中芯国际公司已与Phison电子公司进行了合作。Phsion电子在去年决定将中芯国际列入合作伙伴名单,合作伙伴中还有联华电子公司(UMC)—旨在分散供应链风险。 目前USB控制芯片价格已降至0.35美元,而2004年底是1.6美元,05年三季度是0.6美元。 然而消息来源还指出,目前不能确定位于台湾的IC设计商是否能与中国
[焦点新闻]
智能寻位加工技术中USB接口数据传输方式的应用研究
    摘 要: USB(通用串行总线)作为计算机领域新型成熟的外围设备接口,具有传输速度快、易扩展性、即插即用、支持热拔插等优点,为整个智能寻位加工技术的实现作出重要保证。     关键词: 寻位加工 数控通讯 通用串行总线(USB)     智能寻位加工技术 是一种新型加工方法,其实现思路是利用主动寻位方法获取被加工零件的三维空间位姿,并以该信息为引导,基于CAD模型库,自动生成数控加工程序,通过实现能顺应现实加工的设备完成对零件的无精确定位束缚的加工。它强调多学科信息融合,广泛采用自动控制、计算机、数控等领域最新最成熟的相关技术,促进机械制造领域的发展。     该加工方法的一个重要的基础条件是
[应用]
小广播
最新嵌入式文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved