原创 12

2009-1-4 14:33 3294 10 11 分类: 处理器与DSP
68013的硬件调通到现在应该有一年了吧,眼见课题就要结题了,今日重新拿起设计,发现很多问题还是没有解决,不能在拖了!
现在遇到的门槛是在异步autoin模式下,FIFO的FLAG都起了变化,说明FPGA已经把数据写进FIFO了,但用Bushound检测不到任何数据变化,现在怀疑的重点就落在了固件程序上,因为对固件的整体把握不够,基本是照虎花猫写出来的,所以最不放心的就是她了。

将要遇到的问题:上位机软件的编制
对labview已经比较熟了,前面也做了很多工作,搜集了用VISA都USB数据的资料,大概有了了解,但还是心里面没谱。

需要重头在来的问题:
看看了以前的FPGA程序,怎么看都觉的不舒服,文档记录很是糟糕,好多都记不住了,所以决定有条理的重新来过,模块化,图形化程序。

一下文章转载至驱动开发网

请使用68013的slave fifo方式的大侠帮个忙



CPUCS = 0x12; // CLKSPD[1:0]=10, for 48MHz operation
// 01 for 30MHz,00 for 12MHz,11 reserved
// CLKOE="0", don't drive CLKOUT

IFCONFIG = 0x03; //IFCFG[1:0]=11 for Slave FIFO

SYNCDELAY; // see TRM section 15.14
REVCTL = 0x03; // use enhanced packet

// EP2 512 BULK OUT 4x
SYNCDELAY; //
EP2CFG = 0xA0; // BUF[1:0]=00 for 4x buffering;

// EP6 512 BULK IN 4x
SYNCDELAY; //
EP6CFG = 0xE0; // BUF[1:0]=00 for 4x buffering;

// EP4 and EP8 are not used in this implementation...
SYNCDELAY; //
EP4CFG = 0x20; // clear valid bit
SYNCDELAY; //
EP8CFG = 0x60; // clear valid bit

SYNCDELAY; //
FIFORESET = 0x80;  // activate NAK-ALL to avoid race conditions
SYNCDELAY; //
FIFORESET = 0x02; // reset, FIFO 2
SYNCDELAY; //
FIFORESET = 0x04; // reset, FIFO 4
SYNCDELAY; //
FIFORESET = 0x06; // reset, FIFO 6
SYNCDELAY; //
FIFORESET = 0x08; // reset, FIFO 8
SYNCDELAY; //
FIFORESET = 0x00; // deactivate NAK-ALL

// 8-bit bus (WORDWIDE=0)...

// use manual out mode...
SYNCDELAY; //
EP2FIFOCFG = 0x00; // OEP1=0,AUTOOUT=0, WORDWIDE="0"

SYNCDELAY; //
OUTPKTEND = 0x82; // arm first buffer
SYNCDELAY; //
OUTPKTEND = 0x82; // arm second buffer
SYNCDELAY; //
OUTPKTEND = 0x82; // arm third buffer
SYNCDELAY; //
OUTPKTEND = 0x82; // arm fourth buffer

// use auto in mode
SYNCDELAY; //
EP6FIFOCFG = 0x4C; // INFM1=1,AUTOIN=0, ZEROLENIN="0", WORDWIDE="0"

//set program flag
PINFLAGSAB = 0x8C; // see p341 of TRM,FLAGB is EP2EF,FLAGA is EP2FF
SYNCDELAY;
PINFLAGSCD = 0xAE; // see p341 of TRM,FLAGD is EP6EF,FLAGC is EP6FF
SYNCDELAY;
PORTACFG = 0x80; // use PA7/FLAGD as a fifo flag

AUTOPTRSETUP |= 0x07;
EPIRQ = 0xFF; //clear all interrupt bit

