QNX消息传递及其在线程间通信的应用_第1页
QNX消息传递及其在线程间通信的应用_第2页
QNX消息传递及其在线程间通信的应用_第3页
QNX消息传递及其在线程间通信的应用_第4页
QNX消息传递及其在线程间通信的应用_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、QNX消息传递及其在线程间通信的应用摘要:本文介绍了QNX嵌入式实时多任务操作系统的消息传递和微内核体系结构的特点,创建线程的方法,消息传递的基本原理,以及阻塞式消息传递在线程间通信的实现方法,并给出了实例代码。 关键字:QNX 消息传递 线程间通信 阻塞1 引言QNX操作系统支持多线程,并遵循POSIX线程标准。QNX的进程间通信(IPC)有多种形式,消息传递是最基本的方式,其它还包括代理(proxies),信号(signals),信号灯(semaphore ),共享内存(shared memory),管道(pipes)等,但它们都是建立在消息传递基础之上的。可见消息传递在QNX OS中的重

2、要性,所以本文主要介绍消息传递,并通过实例给出主要编程代码。当进程中只含有一个主线程时,线程间通信也就是进程间通信;当进程中有多个线程时,线程间通信既可以是不同进程的线程间通信,也可以是同一个进程的线程间通信。消息传递既是进程间通信的一种方式,也是同一进程的两个线程间通信的方式。本文统称为线程间通信。2 QNX操作系统21 QNX的微内核结构QNX嵌入式实时多任务操作系统是由加拿大著名的QNX Software Systems LTD专为PC机开发的操作系统。1999年8月QSSL公司发布了QNX Neutrino 2,它是符合线程规范的、完全以线程进行调度的操作系统。QNX提供多任务、优先级

3、驱动的抢先式调度和快速的上下文切换,是实时应用软件的理想开发平台。通过微内核结构和基于消息的IPC ,QNX 在有效性、模块化、和简单性方面达到独一无二的程度。消息传递和微内核体系结构是QNX最大的特点,也是与其它OS最大的不同。微内核实现四种服务:IPC、底层网络通信、进程调度、中断派遣;完成两件基本的功能:消息传递和调度。整个QNX OS是由微内核调度管理的一组进程的集合,其体系结构见图(1)。消息传递是微内核体系结构的核心。在Neutrino 下,取代把OS模块直接绑到内核上,而是通过消息传递完成模块间通信,使得OS具有真正的模块化结构。QNX优异的微内核体系结构使之在实时控制、嵌入式系

4、统等领域软件开发中具有强大的生命力。由于它的高可靠性、强实时性、好的扩展性、以及技术先进性和开放性,使它在PC中得到广泛的应用。22 QNX的线程进程与线程是现代操作系统进行多任务处理的核心内容。QNX微内核支持线程的处理,支持绝大部分的POSIX 标准的线程原语,并且也定义了许多自己的函数。QNX线程的创建,最常用的方法是调用POSIX pthread_create () 函数,其函数原型如下:# include int pthread_create ( pthread_t * thread , const pthread_attr_t * attr , void * ( * start_r

5、outine) ( void *) , void * arg ) ; 函数中有四个变量,它们的含义如下: thread pthread_t结构的指针,用来存放线程ID ; attr 属性结构; start_routine 创建线程后,开始执行子线程的函数,即线程的入口函数; arg 传递给线程入口函数的参数;3 QNX的消息传递31 QNX消息传递的基本原理消息传递是一种阻塞式的通信,发生在两个线程之间,以客户/服务器(C/S)模式实现。两个线程分别为客户端和服务端,客户端向服务端请求服务。在这种C/S模式中线程有三种状态状态:运行、就绪和阻塞。当一个线程因为它必须等待某些消息协议的结束而不能

6、继续执行时,就称线程进入阻塞。阻塞有三种状态:RECEIVE阻塞,SEND阻塞,REPLY阻塞。典型的消息传递“发送接受回应”状态转移图见图(2)。在服务端,起初,服务端等待客户端的消息,在消息到来之前,服务端就处于RECEIVE阻塞;当有消息到来时,服务端就进入就绪(READY)状态,并能够运行;而后它根据客户端的请求,回应客户端。而在客户端,起初,客户端自己单独运行,直到需要向服务端发送消息,则从就绪状态转为SEND 阻塞或REPLY阻塞,具体要根据当时服务端的状态确定。在服务端给与回应后,客户端就从阻塞状态转为就绪状态,准备运行。消息传递还提供一种非阻塞式的通信,是利用脉冲信号(puls

7、e)实现,本文不作介绍。32 QNX消息传递的实现 在Neutrino中,消息传递的体系结构可用如下三句话描述:客户端向服务端发送请求;服务端接收客户端的请求并处理请求;服务端回应客户端的请求。关于消息传递的函数有很多,但是用其中的部分函数就可以写出完美有用的C/S模式的应用程序,所以这里就只介绍主要的函数。在服务端,消息传递具体的实现过程如下:1) 建立一个通道(channel)以等待客户端的连接请求。若成功,返回值为通道的ID。int ChannelCreate(unsigned flags); 2) 服务端线程在已创建的特定通道进行监听,当客户端有请求时接收客户端的消息,把客户端的信息拷

