Diff for /rpl/src/instructions_d5.c between versions 1.157 and 1.159

version 1.157, 2017/06/28 09:20:33 version 1.159, 2017/08/03 15:13:04
Line 815  instruction_der(struct_processus *s_etat Line 815  instruction_der(struct_processus *s_etat
 void  void
 instruction_detach(struct_processus *s_etat_processus)  instruction_detach(struct_processus *s_etat_processus)
 {  {
 #ifndef EXPERIMENTAL_CODE  
     printf("DETACH currently broken is replaced by SPAWN...\n");  
     instruction_spawn(s_etat_processus);  
 #else  
     int                                 pipe_initialisation_segment_signaux[2];      int                                 pipe_initialisation_segment_signaux[2];
   
     logical1                            drapeau;      logical1                            drapeau;
Line 1092  instruction_detach(struct_processus *s_e Line 1088  instruction_detach(struct_processus *s_e
         return;          return;
     }      }
   
       verrouillage_threads_concurrents(s_etat_processus);
   
     if (pthread_mutex_lock(&mutex_liste_variables_partagees) != 0)      if (pthread_mutex_lock(&mutex_liste_variables_partagees) != 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
         return;          return;
     }      }
   
     verrouillage_threads_concurrents(s_etat_processus);  
   
     if (pthread_mutex_lock(&((*s_etat_processus).mutex_allocation_buffer)) != 0)      if (pthread_mutex_lock(&((*s_etat_processus).mutex_allocation_buffer)) != 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
Line 1299  instruction_detach(struct_processus *s_e Line 1295  instruction_detach(struct_processus *s_e
         pthread_mutex_destroy(&((*s_etat_processus).mutex_pile_processus);          pthread_mutex_destroy(&((*s_etat_processus).mutex_pile_processus);
         pthread_mutex_destroy(&((*s_etat_processus).mutex_allocation));          pthread_mutex_destroy(&((*s_etat_processus).mutex_allocation));
 #endif  #endif
   
         pthread_mutexattr_init(&attributs_mutex);          pthread_mutexattr_init(&attributs_mutex);
         pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_RECURSIVE);          pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_RECURSIVE);
         pthread_mutex_init(&mutex_liste_variables_partagees, &attributs_mutex);          pthread_mutex_init(&mutex_liste_variables_partagees, &attributs_mutex);
Line 1322  instruction_detach(struct_processus *s_e Line 1317  instruction_detach(struct_processus *s_e
                 &attributs_mutex);                  &attributs_mutex);
         pthread_mutexattr_destroy(&attributs_mutex);          pthread_mutexattr_destroy(&attributs_mutex);
   
 #if 0  
         liberation_queue_signaux(s_etat_processus);          liberation_queue_signaux(s_etat_processus);
 #endif  
         creation_queue_signaux(s_etat_processus);          creation_queue_signaux(s_etat_processus);
   
         routine_recursive = 0;          routine_recursive = 0;
Line 1340  instruction_detach(struct_processus *s_e Line 1333  instruction_detach(struct_processus *s_e
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_processus;
         }          }
   
 #if 0  
         close(pipe_initialisation_segment_signaux[0]);          close(pipe_initialisation_segment_signaux[0]);
         close(pipe_initialisation_segment_signaux[1]);          close(pipe_initialisation_segment_signaux[1]);
   
Line 1417  instruction_detach(struct_processus *s_e Line 1409  instruction_detach(struct_processus *s_e
             free(l_element_courant);              free(l_element_courant);
             l_element_courant = l_element_suivant;              l_element_courant = l_element_suivant;
         }          }
 #endif  
   
         (*s_etat_processus).liste_mutexes = NULL;          (*s_etat_processus).liste_mutexes = NULL;
   
 #if 0  
         liberation_threads(s_etat_processus);          liberation_threads(s_etat_processus);
 #endif  
         insertion_thread(s_etat_processus, d_vrai);          insertion_thread(s_etat_processus, d_vrai);
   
         // Envoi d'une donnée pour signaler le démarrage du processus au thread          // Envoi d'une donnée pour signaler le démarrage du processus au thread
Line 1435  instruction_detach(struct_processus *s_e Line 1424  instruction_detach(struct_processus *s_e
                 (*s_argument_thread).pipe_nombre_elements_attente[1],                  (*s_argument_thread).pipe_nombre_elements_attente[1],
                 &caractere, sizeof(caractere)) != sizeof(caractere))                  &caractere, sizeof(caractere)) != sizeof(caractere))
         {          {
             pthread_mutex_unlock(&((*s_etat_processus).mutex_pile_processus));  
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_processus;
   
             while((longueur_ecriture = write_atomic(s_etat_processus,              while((longueur_ecriture = write_atomic(s_etat_processus,
Line 1453  instruction_detach(struct_processus *s_e Line 1441  instruction_detach(struct_processus *s_e
             exit(EXIT_FAILURE);              exit(EXIT_FAILURE);
         }          }
   
 #if 0  
         if (pthread_mutex_destroy(&mutex_sections_critiques) != 0)          if (pthread_mutex_destroy(&mutex_sections_critiques) != 0)
         {          {
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_processus;
Line 1472  instruction_detach(struct_processus *s_e Line 1459  instruction_detach(struct_processus *s_e
             BUG(1, uprintf("Process management error line %d\n", __LINE__));              BUG(1, uprintf("Process management error line %d\n", __LINE__));
             exit(EXIT_FAILURE);              exit(EXIT_FAILURE);
         }          }
 #endif  
   
         pthread_mutexattr_init(&attributs_mutex);          pthread_mutexattr_init(&attributs_mutex);
         pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_RECURSIVE);          pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_RECURSIVE);
         pthread_mutex_init(&mutex_sections_critiques, &attributs_mutex);          pthread_mutex_init(&mutex_sections_critiques, &attributs_mutex);
         pthread_mutexattr_destroy(&attributs_mutex);          pthread_mutexattr_destroy(&attributs_mutex);
   
         if (pthread_mutex_unlock(&((*s_etat_processus).mutex_pile_processus))  
                 != 0)  
         {  
             (*s_etat_processus).erreur_systeme = d_es_processus;  
   
             caractere = 0;  
   
             while((longueur_ecriture = write_atomic(s_etat_processus,  
                     (*s_argument_thread).pipe_nombre_elements_attente[1],  
                     &caractere, sizeof(caractere))) != sizeof(caractere))  
             {  
                 if (longueur_ecriture == -1)  
                 {  
                     break;  
                 }  
             }  
   
             destruction_queue_signaux(s_etat_processus);  
             BUG(1, uprintf("Process management error line %d\n", __LINE__));  
             exit(EXIT_FAILURE);  
         }  
   
         pthread_mutex_trylock(&((*s_etat_processus).protection_liste_mutexes));  
   
         if (pthread_mutex_unlock(&((*s_etat_processus)  
                 .protection_liste_mutexes)) != 0)  
         {  
             (*s_etat_processus).erreur_systeme = d_es_processus;  
   
             caractere = 0;  
   
             while((longueur_ecriture = write_atomic(s_etat_processus,  
                     (*s_argument_thread).pipe_nombre_elements_attente[1],  
                     &caractere, sizeof(caractere))) != sizeof(caractere))  
             {  
                 if (longueur_ecriture == -1)  
                 {  
                     break;  
                 }  
             }  
   
             destruction_queue_signaux(s_etat_processus);  
             BUG(1, uprintf("Process management error line %d\n", __LINE__));  
             exit(EXIT_FAILURE);  
         }  
   
         pthread_mutex_trylock(&((*s_etat_processus).mutex_interruptions));  
   
         if (pthread_mutex_unlock(&((*s_etat_processus).mutex_interruptions))  
                 != 0)  
         {  
             (*s_etat_processus).erreur_systeme = d_es_processus;  
   
             caractere = 0;  
   
             while((longueur_ecriture = write_atomic(s_etat_processus,  
                     (*s_argument_thread).pipe_nombre_elements_attente[1],  
                     &caractere, sizeof(caractere))) != sizeof(caractere))  
             {  
                 if (longueur_ecriture == -1)  
                 {  
                     break;  
                 }  
             }  
   
             destruction_queue_signaux(s_etat_processus);  
             BUG(1, uprintf("Process management error line %d\n", __LINE__));  
             exit(EXIT_FAILURE);  
         }  
   
         pthread_mutex_trylock(&((*s_etat_processus).mutex_signaux));  
   
         if (pthread_mutex_unlock(&((*s_etat_processus).mutex_signaux))  
                 != 0)  
         {  
             (*s_etat_processus).erreur_systeme = d_es_processus;  
   
             caractere = 0;  
   
             while((longueur_ecriture = write_atomic(s_etat_processus,  
                     (*s_argument_thread).pipe_nombre_elements_attente[1],  
                     &caractere, sizeof(caractere))) != sizeof(caractere))  
             {  
                 if (longueur_ecriture == -1)  
                 {  
                     break;  
                 }  
             }  
   
             destruction_queue_signaux(s_etat_processus);  
             BUG(1, uprintf("Process management error line %d\n", __LINE__));  
             exit(EXIT_FAILURE);  
         }  
   
         if ((*s_etat_processus).evaluation_expression_compilee == 'N')          if ((*s_etat_processus).evaluation_expression_compilee == 'N')
         {          {
 #if 0  
             free((*s_etat_processus).instruction_courante);              free((*s_etat_processus).instruction_courante);
 #endif  
             (*s_etat_processus).instruction_courante = NULL;              (*s_etat_processus).instruction_courante = NULL;
         }          }
   
 #if 0  
         (*s_etat_processus).var_volatile_processus_pere = 0;          (*s_etat_processus).var_volatile_processus_pere = 0;
         (*s_etat_processus).var_volatile_processus_racine = 0;          (*s_etat_processus).var_volatile_processus_racine = 0;
   
Line 1598  instruction_detach(struct_processus *s_e Line 1487  instruction_detach(struct_processus *s_e
         liberation(s_etat_processus, (*s_etat_processus).at_poke);          liberation(s_etat_processus, (*s_etat_processus).at_poke);
         (*s_etat_processus).at_poke = NULL;          (*s_etat_processus).at_poke = NULL;
         (*s_etat_processus).traitement_at_poke = 'N';          (*s_etat_processus).traitement_at_poke = 'N';
 #endif  
   
         for(i = 0; i < d_NOMBRE_INTERRUPTIONS; i++)          for(i = 0; i < d_NOMBRE_INTERRUPTIONS; i++)
         {          {
 #if 0  
             liberation(s_etat_processus,              liberation(s_etat_processus,
                     (*s_etat_processus).corps_interruptions[i]);                      (*s_etat_processus).corps_interruptions[i]);
 #endif  
   
             (*s_etat_processus).corps_interruptions[i] = NULL;              (*s_etat_processus).corps_interruptions[i] = NULL;
             (*s_etat_processus).masque_interruptions[i] = 'N';              (*s_etat_processus).masque_interruptions[i] = 'N';
             (*s_etat_processus).queue_interruptions[i] = 0;              (*s_etat_processus).queue_interruptions[i] = 0;
   
 #if 0  
             l_element_courant = (*s_etat_processus)              l_element_courant = (*s_etat_processus)
                     .pile_origine_interruptions[i];                      .pile_origine_interruptions[i];
   
Line 1622  instruction_detach(struct_processus *s_e Line 1507  instruction_detach(struct_processus *s_e
                 free(l_element_courant);                  free(l_element_courant);
                 l_element_courant = l_element_suivant;                  l_element_courant = l_element_suivant;
             }              }
 #endif  
   
             (*s_etat_processus).pile_origine_interruptions[i] = NULL;              (*s_etat_processus).pile_origine_interruptions[i] = NULL;
         }          }
Line 1644  instruction_detach(struct_processus *s_e Line 1528  instruction_detach(struct_processus *s_e
             scrutation_interruptions(s_etat_processus);              scrutation_interruptions(s_etat_processus);
         }          }
   
 #if 0  
         (*s_etat_processus).niveau_initial = (*s_etat_processus).niveau_courant;          (*s_etat_processus).niveau_initial = (*s_etat_processus).niveau_courant;
         (*s_etat_processus).presence_pipes = d_vrai;          (*s_etat_processus).presence_pipes = d_vrai;
         (*s_etat_processus).debug_programme = d_faux;          (*s_etat_processus).debug_programme = d_faux;
Line 1667  instruction_detach(struct_processus *s_e Line 1550  instruction_detach(struct_processus *s_e
         (*s_etat_processus).pid_erreur_processus_fils = getpid();          (*s_etat_processus).pid_erreur_processus_fils = getpid();
         (*s_etat_processus).sections_critiques = 0;          (*s_etat_processus).sections_critiques = 0;
         (*s_etat_processus).initialisation_scheduler = d_faux;          (*s_etat_processus).initialisation_scheduler = d_faux;
 #endif  
   
 #if 0  
         if ((*s_etat_processus).profilage == d_vrai)          if ((*s_etat_processus).profilage == d_vrai)
         {          {
             liberation_profil(s_etat_processus);              liberation_profil(s_etat_processus);
         }          }
 #endif  
   
         (*s_etat_processus).pile_profilage = NULL;          (*s_etat_processus).pile_profilage = NULL;
   
 #if 0  
         if ((*s_etat_processus).generateur_aleatoire != NULL)          if ((*s_etat_processus).generateur_aleatoire != NULL)
         {          {
             liberation_generateur_aleatoire(s_etat_processus);              liberation_generateur_aleatoire(s_etat_processus);
         }          }
 #endif  
   
         (*s_etat_processus).generateur_aleatoire = NULL;          (*s_etat_processus).generateur_aleatoire = NULL;
   
Line 1736  instruction_detach(struct_processus *s_e Line 1614  instruction_detach(struct_processus *s_e
                     printf("(*s_argument_thread2).nombre_references = %d\n",                      printf("(*s_argument_thread2).nombre_references = %d\n",
                     (int) (*s_argument_thread2).nombre_references));                      (int) (*s_argument_thread2).nombre_references));
   
 #if 0  
             if ((*s_argument_thread2).nombre_references == 0)              if ((*s_argument_thread2).nombre_references == 0)
             {              {
                 close((*s_argument_thread2).pipe_objets[0]);                  close((*s_argument_thread2).pipe_objets[0]);
Line 1761  instruction_detach(struct_processus *s_e Line 1638  instruction_detach(struct_processus *s_e
                 free((*(*l_element_courant).donnee).objet);                  free((*(*l_element_courant).donnee).objet);
                 free((*l_element_courant).donnee);                  free((*l_element_courant).donnee);
             }              }
 #endif  
   
             l_element_suivant = (*l_element_courant).suivant;              l_element_suivant = (*l_element_courant).suivant;
             free((struct_liste_chainee *) l_element_courant);              free((struct_liste_chainee *) l_element_courant);
Line 1796  instruction_detach(struct_processus *s_e Line 1672  instruction_detach(struct_processus *s_e
          * Initialisation de la pile système           * Initialisation de la pile système
          */           */
   
 #if 0  
         l_element_courant = (struct_liste_chainee *)          l_element_courant = (struct_liste_chainee *)
                 (*s_etat_processus).l_base_pile_systeme;                  (*s_etat_processus).l_base_pile_systeme;
         while(l_element_courant != NULL)          while(l_element_courant != NULL)
Line 1823  instruction_detach(struct_processus *s_e Line 1698  instruction_detach(struct_processus *s_e
   
             l_element_courant = l_element_suivant;              l_element_courant = l_element_suivant;
         }          }
 #endif  
   
         (*s_etat_processus).l_base_pile_systeme = NULL;          (*s_etat_processus).l_base_pile_systeme = NULL;
         (*s_etat_processus).hauteur_pile_systeme = 0;          (*s_etat_processus).hauteur_pile_systeme = 0;
   
 #if 0  
         empilement_pile_systeme(s_etat_processus);          empilement_pile_systeme(s_etat_processus);
   
         if ((*s_etat_processus).erreur_systeme != d_es)          if ((*s_etat_processus).erreur_systeme != d_es)
Line 1851  instruction_detach(struct_processus *s_e Line 1724  instruction_detach(struct_processus *s_e
         }          }
   
         (*(*s_etat_processus).l_base_pile_systeme).retour_definition = 'Y';          (*(*s_etat_processus).l_base_pile_systeme).retour_definition = 'Y';
 #endif  
   
 #if 0  
         l_element_courant = (struct_liste_chainee *)          l_element_courant = (struct_liste_chainee *)
                 (*s_etat_processus).s_marques;                  (*s_etat_processus).s_marques;
   
Line 1866  instruction_detach(struct_processus *s_e Line 1737  instruction_detach(struct_processus *s_e
             free((struct_marque *) l_element_courant);              free((struct_marque *) l_element_courant);
             l_element_courant = l_element_suivant;              l_element_courant = l_element_suivant;
         }          }
 #endif  
   
         (*s_etat_processus).s_marques = NULL;          (*s_etat_processus).s_marques = NULL;
   
Line 1875  instruction_detach(struct_processus *s_e Line 1745  instruction_detach(struct_processus *s_e
          * les variables dans le cas d'un programme compilé.           * les variables dans le cas d'un programme compilé.
          */           */
   
 #if 0  
         empilement_pile_systeme(s_etat_processus);          empilement_pile_systeme(s_etat_processus);
   
         if ((*s_etat_processus).erreur_systeme != d_es)          if ((*s_etat_processus).erreur_systeme != d_es)
Line 1898  instruction_detach(struct_processus *s_e Line 1767  instruction_detach(struct_processus *s_e
         }          }
   
         (*(*s_etat_processus).l_base_pile_systeme).retour_definition = 'Y';          (*(*s_etat_processus).l_base_pile_systeme).retour_definition = 'Y';
 #endif  
   
         /*          /*
          * Destruction des sorties graphiques et PostScript           * Destruction des sorties graphiques et PostScript
          */           */
   
 #if 0  
         while((*s_etat_processus).fichiers_graphiques != NULL)          while((*s_etat_processus).fichiers_graphiques != NULL)
         {          {
             free((*(*s_etat_processus).fichiers_graphiques).nom);              free((*(*s_etat_processus).fichiers_graphiques).nom);
Line 1926  instruction_detach(struct_processus *s_e Line 1793  instruction_detach(struct_processus *s_e
             pclose((*s_etat_processus).entree_standard);              pclose((*s_etat_processus).entree_standard);
             (*s_etat_processus).entree_standard = NULL;              (*s_etat_processus).entree_standard = NULL;
         }          }
 #endif  
   
         (*s_etat_processus).requete_nouveau_plan = d_vrai;          (*s_etat_processus).requete_nouveau_plan = d_vrai;
         (*s_etat_processus).mise_a_jour_trace_requise = d_faux;          (*s_etat_processus).mise_a_jour_trace_requise = d_faux;
Line 1941  instruction_detach(struct_processus *s_e Line 1807  instruction_detach(struct_processus *s_e
          * Destruction des piles de fichiers           * Destruction des piles de fichiers
          */           */
   
 #if 0  
         l_element_courant = (*s_etat_processus).s_fichiers;          l_element_courant = (*s_etat_processus).s_fichiers;
   
         while(l_element_courant != NULL)          while(l_element_courant != NULL)
Line 1996  instruction_detach(struct_processus *s_e Line 1861  instruction_detach(struct_processus *s_e
          */           */
   
         (*s_etat_processus).s_connecteurs_sql = NULL;          (*s_etat_processus).s_connecteurs_sql = NULL;
 #endif  
   
         if ((*s_etat_processus).debug == d_vrai)          if ((*s_etat_processus).debug == d_vrai)
         {          {
Line 2014  instruction_detach(struct_processus *s_e Line 1878  instruction_detach(struct_processus *s_e
             }              }
         }          }
   
 #if 0  
         if ((*s_etat_processus).erreur_systeme == d_es)          if ((*s_etat_processus).erreur_systeme == d_es)
         {          {
             // Évite le warning variable s_copie might be clobbered by              // Évite le warning variable s_copie might be clobbered by
Line 2119  instruction_detach(struct_processus *s_e Line 1982  instruction_detach(struct_processus *s_e
   
             free(s);              free(s);
         }          }
 #endif  
   
 #if 0  
         for(i = 0; i < (*s_etat_processus).sections_critiques; i++)          for(i = 0; i < (*s_etat_processus).sections_critiques; i++)
         {          {
             pthread_mutex_unlock(&mutex_sections_critiques);              pthread_mutex_unlock(&mutex_sections_critiques);
Line 2143  instruction_detach(struct_processus *s_e Line 2004  instruction_detach(struct_processus *s_e
         {          {
             pthread_cancel((*s_etat_processus).thread_fusible);              pthread_cancel((*s_etat_processus).thread_fusible);
         }          }
 #endif  
   
         caractere = 0;          caractere = 0;
   
Line 2248  instruction_detach(struct_processus *s_e Line 2108  instruction_detach(struct_processus *s_e
             }              }
         }          }
   
 #if 0  
         l_element_courant = (*s_etat_processus).s_fichiers;          l_element_courant = (*s_etat_processus).s_fichiers;
   
         while(l_element_courant != NULL)          while(l_element_courant != NULL)
Line 2862  instruction_detach(struct_processus *s_e Line 2721  instruction_detach(struct_processus *s_e
             liberation_profil(s_etat_processus);              liberation_profil(s_etat_processus);
         }          }
   
 #endif  
         attente.tv_sec = 0;          attente.tv_sec = 0;
         attente.tv_nsec = GRANULARITE_us * 1000;          attente.tv_nsec = GRANULARITE_us * 1000;
   
Line 2872  instruction_detach(struct_processus *s_e Line 2730  instruction_detach(struct_processus *s_e
             INCR_GRANULARITE(attente.tv_nsec);              INCR_GRANULARITE(attente.tv_nsec);
         }          }
   
 #if 0  
         closelog();          closelog();
   
         retrait_thread(s_etat_processus);          retrait_thread(s_etat_processus);
         liberation_contexte_cas(s_etat_processus);          liberation_contexte_cas(s_etat_processus);
 #endif  
         destruction_queue_signaux(s_etat_processus);  
   
 #       ifndef SEMAPHORES_NOMMES  
         sem_post(&((*s_etat_processus).semaphore_fork));  
         sem_destroy(&((*s_etat_processus).semaphore_fork));  
 #       else  
         sem_post((*s_etat_processus).semaphore_fork);  
         sem_destroy3((*s_etat_processus).semaphore_fork, getpid(),  
                 pthread_self(), SEM_FORK);  
 #       endif  
   
 #if 0  
         clear_history();          clear_history();
   
         close((*s_argument_thread).pipe_erreurs[1]);          close((*s_argument_thread).pipe_erreurs[1]);
Line 2907  instruction_detach(struct_processus *s_e Line 2752  instruction_detach(struct_processus *s_e
         liberation_allocateur(s_etat_processus);          liberation_allocateur(s_etat_processus);
         liberation_allocateur_buffer(s_etat_processus);          liberation_allocateur_buffer(s_etat_processus);
   
           // Permet d'attendre la libération du mutex de la part
           // de surveillance_processus().
   
           attente.tv_sec = 0;
           attente.tv_nsec = GRANULARITE_us * 1000;
   
           while(pthread_mutex_trylock(&((*s_etat_processus).mutex_pile_processus))
                   == EBUSY)
           {
               nanosleep(&attente, NULL);
               INCR_GRANULARITE(attente.tv_nsec);
           }
   
           pthread_mutex_unlock(&((*s_etat_processus).mutex_pile_processus));
   
           // Libération des mutexes.
   
         pthread_mutex_destroy(&((*s_etat_processus).mutex_pile_processus));          pthread_mutex_destroy(&((*s_etat_processus).mutex_pile_processus));
         pthread_mutex_destroy(&((*s_etat_processus).mutex_allocation));          pthread_mutex_destroy(&((*s_etat_processus).mutex_allocation));
         pthread_mutex_destroy(&((*s_etat_processus).mutex_interruptions));          pthread_mutex_destroy(&((*s_etat_processus).mutex_interruptions));
Line 2915  instruction_detach(struct_processus *s_e Line 2777  instruction_detach(struct_processus *s_e
         pthread_mutex_destroy(&((*s_etat_processus).mutex_allocation_buffer));          pthread_mutex_destroy(&((*s_etat_processus).mutex_allocation_buffer));
         pthread_mutex_destroy(&mutex_sections_critiques);          pthread_mutex_destroy(&mutex_sections_critiques);
         pthread_mutex_destroy(&mutex_liste_variables_partagees);          pthread_mutex_destroy(&mutex_liste_variables_partagees);
   
           destruction_queue_signaux(s_etat_processus);
         pthread_mutex_destroy(&mutex_liste_threads);          pthread_mutex_destroy(&mutex_liste_threads);
   
   #       ifndef SEMAPHORES_NOMMES
           sem_post(&((*s_etat_processus).semaphore_fork));
           sem_destroy(&((*s_etat_processus).semaphore_fork));
   #       else
           sem_post((*s_etat_processus).semaphore_fork);
           sem_destroy3((*s_etat_processus).semaphore_fork, getpid(),
                   pthread_self(), SEM_FORK);
   #       endif
   
         sys_free(s_etat_processus);          sys_free(s_etat_processus);
   
 #       ifdef DEBUG_MEMOIRE  #       ifdef DEBUG_MEMOIRE
         debug_memoire_verification();          debug_memoire_verification();
         analyse_post_mortem();          analyse_post_mortem();
 #       endif  #       endif
 #endif  
   
         exit(EXIT_SUCCESS);          exit(EXIT_SUCCESS);
     }      }

Removed from v.1.157  
changed lines
  Added in v.1.159


CVSweb interface <joel.bertrand@systella.fr>