Linux中写进程与读进程的通信(shm、sem)

本文介绍了Linux中通过共享内存和信号量进行进程间通信的实现方式。eNB process作为写进程,UE process作为读进程,两者之间使用一个共享内存区,其中包含三个信号量:互斥信号量SEM_MUTEX、可读资源信号量SEM_RD和可写资源信号量SEM_WR,确保数据的一致性和安全性。程序详细展示了如何初始化这些资源,并提供了读写进程的示例代码。

工作原理示意图:

 

进程通过shared memory读写

 

 

简单说明:

 

eNB process是写进程,UE process是读进程。首先在他们之间设置一块shared memory,其中前三个变量用于管理这个shared memory

 

shmid由三个信号量组成:

  • 互斥信号量SEM_MUTEX:保证shared memory不会同时被两个进程访问。
  • 可读资源信号量SEM_RD:当前shared memory中已被eNB process写好但还没有被UE process读取的shm_unit数量。初始化为shm_unit的大小SHMLEN
  • 可写资源信号量SEM_WR:当前shared memory中已被UE process读取但还没有被eNB process改写的shm_unit数量。初始化为0

 

shm_st中的shm_unit是一个环形缓冲区,当前写和读的指针分别是wr_ptrrd_ptr,均初始化为0。每写完一个unitwr_ptr自加1。每读完一个unitrd_ptr自加1。当这两个指针等于shm_unit的大小SHMLEN时,将它们重置为0

 

程序清单:

 

 

 

执行:

 

opal@meadfield:~/work$ gcc -o proc -lpthread proc.c

opal@meadfield:~/work$ ./proc

 

打印结果:

 

==== UE ====

[ipc_init] semid = 393222

[ipc_init] SEM_MUTEX = 1

[ipc_init] SEM_RD = 0

[ipc_init] SEM_WR = 7

[ipc_init] shm 4784156 attached at B80C0000

[ipc_init] shm_st->semid = 393222

[ue_proc] shm 4784156 attached at B80B8000

[ue_proc] semid = 393222

[ue_proc] (before RD) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

==== eNB ====

[enb_proc] shm 4784156 attached at B80C0000

[enb_proc] semid = 393222

[enb_proc] (before WR) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

[enb_proc] w: 2 1001

[enb_proc] (durning WR) SEM_MUTEX = 0 SEM_RD = 0 SEM_WR = 6

[enb_proc] (after WR) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 6

[enb_proc] (before WR) SEM_MUTEX = 0 SEM_RD = 0 SEM_WR = 6

[ue_proc]  r: 2 1001

[ue_proc] (durning RD) SEM_MUTEX = 0 SEM_RD = 0 SEM_WR = 5

[ue_proc] (after RD) SEM_MUTEX = 0 SEM_RD = 0 SEM_WR = 6

[ue_proc] (before RD) SEM_MUTEX = 0 SEM_RD = 0 SEM_WR = 6

[enb_proc] w: 0 1002

[enb_proc] (durning WR) SEM_MUTEX = 0 SEM_RD = 0 SEM_WR = 6

[enb_proc] (after WR) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 6

[ue_proc]  r: 0 1002

[ue_proc] (durning RD) SEM_MUTEX = 0 SEM_RD = 0 SEM_WR = 6

[ue_proc] (after RD) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

[ue_proc] (before RD) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

[enb_proc] (before WR) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

[enb_proc] w: 1 1003

[enb_proc] (durning WR) SEM_MUTEX = 0 SEM_RD = 0 SEM_WR = 6

[enb_proc] (after WR) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 6

[ue_proc]  r: 1 1003

[ue_proc] (durning RD) SEM_MUTEX = 0 SEM_RD = 0 SEM_WR = 6

[ue_proc] (after RD) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

[ue_proc] (before RD) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

[enb_proc] (before WR) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

[enb_proc] w: 2 1004

[enb_proc] (durning WR) SEM_MUTEX = 0 SEM_RD = 0 SEM_WR = 6

[enb_proc] (after WR) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 6

[ue_proc]  r: 2 1004

[ue_proc] (durning RD) SEM_MUTEX = 0 SEM_RD = 0 SEM_WR = 6

[ue_proc] (after RD) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

[ue_proc] (before RD) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

[enb_proc] (before WR) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

[enb_proc] w: 0 1005

[enb_proc] (durning WR) SEM_MUTEX = 0 SEM_RD = 0 SEM_WR = 6

[enb_proc] (after WR) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 6

[ue_proc]  r: 0 1005

[ue_proc] (durning RD) SEM_MUTEX = 0 SEM_RD = 0 SEM_WR = 6

[ue_proc] (after RD) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

[ue_proc] (before RD) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

[enb_proc] (before WR) SEM_MUTEX = 1 SEM_RD = 0 SEM_WR = 7

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值