version 1.125, 2013/05/21 12:10:12
|
version 1.128, 2013/05/22 12:05:42
|
Line 99 thread_surveillance_signaux(void *argume
|
Line 99 thread_surveillance_signaux(void *argume
|
if (sem_wait(semaphore_signalisation) == 0) |
if (sem_wait(semaphore_signalisation) == 0) |
# endif |
# endif |
{ |
{ |
|
if ((*s_queue_signaux).requete_arret == d_vrai) |
|
{ |
|
# if (!defined(SEMAPHORES_NOMMES)) || defined(IPCS_SYSV) |
|
sem_post(&(*s_queue_signaux).signalisation); |
|
# else |
|
sem_post(semaphore_signalisation); |
|
# endif |
|
|
|
break; |
|
} |
|
|
# if (!defined(SEMAPHORES_NOMMES)) || defined(IPCS_SYSV) |
# if (!defined(SEMAPHORES_NOMMES)) || defined(IPCS_SYSV) |
sem_post(&(*s_queue_signaux).signalisation); |
sem_post(&(*s_queue_signaux).signalisation); |
# else |
# else |
sem_post(semaphore_signalisation); |
sem_post(semaphore_signalisation); |
# endif |
# endif |
|
|
if ((*s_queue_signaux).requete_arret == d_vrai) |
|
{ |
|
break; |
|
} |
|
|
|
nombre_signaux_envoyes = 0; |
nombre_signaux_envoyes = 0; |
sched_yield(); |
sched_yield(); |
|
|
Line 153 thread_surveillance_signaux(void *argume
|
Line 159 thread_surveillance_signaux(void *argume
|
if ((*((struct_thread *) (*l_element_courant).donnee)).pid |
if ((*((struct_thread *) (*l_element_courant).donnee)).pid |
== getpid()) |
== getpid()) |
{ |
{ |
if ((*(*((struct_thread *) (*l_element_courant).donnee)) |
if (pthread_mutex_lock(&mutex_interruptions) != 0) |
.s_etat_processus).pointeur_signal_ecriture != |
{ |
(*(*((struct_thread *) (*l_element_courant).donnee)) |
(*s_etat_processus).erreur_systeme = d_es_processus; |
.s_etat_processus).pointeur_signal_lecture) |
} |
|
else |
{ |
{ |
nombre_signaux_envoyes++; |
if ((*(*((struct_thread *) (*l_element_courant).donnee)) |
pthread_kill((*((struct_thread *) (*l_element_courant) |
.s_etat_processus).pointeur_signal_ecriture != |
.donnee)).tid, SIGALRM); |
(*(*((struct_thread *) (*l_element_courant) |
|
.donnee)).s_etat_processus) |
|
.pointeur_signal_lecture) |
|
{ |
|
nombre_signaux_envoyes++; |
|
pthread_kill((*((struct_thread *) |
|
(*l_element_courant).donnee)).tid, SIGALRM); |
|
} |
|
|
|
if (pthread_mutex_unlock(&mutex_interruptions) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
} |
} |
} |
} |
} |
|
|
Line 3317 liberation_queue_signaux(struct_processu
|
Line 3336 liberation_queue_signaux(struct_processu
|
# endif |
# endif |
# else // POSIX |
# else // POSIX |
# ifndef SEMAPHORES_NOMMES |
# ifndef SEMAPHORES_NOMMES |
sem_close(&((*s_queue_signaux).semaphore)); |
// Rien à faire, les sémaphores sont anonymes. |
sem_close(&((*s_queue_signaux).signalisation)); |
|
# else |
# else |
sem_close(semaphore_queue_signaux); |
sem_close(semaphore_queue_signaux); |
sem_close(semaphore_signalisation); |
sem_close(semaphore_signalisation); |
Line 3357 destruction_queue_signaux(struct_process
|
Line 3375 destruction_queue_signaux(struct_process
|
unsigned char *nom; |
unsigned char *nom; |
# endif |
# endif |
|
|
// Incrémenter le sémaphore pour être sûr de le débloquer. |
# if (!defined(SEMAPHORES_NOMMES)) || defined(IPCS_SYSV) |
|
sem_wait(&((*s_queue_signaux).signalisation)); |
|
# else |
|
sem_wait(semaphore_signalisation); |
|
# endif |
|
|
(*s_queue_signaux).requete_arret = d_vrai; |
(*s_queue_signaux).requete_arret = d_vrai; |
|
|
Line 3367 destruction_queue_signaux(struct_process
|
Line 3389 destruction_queue_signaux(struct_process
|
sem_post(semaphore_signalisation); |
sem_post(semaphore_signalisation); |
# endif |
# endif |
|
|
|
// Incrémenter le sémaphore pour être sûr de le débloquer. |
|
|
|
# if (!defined(SEMAPHORES_NOMMES)) || defined(IPCS_SYSV) |
|
sem_post(&((*s_queue_signaux).signalisation)); |
|
# else |
|
sem_post(semaphore_signalisation); |
|
# endif |
|
|
pthread_join((*s_queue_signaux).thread_signaux, NULL); |
pthread_join((*s_queue_signaux).thread_signaux, NULL); |
|
|
# ifdef IPCS_SYSV // SystemV |
# ifdef IPCS_SYSV // SystemV |
Line 3427 destruction_queue_signaux(struct_process
|
Line 3457 destruction_queue_signaux(struct_process
|
# endif |
# endif |
# else // POSIX |
# else // POSIX |
# ifndef SEMAPHORES_NOMMES |
# ifndef SEMAPHORES_NOMMES |
sem_close(&((*s_queue_signaux).semaphore)); |
|
sem_destroy(&((*s_queue_signaux).semaphore)); |
sem_destroy(&((*s_queue_signaux).semaphore)); |
|
|
sem_close(&((*s_queue_signaux).signalisation)); |
|
sem_destroy(&((*s_queue_signaux).signalisation)); |
sem_destroy(&((*s_queue_signaux).signalisation)); |
# else |
# else |
sem_close(semaphore_queue_signaux); |
sem_close(semaphore_queue_signaux); |