Diff for /rpl/src/instructions_d5.c between versions 1.167 and 1.178

version 1.167, 2019/02/09 13:36:39 version 1.178, 2023/11/22 10:55:15
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.1.31    RPL/2 (R) version 4.1.35
   Copyright (C) 1989-2019 Dr. BERTRAND Joël    Copyright (C) 1989-2023 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
   
Line 1306  instruction_detach(struct_processus *s_e Line 1306  instruction_detach(struct_processus *s_e
         pthread_mutexattr_destroy(&attributs_mutex);          pthread_mutexattr_destroy(&attributs_mutex);
   
         pthread_mutexattr_init(&attributs_mutex);          pthread_mutexattr_init(&attributs_mutex);
           pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_RECURSIVE);
           pthread_mutex_init(&mutex_liste_threads_surveillance, &attributs_mutex);
           pthread_mutexattr_destroy(&attributs_mutex);
   
           pthread_mutexattr_init(&attributs_mutex);
           pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_RECURSIVE);
           pthread_mutex_init(&mutex_sigaction, &attributs_mutex);
           pthread_mutexattr_destroy(&attributs_mutex);
   
           pthread_mutexattr_init(&attributs_mutex);
         pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_NORMAL);          pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_NORMAL);
         pthread_mutex_init(&((*s_etat_processus).mutex_pile_processus),          pthread_mutex_init(&((*s_etat_processus).mutex_pile_processus),
                 &attributs_mutex);                  &attributs_mutex);
