接口/总线/驱动
随着微处理器的快速发展和广泛的应用,数字通信网络延伸到工业过程现场成为可能,产生了以微处理器为核心,使用集成电路代替常规电子线路,实施信息采集、显示、处理、传输以及优化控制等功能的智能设备。设备之间彼此通信、控制,在精度、可操作性以及可靠性、可维护性等都有更高的要求。由此,导致了现场总线的产生。1984年,现场总线的概念得到正式提出。IEC(International Electrotechnical Commission,国际电工委员会)对现场总线(Fieldbus)的定义为:现场总线是一种应用于生产现场,在现场设备之间、现场设备和控制装置之间实行双向、串形、多结点的数字通信技术。
现有的放开式数控系统实现方案主要采用pc机和数控系统结合的方法,pc机作为上位机实现较为复杂的网络通信,人机交互等功能,数控系统作为下位机将上位机输入的运行参数经过处理交给执行部件执行,同时将检测系统的反馈信息上传给上位机实现实时监控,各个模块之间协调工作互不干扰,给系统升级带来了方便。
放开式系统动态控制器的核心是dsp,它具有运算速度快,支持复杂运动算法的特点,可以满足高精度运动控制的要求,因此,以dsp为核心的多轴动态控制卡越来越广泛地应用在运动控制系统中,将多轴动态控制卡插在pc机扩展槽上,就可以组成高精度运动控制系统,位置反馈信号的采集、闭环控制计算及控制量的输出均由动态控制卡完成,极大的提高了运算速度和控制响应速度,将工控机的资源从烦琐的数据采集和计算中解决出来,从而可以更好的实施整个控制系统的管理。
作者经过综合调研,采用ti公司的2407系列dsp作为微处理单元,采用pci总线作为并行总线与pc机进行通讯,同时采用现在比较流行的现场总线技术同现场设备进行通讯,所以这是一个基于现场总线和pci总线的智能动态控制器。
基于pci总线的动态控制器采用现场总线技术,解决了传统串行总线传输速率低,响应速度慢,出错率高等缺点,同时由于现场总线采用数字信号而不是传统的模拟信号作为通信手段,解决了传统数控系统中的难以解决的零漂问题,简化了系统的实现方案,同时这种总线有利于放开式系统的发展。
can最早由德国BOSCH公司推出,它广泛用于离散控制领域,其总线规范已被ISO国际标准组织制定为国际标准,得到了Intel、Motorola、NEC等公司的支持。CAN协议分为二层:物理层和数据链路层。CAN的信号传输采用短帧结构,传输时间短,具有自动关闭功能,具有较强的抗干扰能力。CAN支持多主工作方式,并采用了非破坏性总线仲裁技术,通过设置优先级来避免冲突,通讯距离最远可达10KM/5Kbps/s,通讯速率最高可达40M /1Mbp/s,网络节点数实际可达110个。目前已有多家公司开发了符合CAN协议的通信芯片。
can是一种多主总线,通信介质可以是双绞线、同轴电缆或光纤,通信速率可达1mb/s,该协议由数据链路层和物理层组成,数据链路层分为逻辑链路控制子层(lic)和媒体访问控制子层(mac)。现在已形成该协议的国际标准(iso1898),can总线通信接口中集成了can协议的物理层和数据链路层功能,可完成对通信数据的帧处理(包括位填充、数据块编码、循环冗余校验等)、can总线有can2.0a和can2.0b两种协议,can协议的一个最大的特点是对通信数据块进行编码(取消了传统的对站地址编码),can协议采用crc校验并提供相应的错误信息处理功能,保证了数据通信的可靠性。
can总线以其可靠性高、通信速率快、稳定性好,抗干扰能力强,开发成本低等特点, 而被工控领域普遍采用,被公认为最有前途的现场总线之一。
作为目前微型计算机主流总线标准的pci总线,原来是专门为了提高系统数据传输性能,现在作为高性能外设接口,与传统的isa总线相比,pci总线有以下特点:
突出的数据传输性能 总线宽度32位(可扩展到64位,)支持突发传输方式,pci总线规范2.0版支持3mhz总线操作,32位33mhz总线在读写操作中峰值传输速率达到132mb/s(isa最大传输速率8mb/s);
良好的兼容性能 pci总线部件和插卡的设计独立于处理器, 定义了3.3-5v两种信号环境,5-3.3v的组件技术可以是使电平平稳过渡;
即插即用 每个pci设备上都有配置空间能实现自动配置,使系统bios和操作系统的系统层软件能自动配置系统部件和插卡;
线主控和同步操作,pci总线接口芯片可以主控总线,其同步操作可以保证cpu和总线主控同时操作;
总线仲裁机制,pci总线仲裁能在另一个总线主设备在pci总线上执行传输时发出,从而提供系统数据传输性能。
在pci总线的设计上采用了plx公司的产品pci9052,这是一种高性能的pci总线控制器,专门为开发pci板卡而设计的一种pci总线控制器,图1是放开式数控系统总体结构框图。
动态控制器板卡上有一个高速dsp芯片作为运动控制模块的控制器,该设计选择it公司生产的tms320lf2407作为动态控制卡的控制芯片,由于tms320xx系列dsp芯片是专门为控制电机设计的一款高性能低价位的产品,同时作为控制电机的伺服控制系统也是采用的这款dsp芯片作为伺服控制器,所以具有良好的通讯和系统兼容性能,tms3201lf2407内部还有一个can控制器模块,这样就不需要另外选择一个can控制器,简化了电路设计,同时提高了系统性能。
由于dsp芯片和pc机都是控制器,他们对存储器编址是不同的,为了统一编码,在pci控制器和dsp之间要加一个双口ram来连接2个控制器。idt7024是idt公司生产的一款双口ram,他和普遍的ram不同之处是它有2个地址4单元,1个存储单元,对于pc机来说他就对对应于一段内存单元,对于dsp来说他可以对应于一段片外存储单元,这样就解决了dsp和pc机之间的通信问题,本设计采用的是通用pc机加实时控制单元的递阶式结构。采用放开式数控系统上pc机的windows环境形成良好的人机界面,利用pc机的资源优势,放开式结构平台(动态控制器)可以集成不同开发商提供的软件并适合连网需要,且具有与硬件无关的特性,设备层高速度、高可靠性,标准化的数字通讯,可满足用户个性化要求且保证高性能、低成本。
基于can总线动态控制卡的硬件结构如图2所示,从个人pc机中传入的参数如:加工参数,插补轨迹以及一些状态信息,通过pci总线传到pci控制器pci9052的高速缓存fifo中,pci9052作为总线主设备将pc机传来的信息经过缓存最终存储到双口ramidt7024内,由于双口ram映射为pc机的一部分内存地址,所以pc机就像操作内存一样将信息存储到双口ram,等待dsp的读取,dsp定时从双口ram中读取pc机传来的各种控制信息,dsp的主要功能是根据pc机送来得插补信息,通过插补算法形成伺服控制模块能够接受的动态信息,通过can总线将运动信息传递到伺服控制器,通过伺服控制器来驱动伺服电机运动,从而控制数控机床的运动。
在设计中由于pci9052,idt7024都是5v元件,tms2320lf2407属于3.3v器件,同时pci插槽提供5v电源模块,所以电路只使用了电压转换电路将5v信号转变为3.3v信号,如图2,由于dsp内嵌can控制器,所以外部只需要一个pcac82520t-can收发器就可以直接挂在can总线上进行通讯。
放开式cac系统解决软件公用的最主要措施是采用通用的操作系统,本系统设计pci动态控制卡可以在windows90/2000/xp中文操作系统下正常工作,软件框图如图3所示。
为了使系统达到控制要求,需要解决如下几个关键问题:
系统对外界信息以足够快的速度进行处理,并在一定的时间内作出响应,本控制系统是利用windows中断保证实时响应;
cnc系统具有多种不同优先级任务,要求系统软件能合理,有序地调度这些任务的运行,多任务意味着多个任务能并行运行,调度的关键在于按照一定的优先权,事件发生的顺序合理的切换各任务的状态;
由于cnc系统中各任务并否是孤立的,任务之间要完成信息交换和资源共享,cnc系统的通信形式有两种,互斥和同步,互斥是针对不可共享资源的访问问题,如大多数外部设备和共享的可读写数据区,同步是指任务之间的协同工作,任务之间的相对速度有不可预见性,必须由任务通信机制达到同步;
定时和延时功能一般由时钟提供,cnc系统大部分任务都是依据定时或延迟条件来激活。
对于即插即用型设备,系统都是动态分配系统资源的,如何获取系统分配给这些内存单元的地址是vxd驱动程序需要解决的首要问题。在pci的配制周期机制中,主桥路提供了两个寄存器用于对配置空间的操作,第一个是配置空间基地址寄存器canfig-address,双字地址是cf8h,第二个是配置空间数据缓冲寄存器config-data,地址是cfch,对配置空间的操作是通过输入一个值到设备的config-data寄存器,在此之后如果对config-data寄存器进行读写操作,pci控制器就会将config-address寄存器中的值转换成pci总线上所需要的配置周期。
vxd运行在系统ring0级,处理系统底层设备,应用程序利用其提供的接口服务来处理硬件,windows允许vxd和应用程序之间进行双向通信。
在windows中,win23应用程序对vxd的通讯方法只有一种,利用设备输入输出控制函数deviceiocontrol()来实现,利用createfile()函数加载vxd获得vxd设备句柄,如果调用成功,win32应用程序就可以调用deviceiocontrol()程序与vxd进行通讯。
vxd的命令代码需要根据其固定格式进行定义,程序中共定义了2个命令代码,分别用于对双口静态ram的读写操作和vxd对win32应用程序异步过程调用时回调函数地址传输。
另外,由于采用中断方式对dsp处理的数据进行读取,所以中断事件发生时, 需要vxd异步通知win32应用程序,设计时在应用程序中创建了两个线程,一个用于等待中断事件,当中断事件发生时,读取dsp送到双口ram中数据,另一个用于显示数据。
在s599的串行存储器中,将pci配置基础地址寄存器badr1配置为4k,16位寄存器空间,badr2设置为8个自己的i/o空间,基地址寄存器badro对应s5933内部16个双字节pci总线操作寄存器,当利用查找方式获得配置空间数据时,即可得到存储器空间基地址和i/o端口基地址。
当dsp处理数据写满2k的存储器空间时pci将产生中断,中断信号从配置空间寄存器中读出,pci设备分配的硬件中断信号是共享中断,必须使用类vsharedhardwareint的中断通知事件处理函数onsharedhardwareint()。
使用vc编写基于pci总线动态控制器板卡的应用程序,主要利用设备输入输出控制函数deviceiocontrol(),将界面上对数控机床的各个参数转换数据送到底层的vxd进行通信。
对从应用程序中人机界面模块中传入的参数进行解释,完成将上位机输入信息解释成下位机dsp能够执行的语言,程序解释模块固化到pci板卡的dsp片内rom中。
实现pci控制卡与现场总线上的plc模块之间的通讯,由于can总线的特点是可以将对plc模块的控制作为一个应用模块做在pci控制卡上,从而实现了模块化控制。
在加工信息解释的基础上,调用运动学算法模块,将运动平台在操作空间的运动转变为空间的伺服运动,实时生成刀具的运动轨迹,并将各伺服轴的移动指令送给伺服模块。
主要为伺服驱动提供逆解、速度映射算法,为加工状态的实时仿真及精度补偿提供正解算法。
采用pc+动态控制卡模式,实现数控系统的放开式设计方法开发周期短,系统可靠性高,便于机床功能扩展,由于软件采用了模块化,同时基于组件技术,界面友好,操作方便,进行软件升级以及用户进行二次开发都比较方便。
全部0条评论
快来发表一下你的评论吧 !