>
首页 » 业界动态 » VB环境下对双端口RAM物理读写的实现

VB环境下对双端口RAM物理读写的实现

作者:  时间:2007-10-31 10:51  来源:

双端口RAM 内存直接映象 高速并行传输 DLL动态链接在集散型控制系统中,一般将计算机或工控机用于终端图文显示,数据采集处理以及机对话接口等方面。计算机或工控机与外部设备需要建立数据传输的通讯联系。但大量数据传输,靠通常的串行通讯方式进行,必须占用CPU大量的时间进行通讯。一些控制系统往往因为传输速率慢而无法实现实时控制,不能满足系统采集和控制需要。上述问题在我们设计的汽车综合检测系统中,得到了较好的解决。系统中采用双端口RAM技术设计了一块PC总线接口的智能型高速并行通讯卡(以下简称通讯卡),实现外部数据同计算机高速并行通讯。由卡上的MCU负责分机的数据采样,将需要传输的数据按系统协议在双端口RAM内任意存取,读写速度快、可靠性高、接口简单,满足了系统设计需要。并且实现了在VB语言环境下对采用内存直接映象技术的双端口RAM的读写操作,将多主CPU采用的总线仲裁方式简单为仅仅对内存操作,在应用计算机总线扩展技术方面具有借鉴意义。

1 系统描述

在汽车综合检测系统中,需要对汽车的底盘、发动机以及综合电路等方面的信号进行采样和判断,其中包含大量的运算处理和汽车标准为资料的对比、分析、判断等环节。整个系统信号采样点多,信号的形式各不相同,系统采用MCU控制方式的分机对各测量点进行数据采集和模拟控制。由于MCU没有高效的运算功能,没有大量的指令和数据存贮空间,更不能直观显示各种汽车标准数据和测量结果,若进行大量的运算、判断、显示,其硬件、软件处理一个比较棘手的问题。因此本系统采用MCU负责采集各种信号,统一由计算机负责相应的运算处理、分析、判断,并管理汽车标准数据库、人机对话接口、显示测量结果和标准图形等等,用一块管理分机的通讯卡实现分机与主机之间数据传输。

通讯卡包含了数字滤波、数据收集、传输等功能,对系统内的并、串行通讯实现分时操作。卡上由一片MCU负责管理各个分机,通过串行通讯方式将分机采集的各种数据,收集到通讯卡内,经过判断、筛选,将有效数据存贮到双端口RAM的规定区域内;计算机从双端口RAM内将数据读入,进行运算处理,与标准数据进行比较判断,将结果或控制命令写入双端口RAM内,实现整个系统统一协调运行。本文主要针对通讯卡的软、硬件设计和在VB环境下的软件实现,作重点的分析。

2 硬件设计

通讯卡的基本硬件设计简图如图1所示。利用计算机总线做扩展卡的技术已经广为应用,但很多都是利用计算机提供固定的I/O端口地址进行读写操作,“瓶颈效应”十分明显。在对实时性要求很高、数据传输量很大的场合,数据阻塞明显,无法满足系统的大量数据高速传输的需要。本系统利用计算机内存直接映象技术,对内存物理地址直接操作,实时性和速度明显改善,完全满足本系统的速度要求。

基本硬件设计简图

2.1 MCU和双端口RAM的选择

此卡是实现计算机与数据采集的分机之间大量、快速的数据交换的中间环节。采用的MCU要求具有较哟的运行速度和数据管理能力,既有双端口RAM的接口总线,又具备同分机双工串行通讯能力,同时考虑到系统硬件加密的必要,选择此MCU是系统的关键。美ATMEL公司出品的89C51是本系统的首选。另一方面根据本系统的需要,数据传输的信息量在一个令牌下,2KB的吞吐量已经满足,因此我们采用美国IDT公司出品的双端口EAM IDT7132,容量为2K×8bits。IDT7132带有两套独立控制总线,可从两侧任意读写存储器中的所有单元,片内硬件端口促裁电路适合当两侧同时访问同一单元时不允许处于等待状态的89C51的操作,允许不经过外部仲裁,能经受冲突的系统进行双机同步读写存储器中的同一单元,确保了数据的准确性,简化了通讯卡的硬件电路设计,同时为软件设计免除了使用信号灯进行判断操作的繁锁过程。

2.2 双端口RAM的地址范围的选择

计算机内部高端地址中有一段保留给I/O适配卡的128KB地址空间,段地址空间为0C0000H~0DFFFFH。利用这128KB中的一段2KB空间即可满足IDT7132的使用,按PC总线的协议经过地址译码和其它控制总线选能,实现内存直接映象方式。地址范围为0D0000H~0D07FFH之间。另一侧,MCU与IDT7132的接法只将IDT7132其中一侧总线接入MCU的总线上,其接法同普通RAM没有区别,设置地址范围在 8000H~87FFH之间。

按工业控制标准实行全地址线译码方式,确保全地址空间的每一个存储单元的地址在总线上唯一。

2.3 对双端口RAM访问的特殊情况处理

IDT7132 两侧的BUSY线分别接到MCU的INT0中断上和PC总线的A10脚(IO-CH-RDY)上,作为MCU和计算机同时读写IDT7132的同一个地址单元时的“忙闲”状态线。当两侧访问不同的地址单元时,BUSY线无效,两侧操作互不影响。当两侧“几乎同时”访问同一个单元时,按IDT7132的总线仲裁逻辑,对两侧的片选信号和地址信号之一

