11-01-2001
When programming such IPC's, you should consider 2 things...
1. Handle all signals so that your exiting process cleans up.
2. Use non-blocking techniques to assure no dead-lock.
The semaphore documentation states...
There are two control flags that can be used with semop():
IPC_NOWAIT
-- Can be set for any operations in the array. Makes the function return without changing any semaphore value if any operation for which IPC_NOWAIT is set cannot be performed. The function fails if it tries to decrement a semaphore more than its current value, or tests a nonzero semaphore to be equal to zero.
SEM_UNDO
-- Allows individual operations in the array to be undone when the process exits.
Any process with read permission can test whether a semaphore has a zero value. To increment or decrement a semaphore requires write permission. When an operation fails, none of the semaphores is altered.
The process blocks (unless the IPC_NOWAIT flag is set), and remains blocked until:
the semaphore operations can all finish, so the call succeeds,
the process receives a signal, or
the semaphore set is removed.
10 More Discussions You Might Find Interesting
1. UNIX for Dummies Questions & Answers
Hi all,
I am using HP 10.20 on A 9000/785. My question is:
If I am the only person logged in as root at the moment, how many "semaphore proccesses" should I have?? Is it only one, or it is relevant to other system proccesses?
Here is what I get listing the current semaphores
# ipcs -sp... (1 Reply)
Discussion started by: guest100
1 Replies
2. Programming
Hi there,
Could someone please confirm which POSIX semaphore routines should be used for a multiprocess (and not multithreaded) environment?
sys/sem.h definitely works. but the routines, semget, semctl, semop are pretty unwieldy. So, I am looking for an easier way out.
From the man pages... (2 Replies)
Discussion started by: qntmteleporter
2 Replies
3. Shell Programming and Scripting
Hi Friends,
If i execute this command it comes back with 300 lines:
ipcs|grep cerebrus >>> i would like to clear the semaphores but ipcrm can remove one id at a time. is there a quicker way of removing semaphores maybe using awk?
Regards, (1 Reply)
Discussion started by: kekanap
1 Replies
4. Programming
been searching around on how to use an up and down function with semaphores but i can't find an example. i looked into using: "semop" but i have no idea how to use it. I have been able to declared the semaphores using semget and initializing them using semctl. (7 Replies)
Discussion started by: ddx08
7 Replies
5. UNIX for Advanced & Expert Users
Hello, first of all I apologize if this thread is not in the correct section of this forum, but this one just seemed the most appropriate.
The question I have does not concern Unix specifically, it applies to virtually any OS, however it is in Unix where I learned about this problem.
So, the... (8 Replies)
Discussion started by: Watto86
8 Replies
6. Programming
Hello,
Iam trying to implement the sleeping barber problem using semaphores and running on UNIX machine. Iam linking it to the thread libraries :
bash-2.03$ g++ sleepingBarber.cpp -lpthread -o sleeping
but when i execute it i get the following error:
bash-2.03$ sleeping
Starting Program... (4 Replies)
Discussion started by: mohit.choudhary
4 Replies
7. Programming
Hello,
I was doing an exercise of semaphores and shared memory, namely the barbers:
-B number of barbers
-S number of chairs
-C number of customers.
I have done already and I compiled the code, but when run I get an error segment. Can not be and it took several days.
If anyone sees the error... (2 Replies)
Discussion started by: ciudadwifi
2 Replies
8. UNIX for Dummies Questions & Answers
I am having problem with semaphores. I am trying to protect line where process prints so that every process with print in proper order.This is the code..
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/ipc.h>
#include <sys/sem.h>
#include <sys/types.h>
union... (3 Replies)
Discussion started by: joker40
3 Replies
9. Programming
Hello Everybody,
I am building a server. this server contains some data. Clients may modify this data or read this data.
If a client is reading the data and at the same time another client is modifying the data then at this case the reading client may read some false data (some old mixed with... (1 Reply)
Discussion started by: Omar_Mokhtar
1 Replies
10. Solaris
Hi,
Can somebody please explain me what semaphores are? there purpose? and there effects?
Thanks in advance:) (0 Replies)
Discussion started by: Laxxi
0 Replies
LEARN ABOUT OSF1
sem_post
sem_post(3) Library Functions Manual sem_post(3)
NAME
sem_post - Unlocks a semaphore (P1003.1b)
LIBRARY
Realtime Library (librt.so, librt.a)
SYNOPSIS
#include <semaphore.h>
int sem_post (
sem_t *sem);
PARAMETERS
sem Pointer to the semaphore to be unlocked.
DESCRIPTION
The sem_post function unlocks the specified semaphore by performing the semaphore unlock operation on that semaphore. The appropriate func-
tion (sem_open for named semaphores or sem_init for unnamed semaphores) must be called for a semaphore before you can call the locking and
unlocking functions, sem_wait, sem_trywait, and sem_post.
If the semaphore value after a sem_post function is positive, no processes were blocked waiting for the semaphore to be unlocked; the sema-
phore value is incremented. If the semaphore value after a sem_post function is zero, one of the processes blocked waiting for the sema-
phore is allowed to return successfully from its call to sem_wait.
If more than one process is blocked while waiting for the semaphore, only one process is unblocked and the state of the semaphore remains
unchanged when the sem_post function returns. The process to be unblocked is selected according to the scheduling policies and priorities
of all blocked processes. If the scheduling policy is SCHED_FIFO or SCHED_RR, the highest-priority waiting process is unblocked. If more
than one process of that priority is blocked, then the process that has waited the longest is unblocked.
The sem_post function can be called from a signal-catching function.
RETURN VALUES
On successful completion, the sem_post function returns the value 0 (zero) and performs a semaphore unlock operation, unblocking a process.
Otherwise, the function returns the value -1 and sets errno to indicate the error. The state of the semaphore remains unchanged.
ERRORS
The sem_post function fails under the following condition:
[EINVAL] The sem does not refer to a valid semaphore.
RELATED INFORMATION
Functions: sem_trywait(3), sem_wait(3)
Guide to Realtime Programming delim off
sem_post(3)