Linux

CentOS 4.8

sem_destroy(3thr)


SEMAPHORES

NOM

sem_init, sem_wait, sem_trywait, sem_post, sem_getvalue, sem_destroy − operations sur les sémaphores

SYNOPSIS

#include <semaphore.h>

int sem_init(sem_t *sem, int pshared, unsigned int valeur);

int sem_wait(sem_t * sem);

int sem_trywait(sem_t * sem);

int sem_post(sem_t * sem);

int sem_getvalue(sem_t * sem, int * sval);

int sem_destroy(sem_t * sem);

DESCRIPTION

Cette page de manuel documentes les sémaphores du standard POSIX 1003.1b, à ne pas confondre avec ceux de SystemV IPC tels que décrits par ipc(5), semctl(2) et semop(2).

Les sémaphores sont des compteurs pour les ressources partagées par plusieurs threads. Les opérations de base sur les sémaphores sont :

incrémenter le compteur de manière atomique et attendre que le compteur soit non-nul

décrémenter le compteur de manière atomique.

sem_init initialise le sémaphore pointé par sem. Le compteur associé au sémaphore est initialisé à valeur. L’argument pshared indique si le sémaphore est local au processus courrant (pshared est zéro) ou partagée entre plusieurs processus (pshared n’est pas nulle). LinuxThreads ne gère actuellement pas les sémaphores partagés entre plusieurs processus, donc sem_init renvoie toujours l’erreur ENOSYS si pshared n’est pas nulle.

sem_wait suspend le thread appelant jusqu’à ce que le sémaphore pointé par sem aît un compteur non nul. Alors, le compteur du sémaphore est atomiquement décrémenté.

sem_trywait est une variante non bloquante de sem_wait. Si le sémaphore pointé par sem a une valeur non nulle, le compteur est atomiquement décrémenté et sem_trywait retourne immédiatement 0. Si le compteur du sémaphore est zéro, sem_trywait retourne immédiatement en indiquant l’erreur EAGAIN.

sem_post incrémente atomiquement le compteur du sémaphore pointé par sem. Cetts fonction ne bloque jamais et peut être utilisée de manière fiable dans un gestionnaire de signaux.

sem_getvalue sauvegarde à l’emplacement pointé par sval la valeur courrante du compteur du sémaphore sem.

sem_destroy détruit un sémaphore, libérant toutes les ressources qu’il possédait. Aucun thread ne doit être bloqué sur ce sémaphore quand sem_destroy est appelée. Dans l’implémentation LinuxThreads, aucune ressource ne peut être associée à un sémaphore, donc sem_destroy ne fait en fait actuellemtn rien si ce n’est vérifier qu’aucun thread n’est bloqué sur ce sémaphore.

ANNULATION

sem_wait est un point d’annulation.

SIGNAUX ASYNCHRONE

Sur les processeurs proposant une opération test_et_affecte (Intel 486, Pentium+, Alpha, PowerPC, MIPS II, Motorola 68k), la fonction sem_post est atomique en ce qui concerne le traitement ds signaux asynchrones. Elle peut donc être appellée par un gestionnaire de signal. C’est la seule fonction de synchronisation de threads définie par POSIX qui soit réentrante vis-à -vis des signaux asynchrones.

Sur les Intel 386 et les Sparc, l’implémentation courrante de sem_post par LinuxThreads n’est pas atomique car le langage machine ne fournit pas d’instructions atomiques. L’utilisation de sem_post dans un gestionnaire de signal n’est donc pas fiable, deux signaux simultanés pouvant amener à n’enregistrer qu’une seule action.

VALEUR RENVOYÃE

Les fonctions sem_wait et sem_getvalue renvoient toujours 0. Toutes les autres fonctions relatives aux sémaphores renvoient zéro en cas de succès et -1 en cas d’erreur. Dans ce dernier cas, la variable errno est positionné au code d’erreur correspondant.

ERREURS

La fonction sem_init initialise errno à l’un des codes d’erreur suivants:

EINVAL

valeur dépasse la valeur maximale du compteur. SEM_VALUE_MAX

ENOSYS

pshared n’est pas zéro.

La fonction sem_trywait initialise errno à l’un des codes d’erreur suivants:

EAGAIN

le compteur du sémaphore vaut actuellement 0.

La fonction sem_post initialise errno à l’un des codes d’erreur suivants:

ERANGE

après l’incrémentation, la valeur du

sémaphore aurait dépassé SEM_VALUE_MAX (Le compteur du sémaphore n’est pas modifié dans ce cas)

La fonction sem_destroy initialise errno à l’un des codes d’erreur suivants:

EBUSY

certains threads sont actuellement bloqués en attente sur le sémaphore.

AUTEUR

Xavier Leroy <Xavier.Leroy@inria.fr>

TRADUCTION

Thierry Vignaud <tvignaud@mandrakesoft.com>, 2000

VOIR AUSSI

pthread_mutex_init(3), pthread_cond_init(3), pthread_cancel(3), ipc(5).


sem_destroy(3thr)