Diff for /rpl/src/instructions_d5.c between versions 1.24 and 1.67

version 1.24, 2010/06/02 10:28:45 version 1.67, 2011/09/14 14:34:28
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.16    RPL/2 (R) version 4.1.3
   Copyright (C) 1989-2010 Dr. BERTRAND Joël    Copyright (C) 1989-2011 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
   
Line 20 Line 20
 */  */
   
   
 #include "rpl.conv.h"  #include "rpl-conv.h"
   
   
 /*  /*
Line 814  instruction_der(struct_processus *s_etat Line 814  instruction_der(struct_processus *s_etat
 void  void
 instruction_detach(struct_processus *s_etat_processus)  instruction_detach(struct_processus *s_etat_processus)
 {  {
     int                         status;  
   
     logical1                    drapeau;      logical1                    drapeau;
     logical1                    variable_partagee;      logical1                    variable_partagee;
   
Line 831  instruction_detach(struct_processus *s_e Line 829  instruction_detach(struct_processus *s_e
     sig_atomic_t                registre_stop;      sig_atomic_t                registre_stop;
   
     sigset_t                    oldset;      sigset_t                    oldset;
     sigset_t                    oldset2;  
     sigset_t                    set;      sigset_t                    set;
     sigset_t                    set2;  
   
     ssize_t                     longueur_ecriture;      ssize_t                     longueur_ecriture;
   
     struct_descripteur_thread   *s_argument_thread;      struct_descripteur_thread   *s_argument_thread;
       struct_descripteur_thread   *s_argument_thread2;
   
     struct_liste_chainee        *l_element_courant;      struct_liste_chainee        *l_element_courant;
     struct_liste_chainee        *l_element_precedent;      struct_liste_chainee        *l_element_precedent;
Line 930  instruction_detach(struct_processus *s_e Line 927  instruction_detach(struct_processus *s_e
         if (recherche_variable(s_etat_processus, (*((struct_nom *)          if (recherche_variable(s_etat_processus, (*((struct_nom *)
                 (*s_objet).objet)).nom) == d_vrai)                  (*s_objet).objet)).nom) == d_vrai)
         {          {
             if ((*s_etat_processus).s_liste_variables              if ((*(*s_etat_processus).pointeur_variable_courante).objet
                     [(*s_etat_processus).position_variable_courante].objet  
                     == NULL)                      == NULL)
             {              {
                 if (pthread_mutex_lock(&((*(*s_etat_processus)                  if (pthread_mutex_lock(&((*(*s_etat_processus)
Line 942  instruction_detach(struct_processus *s_e Line 938  instruction_detach(struct_processus *s_e
                 }                  }
   
                 if (recherche_variable_partagee(s_etat_processus,                  if (recherche_variable_partagee(s_etat_processus,
                         (*s_etat_processus).s_liste_variables                          (*(*s_etat_processus).pointeur_variable_courante).nom,
                         [(*s_etat_processus).position_variable_courante].nom,                          (*(*s_etat_processus).pointeur_variable_courante)
                         (*s_etat_processus).s_liste_variables                          .variable_partagee, (*(*s_etat_processus)
                         [(*s_etat_processus).position_variable_courante]                          .pointeur_variable_courante).origine) == d_faux)
                         .variable_partagee, (*s_etat_processus)  
                         .s_liste_variables[(*s_etat_processus)  
                         .position_variable_courante].origine) == d_faux)  
                 {                  {
                     if (pthread_mutex_unlock(&((*(*s_etat_processus)                      if (pthread_mutex_unlock(&((*(*s_etat_processus)
                             .s_liste_variables_partagees).mutex)) != 0)                              .s_liste_variables_partagees).mutex)) != 0)
Line 1016  instruction_detach(struct_processus *s_e Line 1009  instruction_detach(struct_processus *s_e
             }              }
             else              else
             {              {
                 if (((*(*s_etat_processus).s_liste_variables                  if (((*(*(*s_etat_processus).pointeur_variable_courante).objet)
                         [(*s_etat_processus).position_variable_courante].objet)                          .type != RPN) && ((*(*(*s_etat_processus)
                         .type != RPN) && ((*(*s_etat_processus)                          .pointeur_variable_courante).objet).type != ADR))
                         .s_liste_variables[(*s_etat_processus)  
                         .position_variable_courante].objet).type != ADR))  
                 {                  {
                     liberation(s_etat_processus, s_objet);                      liberation(s_etat_processus, s_objet);
   
Line 1040  instruction_detach(struct_processus *s_e Line 1031  instruction_detach(struct_processus *s_e
         }          }
     }      }
   
     if (sigemptyset(&set) != 0)  
     {  
         (*s_etat_processus).erreur_systeme = d_es_processus;  
         return;  
     }  
   
     if (sigaddset(&set, SIGSTART) != 0)  
     {  
         (*s_etat_processus).erreur_systeme = d_es_processus;  
         return;  
     }  
   
     /*  
      * Le signal SIGFSTOP doit être traité !  
      */  
   
     if (sigaddset(&set, SIGFSTOP) != 0)  
     {  
         (*s_etat_processus).erreur_systeme = d_es_processus;  
         return;  
     }  
   
     if (sigaddset(&set, SIGFABORT) != 0)  
     {  
         (*s_etat_processus).erreur_systeme = d_es_processus;  
         return;  
     }  
   
     if (sigaddset(&set, SIGURG) != 0)  
     {  
         (*s_etat_processus).erreur_systeme = d_es_processus;  
         return;  
     }  
   
     if (pthread_sigmask(SIG_BLOCK, &set, &oldset) != 0)  
     {  
         (*s_etat_processus).erreur_systeme = d_es_processus;  
         return;  
     }  
   
     if ((s_argument_thread = malloc(sizeof(struct_descripteur_thread))) == NULL)      if ((s_argument_thread = malloc(sizeof(struct_descripteur_thread))) == NULL)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