这是我的程序,当EP2FIFOCFG的autoout=1时,为什么不能向68013写数据。如果还有其它的问题,也请指教。EP2FF标志1是full,0是not full是吗?请帮忙指出。谢谢!



  1. 这是我的程序,当EP2FIFOCFG的autoout=1时,为什么不能向68013写数据。如果还有其它的问题,也请指教。EP2FF标志1是full,0是not full是吗?请帮忙指出。谢谢!

    我没看你的程序,因为那些寄存器定义已经忘记了,只是说说我的建议
    1,当autoout=1时,主机和外部设备直接连接,68013的8051失效,此时外部设备是master,也就是说读写时序要有外部设备产 生,你不能向68013写数据是不可能的,原则上说你至少可以写两个512的数据进去,然后就写不下去了,你可以验证一下是不是这样

    如果是这样,并且你的68013工作正常,那么只有一个可能,你的外部设备没有读走数据,可能的原因是时序不匹配或者读信号或者片选信号没有!

    2,如果你没有专门的设定相关寄存器,所有的标志默认的都是低有效的,所以应该是0是full,1是not full!

    个人见解,欢迎批评指正


  2. 需要根据Cypress提供的流程来处理,否则会出现问题的。
    // (2)...when REVCTL.1=1, core blocks auto arming of OUT endp's
    // ...see above EPxBCL/OUTPKTEND sequence(s)
    // ...sequence is as follows:
    // ...(a) REVCTL.1=1
    // ...(b) FIFORESET (as above)
    // ...(c) EPxBCL/OUTPKTEND (as above)
    // ...(d) AUTOOUT="1"


随着现代科学技术的发展和计算机技术的普及,高速数据采集系统已应用于越来越多的场合,如通信、雷达、生物医学、机器人、语音和图像处理等领域。本文介绍的数据采集处理系统采用CPLD控制ADS8364完成数据的A/D转换,转换后的数据预先存储到FIFO中,再经DSP进行前端的数字信号处理后,通过USB总线传给上位机,并在上位机上进行存储、显示和分析等。该系统完全可以满足信号采集处理对高精度及实时性的要求。


中*国*电*子*网 www#dianzi#cn


  1 系统原理


中+国+电+子+网 www.d+i+a+n+z+i.+cn


  数据采集处理系统主要由前端信号调理电路、ADC芯片ADS8364、CPLD芯片EPM3128A、DSP芯片TMS320F2812、USB芯片CY7C68013及其外围电路组成。系统原理框图如图l所示。


中*国*电*子*网 www#dianzi#cn



0105460.jpg


中国电子网 www.dianzi.cn


  系统主要完成的任务为:DSP接收上位机通过USB总线发送的命令,完成系统工作参数的设置,并通过模拟地址/数据总线与CPLD进行通信,向CPLD发送控制命令;对外部的多路模拟量输入进行信号调理,在CPLD控制下进行单通道或多通道A/D转换,将采集到的数据存储在一片FIFO芯片中;当FIFO中存储的数据半满时,对DSP产生一个中断信号,DSP收到此中断信号后,取出FIFO中的部分数据,进行前端数字信号处理,将处理完毕的数据通过USB总线传给上位机;上位机实现各种图形界面操作和后端信号处理,对所采集的信号进行分析。系统可对输入的多路模拟信号进行同步采样,这就使得采集到的数据不仅含有模拟信号的幅度特性,同时还保持不同模拟信号之间的相位差异;采样频率可以预置,以适应不同速率的采样要求。 中国电子网 www.dianzi.cn


  2 系统硬件


中+国+电+子+网 www.d+i+a+n+z+i.+cn



  系统硬件包括信号调理模块、A/D转换模块、DSP处理器模块、CPLD逻辑控制模块以及USB通信模块。 中`国`电`子`网 www.d`i`a`n`z`i.cn


  2.1 信号调理模块的设计 中\国\电\子\网 w w w.di an`zi.cn


  外部的多路模拟量输入信号往往是微弱的传感器信号,信号的幅值较小,为了方便且不失一般性,假定其幅值范围为O~25mV。ADS8364待转换的模拟输入电压范围应保持在AGND-0.3V和AVDD+O.3V之间。这里选用低功率变增益仪表放大器INAl29对模拟量输入信号进行调理放大,将其放大为0~5V之间。 中`国`电`子`网 www.d`i`a`n`z`i.cn


  INAl29是BURR-BROWM公司的一种小功率通用仪表放大器,具有优异的精度和很宽的带宽,在增益高达100时,带宽达200kHz。它可用单一外部电阻器调节其增益,调节范围为l~10000,其放大倍数计算公式为:


中国电子网 www.dianzi.cn



0105461.jpg


中#国#电#子#网 www#dianzi#cn



  从而使放大输出电压在O~5V之间。信号调理模块原理图如图2所示。 中,国电,子网 www@dian zi@cn


0105462.jpg


中`国`电`子`网 www.d`i`a`n`z`i.cn



  2.2 A/D转换模块的设计