Line 1321  instruction_detach(struct_processus *s_e Line 1331  instruction_detach(struct_processus *s_e
         creation_queue_signaux(s_etat_processus);          creation_queue_signaux(s_etat_processus);
   
         routine_recursive = 0;          routine_recursive = 0;
         nombre_thread_surveillance_processus = 0;          nombre_threads_surveillance_processus = 0;
   
         (*s_etat_processus).pointeur_signal_lecture = 0;          (*s_etat_processus).pointeur_signal_lecture = 0;
         (*s_etat_processus).pointeur_signal_ecriture = 0;          (*s_etat_processus).pointeur_signal_ecriture = 0;
Line 1333  instruction_detach(struct_processus *s_e Line 1343  instruction_detach(struct_processus *s_e
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_processus;
         }          }
   
         close(pipe_initialisation_segment_signaux[0]);  
         close(pipe_initialisation_segment_signaux[1]);          close(pipe_initialisation_segment_signaux[1]);
   
         if ((*s_etat_processus).debug == d_vrai)          if ((*s_etat_processus).debug == d_vrai)
Line 1813  instruction_detach(struct_processus *s_e Line 1822  instruction_detach(struct_processus *s_e
         {          {
             l_element_suivant = (*l_element_courant).suivant;              l_element_suivant = (*l_element_courant).suivant;
   
               // On ne détruit pas le descripteur sous prétexte
               // d'avoir le fichier ou la socket fermée dans le processus père
   
               /*
             fclose((*((struct_descripteur_fichier *)              fclose((*((struct_descripteur_fichier *)
                     (*l_element_courant).donnee)).descripteur_c);                      (*l_element_courant).donnee)).descripteur_c);
   
Line 1822  instruction_detach(struct_processus *s_e Line 1835  instruction_detach(struct_processus *s_e
                 sqlite3_close((*((struct_descripteur_fichier *)                  sqlite3_close((*((struct_descripteur_fichier *)
                         (*l_element_courant).donnee)).descripteur_sqlite);                          (*l_element_courant).donnee)).descripteur_sqlite);
             }              }
               */
   
             free((*((struct_descripteur_fichier *) (*l_element_courant)              free((*((struct_descripteur_fichier *) (*l_element_courant)
                     .donnee)).nom);                      .donnee)).nom);
Line 2306  instruction_detach(struct_processus *s_e Line 2320  instruction_detach(struct_processus *s_e
                     (*(*((struct_processus_fils *) (*(*l_element_courant)                      (*(*((struct_processus_fils *) (*(*l_element_courant)
                             .donnee).objet)).thread).nombre_objets_dans_pipe--;                              .donnee).objet)).thread).nombre_objets_dans_pipe--;
   
                       if (pthread_mutex_lock(&mutex_sigaction) != 0)
                       {
                           destruction_queue_signaux(s_etat_processus);
                           (*s_etat_processus).erreur_systeme = d_es_processus;
                           exit(EXIT_FAILURE);
                       }
   
                     action.sa_handler = SIG_IGN;                      action.sa_handler = SIG_IGN;
                     action.sa_flags = 0;                      action.sa_flags = 0;
   
Line 2313  instruction_detach(struct_processus *s_e Line 2334  instruction_detach(struct_processus *s_e
                     {                      {
                         pthread_mutex_unlock(&((*s_etat_processus)                          pthread_mutex_unlock(&((*s_etat_processus)
                                 .mutex_pile_processus));                                  .mutex_pile_processus));
                           pthread_mutex_unlock(&mutex_sigaction);
   
                         if (registre_stop == 0)                          if (registre_stop == 0)
                         {                          {
Line 2366  instruction_detach(struct_processus *s_e Line 2388  instruction_detach(struct_processus *s_e
                     {                      {
                         destruction_queue_signaux(s_etat_processus);                          destruction_queue_signaux(s_etat_processus);
   
                           pthread_mutex_unlock(&mutex_sigaction);
                         pthread_mutex_unlock(&((*s_etat_processus)                          pthread_mutex_unlock(&((*s_etat_processus)
                                 .mutex_pile_processus));                                  .mutex_pile_processus));
                         (*s_etat_processus).erreur_systeme = d_es_signal;                          (*s_etat_processus).erreur_systeme = d_es_signal;
                         exit(EXIT_FAILURE);                          exit(EXIT_FAILURE);
                     }                      }
   
                       if (pthread_mutex_unlock(&mutex_sigaction) != 0)
                       {
                           destruction_queue_signaux(s_etat_processus);
                           pthread_mutex_unlock(&((*s_etat_processus)
                                   .mutex_pile_processus));
                           (*s_etat_processus).erreur_systeme = d_es_processus;
                           exit(EXIT_FAILURE);
                       }
                 }                  }
             }              }
   
Line 2416  instruction_detach(struct_processus *s_e Line 2448  instruction_detach(struct_processus *s_e
         {          {
             l_element_suivant = (*l_element_courant).suivant;              l_element_suivant = (*l_element_courant).suivant;
   
             if ((*((struct_socket *) (*(*l_element_courant).donnee)  
                     .objet)).socket_connectee == d_vrai)  
             {  
                 shutdown((*((struct_socket *) (*(*l_element_courant).donnee)  
                         .objet)).socket, SHUT_RDWR);  
             }  
   
             close((*((struct_socket *) (*(*l_element_courant).donnee)  
                     .objet)).socket);  
   
             if (((*((struct_socket *) (*(*l_element_courant).donnee).objet))              if (((*((struct_socket *) (*(*l_element_courant).donnee).objet))
                     .pid == getpid()) && (pthread_equal((*((struct_socket *)                      .pid == getpid()) && (pthread_equal((*((struct_socket *)
                     (*(*l_element_courant).donnee).objet)).tid, pthread_self())                      (*(*l_element_courant).donnee).objet)).tid, pthread_self())
                     != 0))                      != 0))
             {              {
                   if ((*((struct_socket *) (*(*l_element_courant).donnee)
                           .objet)).socket_connectee == d_vrai)
                   {
                       shutdown((*((struct_socket *) (*(*l_element_courant).donnee)
                               .objet)).socket, SHUT_RDWR);
                   }
   
                   close((*((struct_socket *) (*(*l_element_courant).donnee)
                           .objet)).socket);
   
                 if ((*((struct_socket *) (*(*l_element_courant).donnee).objet))                  if ((*((struct_socket *) (*(*l_element_courant).donnee).objet))
                         .effacement == 'Y')                          .effacement == 'Y')
                 {                  {
Line 2727  instruction_detach(struct_processus *s_e Line 2759  instruction_detach(struct_processus *s_e
         attente.tv_sec = 0;          attente.tv_sec = 0;
         attente.tv_nsec = GRANULARITE_us * 1000;          attente.tv_nsec = GRANULARITE_us * 1000;
   
         while(nombre_thread_surveillance_processus != 0)          pthread_mutex_lock(&((*s_etat_processus).mutex_pile_processus));
   
           while(nombre_threads_surveillance_processus != 0)
         {          {
               pthread_mutex_unlock(&((*s_etat_processus).mutex_pile_processus));
             nanosleep(&attente, NULL);              nanosleep(&attente, NULL);
             INCR_GRANULARITE(attente.tv_nsec);              INCR_GRANULARITE(attente.tv_nsec);
               pthread_mutex_lock(&((*s_etat_processus).mutex_pile_processus));
         }          }
   
           pthread_mutex_unlock(&((*s_etat_processus).mutex_pile_processus));
   
         closelog();          closelog();
   
         retrait_thread(s_etat_processus);          retrait_thread(s_etat_processus);
Line 2783  instruction_detach(struct_processus *s_e Line 2821  instruction_detach(struct_processus *s_e
   
         destruction_queue_signaux(s_etat_processus);          destruction_queue_signaux(s_etat_processus);
         pthread_mutex_destroy(&mutex_liste_threads);          pthread_mutex_destroy(&mutex_liste_threads);
           pthread_mutex_destroy(&mutex_liste_threads_surveillance);
   
 #       ifndef SEMAPHORES_NOMMES  #       ifndef SEMAPHORES_NOMMES
         sem_post(&((*s_etat_processus).semaphore_fork));          sem_post(&((*s_etat_processus).semaphore_fork));
Line 2800  instruction_detach(struct_processus *s_e Line 2839  instruction_detach(struct_processus *s_e
         analyse_post_mortem();          analyse_post_mortem();
 #       endif  #       endif
   
           pthread_mutex_destroy(&mutex_sigaction);
         exit(EXIT_SUCCESS);          exit(EXIT_SUCCESS);
     }      }
     else      else
Line 2890  instruction_detach(struct_processus *s_e Line 2930  instruction_detach(struct_processus *s_e
     }      }
   
     close(pipe_initialisation_segment_signaux[0]);      close(pipe_initialisation_segment_signaux[0]);
     close(pipe_initialisation_segment_signaux[1]);  
   
     // 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.
   

Removed from v.1.167  
changed lines
  Added in v.1.178


CVSweb interface <joel.bertrand@systella.fr>