8、贝到本地,并把本次通信的相关信息存在参数info中。若返回值为0,表示接收到的是一个脉冲(Pulse);正数表示成功;负数表示通信失败。int MsgReceive(int chid , void * rmsg , int rbytes , struct _msg_info * info );3) 根据客户端的请求和开发者的需要进行具体的消息处理。4) 服务端回应客户端的消息,客户端接收到此消息回应后将会解除Reply阻塞状态。int MsgReply(int rcvid , int status , const void * msg , int nbytes);5) 服务端线程销毁通道,在实

9、际应用中,通常运行不到这一步,因为服务端要始终处于运行状态以接收客户端来的消息。int ChannelDestroy(int chid);在客户端,消息传递具体的实现过程如下:1) 客户端线程与服务端线程建立的连接;int ConnectAttach(int nd, pid_t pid ,int chid,unsigned index,int flgas);2) 需要时向服务端发送一个消息,并且提供服务端线程回应消息的缓冲区。发送后即进入SEND阻塞状态,直到服务端处理完消息后给与回应,把“答案”放到提供的缓冲区中。int MsgSend(int coid , const void * sms

10、g, int sbytes ,void *rmsg, int rbytes);3) 客户端线程销毁与服务端通道之间的连接,结束通信。在实际应用中通常通信要始终进行,所以不必执行这一步;int ConnectDetach(int coid);线程间通信的消息传递流程图见图(3)。33 QNX消息传递的自同步消息传递不仅可以实现线程间通信,而且提供线程的同步,即消息传递的自同步。这种线程间通信的自同步是暗含在消息传递机制中的,有利于应用程序设计的简化。参考图(3)来说明消息传递的自同步。客户端线程A调用MsgSend()函数向服务端发送消息,然后就进入阻塞状态,这种状态直到接收到服务端的回应Msg

11、Reply()才被唤醒。这就保证了服务端线程B在为线程A提供服务时,线程A一直处于阻塞状态,当线程B提供服务结束后,客户线程A才能继续执行。线程B一旦调用MsgReceive()函数,就不能继续执行原来工作直到为线程A提供服务结束。 图(3)线程间通信的消息传递流程4 QNX消息传递应用的程序代码 由于消息传递的良好性能,在某实时控制系统中就采用了阻塞式消息传递来实现线程间通信。在该系统的一个控制模块中有两个线程,一个线程作为服务端完成系统控制调度工作;另一个线程作为客户端完成控制系统外部信息的采集工作,按一定的周期采集信息并用消息传递机制完成与控制调度线程的数据通信,为系统的控制调度提供依据

12、。在这里没有对整个程序进行说明,只是说明了消息传递用到的通信程序代码。 应用程序中线程间通信的客户端主要程序代码如下:#include char * smsg=“This is clients message!n”;/待传送的信息 char rmsg1024; /存放服务端回应的信息 int coid, chid; /连接ID,通道ID coid=ConnectAttach(0,0, chid,0,0); /建立一个连接,需要时用以向服务器发送消息 if(coid= = -1) fprintf(stderr,“Couldnt ConnectAttach to servern”);perror(

13、NULL);exit(EXIT_FAILURE); /执行程序的其它任务/当需要向服务端发送请求消息(传送采集数据)时,发送消息 if(MsgSend(coid,smsg,strlen(smsg)+1,rmsg,sizeof(rmsg)= = -1) fprintf(stderr,“Error during MsgSend n”);perror(NULL);exit(EXIT_FAILURE); if(strlen(rmsg)0) /接到回应消息 /继续执行原来的程序应用程序中线程间通信的服务端主要程序代码如下:#include int rcvid ; /接收ID int chid ; /通道

14、ID char message1024; /存放接收的消息数据 chid=ChannelCreate(0); /创建一个通道 while(1) /这是一个典型的服务端框架 rcvid= MsgReceive(chid , message , sizeof(message) , NULL); /接收消息 /对消息进行分析处理,完成客户的要求 MsgReply(rcvid , EOK , message , sizeof(message); /回应客户 /执行程序的其它功能 ChannelDestroy(chid); /销毁通信通道,运行不到这里;5 结束语消息传递是QNX与其它OS的最大区别。它使QNX成为真正的微内核和模块化的OS。它的线程自同步,使得应用程序的开发变得容易。由于消息传递的良好特性,被广泛应用于线程间通信。在某实时控制系

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论