中_国_电_子_网 www.d i a n z i.cn



  该模块采用了TI公司的高速、低功耗、六通道同步采样模/教转换器ADS8364,它采用+5V工作电压,其6个模拟输入通道分为三组(A,B和C),每组都有一个ADCs保持信号(HOLDA,HOLDB和HOLDC),用来启动各组的AID转换,6个通道可以进行同步并行采样和转换。ADS8364采用具有80dB共模抑制能力的全差分输入通道,将其REFin和REFout引脚接到一起,为差分电路提供2.5V的参考电压。这里模拟量采用单端输入,将-IN端接共模电压2.5V,+IN端接前端信号调理模块的输出。


中`国`电`子`网 www.d`i`a`n`z`i.cn



  ADS8364的时钟信号由外部提供,最高频率为5MHz,对应的采样频率是250kHz。这里由CPLD提供时钟信号,主要是考虑到CPLD可以灵活地改变时钟频率,进而改变系统的采样频率。A/D转换完成后产生转换结束信号EOC。将ADS8364的。BYTE引脚接低电平,使转换结果以16位的方式输出。地址/模式信号(A0,Al,A2)决定ADS8364的数据读取方式,可以选择的方式包括单通道、周期或FIFO模式。将ADD引脚置为高电平,使得读出的数据中包含转换通道信息。考虑到数据采集处理系统的采样频率一般较高,如果用DSP直接控制ADS8364的访问,将占用DSP较多的资源,同时对DSP的实时性要求也较高。因此在本系统设计中,用CPLD实现ADS8364的接口控制电路,并将转换结果存储在FIFO芯片中,用DSP实现FIFO芯片的输出接口。 中^国^电^子^网 w^w^w.d^i^a^n^z^i.c^n


  DSP、CPLD、ADS8364及FIFO之间的接口设计如图3所示。


中国电子网 www.dianzi.cn



0105463.jpg 中\国\电\子\网 w w w.di an`zi.cn


  2.3 DSP处理器模块的设计


中#国#电#子#网 www#dianzi#cn


  DSP主要负责与USB通信模块交换数据、以模拟地址/数据总线的方式与CPLD通信,实现对数据采集的控制,完成与FIFO芯片的输出接口以及对采样后的数据进行前端数字信号处理(FIR低通滤波)。这里选用TI公司的32位定点DSP TMS320F2812 (以下简称F2812),它采用1.8V的内核电压,具有3.3V的外围接口电压,最高频率150MHz,片内有18K字的RAM,128K字的高速Flash。


中*国*电*子*网 www#dianzi#cn


 2.4 CPLD逻辑控制模块的设计 中_国_电_子_网 www.d i a n z i.cn


  在该数据采集处理系统中,CPLD是一个重要的组成部分。由CPLD组成的逻辑控制模块接收DSP传送过来的动作命令,控制A/D转换模块进行数据采集,并提供对FIFO的接口时序,实现转换数据的存储。这里选用Altem公司的EPM3128A芯片,它共有128个宏单元,2500个可用门。 中%国%电%子%网 www%dian'zi%cn



中.国.电.子.网 www-dianzi-cn



  CPLD作为一个单独的控制执行结构.通过编写相应的Verilog HDL代码,即可生成相应的操作电路,实现对各种输入信号的锁存、判断和处理以及对各种命令信号的执行和输出信号的控制。


