Solved

How to share semaphore between processes

Posted on 2006-10-29
11
1,624 Views
Last Modified: 2008-01-09
How to share semaphore between processes?
eg
static sem_t count_sem;
sem_init(&count_sem,1,3);

How to shared this  &count_sem between processes? So we can synchronise between processes.
0
Comment
Question by:william007
  • 6
  • 5
11 Comments
 
LVL 53

Expert Comment

by:Infinity08
ID: 17829577
Take a look at this wiki article about IPC (InterProcess Communication) :

http://en.wikipedia.org/wiki/Inter-process_communication

There's a few ways to achieve this. Shared memory could be a good option for you :

http://en.wikipedia.org/wiki/Shared_memory

What system/OS are you developing for ?
0
 
LVL 9

Author Comment

by:william007
ID: 17829598
I am using Linux fedora core 5.
I just researching for semaphore.h, there is a system call called sem_open to create named semaphore, I think it is possible that we can use that.
0
 
LVL 53

Expert Comment

by:Infinity08
ID: 17829669
If all you want to share between the processes is that semaphore, then that's indeed an option.

More info for that on the man page for sem_open :

http://www.penguintutor.com/man/man.php?topic=sem_open§ion=3


    sem_t *sem = sem_open("/tmp/semname", O_CREAT, 0644, 0);
    if (sem == SEM_FAILED) {
      perror("sem_open() failed ");
    }

Chec kthe man pages for your system to get the implementation you'll use.
0
Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 9

Author Comment

by:william007
ID: 17829699
>sem_t *sem = sem_open("/tmp/semname", O_CREAT, 0644, 0);
This gives me segmentation fault
>sem_t *sem = sem_open("semname", O_CREAT, 0644, 0);
This Works ok.

What is the reason"?
0
 
LVL 9

Author Comment

by:william007
ID: 17829727
Code
====
#include <semaphore.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <sys/types.h>
#include <fcntl.h>
static sem_t *count_sem;
int main(int argc, char* argv[]){
char* semName=argv[1];
mode_t mode=0777;
unsigned int maxProcess=3;
unsigned int i=O_CREAT|O_EXCL;
int value=0;
count_sem=sem_open(semName,i,mode,maxProcess);
if (count_sem==(void *)-1){
printf("Error create named semaphore\n");
exit(1);
}
while(1){
      sem_getvalue(count_sem,&value);
      printf("value=%d\n",value);
      sem_wait(count_sem);
}


}

Several Test Results
================
[root@localhost Desktop]# ./sem "/tmp/name1"
Segmentation fault
[root@localhost Desktop]# ./sem "/tmp/name2"
Segmentation fault
[root@localhost Desktop]# ./sem "/tmp/name3"
Segmentation fault
[root@localhost Desktop]# ./sem "sem1"
Segmentation fault
[root@localhost Desktop]# ./sem "sem2"
value=3
value=2
value=1
value=0

[root@localhost Desktop]# ./sem "sem2"
Segmentation fault
[root@localhost Desktop]# ./sem "sem3"
value=3
value=2
value=1
value=0
0
 
LVL 53

Accepted Solution

by:
Infinity08 earned 500 total points
ID: 17829728
I guess your implementation doesn't support slashes other than the first. Try :

    sem_t *sem = sem_open("/semname", O_CREAT, 0644, 0);

The leading slash is to make sure that other processes will refer to the same named semaphore when using "/semname".
Although your implementation might not need the leading slash either. For that you'll have to check the man pages on your system.
0
 
LVL 9

Author Comment

by:william007
ID: 17829734
Now I have faced a big problem...How to clean up the named semaphore that I have created and forget to clear? What is the proper way to actually clean up with code?
0
 
LVL 9

Author Comment

by:william007
ID: 17829735
*What is the proper way to actually clean up the semaphore in the  code?
0
 
LVL 53

Assisted Solution

by:Infinity08
Infinity08 earned 500 total points
ID: 17829737
And about your last post (with the code)

From the man pages :

    "If O_EXCL and O_CREAT are set, sem_open() fails if the semaphore name exists."

Don't set both :)

Also, don't compare with (void *)-1 to check for errors, use SEM_FAILED for that as in my earlier example - it's a lot more portable.
0
 
LVL 53

Assisted Solution

by:Infinity08
Infinity08 earned 500 total points
ID: 17829767
>> *What is the proper way to actually clean up the semaphore in the  code?
Use sem_close to close the semaphore in each process, and sem_unlink in the process that actually created it (to remove it from the file system).

    sem_close(sem);
    sem_unlink("/semname");

Don't forget to check the return codes !
0
 
LVL 9

Author Comment

by:william007
ID: 17853551
Thanks=)
0

Featured Post

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
memory leak detection 9 101
Pointer in one class to member in another 6 127
C language IDE – Compilers installation 14 78
outlook office 365 8 159
Preface I don't like visual development tools that are supposed to write a program for me. Even if it is Xcode and I can use Interface Builder. Yes, it is a perfect tool and has helped me a lot, mainly, in the beginning, when my programs were small…
Summary: This tutorial covers some basics of pointer, pointer arithmetic and function pointer. What is a pointer: A pointer is a variable which holds an address. This address might be address of another variable/address of devices/address of fu…
The goal of this video is to provide viewers with basic examples to understand opening and writing to files in the C programming language.
The goal of this video is to provide viewers with basic examples to understand recursion in the C programming language.

749 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question