到达时间间隔只要大于5ns,就能对先到达的一侧提供读写通道,保证数据读写的真实性。同时将另一侧的BUSY 线置低,为MCU或计算机提供中断或等待信号。众所周知,89C51不具备插入等待周期延时操作的能力。当MCU一侧先行操作时,计算机一侧的BUSY线有效,PC总线上的IO-CH-RDY状态线被拉低,命令计算机CPU插入等待周期,延时等待MCU一侧完成读写操作后,再进行读写操作。当计算机一侧占据IDT7132的一个地址单元时,MCU一侧再操作该单元,MCU读写的数据无效。我们采用了判断标志位的方式解决此问题。当对应的BUSY线变低 INT0中断有效时,MCU完成该条读写指令后立即进入中断,置标志位,中断返回后,即执行查询标志位的指令同,判断此次操作是否有效。未成功,重复操作,直至读写成功。

3 软件设计

整个系统的全部软件共三部分,每一部分的设计侧重点不同。计算机方面软件实现的功能包括:用户人机对话接口、汽车技术资料库的管理和扩充、底层全部数据传输、运算处理、零点校正设定、实时监控操作、各分机的模拟信号线化处理、大量图片资料的处理与调用等等。通讯卡的软件设计包括:对各个分机的管理、数据收集分类整理、筛选判断、与计算机进行有效数据传输等等。分机的软件包括数据采集和模拟控制等部分。要求数据采集准确、一致。实际应用中采用数据滤波、指令冗余、自依断以及现场断点返回等抗干扰技术。

全部软件涉及的编程语言共三种。分机和通讯卡的软件设计采用汇编语言,计算机方面采用Visual Basic6.0、Visual C++ 6.0两种语言,分机方面的软件这里不作介绍,本文主要针对在通讯卡上以及在Visual Basic 6.0环境下对双端口RAM的操作软件设计作详细介绍。

Visual Basic 6.0不具备对计算机底层地址操作的功能,不如Visual C++ 6.0、Delphi等。特别在本系统中采用的高速并行通信方式,对内存物理地址读写操作的频率很高,按常规应改用其它语言。但系统其它方面的工作,不是其它语言所能替代的,所以必须将VB语言环境下不能对底层地址读写操作的问题加以解决。经过实验,通过如下方法实现。

笔者采用的方法是调用动态链接库DLL。用VisualC++ 6.0编写对内存物理地址进行读写操作的DLL动态链接库函数,进行数据采集和发送;用Visual Basic 6.0调用DLL实现数据通信,从而弥补VB对底层数据操作的缺陷,使VB环境下开发数据通信系统软件更为方便。

(1)首先使用Visual C++ 6.0创建一个MFC Appwizard dll项目,这样就可以在DLL中编写程序。因为我们要对直接映象在高端内在范围内的地址进行操作,所以在编写程序时,要使用如下方法:

-asm{ mov A B

mov ……

…………

mov i A}

return i;

-asm{}是嵌入式汇编函数,在Visual C++6.0中只有使用此方法才可以访问高端内存地睛。还要在DLL中编写两个函数。一个从内存地址读数函数,一个对内存地址写数函数。这样才能完成对高端内存地址读写的操作,实现底层的数据传输。

(2)使用Visual Basic 6.0调用DLL动态链接库函数。

第一步:运行VB6.0时,新建一个工程项目,在项目中添加模块,在模块中声明两个API函数:

Declare Function write% lib“C:兡?#12;C”

(ByVal localport%,ByVal value%)

Declare Function read% lib “C:兡?#12;C”

(ByVal localport%)

其中:write( )函数是向高端内存地址写数据;

read( )函数是从高端内存地址读数据。

第二步:在窗体中放入三个文本框(Text 1,Text2,Text3),一个命令按扭(Command 1),就可以在代码窗口中编写代码:

Option Explicit

Dim Port 1 ‘内存地址 如:0D0000H

Dim Port 2 ‘16进制数 如:12H

Private Sub Command 1-click()

Dim Gg As Integer ‘声明一个返回整数

Dim Salp As Integer ‘声明一个返回整数

Port 1=Val(Text 1.Text) ‘把Text 1赋给port 1

Port 2=Val(Text 2.Text) ‘把Text 2赋给port 2

Gg="write"(port 1,port2) ‘往Port 1地址中写Port 2

Salp="read"(port 1) ‘从Port 1地址中读数

Text3.Text=Salp ‘在Text3中显示

Salp

End Sub

两个函数的调用过程如上所述,可根据编程的意图放在任何位置。特别注意,函数地址不能与其它硬件的地址或系统内存地址冲突,否则会造成计算机死机。

本文采用双端口RAM器件设计的智能型高速并行通讯卡,在监控软件、硬件,以及在VB环境下对直接映象方式的高端内存进行读写操作的实现,具有通用性。尤其在自动控制领域设计A/D、D/A转换、实现闭环控制,以及设计虚拟仪器、视频信号数字化处理、语音处理、各种系统动态仿真等需要高速数据传输的场合,都具有借鉴意义。总之,智能化板卡在PC总线工业控制的应用,是今后发展的主流。

相关推荐

半导体:内存价格居高不下的异常之年

半导体  内存  2013-12-27

嵌入式系统的固件更新

嵌入式  Flash  RAM  缓冲区  2013-09-12

微软Surface被起诉 因内存与宣传不符

微软  Surface  内存  2012-11-19

解读三星崛起:牺牲中小企业 成就财阀品牌

三星D  RAM  2012-08-21

尔必达破产牵动全球内存版图 内存条报价上涨

尔必达  内存  2012-03-04

三星发布新一代智能手机内存 速度提升1倍

三星  内存  2012-02-24
在线研讨会
焦点