Line 1153  instruction_detach(struct_processus *s_e Line 1104  instruction_detach(struct_processus *s_e
      * de mémoire, ni libération, ni copie d'objet concurrent au fork().       * de mémoire, ni libération, ni copie d'objet concurrent au fork().
      */       */
   
     sigfillset(&set2);      sigfillset(&set);
     pthread_sigmask(SIG_BLOCK, &set2, &oldset2);      pthread_sigmask(SIG_BLOCK, &set, &oldset);
   
     verrouillage_threads_concurrents(s_etat_processus);      verrouillage_threads_concurrents(s_etat_processus);
     (*s_argument_thread).pid = fork();      (*s_argument_thread).pid = fork();
     deverrouillage_threads_concurrents(s_etat_processus);      deverrouillage_threads_concurrents(s_etat_processus);
       pthread_sigmask(SIG_SETMASK, &oldset, NULL);
     pthread_sigmask(SIG_SETMASK, &oldset2, NULL);      sigpending(&set);
     sigpending(&set2);  
   
     (*s_argument_thread).thread_pere = pthread_self();      (*s_argument_thread).thread_pere = pthread_self();
     (*s_argument_thread).processus_detache = d_vrai;      (*s_argument_thread).processus_detache = d_vrai;
Line 1171  instruction_detach(struct_processus *s_e Line 1120  instruction_detach(struct_processus *s_e
     pthread_mutex_init(&((*s_argument_thread).mutex), &attributs_mutex);      pthread_mutex_init(&((*s_argument_thread).mutex), &attributs_mutex);
     pthread_mutexattr_destroy(&attributs_mutex);      pthread_mutexattr_destroy(&attributs_mutex);
   
       pthread_mutexattr_init(&attributs_mutex);
       pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_RECURSIVE);
       pthread_mutex_init(&((*s_argument_thread).mutex_nombre_references),
               &attributs_mutex);
       pthread_mutexattr_destroy(&attributs_mutex);
   
     if ((*s_argument_thread).pid > 0)      if ((*s_argument_thread).pid > 0)
     {      {
         /*          /*
Line 1182  instruction_detach(struct_processus *s_e Line 1137  instruction_detach(struct_processus *s_e
             liberation(s_etat_processus, s_copie);              liberation(s_etat_processus, s_copie);
         }          }
   
         if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)          liberation(s_etat_processus, s_objet);
   
           if ((s_objet = allocation(s_etat_processus, PRC)) == NULL)
         {          {
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
             return;              return;
         }          }
   
         if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)          (*((struct_processus_fils *) (*s_objet).objet)).thread =
                   s_argument_thread;
           (*(*((struct_processus_fils *) (*s_objet).objet)).thread)
                   .nombre_objets_dans_pipe = 0;
           (*(*((struct_processus_fils *) (*s_objet).objet)).thread)
                   .nombre_interruptions_dans_pipe = 0;
           (*(*((struct_processus_fils *) (*s_objet).objet)).thread)
                   .nombre_references = 1;
   
           /*
            * On copie l'objet plutôt que le pointeur car cet objet peut être
            * accédé depuis deux threads distincts et aboutir à un blocage lors
            * d'une copie.
            */
   
           if ((s_objet_systeme = copie_objet(s_etat_processus, s_objet, 'O'))
                   == NULL)
         {          {
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
             return;              return;
         }          }
   
Line 1256  instruction_detach(struct_processus *s_e Line 1229  instruction_detach(struct_processus *s_e
             return;              return;
         }          }
   
   #       ifndef OS2
   #       ifndef Cygwin
         if (pthread_attr_setschedpolicy(&attributs, SCHED_OTHER) != 0)          if (pthread_attr_setschedpolicy(&attributs, SCHED_OTHER) != 0)
         {          {
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_processus;
Line 1274  instruction_detach(struct_processus *s_e Line 1249  instruction_detach(struct_processus *s_e
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_processus;
             return;              return;
         }          }
   #       endif
   #       endif
   
         (*s_argument_thread).s_etat_processus = s_etat_processus;          (*s_argument_thread).s_etat_processus = s_etat_processus;
   
Line 1296  instruction_detach(struct_processus *s_e Line 1273  instruction_detach(struct_processus *s_e
          * Processus fils           * Processus fils
          */           */
   
           liberation_queue_signaux(s_etat_processus);
           creation_queue_signaux(s_etat_processus);
   
           (*s_etat_processus).pointeur_signal_lecture = 0;
           (*s_etat_processus).pointeur_signal_ecriture = 0;
           (*s_etat_processus).tid_courant = pthread_self();
   
           if ((*s_etat_processus).debug == d_vrai)
               if (((*s_etat_processus).type_debug &
                       d_debug_processus) != 0)
           {
               if ((*s_etat_processus).langue == 'F')
               {
                   printf("[%d] Lancement du processus fils %d de %d\n",
                           (int) getpid(), (int) getpid(), (int) ppid);
               }
               else
               {
                   printf("[%d] Start child process %d from %d\n", (int) getpid(),
                           (int) getpid(), (int) ppid);
               }
   
               fflush(stdout);
           }
   
 #       ifndef SEMAPHORES_NOMMES  #       ifndef SEMAPHORES_NOMMES
         sem_post(&semaphore_gestionnaires_signaux);          sem_post(&semaphore_gestionnaires_signaux);
         sem_destroy(&semaphore_gestionnaires_signaux);          sem_destroy(&semaphore_gestionnaires_signaux);
Line 1389  instruction_detach(struct_processus *s_e Line 1391  instruction_detach(struct_processus *s_e
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_processus;
         }          }
   
           if ((*s_etat_processus).debug == d_vrai)
               if (((*s_etat_processus).type_debug &
                       d_debug_processus) != 0)
           {
               if ((*s_etat_processus).langue == 'F')
               {
                   printf("[%d] Libération des objets du processus père\n",
                           (int) getpid());
               }
               else
               {
                   printf("[%d] Freeing parent process memory\n", getpid());
               }
   
               fflush(stdout);
           }
   
         l_element_courant = (*s_etat_processus).liste_mutexes;          l_element_courant = (*s_etat_processus).liste_mutexes;
         while(l_element_courant != NULL)          while(l_element_courant != NULL)
         {          {
Line 1450  instruction_detach(struct_processus *s_e Line 1469  instruction_detach(struct_processus *s_e
                 }                  }
             }              }
   
               destruction_queue_signaux(s_etat_processus);
               BUG(1, uprintf("Process management error line %d\n", __LINE__));
             exit(EXIT_FAILURE);              exit(EXIT_FAILURE);
         }          }
   
Line 1479  instruction_detach(struct_processus *s_e Line 1500  instruction_detach(struct_processus *s_e
                 }                  }
             }              }
   
               destruction_queue_signaux(s_etat_processus);
               BUG(1, uprintf("Process management error line %d\n", __LINE__));
             exit(EXIT_FAILURE);              exit(EXIT_FAILURE);
         }          }
   
           pthread_mutex_trylock(&((*s_etat_processus).protection_liste_mutexes));
   
         if (pthread_mutex_unlock(&((*s_etat_processus)          if (pthread_mutex_unlock(&((*s_etat_processus)
                 .protection_liste_mutexes)) != 0)                  .protection_liste_mutexes)) != 0)
         {          {
Line 1509  instruction_detach(struct_processus *s_e Line 1534  instruction_detach(struct_processus *s_e
                 }                  }
             }              }
   
               destruction_queue_signaux(s_etat_processus);
               BUG(1, uprintf("Process management error line %d\n", __LINE__));
             exit(EXIT_FAILURE);              exit(EXIT_FAILURE);
         }          }
   
Line 1519  instruction_detach(struct_processus *s_e Line 1546  instruction_detach(struct_processus *s_e
         }          }
   
         (*s_etat_processus).var_volatile_processus_pere = 0;          (*s_etat_processus).var_volatile_processus_pere = 0;
           (*s_etat_processus).var_volatile_processus_racine = 0;
   
         // On réinitialise toutes les interruptions.          // On réinitialise toutes les interruptions.
   
Line 1530  instruction_detach(struct_processus *s_e Line 1558  instruction_detach(struct_processus *s_e
   
         liberation(s_etat_processus, (*s_etat_processus).at_exit);          liberation(s_etat_processus, (*s_etat_processus).at_exit);
         (*s_etat_processus).at_exit = NULL;          (*s_etat_processus).at_exit = NULL;
           liberation(s_etat_processus, (*s_etat_processus).at_poke);
           (*s_etat_processus).at_poke = NULL;
           (*s_etat_processus).traitement_at_poke = 'N';
   
         for(i = 0; i < d_NOMBRE_INTERRUPTIONS; i++)          for(i = 0; i < d_NOMBRE_INTERRUPTIONS; i++)
         {          {
Line 1554  instruction_detach(struct_processus *s_e Line 1585  instruction_detach(struct_processus *s_e
             (*s_etat_processus).pile_origine_interruptions[i] = NULL;              (*s_etat_processus).pile_origine_interruptions[i] = NULL;
         }          }
   
         if ((*s_etat_processus).debug == d_vrai)  
             if (((*s_etat_processus).type_debug &  
                     d_debug_processus) != 0)  
         {  
             if ((*s_etat_processus).langue == 'F')  
             {  
                 printf("[%d] Lancement du processus fils %d de %d\n",  
                         (int) getpid(), (int) getpid(), (int) ppid);  
             }  
             else  
             {  
                 printf("[%d] Start child process %d from %d\n", (int) getpid(),  
                         (int) getpid(), (int) ppid);  
             }  
   
             fflush(stdout);  
         }  
   
         /*          /*
          * On bloque l'exécution du processus fils jusqu'à ce que           * On bloque l'exécution du processus fils jusqu'à ce que
          * le père ait renseigné correctement la pile des processus.           * le père ait renseigné correctement la pile des processus.
Line 1580  instruction_detach(struct_processus *s_e Line 1593  instruction_detach(struct_processus *s_e
          * renseignée.           * renseignée.
          */           */
   
         if (sigpending(&set) != 0)          // Attente de la réception du signal rpl_sigstart.
         {  
             (*s_etat_processus).erreur_systeme = d_es_processus;          for((*s_etat_processus).demarrage_fils = d_faux;;)
         }  
         else if (sigismember(&set, SIGSTART) == 0)  
         {          {
             while(sigismember(&set, SIGSTART) == 0)              scrutation_interruptions(s_etat_processus);
             {  
                 if (sigpending(&set) != 0)  
                 {  
                     (*s_etat_processus).erreur_systeme = d_es_processus;  
                 }  
   
                 nanosleep(&attente, NULL);              if ((*s_etat_processus).demarrage_fils == d_vrai)
               {
                   break;
             }              }
   
               nanosleep(&attente, NULL);
         }          }
   
         (*s_etat_processus).niveau_initial = (*s_etat_processus).niveau_courant;          (*s_etat_processus).niveau_initial = (*s_etat_processus).niveau_courant;
Line 1641  instruction_detach(struct_processus *s_e Line 1651  instruction_detach(struct_processus *s_e
         }          }
   
         /*          /*
          * Initialisation de la pile des processus           * Initialisation de la pile des processus. Cette pile est effacée
            * par liberation_threads().
          */           */
   
           if (pthread_mutex_lock(&((*s_etat_processus).mutex)) != 0)
           {
               (*s_etat_processus).erreur_systeme = d_es;
   
               pid_final = -2;
   
               while((longueur_ecriture = write_atomic(s_etat_processus,
                       (*s_argument_thread).pipe_nombre_interruptions_attente[1],
                       &pid_final, sizeof(pid_final))) != sizeof(pid_final))
               {
                   if (longueur_ecriture == -1)
                   {
                       break;
                   }
               }
   
               while((longueur_ecriture = write_atomic(s_etat_processus,
                       (*s_argument_thread).pipe_nombre_objets_attente[1],
                       &pid_final, sizeof(pid_final))) != sizeof(pid_final))
               {
                   if (longueur_ecriture == -1)
                   {
                       break;
                   }
               }
   
               destruction_queue_signaux(s_etat_processus);
               BUG(1, uprintf("Process management error line %d\n", __LINE__));
               exit(EXIT_FAILURE);
           }
   
         l_element_courant = (struct_liste_chainee *)          l_element_courant = (struct_liste_chainee *)
                 (*s_etat_processus).l_base_pile_processus;                  (*s_etat_processus).l_base_pile_processus;
   
         while(l_element_courant != NULL)          while(l_element_courant != NULL)
         {          {
             l_element_suivant = (*l_element_courant).suivant;              s_argument_thread2 = (struct_descripteur_thread *)
                       (*((struct_processus_fils *) (*(*l_element_courant).donnee)
                         .objet)).thread;
   
               (*s_argument_thread2).nombre_references--;
   
             if ((*((*(struct_processus_fils *) (*(*l_element_courant).donnee)              BUG((*s_argument_thread2).nombre_references < 0,
                     .objet)).thread).processus_detache == d_faux)                      destruction_queue_signaux(s_etat_processus),
                       printf("(*s_argument_thread2).nombre_references = %d\n",
                       (int) (*s_argument_thread2).nombre_references));
   
               if ((*s_argument_thread2).nombre_references == 0)
             {              {
                 liberation(s_etat_processus, (*((*(struct_processus_fils *)                  close((*s_argument_thread2).pipe_objets[0]);
                         (*(*l_element_courant).donnee).objet)).thread)                  close((*s_argument_thread2).pipe_acquittement[1]);
                         .argument);                  close((*s_argument_thread2).pipe_injections[1]);
             }                  close((*s_argument_thread2).pipe_nombre_injections[1]);
                   close((*s_argument_thread2).pipe_nombre_objets_attente[0]);
                   close((*s_argument_thread2).pipe_interruptions[0]);
                   close((*s_argument_thread2)
                           .pipe_nombre_interruptions_attente[0]);
   
             free((*(*l_element_courant).donnee).objet);                  pthread_mutex_destroy(&((*s_argument_thread2).mutex));
             free((*l_element_courant).donnee);  
             free(l_element_courant);  
   
                   if ((*s_argument_thread2).processus_detache == d_faux)
                   {
                       if ((*s_argument_thread2).destruction_objet == d_vrai)
                       {
                           liberation(s_etat_processus,
                                   (*s_argument_thread2).argument);
                       }
                   }
   
                   free(s_argument_thread2);
                   free((*(*l_element_courant).donnee).objet);
                   free((*l_element_courant).donnee);
               }
   
               l_element_suivant = (*l_element_courant).suivant;
               free((struct_liste_chainee *) l_element_courant);
             l_element_courant = l_element_suivant;              l_element_courant = l_element_suivant;
         }          }
   
         (*s_etat_processus).l_base_pile_processus = NULL;          (*s_etat_processus).l_base_pile_processus = NULL;
   
           if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)
           {
               (*s_etat_processus).erreur_systeme = d_es;
   
               pid_final = -2;
   
               while((longueur_ecriture = write_atomic(s_etat_processus,
                       (*s_argument_thread).pipe_nombre_interruptions_attente[1],
                       &pid_final, sizeof(pid_final))) != sizeof(pid_final))
               {
                   if (longueur_ecriture == -1)
                   {
                       break;
                   }
               }
   
               while((longueur_ecriture = write_atomic(s_etat_processus,
                       (*s_argument_thread).pipe_nombre_objets_attente[1],
                       &pid_final, sizeof(pid_final))) != sizeof(pid_final))
               {
                   if (longueur_ecriture == -1)
                   {
                       break;
                   }
               }
   
               destruction_queue_signaux(s_etat_processus);
               BUG(1, uprintf("Process management error line %d\n", __LINE__));
               exit(EXIT_FAILURE);
           }
   
         /*          /*
          * Initialisation de la pile système           * Initialisation de la pile système
          */           */
Line 1728  instruction_detach(struct_processus *s_e Line 1827  instruction_detach(struct_processus *s_e
                 }                  }
             }              }
   
               destruction_queue_signaux(s_etat_processus);
               BUG(1, uprintf("Process management error line %d\n", __LINE__));
             exit(EXIT_FAILURE);              exit(EXIT_FAILURE);
         }          }
   
