VxWorks操作系统指南.docx
《VxWorks操作系统指南.docx》由会员分享,可在线阅读,更多相关《VxWorks操作系统指南.docx(48页珍藏版)》请在冰点文库上搜索。
VxWorks操作系统指南
VxWorks操作系统指南
目录
1.VxWorks操作系统概述
4
1.1.VxWorks操作系统简介
4
1.2.VxWorks操作系统内核
5
1.3.任务管理
6
1.4.通信、同步和互斥机制
9
1.5.网络通信
11
1.6.中断服务程序
14
1.7.时间管理器
14
2.VxWorks应用指导
16
2.1.系统启动
17
2.2.应用系统配置
19
2.3.板级支持包BSP
21
2.4.VxWorks系统任务
23
2.5.应用软件开发指导
23
2.6.应用示例分析
25
关键词:
实时操作系统任务消息VxWorksTornado
摘要:
本文档对实时操作系统作了简要介绍,并针对VxWorks系统的特点进行了具体的说明和分析,从VxWorks系统的任务管理、通信机制、系统配置、系统接口几个方面展开。
1.VxWorks操作系统概述
1.1.VxWorks操作系统简介
实时多任务操作系统是能在确定的时间内执行其功能,并对外部的异步事件作出响应的计算机系统。
多任务环境允许一个实时应用作为一系列独立任务来运行,各任务有各自的线程和系统资源。
VxWorks系统提供多处理器间和任务间高效的信号灯、消息队列、管道、网络透明的套接字。
实时系统的另一关键特性是硬件中断处理。
为了获得最快速可靠的中断响应,VxWorks系统的中断服务程序ISR有自己的上下文。
VxWorks实时操作系统由400多个相对独立的、短小精炼的目标模块组成,用户可根据需要选择适当模块来裁剪和配置系统,这有效地保证了系统的安全性和可靠性。
系统的链接器可按应用的需要自动链接一些目标模块。
这样,通过目标模块之间的按需组合,可得到许多满足功能需求的应用。
VxWorks操作系统的基本构成模块包括以下部分:
•高效的实时内核Wind
VxWOrks实时内核(Wind)主要包括基于优先级的任务调度、任务同步和通信、中断处理、定时器和内存管理。
•兼容实时系统标准POSIX
VxWOrks提供接口来支持实时系统标准P.1003.1b.
•I/O系统
VxWOrks提供快速灵活的与ANSI-C相兼容的I/O系统,包括UNIX的缓冲I/O和实时系统标准POSIX的异步I/O。
VxWOrks包括以下驱动:
网络---网络设备(以太网、共享内存)
管道---任务间通信
RAM---驻留内存文件
SCSI---SCSI硬盘,磁碟,磁带
键盘---PCx86键盘(BSP仅支持x86)
显示器---PCx86显示器(BSP仅支持x86)
磁碟---IDE和软盘(BSP仅支持x86)
并口---PC格式的目标硬件
•本机文件系统
•I/O系统
VxWorks的文件系统与MS-DOS、RT-11、RAM、SCSI等相兼容。
•网络特性
VxWorks网络能与许多运行其它协议的网络进行通信,如TCP/IP、4.3BSD、NFS、UDP、SNMP、FTP等。
VxWorks可通过网络允许任务存取文件到其它系统中,并对任务进行远程调用。
•虚拟内存(可选单元VxVMI)
VxVMI主要用于对指定内存区的保护,如内存块只读等,加强了系统的健壮性。
•共享内存(可选单元VxMP)
VxMP主要用于多处理器上运行的任务之间的共享信号量、消息队列、内存块的管理。
•驻留目标工具
Tornado集成环境中,开发工具工作于主机侧。
驻留目标外壳、模块加载和卸载、符号表都可进行配置。
•Wind基类
VxWorks系统提供对C++的支持,并构造了系统基类函数。
•工具库
VxWorks系统向用户提供丰富的系统调用,包括中断处理、定时器、消息注册、内存分配、字符串转换、线性和环形缓冲区管理,以及标准ANSI-C程序库。
•性能优化
VxWorks系统通过运行定时器来记录任务对CPU的利用率,从而进行有效地调整,合理安排任务的运行,给定适宜的任务属性。
•目标代理
目标代理可使用户远程调试应用程序。
•板级支持包
板级支持包提供硬件的初始化、中断建立、定时器、内存映象等。
•VxWorks仿真器(VxSim)
可选产品VxWorks仿真器,能模拟VxWorks目标机的运行,用于应用系统的分析。
1.2.VxWorks操作系统内核
VxWorks内核(wind)的基本功能可以分为如下几大类:
u任务管理;
u事件和异步信号服务;
u信号量服务;
u消息队列服务;
u内存管理;
u中断服务程序;
u时钟管理和定时器服务;
u出错处理。
在以下各节中将对VxWorks内核的各类功能分别进行描述。
1.1.任务管理
任务是代码运行的一个映象,从系统的角度看,任务是竞争系统资源的最小运行单元。
任务可以使用或等待CPU、I/O设备及内存空间等系统资源,并独立于其它任务,与它们一起并发运行(宏观上如此)。
VxWorks内核使任务能快速共享系统的绝大部分资源,同时有独立的上下文来控制个别线程的执行。
1.1.1.任务结构
多任务设计能随时打断正在执行着的任务,对内部和外部发生的事件在确定的时间里作出响应。
VxWorks实时内核Wind提供了基本的多任务环境。
从表面上来看,多个任务正在同时执行,实际上,系统内核根据某一调度策略让它们交替运行。
系统调度器使用任务控制块的数据结构(简记为TCB)来管理任务调度功能。
任务控制块用来描述一个任务,每一任务都与一个TCB关联。
TCB包括了任务的当前状态、优先级、要等待的事件或资源、任务程序码的起始地址、初始堆栈指针等信息。
调度器在任务最初被激活时以及从休眠态重新被激活时,要用到这些信息。
此外,TCB还被用来存放任务的"上下文"(context)。
任务的上下文就是当一个执行中的任务被停止时,所要保存的所有信息。
在任务被重新执行时,必须要恢复上下文。
通常,上下文就是计算机当前的状态,也即各个寄存器的内容。
如同在发生中断所要保存的内容一样。
当发生任务切换时,当前运行的任务的上下文被存入TCB,将要被执行的任务的上下文从它的TCB中取出,放入各个寄存器中。
于是转而执行这个任务,执行的起点是前次它在运行时被中止的位置。
VxWorks中,内存地址空间不是任务上下文的一部分。
所有的代码运行在同一地址空间。
如每一任务需各自的内存空间,需可选产品VxVMI的支持。
1.1.2.任务状态和状态迁移
实时系统的一个任务可有多种状态,其中最基本的状态有四种:
就绪态:
任务只等待系统分配CPU资源;
悬置态:
任务需等待某些不可利用的资源而被阻塞;
休眠态:
如果系统不需要某一个任务工作,则这个任务处于休眠状态;
延迟态:
任务被延迟时所处状态;
当系统函数对某一任务进行操作时,任务从一种状态迁移到另一状态。
处于任一状态的任务都可被删除。
状态迁移调用
就绪态---->悬置态semTake()/msgQReceive()
就绪态---->延迟态taskDelay()
就绪态---->休眠态taskSuspend()
悬置态---->就绪态semGive()/msgQSend()
悬置态---->休眠态taskSuspend()
延迟态---->就绪态expireddelay
延迟态---->休眠态taskSuspend()
休眠态---->就绪态taskResume()/taskActivate()
休眠态---->悬置态taskResume()
休眠态---->延迟态taskResume()
1.1.3.任务调度策略
多任务调度须采用一种调度算法来分配CPU给就绪态任务。
Wind内核采用基于优先级的抢占式调度法作为它的缺省策略,同时它也提供了轮转调度法。
基于优先级的抢占式调度,它具有很多优点。
这种调度方法为每个任务指定不同的优先级。
没有处于悬置或休眠态的最高优先级任务将一直运行下去。
当更高优先级的任务由就绪态进入运行时,系统内核立即保存当前任务的上下文,切换到更高优先级的任务。
多任务调度须采用一种调度算法来分配CPU给就绪态任务。
Wind内核采用基于优先级的抢占式调度法作为它的缺省策略,同时它也提供了轮转调度法。
基于优先级的抢占式调度,它具有很多优点。
这种调度方法为每个任务指定不同的优先级。
没有处于悬置或休眠态的最高优先级任务将一直运行下去。
当更高优先级的任务由就绪态进入运行时,系统内核立即保存当前任务的上下文,切换到更高优先级的任务。
Wind内核划分优先级为256级(0~255)。
优先级0为最高优先级,优先级255为最低。
当任务被创建时,系统根据给定值分配任务优先级。
然而,优先级也可以是动态的,它们能在系统运行时被用户使用系统调用taskPrioritySet()来加以改变,但不能在运行时被操作系统所改变。
轮转调度法分配给处于就绪态的每个同优先级的任务一个相同的执行时间片。
时间片的长度可由系统调用KernelTimeSlice()通过输入参数值来指定。
很明显,每个任务都有一运行时间计数器,任务运行时每一时间滴答加1。
一个任务用完时间片之后,就进行任务切换,停止执行当前运行的任务,将它放入队列尾部,对运行时间计数器置零,并开始执行就绪队列中的下一个任务。
当运行任务被更高优先级的任务抢占时,此任务的运行时间计数器被保存,直到该任务下次运行时。
1.1.4.抢占禁止
Wind内核可通过调用taskLock()和taskUnlock()来使调度器起作用和失效。
当一个任务调用taskLock()使调度器失效,任务运行时没有基于优先级的抢占发生。
然而,如果任务被阻塞或是悬置时,调度器从就绪队列中取出最高优先级的任务运行。
当设置抢占禁止的任务解除阻塞,再次开始运行时,抢占又被禁止。
这种抢占禁止防止任务的切换,但对中断处理不起作用。
1.1.5.异常处理
程序代码和数据的出错,如非法命令、总线或地址错误、被零除等。
VxWorks异常处理包,一般是将引起异常的任务休眠,保存任务在异常出错处的状态值。
内核和其它任务继续执行。
用户可借助Tornado开发工具,查看当前任务状态,从而确定被休眠的任务。
1.1.6.任务管理
VxWorks内核的任务管理提供了动态创建、删除和控制任务的功能,具体实现通过如下一些系统调用:
taskSpawn()创建(产生并激活)新任务
taskInit()初始化一个新任务
taskActivate()激活一个已初始化的任务
taskName()由任务ID号得到任务名
taskNameToId()由任务名得到任务ID号
taskPriorityGet()获得任务的优先级
taskIsSuspended()检查任务是否被悬置
taskIsReady()检查任务是否准备运行
taskTcb()得到一个任务控制块的指针
taskDelete()中止指定任务并自由内存(仅任务堆栈和控制块)
taskSafe()保护被调用任务
taskSuspend()悬置一个任务
taskResume()恢复一个任务
taskRestart()重启一个任务
taskDelay()延迟一个任务
1.2.通信、同步和互斥机制
VxWorks支持各种任务间通信机制,提供了多样的任务间通信方式,主要有如下几种:
Ÿ共享内存,主要是数据的共享;
Ÿ信号量,用于基本的互斥和任务同步;
Ÿ消息队列和管道,单CPU的消息传送;
ŸSocket和远程过程调用,用于网络间任务消息传送;
Ÿ二进制信号,用于异常处理。
在多处理器之间的任务也可采用共享内存对象来实现任务间通信,只是在系统配置上有所不同.
1.1.1.共享存储区
任务间通信的最简单的方法是采用共享存储区,也即相关的各个任务分享属于它们的地址空间的同一内存区域。
因为所有任务都存在于单一的线性地址空间,任务间共享数据。
全局变量、线性队列、环形队列、链表、指针都可被运行在不同上下文的代码所指向。
1.1.2.互斥
当某一地址空间用于数据交换时,为了避免冲突,对于内存的锁定是非常重要的。
两个或多个任务读写某些共享数据时,最后的结果取决于任务运行的精确时序,有可能得到错误值,这样必须以某种手段确保当一个任务在使用一个共享变量或文件时,其他任务不能做同样的操作。
主要有关中断、抢占禁止和用信号量锁定资源等方法。
一般来说,关中断是最有效的解决互斥的方法。
但这对于实时应用来说,它阻止系统对外部事件的响应,无法满足实时性的要求。
同样,中断延迟也是不能接受。
1.1.3.信号量
VxWorks信号量提供最快速的任务间通信机制,它主要用于解决任务间的互斥和同步。
针对不同类型的问题,有以下三种信号量:
Ÿ二进制信号量使用最快捷、最广泛,主要用于同步或互斥;
Ÿ互斥信号量主要用于优先级继承、安全删除和回溯;
Ÿ计数器
VxWorks还提供POSIX信号量和多处理器上信号量的应用。
1.1.1.消息队列
现实的实时应用由一系列互相独立又协同工作的任务组成。
信号量为任务间同步和联锁提供了高效方法。
单处理器中任务间消息的传送采用消息消息队列。
消息机制使用一个被各有关进程共享的消息队列,任务之间经由这个消息队列发送和接收消息。
任务间全双工信息传送
1.1.2.管道
管道用VxWorks的I/O系统提供一种灵活的消息传送机制,它是受驱动器pipeDrv(VxWorks所提供)管理的虚拟I/O设备。
任务能调用标准的I/O函数打开、读出、写入管道。
当任务试图从一个空的管道中读取数据,或向一个满的管道中写入数据时,任务被阻塞。
和消息队列类似,ISR能向管道中写入信息,但不能从中读取。
象I/O设备一样,管道有一个消息队列所没有的优势----调用select(),任务等待一系列I/O设备上的数据。
1.1.3.系统实现
Wind信号量对于各种类型的信号量的控制提供了同一规范化的接口,仅创建函数要特别指明信号量类型。
semBCreate()创建(产生并激活)一个二进制信号量
semMCreate()创建(产生并激活)一个互斥信号量
semCCreate()创建(产生并激活)制一个计数信号量
semDelete()中止并自由信号量
semTake()获得信号量
semGive()给出信号量
semFlush()解锁所有正等待某一信号量的任务
Wind消息队列管理:
msgQCreate()创建(产生并激活)消息队列
msgQDelete()中止并自由信号量
msgQSend()向消息队列发送消息
msgQReceive()从消息队列接收消息
1.2.网络通信
VxWorks提供了强大的网络功能,能与其它许多主机系统进行通信。
网络完全兼容4.3BSD,也兼容SUN公司的NFS。
这种广泛的协议支持在主机和VxWorksh目标机之间提供了无缝的工作环境,任务可通过网络向其它系统的主机存取文件,即远程文件存取,也支持远程过程调用。
通过以太网,采用TCP/IP和UDP/IP协议在不同主机之间传送数据。
VxWorks提供了如下一些网络工具完成信息传送:
ŸSockets
完成运行在VxWorks系统或其它系统之间任务的消息传送;
Ÿ远程过程调用(RPC)
允许任务调用另一主机(运行的系统为VxWorks或是其它)上的过程。
Ÿ远程文件存取
VxWorks任务可采用NFS、RSH、FTP、TFTP等方式远程存取主机文件。
Ÿ文件输出
Ÿ远程执行命令
VxWorks任务可通过网络激活主机系统中的命令。
VxWorks网络组件结构如下:
1.2.1.套接口(Sockets)
Vxworks系统和网络协议的接口是靠套接字(sockets)来实现的。
Sockets规范是得到广泛应用的、开放的、支持多种协议的网络编程接口。
通讯的基石是套接口,一个通讯口是套接的一端,在这一端上你可以找到其对应的一个名字。
一个正在被使用的套接口都有它的类型和与其相关的任务。
套接口存在于通讯域中。
通讯域是为了处理一般的线程通过套接口通讯而引进的一种抽象概念。
套接口通常和同一个域中的套接口交换数据(数据交换也可能穿越域的界限,但这时一定要执行某种解释程序)。
各个任务使用这个域互相之间用Internet协议来进行通讯。
套接口可以根据通讯性质分类。
应用程序一般仅在同一类的套接口间通讯。
不过只要底层的通信协议允许,不同类型的套接口间也照样可以通信。
用户目前使用两种套接口,即流套接口(采用TCP协议)和数据报套接口(采用UDP协议)。
流套接口提供了双向的、有序的、无重复并且无记录边界的数据流服务。
数据报套接口支持双向的数据流,但并不保证是可靠、有序、无重复的。
也就是说,一个从数据报套接口接收信息的任务有可能发现信息重复了,或者和发出时的顺序不同。
数据报套接口的一个重要特点是它保留了记录边界。
对于这一特点,数据报套接口采用了与现在许多包交换网络(例如以太网)非常类似的模型。
套接口(socket)通信的最大优点是:
过程间的通信是完全对等的,不管网络中过程的定位或主机所运行的操作系统。
一般来说,流套套接口提供了可靠的面向连接的服务,应用较广泛。
其应用程序时序图如下:
Socket函数:
socket()创建一个套接口
bind()给套接口分配名称
listen()打开TCP套接口连接
accept()完成套接口间连接
connect()请求连接套接口
shutdown()关闭套接口间连接
send()向TCP套接口发送数据
recv()从TCP套接口接收数据
select()完成同步I/O传输
read()从套接口读取信息
write()向套接口写入信息
ioctl()完成对套接口的控制
close()关闭套接口
1.1.中断服务程序
实时系统中硬件中断处理是至关重要的,因为它是以中断方式通知系统外部事件的发生。
为了快速响应中断,中断服务程序ISR运行在特定的空间,不同于其它任何任务,因此中断处理没有任务的上下文切换。
中断函数:
intConnect()将C函数和中断向量联结
intCount()得到当前中断套叠深度
intLevelSet()设置程序中断级别
intLock()使中断禁止
intUnlock()开中断
intVecSet()设置异常向量
intVecGet()得到异常向量
所有的中断服务程序使用同一中断堆栈,它在系统启动时就已根据具体的配置参数进行了分配和初始化,必须保证它的大小,以使它能满足最坏的多中断情况。
中断也有缺陷:
ISR不运行在常规的任务上下文,它没有任务控制块。
对于ISR的基本约束就是它们不能激活那些可能使调用程序阻塞的函数,例如,它不能获取信号量,因如果该信号量不可利用,内核会试图让调用者切换到悬置态。
然而,ISR能给出信号量。
一个ISR通常与一个或多个任务进行通信,有直接的也有间接的作为输入输出事务的一部分。
这种通信的本质是驱动任务执行,从而处理中断和各种情况。
这与任务到任务的通信和同步基本相同,但是有两点不同:
•一个ISR通常作为通信或同步的发起者,它通常返回一个信号量、向队列发送一个信息包或事件给一个任务。
ISR很少作为信息的接收者,它不可以等待接收信息包或事件。
•ISR内的系统调用总是立即返回ISR本身。
例如,即使ISR通过发送信息包唤醒了一个很高优先级的任务,它也首先必须返回ISR。
这是因为ISR必须先完成。
1.1.时钟管理
时钟管理提供以下功能:
Ÿ维护系统日历时钟;
Ÿ在任务等待消息包、信号量、事件或内存段时的超时处理;
Ÿ以一定的时间间隔或在特定的时间唤醒或发送告警到一个任务。
Ÿ处理任务调度中的时间片轮循。
这些功能都依赖于周期性的定时中断,离开实时时钟或定时器硬件就无法工作。
时钟管理的系统调用有:
tickAnnounce()通知系统内核时钟“滴答”
tickSet()设定内核时钟计数器值
tickGet()得到内核时钟计数器值
timer_create()创建时钟
timer_gettime()获得时钟器给定值的当前剩余值
timer_settime()设定时钟值
timer_connect()联系用户函数和时钟信号
timer_cancel()取消一个时钟
sysClkRateSet()系统时钟速率设置
VxWorks看门狗定时器作为系统时钟中断服务程序的一部分,允许C语言函数指明某一时间延迟。
一般来说,被看门狗定时器激活的函数运行在系统时钟中断级。
然而,如果内核不能立即运行该函数,函数被放入tExcTask工作队列中。
在tExcTask工作队列中的任务运行在最高优先级0。
看门狗定时器调用函数:
wdCreate()分配并初始化看门狗定时器
wdDelete()中止并解除看门狗定时器
wdStart()启动看门狗定时器
wdCancel()取消当前正在计数的看门狗定时器
1.VxWorks应用指导
Tornado集成环境提供了高效明晰的图形化的实时应用开发平台,它包括一套完整的面向嵌入式系统的开发和调测工具。
Tornado环境采用主机--目标机交叉开发模型,应用程序在主机的Windows环境下编译链接生成可执行文件,下载到目标机,通过主机上的目标服务器与目标机上的目标代理程序的通信完成对应用程序的调测、分析。
它主要由以下几部分组成:
ŸVxWorks,高性能的实时操作系统;
Ÿ应用编译工具;
Ÿ交互开发工具;
下面对Tornado集成环境的各组件功能分别介绍:
ŸTornado开发环境
Tornado是集成了编辑器、编译器、调试器于一体的高度集成的窗口环境,同样也可以从Shell窗口下发命令和浏览。
ŸWindConfig:
Tornado系统配置
通过WindConfig可选择需要的组件组成VxWorks实时环境,并生成板级支持包BSP的配置。
ŸWindSh:
Tornado外壳
WindSh是一个驻留在主机内的C语言解释器,通过它可运行下载到目标机上的所有函数,包括VxWorks和应用函数。
Tornado外壳还能解释常规的工具命令语言TCL。
Ÿ浏览器
Tornado浏览器可查看内存分配情况、系统目标(如任务、消息队列、信号量等)。
这些信息可周期性地进行更新。
ŸCrossWind:
源码级调试器
源码级调试器CrossWind提供了图形和命令行方式来调试,可进行指定任务或系统级断点设置、单步执行、异常处理。
Ÿ驻留主机的目标服务器
目标服务器管理主机与目标机的通信,所有与目标机的交互工具都通过目标服务器,它也管理主机上的目标机符号表,提供目标模块的加载和卸载。
ŸTornado注册器
所有目标服务器注册其提供的服务在注册器中。
注册器映射用户定