工作原理示意图: 
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_ptr和rd_ptr,均初始化为0。每写完一个unit,wr_ptr自加1。每读完一个unit,rd_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
本文介绍了Linux中通过共享内存和信号量进行进程间通信的实现方式。eNB process作为写进程,UE process作为读进程,两者之间使用一个共享内存区,其中包含三个信号量:互斥信号量SEM_MUTEX、可读资源信号量SEM_RD和可写资源信号量SEM_WR,确保数据的一致性和安全性。程序详细展示了如何初始化这些资源,并提供了读写进程的示例代码。
1121

被折叠的 条评论
为什么被折叠?



