--- rpl/src/interruptions.c 2013/05/22 09:25:47 1.127 +++ rpl/src/interruptions.c 2013/05/22 12:05:42 1.128 @@ -159,14 +159,27 @@ thread_surveillance_signaux(void *argume if ((*((struct_thread *) (*l_element_courant).donnee)).pid == getpid()) { - if ((*(*((struct_thread *) (*l_element_courant).donnee)) - .s_etat_processus).pointeur_signal_ecriture != - (*(*((struct_thread *) (*l_element_courant).donnee)) - .s_etat_processus).pointeur_signal_lecture) + if (pthread_mutex_lock(&mutex_interruptions) != 0) { - nombre_signaux_envoyes++; - pthread_kill((*((struct_thread *) (*l_element_courant) - .donnee)).tid, SIGALRM); + (*s_etat_processus).erreur_systeme = d_es_processus; + } + else + { + if ((*(*((struct_thread *) (*l_element_courant).donnee)) + .s_etat_processus).pointeur_signal_ecriture != + (*(*((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; + } } }