Diff for /rpl/src/gestion_processus.c between versions 1.10 and 1.16

version 1.10, 2010/05/10 08:30:32 version 1.16, 2010/06/09 12:19:13
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.15    RPL/2 (R) version 4.0.16
   Copyright (C) 1989-2010 Dr. BERTRAND Joël    Copyright (C) 1989-2010 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
Line 85  surveillance_processus(void *argument) Line 85  surveillance_processus(void *argument)
   
     s_argument_thread = argument;      s_argument_thread = argument;
     s_etat_processus = (*s_argument_thread).s_etat_processus;      s_etat_processus = (*s_argument_thread).s_etat_processus;
   
       if (pthread_mutex_lock(&((*s_etat_processus).mutex)) != 0)
       {
           (*s_etat_processus).erreur_systeme = d_es_processus;
           BUG(1, uprintf("General mutex error!\n"));
       }
   
     insertion_thread_surveillance(s_etat_processus, s_argument_thread);      insertion_thread_surveillance(s_etat_processus, s_argument_thread);
   
       if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)
       {
           (*s_etat_processus).erreur_systeme = d_es_processus;
           BUG(1, uprintf("General mutex error!\n"));
       }
   
   
     attente.tv_sec = 0;      attente.tv_sec = 0;
     attente.tv_nsec = GRANULARITE_us * 1000;      attente.tv_nsec = GRANULARITE_us * 1000;
   
Line 714  surveillance_processus(void *argument) Line 728  surveillance_processus(void *argument)
                         }                          }
   
                         BUG(l_element_courant == NULL,                          BUG(l_element_courant == NULL,
                                 printf("Process or thread not found"));                                  printf("Process or thread not found\n"));
   
                         if (pthread_mutex_unlock(&((*s_etat_processus).mutex))                          if (pthread_mutex_unlock(&((*s_etat_processus).mutex))
                                 != 0)                                  != 0)
Line 1754  surveillance_processus(void *argument) Line 1768  surveillance_processus(void *argument)
                     (*s_etat_processus).l_base_pile_processus =                      (*s_etat_processus).l_base_pile_processus =
                             (*l_element_courant).suivant;                              (*l_element_courant).suivant;
   
                       (*(*((struct_processus_fils *) (*(*l_element_courant)
                               .donnee).objet)).thread).nombre_references--;
   
                       // Cette référence ne peut être nulle car l'objet est encore
                       // référencé par la liste des threads de surveillance.
   
                       BUG((*(*((struct_processus_fils *) (*(*l_element_courant)
                               .donnee).objet)).thread).nombre_references <= 0,
                               uprintf("(*(*((struct_processus_fils *) "
                               "(*(*l_element_courant).donnee).objet)).thread)"
                               ".nombre_references = %d\n",
                               (*(*((struct_processus_fils *)
                               (*(*l_element_courant).donnee).objet)).thread)
                               .nombre_references));
   
                       free((*(*l_element_courant).donnee).objet);
                       free((*l_element_courant).donnee);
                     free(l_element_courant);                      free(l_element_courant);
   
                     l_element_courant = (struct_liste_chainee *)                      l_element_courant = (struct_liste_chainee *)
Line 1763  surveillance_processus(void *argument) Line 1794  surveillance_processus(void *argument)
                 {                  {
                     (*l_element_precedent).suivant =                      (*l_element_precedent).suivant =
                             (*l_element_courant).suivant;                              (*l_element_courant).suivant;
   
                       (*(*((struct_processus_fils *) (*(*l_element_courant)
                               .donnee).objet)).thread).nombre_references--;
   
                       // Cette référence ne peut être nulle car l'objet est encore
                       // référencé par la liste des threads de surveillance.
   
                       BUG((*(*((struct_processus_fils *) (*(*l_element_courant)
                               .donnee).objet)).thread).nombre_references <= 0,
                               uprintf("(*(*((struct_processus_fils *) "
                               "(*(*l_element_courant).donnee).objet)).thread)"
                               ".nombre_references = %d\n",
                               (*(*((struct_processus_fils *)
                               (*(*l_element_courant).donnee).objet)).thread)
                               .nombre_references));
   
                       free((*(*l_element_courant).donnee).objet);
                       free((*l_element_courant).donnee);
                     free(l_element_courant);                      free(l_element_courant);
                 }                  }
   
Line 1775  surveillance_processus(void *argument) Line 1824  surveillance_processus(void *argument)
             }              }
         }          }
   
         if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)          if ((*s_etat_processus).debug == d_vrai)
         {              if (((*s_etat_processus).type_debug &
             (*s_etat_processus).erreur_systeme_processus_fils = d_es_processus;                      d_debug_processus) != 0)
         }  
     }  
   
     if ((*s_etat_processus).debug == d_vrai)  
         if (((*s_etat_processus).type_debug &  
                 d_debug_processus) != 0)  
     {  
         if ((*s_argument_thread).processus_detache == d_vrai)  
         {          {
             if ((*s_etat_processus).langue == 'F')              if ((*s_argument_thread).processus_detache == d_vrai)
             {              {
                 printf("[%d] Arrêt du thread de surveillance du"                  if ((*s_etat_processus).langue == 'F')
                         " processus %d\n", (int) getpid(),                  {
                         (int) (*s_argument_thread).pid);                      printf("[%d] Arrêt du thread de surveillance du"
                               " processus %d\n", (int) getpid(),
                               (int) (*s_argument_thread).pid);
                   }
                   else
                   {
                       printf("[%d] Stop monitoring of process %d", (int) getpid(),
                               (int) (*s_argument_thread).pid);
                   }
             }              }
             else              else
             {              {
                 printf("[%d] Stop monitoring of process %d", (int) getpid(),                  if ((*s_etat_processus).langue == 'F')
                         (int) (*s_argument_thread).pid);                  {
                       printf("[%d] Arrêt du thread de surveillance du"
                               " thread %llu\n", (int) getpid(),
                               (unsigned long long) (*s_argument_thread)
                               .tid);
                   }
                   else
                   {
                       printf("[%d] Stop monitoring of thread %llu",
                               (int) getpid(),
                               (unsigned long long) (*s_argument_thread)
                               .tid);
                   }
             }              }
   
               fflush(stdout);
         }          }
         else  
           retrait_thread_surveillance(s_etat_processus, s_argument_thread);
   
           if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)
         {          {
             if ((*s_etat_processus).langue == 'F')              (*s_etat_processus).erreur_systeme_processus_fils = d_es_processus;
             {  
                 printf("[%d] Arrêt du thread de surveillance du"  
                         " thread %llu\n", (int) getpid(),  
                         (unsigned long long) (*s_argument_thread)  
                         .tid);  
             }  
             else  
             {  
                 printf("[%d] Stop monitoring of thread %llu", (int) getpid(),  
                         (unsigned long long) (*s_argument_thread)  
                         .tid);  
             }  
         }          }
   
         fflush(stdout);  
     }      }
   
     retrait_thread_surveillance(s_etat_processus, s_argument_thread);  
   
     pthread_exit(NULL);      pthread_exit(NULL);
 }  }
   

Removed from v.1.10  
changed lines
  Added in v.1.16


CVSweb interface <joel.bertrand@systella.fr>