文档详情

106Linux操作系统 SYSV进程间通信.ppt

发布:2017-04-23约5.6千字共26页下载文档
文本预览下载声明
10.6??SYS V 进程间通信;10.6.1 三者共有的特性 IPC资源 表示单独的消息队列、共享内存或是信号量集合 ;oflag包括读写权限,还可以包含IPC_CREATE和IPC_EXCL标志位。它们组合的效果如下: (1)指定key为IPC_PRIVATE保证创建一个唯一的IPC资源。 (2)设置oflag参数的IPC_CREATE标志位但不设置IPC_EXCL。如果相应key的IPC资源不存在,则创建一个IPC资源,否则返回已存在的IPC资源。 (3)oflag参数的IPC_CREATE和IPC_EXCL同时设置。如果相应key的IPC资源不存在,则创建一个IPC资源。否则返回一个错误信息。 ;(b)XXXctl() 均提供IPC_SET、IPC_STAT和IPC_RMID命令。前两者用来设置或得到IPC资源的状态信息,IPC_RMID用来释放IPC资源。 ;共同的数据结构 每一类IPC资源都有一个ipc_ids结构的全局变量用来描述同一类资源的公有数据,三个全局变量分别是semid_ds,msgid_ds和shmid_ds。 struct ipc_ids { int size; /* entries数组的大小*/ int in_use; /* entries数组已使用的元素个数*/ int max_id; unsigned short seq; unsigned short seq_max; truct semaphore sem; /*控制对ipc_ids结构的访问*/ spinlock_t ary;/*自旋锁控制对数组entries的访问*/ struct ipc_id* entries; }; struct ipc_id { struct kern_ipc_perm* p;};; 数组entries的每一项指向一个kern_ipc_perm结构,kern_ipc_perm结构表示每一个IPC资源的属性,用来控制操作权限。 struct kern_ipc_perm{ key_t key;/*用户提供的键值,为XXXget()所用*/ uid_t uid; /*创建者用户ID*/ gid_t gid; /*创建者组ID*/ uid_t cuid; /*所有者用户ID*/ gid_t cgid; /*所有者组ID*/ mode_t mode; /*操作权限,包括读、写等*/ unsigned long seq; }; 因为每个IPC资源描述符的第一个成员就是kern_ipc_perm结构。因此,我们可以认为数组entries 的每一非空项均指向一个IPC资源。;IPC资源ID与entries数组下标的联系 (1)当创建一个IPC资源时, 调用函数ipc_addid()从相应ipc_ids结构的entries数组中找出第一个未使用的项然后返回其下标index。 返回IPC资源ID IPC资源ID = SEQ_MULTIPLIER * seq + index SEQ_MULTIPLIER是可用资源的最大数目,seq是ipc_ids结构中的seq。每当分配一个IPC资源时,ipc_ids结构中的seq就增一。 (2)当知道IPC资源ID时,可通过 IPC资源ID % SEQ_MULTIPLIER 得到其在entries数组中的index,从而找到相应的IPC资源。 (3)why 保证在一段时期内IPC资源ID的唯一性? ;10.6.2? 信号量 信号量是具有整数值的对象,它支持P、V原语。进程可以利用信号量实现同步和互斥 SYSV支持的信号量实质上是一个信号量集合,由多个单独的信号量组成。我们称SYSV信号量为信号量集合,而单个的信号量直接称为信号量。 信号量集合在内核中用结构sem_array表示;struct sem_array { struct kern_ipc_perm sem_perm; time_t sem_otime; /* 最近一次操作时间 */ time_t sem_ctime; /* 最近一次的改变时间 */ struct sem *sem_base; /*指向第一个信号量 */ struct sem_queue *sem_pending;/* 挂起操作队列*/ struct sem_queue **sem_pending_last; struct sem_undo *undo; unsigned long sem_nsems;/*
显示全部
相似文档