摘要:从技术背景、系统结构、硬件和软件设计等方面论述了基于RTLinux的闸门实时控制系统的组成、原理以及实现方法,并着重分析了软件实现的关键问题。
关键词:RTLinux 实时控制 TCP/IP MYSQL数据库
在水电站闸门控制系统中,设备地理位置分散、控制分散,基于常规继电器的控制系统不能满足电厂无人值班控制系统和全厂综合自动化的要求,必须将智能控制和工业网络相结合,实现实时控制的同时又能对设备进行智能管理和维护。目前比较常用的控制系统大多由PLC构成,成本较高,缺乏客户定制的灵活性。本文从系统功能实现和经济指标两个方面考虑,半基于RTLinux的控制平台、工业以太网和数据库技术引入闸门控制系统。
1 RTLlinux、工业以太网和数据库
RTLinux是由新墨西大学的Victor Yodaiken等人开发的,现在已有商业化的版本推出。在RTLinux面世之前,Linux在实时性方面作过一些尝试。在POSIX1.b中,规定了实时进程的一些标准,但由于Linux内核的不可抢先性,真正的实时进程无法在标准的Linux环境下实现。RTLinux采用简单而有效的方法解决了此问题而不用重写Linux内核代码。RTLinux实现了一个高效的可抢先的实时调度,全面接管中断,并把Linux作为此实时的一个优先级的进程运行。当有实时任务需要处理时,RTLinux运行实时任务;无实时任务时,RTLinux运行Linux的非实时进程。图1是RTLinux的结构图。
为保证实时进程与非实时Linux进程部顺序进行数据交换,RTLinux引入了RT-FIFO队列。RT-FIFO被Linux视为字符设备,多可达150个,分别命名为/der/rtf0、/dev/rtf1……/dev/rtf63。的RT-FIFO数量在系统内核编译时设定。图2说明了RT-FIFO的工作原理。
RTLinux程序运行于两个空间:用户空间内核态。RTLinux提供了应用程序接口,借助这些API函数将实时处理部分编写成内核模块,并装载到RTLinux内核中,运行于RTLinux的内核态。非实时部分的应用程序则在Linux下的用户空间中执行,这样可以发挥Linux对网络和数据库的强大支持功能。
TCP/IP协议和以太网在Internet上的成功应用吸引着越来越多控制程师。尽管以太网的时间不确定性给以太网应用于工业控制现场的实时性带来了很多争论,但是实际应用中,经网络传输的数据绝大多数用于系统管理和维护等方面,用于实时控制的数据传输很少,这也是基于管理集中、控制分散的系统设计策略考虑的。在较高的以太网传输速度下,现场智能处理单元的处理速度才是传输延迟的主要原因。本系统现场控制单元采用高速处理器,并采用RTLinux作为现场控制单元的控制平台,直接用以太网传输数据,系统的网络层次减少,信号的传输实时性也得到提高。
目前,有许多数据库开发商提供了Linux平台上的数据库软件,例如Oracle、Sybase、Informix和MYSQL等都推出了Linux版本。基于RTLinux的控制系统在实时控制领域有巨大的潜力。
2 系统组成
本系统分为现场和集中级。现场控制级由分散在现场的4个现场控制单元控制,分别完成闸门位置、油缸油压和油路状态等的采集,现场操作按钮的监视以及闸门提升和下降的控制等。集中级由集中监控站、维护站组成,分别执行监视、智能维护及诊断等功能。打印机用于数据的硬备份、报表的输出。系统结构如图3所示。
2.1 系统硬件构成
在工业控制系统中通常采用PLC作为现场的控制。PLC的不足一方面在于其较高的价格,另一方面在于其难以实现非顺序控制算法,以及缺乏对TCP/IP灵活的支持。本系统采用嵌入式PC作为控制单元的,开发人员可自行开发外围接口板,根据系统需要灵活组态,既经济又能使用语言开发控制程序。
现场控制闸门的LCU采用相同的硬件配置。CPU板采用研华公司的PCM-5864,CPU的Intel公司的Pentium MMX 166MHz,内存为64MB,以太网接口为10MHz的RTL-8139A。CPU板通过PC104总线与采样模块和输出模块相连。此外该板上配有显示、键盘和鼠标等标准接口,便于在线修改和检查程序。硬盘选用容量为4.3GB的笔记本硬盘。16通道的A/D采样模块PCM-3718H完成模拟量的采集,分辨率为12位;16通道的数字I/O模块PCM-3730用于开关量的采集、控制闸门的启动和停止。为便于现场巡检,LCU配有显示中文信息的LCD模块MGLS-240128,内置T6963C控制器。系统采用了16端口的HUB。
为保证集中站可靠地工作,集中监控站、集中维护站采用工业PC,配有Intel公司的P处理器,256MB内存和40GB的大硬盘,TCP/IP通信由3COM公司的10/100MbpsPCI网卡3C905C来完成。
2.2 系统软件构成
系统的软件也分为两部分。集中监控站采用Windows2000操作系统,并安装有MYSQL-3.23.49 for Windows服务器软件和监控软件;维护也采用Windows2000操作系统。此外装有MYSQL的客户端软件包和维护及诊断软件。监控软件和维护及诊断软件均用Visual C++开发。
LCU的软件包括实时Linux操作系统、数据库客户端软件和控制程序。在LCU中,操作系统Redhat6.2经升级和安装RTLinux后被改造成实时Linux。升级后的核为Linux-2.2.18,RTLinux的版本号为RTLinux2.2 for Linux-2.2.18。数据库的客户端程序包为MYSQL-3.23.49RPM。控制程序包括实时控制程序和非实时程序两部分。
3 系统设计的关键问题
现场单元中与实现控制部分和非实时控制部分程序相对应的文件为gatectl_module.c和gatectl_app.c。二者由gcc编译后生成目标文件gatectl_module.o和gatectl_app.o。前者为内核模块,嵌入到RTLinux核中,用于实时采集和实时控制输出,运行于内核态。后者为Linux应用环境,运行于用户空间,完成数据的预处理、访问数据库和人机接口等工作。
3.1 内核模块
内核模块程序按多线程模式编写,RTLinux提供了与多线程编程相应的API函数。
RTLinux2.2内核中,完成实时任务的模块主要包括以下两个功能函数:
Int init_module();
Void cleanup_module()。
前者在模块次装入核中时被调用,完成实时任务的参数(优先级别、中断周期等)的设置,进行任务的启动和终止等操作。后者在模块卸载时被调用,一般在调试或系统退出时使用。模块中可启动多个任务,本系统在实时部分只设计一个实时任务即Task1。
启动实时任务前必须进行初始化。init_module()中的初始化工作包括以下三部分:
·为保证内核态的实时进程与用户空间的非实时进程间交换信息。须创建3个RTL-FIFO,具体为:rtf1用于实时进程与非实时进程间的数据交换,数据包括采集到的模拟量和数字量;rtf3用于非实时进程向实时进程传递控制命令字,以启动和终止实时任务;rtf2用于保存经ttf3传递的实时任务的控制命令字。创建工作由RTLinux提供的API函数rtf_create(n,buf)来完成。
·创建实时任务Task1对应的线程,并设定其调度优先级,由API函数pthread_create来完成。
·当非实时进程通过rtf3进行控制命令传递时,实时进程应及时响应。因此必须在实时程序中建立跟踪rtf3变化的子程序,调用rtf_create_handler(3,&data_handler)来完成此功能。
内核态的主体程序有两种实现方式:中断处理和周期实时线程方式。本系统采用周期性实时线,即周期性地执行数据采集、输出控制结果以及与处于用户空间中的非实时进程交换数据。具体过程见图4。
在编写实时程序时,应特别注意的是:实时任务运行在内核水平,是为了提供对计算机硬件的直接访问能力,为避免不确定的延迟,RTLinux给代码和数据分配固定的内存空间。实时任务不能使用Linux的系统调用及Linux中的程序与数据结构,否则难以保证数据的一致性。此外应控制实时程序的执行时间,编写程序时应注意包含与API函数对应的头文件。
内核程序中与RT-FIFO相关的函数有:
rtf_create():创建RT-FIFO。
rtf_get():从RT-FIFO读数据。
rtf_put():向RT-FIFO写数据。
rtf_create_handler():建立响应RT-FIFO变化的子程序。
内核程序中与实时任务线程相关的函数有:
pthread_create():创建实时任务对应的线程。
pthread_wait_np():将当前线程挂起,直至下一个周期线程。
pthread_makeperiodic_np():设置线程的属性并启动线程。
pthread_suspend_np():将本线程无限期挂起,即终止任务。
在调试阶段,需要将有bug的模块卸载。该项工作由cleanup_module()来完成。在卸载模块时将rtf1、rf2和rtf3撤销,并撤销实时任务Task1。
3.2 应用程序
Linux下应用程序gatect1_app工作流程见图4,其程序用Linux下的C语言开发。集中监控站和维护站的程序在Windows下用Visual C++开发。其中有几点要说明:
·RT-FIFO被Linux视为字符设备,因此可以通过调用open("/dev/rtf1",O_RDONLY)来获得rtf1的指针,rtf2的rtf3类似。获得指针后通过read和write函数实现对RT_FIFO的读写操作。
·程序中调用select函数检查RT_FIFO是否忙,以避免读RT_FIFO时出现阻塞现象。
·LCD显示模块MGLS-240128内置智能控制器,只需将待显示的数据送控制器的显示缓冲区就能实现显示功能,数据显示不会占用系统过多的时间。
·系统数据传输和维护通过网络数据库来实现。数据库采用客户端/服务器模块,将LCU、集中维护站设置为客户端,将集中监控站设置为服务器。本系统采用基于TCP/IP协议的MYSQL数据库为实现数据管理。MYSQL是一个多用户、多线程的SQL数据库服务器,由客户端/服务器结构来实现。它由一个服务器守护程序mysqld和不同的客户程序及库组成,使用TCP/IP把多个客户(LCU等)连接到一个服务器(集中监控站)上。在运行前应将主机名、IP地址等设备就绪,在LCU的应用程序gatectl_app中应包含MYSQL.h头文件,其中有MYSQL的API函数的具体实现。在用户空间,C语言程序通过这些API函数访问远程的数据库服务器。
·数据的预处理:为防止被干扰的数据上传到服务器,应用程序对数据进行滤波,再对数据进行分类。经过预处理后的数据才可以送数据缓冲区,通过API函数向数据库服务器上传。
4 应用效果
目前该系统正在试验室运行。从连续运转的情况看,控制实时性和可靠性均达到了设计要求,网络和数据库均运行正常,可见本设计思路是可行的。下一步将设放到工业现场进一步验证。RTLinux实现实时控制功能并与Linux有机结合,这一设计思路既满足了实时控制系统对响应的快速性、时间的性和控制的可预测性的要求,又充分发挥了Linux对网络和数据库的支持功能。将RTLinux引入控制领域,拓宽了Linux的应用范围,必须加速工业控制的信息化。