中\国\电\子\网 w w w.di an`zi.cn



  2.5 USB通信模块的设计 中^国^电^子^网 w^w^w.d^i^a^n^z^i.c^n


  这里选用CYPRESS公司的EZ-USB FX2系列中的CY7C68013作为USB通信控制器芯片,它内含增强型8051微控制器,支持USB2.0传输协议,同时也向下兼容USBl.1规范。该芯片把USB2.0收发器、SIE(串行接口引擎)、增强型8051微控制器、I2C总线接口以及GPIF(通用可编程接口)集成于一体。CY7C68013提供了SlaveFIFO和GPIF两种接口模式,Slave FIFO模式是从机模式,外部控制器可以像对普通FIFO存储器一样对FX2的多层缓冲FIFO存储器进行读写;GPIF模式是主机模式,可以由软件设置读写的控制波形,灵活性很大。这里采用的是Slave FIFO模式。


中*国*电*子*网 www#dianzi#cn


  3 系统软件设计 中%国%电%子%网 www%dian'zi%cn


  系统软件设计包括DSP程序设计、USB固件程序设计、USB驱动程序设计和上位机应用程序设计。 中,国电,子网 www@dian zi@cn


  3.1 DSP程序设计


中#国#电#子#网 www#dianzi#cn



  DSP编程的主要任务是初始化、管理板上的资源和实现前端数字信号处理的算法。这里以TI公司提供的功能强大的CCS(Code Composer Studio)为集成开发环境。系统上电复位后。首先完成F2812自身的初始化,包括配置RAM块,设置I/O模式、定时器模式、中断等;然后程序进人循环状态,等待USB及FIFO的中断。F2812主程序流程图如图4所示。


中\国\电\子\网 w w w.di an`zi.cn



0105464.jpg 中国电子网 www.dianzi.cn


  在F2812的程序存储器中存储常用的数字信号处理算法,F2812在收到上位机通过USB总线发送的控制信息后,在中断函数中选择某种处理算法,同时向CPLD发出动作命令,控制A/D转换模块完成信号的采集并将采集到的数据存入FIFO中。当FIFO中数据达到半满时,向F2812提出中断申请,F2812响应此中断,在中断函数中实现对部分采样数据的读取,在主循环程序中根据上位机选定的处理算法完成数据的前端处理,然后将数据打包,通过USB总线传输给上位机。对于常用的数字信号处理算法在DSP上的实现,这里不再赘述。 中*国*电*子*网 www#dianzi#cn


  3.2 USB固件程序设计 中*国*电*子*网 www#dianzi#cn


  固件负责辅助硬件让设备双向交换数据,其主要功能是:接收并处理USB驱动程序的请求及应用程序的控制指令。CYPRESS公司针对EZ-USB FX2系列芯片给出了一个Firmware库和Firmware框架(Frame Works),均采用Kei C5l开发。Firmware库提供了一些常量、数据结构、宏定义、函数来简化用户对芯片的使用。用户只需要在源程序中包含进fx2.h、fx2regs.h和fx2sdly.h,并且把Ezusb.1ib和UsBJmpTB.obj添加进项目即可。Firmware框架实现了初始化芯片、处理USB标准设备请求以及挂起状态下的电源管理等功能。该框架无需添加任何代码,将编译后产生的*.hex文件载入芯片就能与主机进行基本的USB通信,只是不能完成特定的任务。在本系统中,需要选择适当的传输方式,添加需要使用的端点(Endpoint),在框架预留的地方(如TD_Init()、TD_Poll()等函数中)添加初始化代码和完成特定功能的代码。


