ARM Cortex-A8/A9开发板 | ARM11开发板ARM11开发套件 | ARM9开发板ARM9开发套件 | 飞思卡尔I.MX28I.MX6开发板 |
tiny210/mini210开发板 | mini6410开发板/套餐 | Tiny6410开发板无线套件 | mini2440开发板/套餐 | micro2440开发板带核心板 | 友善开发板配件 模块 | QQ2440 V3 SBC-2410X |
FL2440 OK2440-IV V4 | OK2440-III OK2440V3 | TE2440-II TE2440V2 | OK6410 S3C6410 ARM11 | FL6410/OK6410B ARM11 | TE6410 S3C6410 ARM11 | TE-9263 AT91SAM9263 | 开发板配件 模块和其他 |
Xilinx开发板/fpga开发套件 | altera开发板/fpga开发套件 | 基于FMC FPGA/DSP子卡 |
BeagleBoard原厂开发板 | PandaBoard原厂开发板 |
TI DM3730 DevKit8500D | TI系列 omap3530开发板 | ATMEL系列 开发板 | Samsung系列 开发板 | 开发板配件-仿真器 模块 | NXP LPC3250 mini3250 |
Tiny210 三星S5PV210 | Mini210/Mini210s开发板 | Tiny4412开发板Cortex-A9 | Tiny6410开发板 ARM11 | mini2440开发板 ARM9 | micro2440开发板 ARM9 | mini6410开发板 ARM11 | 友善ARM开发板配件 模块 |
keil ARM仿真器/开发工具 | STM32开发板 Cortex-M3 | NXP LPC开发板Cortex-M3 | ATMEL系列 ARM开发板 | Luminary EKK8962开发板 | Freescale i.MX31开发板 | 三星s3c2440 s3c6410开发板 |
FL2440 OK2440-IV V4 | OK6410 S3C6410 ARM11 | FL6410/OK6410B ARM11 | OK210/-A Cortex-A8 | TE2440-II TE2440V2 | TE6410 S3C6410 ARM11 | TE-9263 AT91SAM9263 | ARM开发板配件 模块等 |
Real6410开发板/套餐 | Real210开发板/Real2410 | WIFI GPS GPRS模块摄像头 |
Xilinx开发板/开发套件KIT | Altera开发板/开发套件KIT | 配套模块 |
NXP LPC开发板 ARM7 | Cortex-M3 STM32开发板 | 最小系统模块类(初学者勿选) | 开发工具 仿真器 调试器 | TFT液晶屏LCD 液晶模块 |
DM642开发板/DM642实验箱 | DM6446开发板/DSP实验箱 | DSP仿真器 液晶屏 摄像头等 |
DM3730/AM3715/AM3359 | OMAP3530AM1808AM3517 | 飞思卡尔Cortex-A9开发板 | ATMEL系列ARM开发板 | NXP LPC3250 LPC1788 | Samsung系列ARM开发板 | STM32系列F207/F407 | ARM开发板配件-仿真器 模块 |
Realv210 S5PV210开发板 | Real6410开发板 ARM11 | WIFI GPS GPRS模块摄像头 |
NXP LPC开发板 ARM7 | Cortex-M3 STM32开发板 | ARM小系统模块(初学勿选) | 开发工具 ARM仿真器 调试器 | TFT液晶屏LCD 液晶模块 |
keil ARM仿真器/开发工具 | STM32开发板 Cortex-M3 | NXP LPC开发板Cortex-M3 | ATMEL系列 ARM开发板 | Luminary EKK8962开发板 | Freescale i.MX31开发板 | 三星s3c2440 s3c6410开发板 |
Exynos4412开发板A9四核 | UT-S5PV210 S5PC100 | UT-S3C6410开发板 ARM11 | idea 6410开发板 ARM11 | UT-S3C2450开发板 ARM9 | UT-S3C2416开发板 ARM9 | UT-S3C6410核心板 工控 |
Xilinx开发板 FPGA开发套件 | altera开发板 FPGA开发套件 | FMC模块 配件 下载线 |
DM642开发板/DM642实验箱 | DM6446开发板/DSP实验箱 | DSP仿真器 液晶屏 摄像头等 |
s3c2410 ARM9 FS2410 | s3c2440开发板 ARM9 | s3c44B0开发板 ARM7 | s3c6410 2450 2443/13 | PXA270 PXA320 PXA255 | Atmel 9200 9261 9G20 | Philips NXP开发板YL-LPC | FS-EP9315开发板ARM9 | LCD液晶屏TFT真彩/触摸屏 | ARM仿真器/仿真调试工具 | ARM开发板配套ARM核心板 |
三星s3c2410 s3c44B0 | 三星s3c6410 s3c2443 | Intel PXA270 PXA320 | UP-CUP OMAP5910平台 | FPGA Xilinx altera平台 | 配件-仿真器 模块 液晶屏LCD | 龙芯开发板UP-DRAGON-I | 物联网教学科研设备 | EDA/FPGA/SOPC教学科研 |
utu2440-F-V4.5 含核心板 | utu2440-S-V4.1 单板结构 | YC2440-F-V5.1开发板 豪华型 | YC-ePC-A系列人机界面 | Mars-EDA套件CPLD FPGA | 触摸屏LCD 摄像头 WI-FI模块 |
ARM开发板/开发平台 | FPGA开发板/开发平台 | 编程器/烧写器下载器烧录 | ZLG 仿真器ARM FPGA DSP | ZLG周立功逻辑分析仪 |
DSP初学者开发套件(DSK) | DSP仿真器/仿真系统 | DSP开发板/DSP试验箱 | DaVinci系列多媒体平台 | Xilinx FPGA大学计划产品 | SEED教学实验系统 | FPGA/DSP FPGA开发板 | TI原厂开发板套件/CCS软件 |
ARM开发板 | XSCALE开发板 | ARM仿真器 | SOPC开发板 | DSP开发板 | 达芬奇系列DSP开发平台 | DSP仿真器 | DSP实验箱 | DSP专业研究平台 | ARM实验箱系列 |
广嵌实验室项目产品 | GEC2440/GEC6410开发板 |
泰克Tektronix示波器 | 普源RIGOL示波器 | USB虚拟示波器 |
UT-S5PC100 UT-S5PV210 | UT-S3C6410开发板 ARM11 | idea 6410开发板 ARM11 | UT-S3C2450开发板 ARM9 | UT-S3C2416开发板 ARM9 | UT-S3C6410核心板 工控 | 开发板模块wifi gps等 |
EMA OMAP3530开发板 | EMA OMAP 3530核心板 |
三星s3c2410 s3c44B0 | 三星s3c6410 s3c2443 | Intel PXA270 PXA320 | UP-CUP OMAP5910平台 | FPGA Xilinx Altera平台 | 配件-仿真器 模块 液晶屏LCD | 龙芯系列 UP-DRAGON-I |
utu2440-F-V4.5 含核心板 | utu2440-S-V4.1 单板结构 | YC2440-F-V5.1开发板 豪华型 | 触摸屏LCD 摄像头 WI-FI模块 | Mars-EDA套件CPLD FPGA | ePC系列工控一体机ARM9 A8 |
ARM开发板/开发平台 | FPGA开发板/开发平台 | 编程器/烧写器下载器烧录 | ZLG 仿真器ARM FPGA DSP | ZLG周立功逻辑分析仪 |
DSP初学者开发套件(DSK) | DSP仿真器 | DSP开发板 | DSP实验箱 | Xilinx FPGA大学计划产品 |
ARM开发板 | XSCALE开发板 | ARM仿真器 | SOPC开发板 | DSP开发板 | 达芬奇系列DSP开发平台 | DSP仿真器 | DSP实验箱 | DSP专业研究平台 | ARM实验箱系列 |
ARM开发板S3C6410等 | Cortex-A8/ARM11仿真器 | ADSP Blackfin开发板 | FPGA Spartan-3E开发板 |
GEC2410开发套件ARM9 | GEC2440开发套件ARM9 |
泰克 示波器 |
小序
数据征求卡(DAQ)的存储空间是体系计划的一个紧张的硬件资源,对采样速率、及时处理惩罚性与体系成果都有很大的影响。在假造频谱仪计划中,信号采样数据的存储、DSP阐发、处理惩罚信号步伐,都必要有充足内存空间。由于该仪器信号征求数据量大,DSP所实现的成果多,导致出现存储空间不敷。针对上述题目,本文谈谈怎样基于LabVIEW通过CLFN调用DLL加载DSP 目标文件(*.out),从而在肯定的步伐存储空间环境下来完成基于DSP数据征求卡的假造仪器的研制。
LabVIEW中的CLFN
LabVIEW步伐由三部分构成:前外观、框图步伐和图标/连接器。步伐前外观用于设置输入量和观丈量,模仿真实仪器的前外观;每一个步伐前外观都有相应的框图步伐与之映射,框图步伐用图形编程语言编写。图标/连接端口可以让用户把VI步伐定义为一个子步伐,从而实现模块化编程。
调用库函数节点(Call Library Function Node,CLFN)是一个图形化节点,是LabVIEW调用C语言编写的可实行步伐代码的一个通用的要领,常用于调用动态连接库(DLL),这种方法分外得当于用户创建实现本身特定成果的DLL。但是对C语言的编译必须通过外部的开辟平台环境,在Win9x/NT下可以利用Microsoft Visual C++软件平台。
用CLFN调用DLL来实现DSP 目标文件加载,扼要步调如下:
(1)在LabVIEW步伐框图中安排一CLFN节点。对CLFN设置,创建函数原型:unsigned char dspload(CStr coffname)。此中coffname 是被加载的DSP 目标文件名(*.out),unsigned char 是函数dspload返回值error的范例,返回值为0,表明DSP目标文件加载告成,别的值表明加载失败。
(2)在Microsoft Visual C++环境下创建DLL工程,从而天生dspload.dll文件。
在源步伐中必须包括头文件:extcode.h和evm6xdll.h。前者是LabVIEW调用外部代码办理函数集的头文件,后者是DSP数据征求卡的DLL的头文件。
(3)设置前外观参数并完成框图步伐,将DSP目标文件加载的前外观与相应的框图步伐,生存为dspload.vi。实行步伐dspload.vi前,输入目标文件名(*.out)。
DSP数据征求卡
所用的数据征求卡是美国TI公司的TMS320C6701 DSP数据征求卡,方框图如图1所示。
DSP数据征求卡的特点有:
PCI总线接口,支持即插即用;通过HPI(Host Port Interface)访问DSP内存;16-bit音频编解码器,支持5.5kHz~48kHz采样率;三种DSP boot 模式:无自举模式,HPI 自举模式,ROM 自举 模式;256kB同步突发静态RAM (SBSRAM);8MB同步动态RAM (SDRAM)。
TMS320C6701是浮点型DSP,片内有8个并行的处理惩罚单位,分为雷同的两组。8个独立的成果单位采取加载/存储(load/store)体系布局,数据在多处理惩罚单位之间的传输寄托32个32bit通用寄存器。
DSP的体系布局采取甚长指令字(VLIW)布局,8个指令构成一个指令包,总字长为256 bit。芯片内部设置了专门的指令分派模块,可以将每个256bit的指令包同时分派到8个处理惩罚单位,并由8个单位同时运行。芯片最大处理惩罚本领可以到达2400MIPs。
C6701的存储器寻址空间为32bit,片内RAM被分为内部步伐/Cache存储器和内部数据/Cache存储器。当片内的RAM容量不餍足体系的步伐/数据空间请求时,可利用外存储器接口(External Memory Interface,EMIF)在片外举行存储器扩展。EMIF整个外部空间最大容量为64MB,分为4个空间CE0~CE3。
HPI(Host-Port Interface)是一个16bit 的并行接口,外部主机可以通过HPI直接访问CPU的存储空间。外部的主机是该接口的主控者。
HPI存取的接口由一套寄存器来实现。HPI控制寄存器HPIC(HPI Control Register)完成对接口的设置,主机和CPU都可以访问HPIC;外部主机进一步通过主机地点寄存器HPIA(Host Address Register)和主机数据寄存器HPID(Host Data Register)来完成对CPU存储空间的访问。主机对这些寄存器的访问是通过外部的控制信号实现的。
HPI到CPU的存储空间的连接由DMA控制器完成。在C6701中有专门的DMA帮助通道完成数据传输任务。
软件计划
在DSP数据征求卡与LabVIEW 的接口应用中重要利用CLFN来实现此成果:PC机通过HPI接口把文件名为*.out可实行文件装载到DSP步伐存储空间,之后DSP实行该文件。
DSP boot模式设置为HPI 自举。HPI自发难情原理如下:在自举时,内核CPU停顿在复位状态,硬件别的部分均保持正常状态。在这时期,外部主机通过HPI初始化CPU的存储空间。主机完成全部的初始化事变后,将HPI控制存储器中的DSPINT设置为1,结束自举进程。此时CPU退出复位状态,开始实行地点0处的指令。HPI自举进程中,主机可以对DSPs全部的存储空间举行读和写。
在软件计划中,打开数据征求卡,以获取征求卡的句柄;复位DAQ卡之后,设置HPI自举模式,使DSP处于复位状态;这时要是DSP与HPI创建了连接,并且DMA帮助通道的优先级比DSP高,通过调用函数evm6x_coff_load把coffname所指定的目标文件加载到DSP内存中。一旦DSP不处于复位状态时,DSP就开始实行被加载的文件。
结语
通过CLFN调用DLL加载DSP目标文件从而节流数据征求卡的内存空间的要领已经应用到吉林大学-TI DSPs实行室的假造频谱阐发仪中。由于DSP加载步伐是C语言步伐,因此可移植性好。别的,可看出通过调用库函数节点CLFN,将C语言同LabVIEW中编程直观方便的图形化G语言连合起来,以加快步伐运行速率,进步软件性能,并方便步伐模块共享,节流编程时间。
参考文献:
1. TMS320C6201/6701 Evaluation Module Technical Reference, Texas Instruments, 1998.
2. 任丽香,马淑芬,李方慧,TMS320C6000系列DSPs的原理与应用,北京:电子产业出版社,2000.
3. 张雄伟,曹铁勇,DSP芯片的原理与开辟应用(第2版),北京:电子产业出版社,2001.
4. Using External Code in LabVIEW, National Instruments, 2000.
5. 袁渊,古军,假造仪器底子教程,电子科技大学出版社,2000
博航网 www.broadon.net 版权所有
京ICP备10051899号-2 京公网安备110108006479号