Line 1779  instruction_detach(struct_processus *s_e Line 1880  instruction_detach(struct_processus *s_e
                 }                  }
             }              }
   
               destruction_queue_signaux(s_etat_processus);
               BUG(1, uprintf("Process management error line %d\n", __LINE__));
             exit(EXIT_FAILURE);              exit(EXIT_FAILURE);
         }          }
   
Line 1878  instruction_detach(struct_processus *s_e Line 1981  instruction_detach(struct_processus *s_e
   
         (*s_etat_processus).s_fichiers = NULL;          (*s_etat_processus).s_fichiers = NULL;
   
         if (pthread_sigmask(SIG_SETMASK, &oldset, NULL) != 0)          if ((*s_etat_processus).debug == d_vrai)
         {          {
             (*s_etat_processus).erreur_systeme = d_es_processus;              if (((*s_etat_processus).type_debug & d_debug_processus)
                       != 0)
               {
                   if ((*s_etat_processus).langue == 'F')
                   {
                       printf("[%d] Évaluation de l'objet détaché\n", getpid());
                   }
                   else
                   {
                       printf("[%d] Évaluation of detached object\n", getpid());
                   }
               }
         }          }
   
         sigpending(&set);  
   
         if ((*s_etat_processus).erreur_systeme == d_es)          if ((*s_etat_processus).erreur_systeme == d_es)
         {          {
             if (variable_partagee == d_faux)              if (setjmp(contexte_processus) == 0)
             {              {
                 if (evaluation(s_etat_processus, s_objet, 'E') == d_erreur)                  if (variable_partagee == d_faux)
                 {                  {
                     if (((*s_etat_processus).erreur_execution == d_ex) &&                      if (evaluation(s_etat_processus, s_objet, 'E') == d_erreur)
                             ((*s_etat_processus).erreur_systeme == d_es))  
                     {                      {
                         (*s_etat_processus).erreur_execution =                          if (((*s_etat_processus).erreur_execution == d_ex) &&
                                 d_ex_erreur_evaluation;                                  ((*s_etat_processus).erreur_systeme == d_es))
                     }  
                 }  
                 else  
                 {  
                     if (((*s_etat_processus).var_volatile_alarme == 0)  
                             && ((*s_etat_processus).arret_depuis_abort == 0)  
                             && ((*s_etat_processus).at_exit != NULL))  
                     {  
                         (*s_etat_processus).var_volatile_requete_arret = 0;  
   
                         if (evaluation(s_etat_processus,  
                                 (*s_etat_processus).at_exit, 'E') == d_erreur)  
                         {                          {
                             (*s_etat_processus).erreur_execution =                              (*s_etat_processus).erreur_execution =
                                     d_ex_erreur_evaluation;                                      d_ex_erreur_evaluation;
                         }                          }
                     }                      }
                 }                      else
             }  
             else  
             {  
                 if (evaluation(s_etat_processus, s_copie, 'E') == d_erreur)  
                 {  
                     if (((*s_etat_processus).erreur_execution == d_ex) &&  
                             ((*s_etat_processus).erreur_systeme == d_es))  
                     {                      {
                         (*s_etat_processus).erreur_execution =                          if (((*s_etat_processus).var_volatile_alarme == 0)
                                 d_ex_erreur_evaluation;                                  && ((*s_etat_processus).arret_depuis_abort == 0)
                                   && ((*s_etat_processus).at_exit != NULL))
                           {
                               (*s_etat_processus).var_volatile_requete_arret = 0;
   
                               if (evaluation(s_etat_processus,
                                       (*s_etat_processus).at_exit, 'E') ==
                                       d_erreur)
                               {
                                   (*s_etat_processus).erreur_execution =
                                           d_ex_erreur_evaluation;
                               }
                           }
                     }                      }
                 }                  }
                 else                  else
                 {                  {
                     if ((*s_etat_processus).at_exit != NULL)                      if (evaluation(s_etat_processus, s_copie, 'E') == d_erreur)
                     {                      {
                         (*s_etat_processus).var_volatile_requete_arret = 0;                          if (((*s_etat_processus).erreur_execution == d_ex) &&
                                   ((*s_etat_processus).erreur_systeme == d_es))
                         if (evaluation(s_etat_processus,  
                                 (*s_etat_processus).at_exit, 'E') == d_erreur)  
                         {                          {
                             (*s_etat_processus).erreur_execution =                              (*s_etat_processus).erreur_execution =
                                     d_ex_erreur_evaluation;                                      d_ex_erreur_evaluation;
                         }                          }
                     }                      }
                 }                      else
                       {
                           if ((*s_etat_processus).at_exit != NULL)
                           {
                               (*s_etat_processus).var_volatile_requete_arret = 0;
   
                 liberation(s_etat_processus, s_copie);                              if (evaluation(s_etat_processus,
                                       (*s_etat_processus).at_exit, 'E') ==
                                       d_erreur)
                               {
                                   (*s_etat_processus).erreur_execution =
                                           d_ex_erreur_evaluation;
                               }
                           }
                       }
   
                       liberation(s_etat_processus, s_copie);
                   }
             }              }
         }          }
   
         liberation(s_etat_processus, (*s_etat_processus).at_exit);          liberation(s_etat_processus, (*s_etat_processus).at_exit);
           liberation(s_etat_processus, (*s_etat_processus).at_poke);
   
         l_element_courant = (*s_etat_processus).liste_mutexes;          l_element_courant = (*s_etat_processus).liste_mutexes;
         while(l_element_courant != NULL)          while(l_element_courant != NULL)
Line 2167  instruction_detach(struct_processus *s_e Line 2285  instruction_detach(struct_processus *s_e
   
                 if ((*s_etat_processus).var_volatile_alarme != 0)                  if ((*s_etat_processus).var_volatile_alarme != 0)
                 {                  {
                     kill((*(*((struct_processus_fils *)                      envoi_signal_processus((*(*((struct_processus_fils *)
                             (*(*l_element_courant).donnee).objet)).thread).pid,                              (*(*l_element_courant).donnee).objet)).thread).pid,
                             SIGURG);                              rpl_sigurg);
                 }                  }
                 else                  else
                 {                  {
                     if ((*s_etat_processus).arret_depuis_abort == -1)                      if ((*s_etat_processus).arret_depuis_abort == -1)
                     {                      {
                         kill((*(*((struct_processus_fils *)                          envoi_signal_processus((*(*((struct_processus_fils *)
                                 (*(*l_element_courant).donnee).objet)).thread)                                  (*(*l_element_courant).donnee).objet)).thread)
                                 .pid, SIGFABORT);                                  .pid, rpl_sigabort);
                     }                      }
                     else                      else
                     {                      {
                         kill((*(*((struct_processus_fils *)                          envoi_signal_processus((*(*((struct_processus_fils *)
                                 (*(*l_element_courant).donnee).objet)).thread)                                  (*(*l_element_courant).donnee).objet)).thread)
                                 .pid, SIGFSTOP);                                  .pid, rpl_sigstop);
                     }                      }
                 }                  }
             }              }
Line 2225  instruction_detach(struct_processus *s_e Line 2343  instruction_detach(struct_processus *s_e
                 {                  {
                     if ((*s_etat_processus).var_volatile_alarme != 0)                      if ((*s_etat_processus).var_volatile_alarme != 0)
                     {                      {
                         pthread_kill((*(*((struct_processus_fils *)                          envoi_signal_thread((*(*((struct_processus_fils *)
                                 (*(*l_element_courant).donnee).objet)).thread)                                  (*(*l_element_courant).donnee).objet)).thread)
                                 .tid, SIGURG);                                  .tid, rpl_sigurg);
                     }                      }
                     else                      else
                     {                      {
                         if ((*s_etat_processus).arret_depuis_abort == -1)                          if ((*s_etat_processus).arret_depuis_abort == -1)
                         {                          {
                             pthread_kill((*(*((struct_processus_fils *)                              envoi_signal_thread((*(*((struct_processus_fils *)
                                     (*(*l_element_courant).donnee).objet))                                      (*(*l_element_courant).donnee).objet))
                                     .thread).tid, SIGFABORT);                                      .thread).tid, rpl_sigabort);
                         }                          }
                         else                          else
                         {                          {
                             pthread_kill((*(*((struct_processus_fils *)                              envoi_signal_thread((*(*((struct_processus_fils *)
                                     (*(*l_element_courant).donnee).objet))                                      (*(*l_element_courant).donnee).objet))
                                     .thread).tid, SIGFSTOP);                                      .thread).tid, rpl_sigstop);
                         }                          }
                     }                      }
                 }                  }
Line 2265  instruction_detach(struct_processus *s_e Line 2383  instruction_detach(struct_processus *s_e
   
         while((*s_etat_processus).l_base_pile_processus != NULL)          while((*s_etat_processus).l_base_pile_processus != NULL)
         {          {
             status = 0;  
   
             l_element_courant = (struct_liste_chainee *)              l_element_courant = (struct_liste_chainee *)
                     (*s_etat_processus).l_base_pile_processus;                      (*s_etat_processus).l_base_pile_processus;
   
Line 2309  instruction_detach(struct_processus *s_e Line 2425  instruction_detach(struct_processus *s_e
                                     registre_stop;                                      registre_stop;
                         }                          }
   
                           destruction_queue_signaux(s_etat_processus);
                         (*s_etat_processus).erreur_systeme = d_es_signal;                          (*s_etat_processus).erreur_systeme = d_es_signal;
                         exit(EXIT_FAILURE);                          exit(EXIT_FAILURE);
                     }                      }
Line 2343  instruction_detach(struct_processus *s_e Line 2460  instruction_detach(struct_processus *s_e
   
                     if (sigaction(SIGPIPE, &registre, NULL) != 0)                      if (sigaction(SIGPIPE, &registre, NULL) != 0)
                     {                      {
                         pthread_mutex_unlock(&((*s_etat_processus).mutex));                          destruction_queue_signaux(s_etat_processus);
   
                           pthread_mutex_unlock(&((*s_etat_processus).mutex));
                         (*s_etat_processus).erreur_systeme = d_es_signal;                          (*s_etat_processus).erreur_systeme = d_es_signal;
                         exit(EXIT_FAILURE);                          exit(EXIT_FAILURE);
                     }                      }
Line 2484  instruction_detach(struct_processus *s_e Line 2602  instruction_detach(struct_processus *s_e
             (*s_etat_processus).instruction_derniere_erreur = NULL;              (*s_etat_processus).instruction_derniere_erreur = NULL;
         }          }
   
         for(i = 0; i < (*s_etat_processus).nombre_variables; i++)          liberation_arbre_variables(s_etat_processus,
         {                  (*s_etat_processus).s_arbre_variables, d_vrai);
             liberation(s_etat_processus,          free((*s_etat_processus).pointeurs_caracteres_variables);
                     (*s_etat_processus).s_liste_variables[i].objet);  
             free((*s_etat_processus).s_liste_variables[i].nom);  
         }  
   
         free((*s_etat_processus).s_liste_variables);  
   
         for(i = 0; i < (*s_etat_processus).nombre_variables_statiques; i++)          for(i = 0; i < (*s_etat_processus).nombre_variables_statiques; i++)
         {          {
Line 2659  instruction_detach(struct_processus *s_e Line 2772  instruction_detach(struct_processus *s_e
   
         liberation(s_etat_processus, s_objet);          liberation(s_etat_processus, s_objet);
   
 #       ifndef Cygwin  
         (*s_etat_processus).pile_signal.ss_flags = SS_DISABLE;  
         sigaltstack(&((*s_etat_processus).pile_signal), NULL);  
         free((*s_etat_processus).pile_signal.ss_sp);  
 #       endif  
   
         free((*s_etat_processus).definitions_chainees);          free((*s_etat_processus).definitions_chainees);
         free((*s_etat_processus).nom_fichier_historique);          free((*s_etat_processus).nom_fichier_historique);
   
Line 2704  instruction_detach(struct_processus *s_e Line 2811  instruction_detach(struct_processus *s_e
         retrait_thread(s_etat_processus);          retrait_thread(s_etat_processus);
   
         pthread_mutex_destroy(&((*s_etat_processus).mutex));          pthread_mutex_destroy(&((*s_etat_processus).mutex));
           pthread_mutex_destroy(&((*s_etat_processus).mutex_allocation));
         pthread_mutex_destroy(&((*s_etat_processus).protection_liste_mutexes));          pthread_mutex_destroy(&((*s_etat_processus).protection_liste_mutexes));
   
         pthread_key_delete(semaphore_fork_processus_courant);          pthread_key_delete(semaphore_fork_processus_courant);
Line 2735  instruction_detach(struct_processus *s_e Line 2843  instruction_detach(struct_processus *s_e
   
         clear_history();          clear_history();
   
           destruction_queue_signaux(s_etat_processus);
           liberation_contexte_cas(s_etat_processus);
         free(s_etat_processus);          free(s_etat_processus);
   
 #       ifdef DEBUG_MEMOIRE  #       ifdef DEBUG_MEMOIRE
Line 2750  instruction_detach(struct_processus *s_e Line 2860  instruction_detach(struct_processus *s_e
         return;          return;
     }      }
   
     liberation(s_etat_processus, s_objet);  
   
     if ((s_objet = allocation(s_etat_processus, PRC)) == NULL)  
     {  
         (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;  
         return;  
     }  
   
     (*((struct_processus_fils *) (*s_objet).objet)).thread = s_argument_thread;  
     (*(*((struct_processus_fils *) (*s_objet).objet)).thread)  
             .nombre_objets_dans_pipe = 0;  
     (*(*((struct_processus_fils *) (*s_objet).objet)).thread)  
             .nombre_interruptions_dans_pipe = 0;  
     (*(*((struct_processus_fils *) (*s_objet).objet)).thread)  
             .nombre_references = 1;  
   
     /*  
      * On copie l'objet plutôt que le pointeur car cet objet peut être  
      * accédé depuis deux threads distincts et aboutir à un blocage lors d'une  
      * copie.  
      */  
   
     if ((s_objet_systeme = copie_objet(s_etat_processus, s_objet, 'O')) == NULL)  
     {  
         (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;  
         return;  
     }  
   
     if (pthread_mutex_lock(&((*s_etat_processus).mutex)) != 0)  
     {  
         (*s_etat_processus).erreur_systeme = d_es_processus;  
         return;  
     }  
   
     // Si le pid existe déjà dans la pile des processus, il s'agit forcement      // Si le pid existe déjà dans la pile des processus, il s'agit forcement
     // d'un processus moribond. On attend donc qu'il soit effectivement      // d'un processus moribond. On attend donc qu'il soit effectivement
     // libéré.      // libéré.
Line 2848  instruction_detach(struct_processus *s_e Line 2924  instruction_detach(struct_processus *s_e
   
     // Être sûr que le processus fils soit déjà présent...      // Être sûr que le processus fils soit déjà présent...
   
       attente.tv_sec = 0;
       attente.tv_nsec = GRANULARITE_us * 1000;
   
     while(kill((*s_argument_thread).pid, 0) != 0)      while(kill((*s_argument_thread).pid, 0) != 0)
     {      {
         //if ((errno != ESRCH) && (errno != EAGAIN))          //if ((errno != ESRCH) && (errno != EAGAIN))
Line 2859  instruction_detach(struct_processus *s_e Line 2938  instruction_detach(struct_processus *s_e
         }          }
   
         nanosleep(&attente, NULL);          nanosleep(&attente, NULL);
           INCR_GRANULARITE(attente.tv_nsec);
     }      }
   
     // Le fils peut être présent sans être en attente du signal de départ.      // Le fils peut être présent sans être en attente du signal de départ.
   
     if (kill((*s_argument_thread).pid, SIGSTART) != 0)      if (envoi_signal_processus((*s_argument_thread).pid, rpl_sigstart) != 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
         pthread_mutex_unlock(&((*s_etat_processus).mutex));          pthread_mutex_unlock(&((*s_etat_processus).mutex));
         return;          return;
     }      }
   
     if (pthread_sigmask(SIG_SETMASK, &oldset, NULL) != 0)  
     {  
         (*s_etat_processus).erreur_systeme = d_es_processus;  
         pthread_mutex_unlock(&((*s_etat_processus).mutex));  
         return;  
     }  
   
     sigpending(&set);  
   
     if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)      if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;

Removed from v.1.24  
changed lines
  Added in v.1.67


CVSweb interface <joel.bertrand@systella.fr>