中_国_电_子_网 www.d i a n z i.cn



  USB共有四种数据传输方式:控制传输、中断传输、块传输及同步传输,本系统中使用了控制传输和块传输。控制传输主要用来完成主机对设备的各种控制操作,即用来实现位于主机上的USB总线驱动程序以及编写的功能驱动程序对设备的各种控制操作;块传输主要用来完成主机和设备间的大批量数据传输以及对传输的数据进行错误检测(支持“错误重传”功能)。 中`国`电`子`网 www.d`i`a`n`z`i.cn


  3.3 USB驱动程序设计


中*国*电*子*网 www#dianzi#cn


  CYPRESS FX2开发包中提供了一个通用的设备驱动程序Ezusb.sys,可用于基于EZ-USB FX2系列的芯片,能够完成基本的USB通信任务。本系统设计中,利用DDK对上述驱动程序进行了修改,将不常用的函数删除,同时添加了自己定义的函数。 中,国电,子网 www@dian zi@cn


 3.4 上位机应用程序设计 中_国_电_子_网 www.d i a n z i.cn


  上位机应用程序主要实现与数据采集处理系统间的USB通信、向系统发送控制命令以及接收系统传送过来的数据并进行存储、处理与显示。在Win32系统中,各个设备被抽象为文件,应用程序通过文件操作API函数实现与驱动程序中某个设备的通信。USB通信常用的API函数有;CreateFile(),WriteFile(),ReadFile(),DeviceloControl(),CloseFile()等。在应用程序中,只需将上述函数添加到相应的功能模块中便可完成应用程序对USB设备的打开、读、写等操作,从而实现两者的通信。采用LabVIEW语言实现USB通信及仪器界面,而对于后端的信号处理算法则在VC++环境下实现并生成动态链接库文件(*.d11),方便LabVIEW的调用。图5为上位机上层应用程序的流程图。 中\国\电\子\网 w w w.di an`zi.cn


  中\国\电\子\网 w w w.di an`zi.cn


0105465.jpg


中*国*电*子*网 www#dianzi#cn



  本文将TMS320F2812与ADS8364相结合,设计了一套数据采集处理系统。该系统采用uSB总线与上位机通信,充分发挥了USB2.O方便、快捷的优点;考虑到对实时性的要求,将某些特定的数字信号处理算法(如FIR滤波、快速FFT等)放到数据采集处理卡上由DSP快速完成。该系统采集精度高,速度快,并可同时采集多路信号。实践证明,该数据采集处理系统可适用于高精度、实时性信号的数据采集和处理,具有广泛的实用价值。

PARTNER CONTENT

文章评论1条评论)

登录后参与讨论

用户112450 2009-3-15 12:11

请问你的问题搞定了么?跟你遇到相似的问题,想知道你怎么解决的,谢!
相关推荐阅读
用户208507 2011-06-02 09:13
负载
1 引言 随着国内变频器技术的飞速发展,变频器生产厂家的迅速崛起,变频器的应用大户、制造厂家迫切需要变频器性能测试,优化加载设备。如何选择有效的测试机组成为一个值得研究的课题。     2...
用户208507 2010-05-26 16:56
变频器论坛
变频器假负载如何连接:W~4R~(\ FP 假负载连接在直流储能电容与三相IGBT之间,在电路中一般为连接铜排或快熔,有快熔的直接连接即可,无快熔拆去一段连接铜牌即可,实际上就是将三相逆变IBGT正电...
用户208507 2010-05-26 16:41
变频器1
最近维修一台三菱A540-55K变频器,是一位维修新手维修不好才拿到我们这里来,这台机本来是坏了一个模块,换好模块后,这位新手想测量驱动是否正常,把模块触发线拨掉,结果一通电就跳闸,检查后发现又烧掉一...
用户208507 2010-05-25 15:51
变频器
变频器过压保护只是停止输出,不能保护本身不烧毁!当压敏电阻烧通时,这时要求空气开关动作,否则变频器其它元件也会烧掉,    变频器使用时对其它电子设备的干扰是一个头痛的问题,如果你是第一次使用,又不知...
用户208507 2009-03-03 09:36
TLC2274新的电流采样方案
基于TLC2274新的电流采样方案及其在DSP中的实现广东工业大学自动化研究所郭 建 张新政摘要:介绍了一种新的电流采样方案,提出了实用电路,阐述其工作原理,并给出了在TMS320LF240x DSP...
用户208507 2009-03-02 08:17
2407
基于TMS320LF2407A的直流脉宽调速系统设计[作者:许又泉 夏卫锋 唐旭 林立????转贴自:微计算机信息????点击数:81????更新时间:2008-12-4【字体:?????A?】PWM...
我要评论
1
10
关闭 站长推荐上一条 /3 下一条