Diff for /rpl/src/interruptions.c between versions 1.13 and 1.16

version 1.13, 2010/04/30 15:01:14 version 1.16, 2010/05/19 09:22:34
Line 1156  liberation_threads(struct_processus *s_e Line 1156  liberation_threads(struct_processus *s_e
                 element_courant = element_suivant;                  element_courant = element_suivant;
             }              }
   
   /*
   ================================================================================
     À noter : on ne ferme pas la connexion car la conséquence immédiate est
     une destruction de l'objet pour le processus père.
   ================================================================================
   
             element_courant = (*s_etat_processus).s_connecteurs_sql;              element_courant = (*s_etat_processus).s_connecteurs_sql;
             while(element_courant != NULL)              while(element_courant != NULL)
             {              {
Line 1239  liberation_threads(struct_processus *s_e Line 1245  liberation_threads(struct_processus *s_e
   
                 element_courant = element_suivant;                  element_courant = element_suivant;
             }              }
   */
   
               (*s_etat_processus).s_connecteurs_sql = NULL;
   
             element_courant = (*s_etat_processus).s_marques;              element_courant = (*s_etat_processus).s_marques;
             while(element_courant != NULL)              while(element_courant != NULL)
Line 1963  interruption5(int signal, siginfo_t *sig Line 1972  interruption5(int signal, siginfo_t *sig
             return;              return;
         }          }
   
         if (signal == SIGFABORT)  
         {  
             (*s_etat_processus).arret_depuis_abort = -1;  
         }  
   
         if (((*s_etat_processus).type_debug & d_debug_signaux) != 0)          if (((*s_etat_processus).type_debug & d_debug_signaux) != 0)
         {          {
             if (signal == SIGFSTOP)              printf("[%d] SIGFSTOP (thread %llu)\n", (int) getpid(),
             {                      (unsigned long long) pthread_self());
                 printf("[%d] SIGFSTOP (thread %llu)\n", (int) getpid(),              fflush(stdout);
                         (unsigned long long) pthread_self());  
                 fflush(stdout);  
             }  
             else  
             {  
                 printf("[%d] SIGFABORT (thread %llu)\n", (int) getpid(),  
                         (unsigned long long) pthread_self());  
                 fflush(stdout);  
             }  
         }          }
   
         /*          /*
Line 2009  interruption5(int signal, siginfo_t *sig Line 2004  interruption5(int signal, siginfo_t *sig
             return;              return;
         }          }
   
         if (signal == SIGFABORT)  
         {  
             (*s_etat_processus).arret_depuis_abort = -1;  
         }  
   
         // Envoi d'un signal au thread maître du groupe.          // Envoi d'un signal au thread maître du groupe.
   
         if (recherche_thread_principal(getpid(), &thread) == d_vrai)          if (recherche_thread_principal(getpid(), &thread) == d_vrai)
Line 2185  interruption10(int signal, siginfo_t *si Line 2175  interruption10(int signal, siginfo_t *si
     }      }
   
     deverrouillage_gestionnaire_signaux();      deverrouillage_gestionnaire_signaux();
       return;
   }
   
   void
   interruption11(int signal, siginfo_t *siginfo, void *context)
   {
       pthread_t               thread;
       struct_processus        *s_etat_processus;
   
       verrouillage_gestionnaire_signaux();
   
       if ((*siginfo).si_pid == getpid())
       {
           if ((s_etat_processus = recherche_thread(getpid(), pthread_self()))
                   == NULL)
           {
               deverrouillage_gestionnaire_signaux();
               return;
           }
   
           (*s_etat_processus).arret_depuis_abort = -1;
   
           if (((*s_etat_processus).type_debug & d_debug_signaux) != 0)
           {
               printf("[%d] SIGFABORT (thread %llu)\n", (int) getpid(),
                       (unsigned long long) pthread_self());
               fflush(stdout);
           }
   
           /*
            * var_globale_traitement_retarde_stop :
            *  0 -> traitement immédiat
            *  1 -> traitement retardé (aucun signal reçu)
            * -1 -> traitement retardé (un ou plusieurs signaux stop reçus)
            */
   
           if ((*s_etat_processus).var_volatile_traitement_retarde_stop == 0)
           {
               (*s_etat_processus).var_volatile_requete_arret = -1;
           }
           else
           {
               (*s_etat_processus).var_volatile_traitement_retarde_stop = -1;
           }
       }
       else
       {
           if ((s_etat_processus = recherche_thread(getpid(), pthread_self()))
                   == NULL)
           {
               deverrouillage_gestionnaire_signaux();
               return;
           }
   
           (*s_etat_processus).arret_depuis_abort = -1;
   
           // Envoi d'un signal au thread maître du groupe.
   
           if (recherche_thread_principal(getpid(), &thread) == d_vrai)
           {
               pthread_kill(thread, signal);
               deverrouillage_gestionnaire_signaux();
               return;
           }
       }
   
       deverrouillage_gestionnaire_signaux();
     return;      return;
 }  }
   

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


CVSweb interface <joel.bertrand@systella.fr>