--- rpl/src/interruptions.c 2010/06/08 10:22:37 1.21 +++ rpl/src/interruptions.c 2010/08/13 21:00:37 1.29 @@ -1,6 +1,6 @@ /* ================================================================================ - RPL/2 (R) version 4.0.16 + RPL/2 (R) version 4.0.18 Copyright (C) 1989-2010 Dr. BERTRAND Joël This file is part of RPL/2. @@ -20,7 +20,7 @@ */ -#include "rpl.conv.h" +#include "rpl-conv.h" /* @@ -125,7 +125,6 @@ insertion_thread(struct_processus *s_eta } (*l_nouvel_objet).suivant = liste_threads; - liste_threads = l_nouvel_objet; # ifndef SEMAPHORES_NOMMES @@ -184,7 +183,10 @@ insertion_thread_surveillance(struct_pro } } + pthread_mutex_lock(&((*s_argument_thread).mutex)); (*s_argument_thread).nombre_references++; + pthread_mutex_unlock(&((*s_argument_thread).mutex)); + (*l_nouvel_objet).suivant = liste_threads_surveillance; (*l_nouvel_objet).donnee = (void *) s_argument_thread; @@ -1731,6 +1733,10 @@ interruption1(int signal, siginfo_t *sig volatile sig_atomic_t exclusion = 0; +# ifdef _BROKEN_SIGINFO + (*siginfo).si_pid=getpid(); +# endif + verrouillage_gestionnaire_signaux(); switch(signal) @@ -1866,6 +1872,10 @@ interruption2(int signal, siginfo_t *sig pthread_t thread; struct_processus *s_etat_processus; +# ifdef _BROKEN_SIGINFO + (*siginfo).si_pid=getpid(); +# endif + verrouillage_gestionnaire_signaux(); if (siginfo == NULL) @@ -1939,6 +1949,10 @@ interruption3(int signal, siginfo_t *sig static int compteur = 0; +# ifdef _BROKEN_SIGINFO + (*siginfo).si_pid=getpid(); +# endif + verrouillage_gestionnaire_signaux(); if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) @@ -1997,6 +2011,10 @@ interruption4(int signal, siginfo_t *sig { struct_processus *s_etat_processus; +# ifdef _BROKEN_SIGINFO + (*siginfo).si_pid=getpid(); +# endif + verrouillage_gestionnaire_signaux(); if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) @@ -2026,6 +2044,10 @@ interruption5(int signal, siginfo_t *sig pthread_t thread; struct_processus *s_etat_processus; +# ifdef _BROKEN_SIGINFO + (*siginfo).si_pid=getpid(); +# endif + verrouillage_gestionnaire_signaux(); if ((*siginfo).si_pid == getpid()) @@ -2088,6 +2110,10 @@ interruption6(int signal, siginfo_t *sig { struct_processus *s_etat_processus; +# ifdef _BROKEN_SIGINFO + (*siginfo).si_pid=getpid(); +# endif + verrouillage_gestionnaire_signaux(); if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) @@ -2112,6 +2138,10 @@ interruption7(int signal, siginfo_t *sig { struct_processus *s_etat_processus; +# ifdef _BROKEN_SIGINFO + (*siginfo).si_pid=getpid(); +# endif + verrouillage_gestionnaire_signaux(); if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) @@ -2140,6 +2170,10 @@ interruption8(int signal, siginfo_t *sig pthread_t thread; struct_processus *s_etat_processus; +# ifdef _BROKEN_SIGINFO + (*siginfo).si_pid=getpid(); +# endif + verrouillage_gestionnaire_signaux(); if ((*siginfo).si_pid == getpid()) @@ -2182,6 +2216,10 @@ interruption9(int signal, siginfo_t *sig { struct_processus *s_etat_processus; +# ifdef _BROKEN_SIGINFO + (*siginfo).si_pid=getpid(); +# endif + verrouillage_gestionnaire_signaux(); if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) @@ -2211,6 +2249,10 @@ interruption10(int signal, siginfo_t *si unsigned char nom[8 + 64 + 1]; +# ifdef _BROKEN_SIGINFO + (*siginfo).si_pid=getpid(); +# endif + verrouillage_gestionnaire_signaux(); if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) @@ -2249,6 +2291,10 @@ interruption11(int signal, siginfo_t *si pthread_t thread; struct_processus *s_etat_processus; +# ifdef _BROKEN_SIGINFO + (*siginfo).si_pid=getpid(); +# endif + verrouillage_gestionnaire_signaux(); if ((*siginfo).si_pid == getpid())