微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 探讨研华32位DLL驱动程序

探讨研华32位DLL驱动程序

时间:05-14 来源:互联网 点击:

摘要:本文概述了研华32位DLL驱动程序的构成,并对利用驱动程序开发动态数据采集程序所涉及的部分概念和一些重要参数进行了详细的分析,对利用32位驱动程序有实用价值。

关键词:32位DDL驱动程序动态数据采集

1引言

研华公司是台湾和中国大陆工业电脑产品最大的供应厂商,其PCWeb-based数据采集和控制产品更是以优良的性价比获得了众多的客户的青睐。32位DLL驱动程序是研华为诸如VC,VB,DELPHI,BorlandC++,C++Builder等高级语言提供的接口,通过这个驱动程序,编程人员可以方便的对硬件进行编程控制。该驱动程序覆盖了每一款研华的数据采集卡以及MIC-2000、ADAM-4000和ADAM-5000系列模块,应用极为广泛,是编制数据采集程序的基础。虽然该驱动程序的功能强大,但是研华公司为其提供的产品手册对该驱动程序的讲解却不够详尽,让使用者,有只能修改例子来达到目的的感觉,一些重要函数的参数设置缺乏相应说明。对其使用的概念有些解释不够清楚……。本文是在实际编写动态数据采集程序中经验的积累,对利用32位驱动程序有实用价值。

232位驱动程序概览

32位驱动程序主要包括10类函数及其相应的数据结构,这些函数和数据结构在Adsapi32.lib中实现。这10类函数分别是:

DeviceFunctions设备函数

AnalogInputFunctionGroup模拟输入函数组

AnalogOutputFunctionGroup模拟输出函数组

DigitalInput/OutputFunctionGroup数字输入/输出函数组

CounterFunctionGroup计数器函数组

TemperatureMeasurementFunctionGroup温度测量函数组

AlarmFunctionGroup报警函数组

PortFunctionGroup端口函数组

CommunicationFunctionGroup通信函数组

EventFunctionGroup事件函数组

可以把这10类函数分为两个部分:设备函数部分(只包括第一类函数)和操作函数部分(包括第一类函数外的所有函数),设备函数部分负责获取硬件特征和开关硬件。而操作函数部分则在硬件设备就绪以后,进行具体的采集、通信、输出、报警等工作。具体工作结束后,调用设备函数关闭设备。这些函数的调用过程如图1所示。

3动态数据采集程序的实现

用32位DLL驱动程序实现动态数据采集程序时,按触发方式可以有中断触发,DMA触发和看门狗触发三种方式可选。DMA触发方式下的编程难度较大,而看门狗触发方式是PCL1800特有的触发方式,所以中断触发方式是最常用的触发方式。

在各种高级语言下,驱动程序提供的函数形式相同,所以此处只给出驱动程序函数的调用流程,在具体的某种高级语言下,只要按照流程图就能实现动态数据采集。流程图如下:

ADS_EVT_BUFCHANGE事件,该事件表示内部缓冲区已经半满。可以将这部分数据传输到用户缓冲区中。

DRV_FAIIntScanStart:开始中断触发方式的A/D转换。

DRV_CheckEvent:检查是否有设定的事件发生。

DRV_FAICheck:检查A/D转换的状态。在本例中用于检查究竟是内部缓冲区的前半部分满了,还是后半部分满了。

DRV_FAITransfer:将采集的数据从内部缓冲区传输到用户缓冲区。

DRV_FAIStop:结束A/D转换。

DRV_DeviceClse:关闭指定的数据采集板。

4动态采集程序涉及到驱动程序中部分概念的分析

4.1使用的缓冲区

在驱动程序进行A/D或D/A转换时,最多可使用三种缓冲区:采集板上的FIFO缓冲区,计算机内存中的内部缓冲区和用户缓冲区。

使用FIFO缓冲区可以达到更高的采集频率,如PCL1800使用1K的FIFO缓冲区后,最高采样频率可达到330KHZ。但是有些型号的采集板不带FIFO缓冲区。

内部缓冲区和用户缓冲区是数据采集程序动态分配给驱动程序使用的两块内存区域。这二者的区别在于,内部缓冲区中存放的是RawData(原始数据),用户缓冲区中存放的是电压值。关于原始数据和电压值的区别后面会有介绍。

中断触发方式的A/D转换中这三种缓冲区的使用如图3所示。

在使用DRV_FAIIntScanStart函数将采样值放到内部缓冲区有两种方式:有FIFO和无FIFO。没有FIFO时,每完成一次A/D转换就产生一个中断,驱动程序响应中断将这个采样值传到内部缓冲区中。有FIFO时,采样值先放在FIFO中,当FIFO半满或全满时,才产生一个中断,驱动程序响应中断将FIFO中的数据传送到内部缓冲区中,这是使用FIFO能提高采样频率的原因。

4.2双缓冲区

在不了解数据采集的DMA触发方式时,很容易把中断触发方式下,调用DRV_FAIIntScanStart函数时同时使用FIFO和内部缓冲区的方式认为是双缓冲区工作方式,进而对PTFAICheck结构的ActiveBuf域产生误解。实际上,双缓冲区是指同时使用A、B两个内部缓冲区。这是在DMA触发方式下的特殊工作方式,由DRV_FAIDualDmaStart函数启动。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top