Diff for /rpl/src/instructions_s10.c between versions 1.45 and 1.56

version 1.45, 2011/09/15 17:51:43 version 1.56, 2012/04/12 09:56:40
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.1.3    RPL/2 (R) version 4.1.7
   Copyright (C) 1989-2011 Dr. BERTRAND Joël    Copyright (C) 1989-2012 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
   
Line 45  instruction_spawn(struct_processus *s_et Line 45  instruction_spawn(struct_processus *s_et
   
     pthread_mutexattr_t         attributs_mutex;      pthread_mutexattr_t         attributs_mutex;
   
     pthread_t                   thread_id;  
     pthread_t                   thread_surveillance;      pthread_t                   thread_surveillance;
   
     struct_descripteur_thread   *s_argument_thread;      struct_descripteur_thread   *s_argument_thread;
Line 353  instruction_spawn(struct_processus *s_et Line 352  instruction_spawn(struct_processus *s_et
         return;          return;
     }      }
   
 #   ifndef OS2  #   ifdef SCHED_OTHER
 #   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;
         return;          return;
     }      }
   #   endif
   
   #   ifdef PTHREAD_EXPLICIT_SCHED
     if (pthread_attr_setinheritsched(&attributs, PTHREAD_EXPLICIT_SCHED) != 0)      if (pthread_attr_setinheritsched(&attributs, PTHREAD_EXPLICIT_SCHED) != 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
         return;          return;
     }      }
   #   endif
   
   #   ifdef PTHREAD_SCOPE_SYSTEM
     if (pthread_attr_setscope(&attributs, PTHREAD_SCOPE_SYSTEM) != 0)      if (pthread_attr_setscope(&attributs, PTHREAD_SCOPE_SYSTEM) != 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
         return;          return;
     }      }
 #   endif  #   endif
 #   endif  
   
     /*      /*
      * Création de l'objet à retourner       * Création de l'objet à retourner
Line 397  instruction_spawn(struct_processus *s_et Line 398  instruction_spawn(struct_processus *s_et
   
     // Lancement du thread fils      // Lancement du thread fils
   
     if (pthread_mutex_lock(&((*s_nouvel_etat_processus).mutex)) != 0)  
     {  
         (*s_etat_processus).erreur_systeme = d_es_processus;  
         return;  
     }  
   
     (*s_argument_thread).s_nouvel_etat_processus = s_nouvel_etat_processus;      (*s_argument_thread).s_nouvel_etat_processus = s_nouvel_etat_processus;
     (*s_argument_thread).s_etat_processus = s_etat_processus;      (*s_argument_thread).s_etat_processus = s_etat_processus;
   
Line 419  instruction_spawn(struct_processus *s_et Line 414  instruction_spawn(struct_processus *s_et
   
     (*s_argument_thread).thread_actif = d_faux;      (*s_argument_thread).thread_actif = d_faux;
   
     if (pthread_create(&thread_id, &attributs, lancement_thread,      if (pthread_create(&(*s_nouvel_etat_processus).tid,
             s_argument_thread) != 0)              &attributs, lancement_thread, s_argument_thread) != 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
         return;          return;
Line 455  instruction_spawn(struct_processus *s_et Line 450  instruction_spawn(struct_processus *s_et
         return;          return;
     }      }
   
 #   ifndef OS2  #   ifdef SCHED_OTHER
 #   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;
         return;          return;
     }      }
   #   endif
   
   #   ifdef PTHREAD_EXPLICIT_SCHED
     if (pthread_attr_setinheritsched(&attributs,      if (pthread_attr_setinheritsched(&attributs,
             PTHREAD_EXPLICIT_SCHED) != 0)              PTHREAD_EXPLICIT_SCHED) != 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
         return;          return;
     }      }
   #   endif
   
   #   ifdef PTHREAD_SCOPE_SYSTEM
     if (pthread_attr_setscope(&attributs, PTHREAD_SCOPE_SYSTEM) != 0)      if (pthread_attr_setscope(&attributs, PTHREAD_SCOPE_SYSTEM) != 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
         return;          return;
     }      }
 #   endif  #   endif
 #   endif  
   
     // Attente de l'affectation de la grandeur processus.tid par le thread fils.  
   
     if (pthread_mutex_lock(&((*s_nouvel_etat_processus).mutex)) != 0)  
     {  
         (*s_etat_processus).erreur_systeme = d_es_processus;  
         return;  
     }  
   
     /*      /*
      * On copie l'objet plutôt que le pointeur car cet objet peut être       * On copie l'objet plutôt que le pointeur car cet objet peut être
Line 501  instruction_spawn(struct_processus *s_et Line 490  instruction_spawn(struct_processus *s_et
   
     if (pthread_mutex_lock(&((*s_etat_processus).mutex)) != 0)      if (pthread_mutex_lock(&((*s_etat_processus).mutex)) != 0)
     {      {
           pthread_mutex_unlock(&((*s_nouvel_etat_processus).mutex));
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
         return;          return;
     }      }
Line 572  instruction_spawn(struct_processus *s_et Line 562  instruction_spawn(struct_processus *s_et
             .l_base_pile_processus), s_objet_systeme) == d_erreur)              .l_base_pile_processus), s_objet_systeme) == d_erreur)
     {      {
         pthread_mutex_unlock(&((*s_etat_processus).mutex));          pthread_mutex_unlock(&((*s_etat_processus).mutex));
         pthread_mutex_unlock(&((*s_nouvel_etat_processus).mutex));  
         return;          return;
     }      }
   
Line 585  instruction_spawn(struct_processus *s_et Line 574  instruction_spawn(struct_processus *s_et
     if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),      if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
             s_objet_resultat) == d_erreur)              s_objet_resultat) == d_erreur)
     {      {
         pthread_mutex_unlock(&((*s_nouvel_etat_processus).mutex));  
         return;          return;
     }      }
   
     if (pthread_mutex_lock(&(*s_argument_thread).mutex) != 0)      if (pthread_mutex_lock(&(*s_argument_thread).mutex) != 0)
     {      {
         pthread_mutex_unlock(&((*s_nouvel_etat_processus).mutex));  
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
         return;          return;
     }      }
Line 601  instruction_spawn(struct_processus *s_et Line 588  instruction_spawn(struct_processus *s_et
         // Le thread n'existe plus.          // Le thread n'existe plus.
   
         pthread_join((*s_argument_thread).tid, NULL);          pthread_join((*s_argument_thread).tid, NULL);
         pthread_mutex_unlock(&((*s_nouvel_etat_processus).mutex));  
         pthread_mutex_unlock(&(*s_argument_thread).mutex);          pthread_mutex_unlock(&(*s_argument_thread).mutex);
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
         return;          return;
Line 609  instruction_spawn(struct_processus *s_et Line 595  instruction_spawn(struct_processus *s_et
   
     if (pthread_mutex_unlock(&(*s_argument_thread).mutex) != 0)      if (pthread_mutex_unlock(&(*s_argument_thread).mutex) != 0)
     {      {
         pthread_mutex_unlock(&((*s_nouvel_etat_processus).mutex));  
         (*s_etat_processus).erreur_systeme = d_es_processus;  
         return;  
     }  
   
     if (pthread_mutex_unlock(&((*s_nouvel_etat_processus).mutex)) != 0)  
     {  
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
         return;          return;
     }      }
Line 727  instruction_sqlconnect(struct_processus Line 706  instruction_sqlconnect(struct_processus
         if ((s_objet_resultat = parametres_sql(s_etat_processus,          if ((s_objet_resultat = parametres_sql(s_etat_processus,
                 s_objet_argument)) == NULL)                  s_objet_argument)) == NULL)
         {          {
               liberation(s_etat_processus, s_objet_resultat);
             liberation(s_etat_processus, s_objet_argument);              liberation(s_etat_processus, s_objet_argument);
             return;              return;
         }          }
   
           if ((*s_etat_processus).erreur_execution ==
                   d_ex_instruction_indisponible)
           {
               liberation(s_etat_processus, s_objet_resultat);
               return;
           }
   
         if ((s_objet_systeme = copie_objet(s_etat_processus, s_objet_resultat,          if ((s_objet_systeme = copie_objet(s_etat_processus, s_objet_resultat,
                 'O')) == NULL)                  'O')) == NULL)
         {          {
Line 1129  instruction_smphrdecr(struct_processus * Line 1116  instruction_smphrdecr(struct_processus *
             }              }
         }          }
   
         if (pthread_mutex_unlock(&((*s_etat_processus).mutex_fork)) != 0)  #       ifndef SEMAPHORES_NOMMES
               if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)
   #       else
               if (sem_post((*s_etat_processus).semaphore_fork) != 0)
   #       endif
         {          {
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_processus;
             return;              return;
Line 1140  instruction_smphrdecr(struct_processus * Line 1131  instruction_smphrdecr(struct_processus *
         {          {
             if (errno != EINTR)              if (errno != EINTR)
             {              {
                 pthread_mutex_lock(&((*s_etat_processus).mutex_fork));  #               ifndef SEMAPHORES_NOMMES
                       sem_post(&((*s_etat_processus).semaphore_fork));
   #               else
                       sem_post((*s_etat_processus).semaphore_fork);
   #               endif
   
                 (*s_etat_processus).erreur_execution = d_ex_semaphore;                  (*s_etat_processus).erreur_execution = d_ex_semaphore;
   
                 if ((*s_etat_processus).profilage == d_vrai)                  if ((*s_etat_processus).profilage == d_vrai)
Line 1153  instruction_smphrdecr(struct_processus * Line 1149  instruction_smphrdecr(struct_processus *
             }              }
         }          }
   
         if (pthread_mutex_lock(&((*s_etat_processus).mutex_fork)) != 0)  #       ifndef SEMAPHORES_NOMMES
               while(sem_wait(&((*s_etat_processus).semaphore_fork)) != 0)
   #       else
               while(sem_wait((*s_etat_processus).semaphore_fork) != 0)
   #       endif
         {          {
             if ((*s_etat_processus).profilage == d_vrai)              if (errno != EINTR)
             {              {
                 profilage(s_etat_processus, NULL);                  if ((*s_etat_processus).profilage == d_vrai)
             }                  {
                       profilage(s_etat_processus, NULL);
                   }
   
             (*s_etat_processus).erreur_systeme = d_es_processus;                  (*s_etat_processus).erreur_systeme = d_es_processus;
             return;                  return;
               }
         }          }
   
         if ((*s_etat_processus).profilage == d_vrai)          if ((*s_etat_processus).profilage == d_vrai)
Line 1269  instruction_smphrtrydecr(struct_processu Line 1272  instruction_smphrtrydecr(struct_processu
             }              }
         }          }
   
         if (pthread_mutex_unlock(&((*s_etat_processus).mutex_fork)) != 0)  #       ifndef SEMAPHORES_NOMMES
               if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)
   #       else
               if (sem_post((*s_etat_processus).semaphore_fork) != 0)
   #       endif
         {          {
             if ((*s_etat_processus).profilage == d_vrai)              if ((*s_etat_processus).profilage == d_vrai)
             {              {
Line 1318  instruction_smphrtrydecr(struct_processu Line 1325  instruction_smphrtrydecr(struct_processu
             }              }
         }          }
   
         if (pthread_mutex_lock(&((*s_etat_processus).mutex_fork)) != 0)  #       ifndef SEMAPHORES_NOMMES
               while(sem_wait(&((*s_etat_processus).semaphore_fork)) != 0)
   #       else
               while(sem_wait((*s_etat_processus).semaphore_fork) != 0)
   #       endif
         {          {
             if ((*s_etat_processus).profilage == d_vrai)              if (errno != EINTR)
             {              {
                 profilage(s_etat_processus, NULL);                  if ((*s_etat_processus).profilage == d_vrai)
             }                  {
                       profilage(s_etat_processus, NULL);
                   }
   
             (*s_etat_processus).erreur_systeme = d_es_processus;                  (*s_etat_processus).erreur_systeme = d_es_processus;
             return;                  return;
               }
         }          }
   
         if ((*s_etat_processus).profilage == d_vrai)          if ((*s_etat_processus).profilage == d_vrai)

Removed from v.1.45  
changed lines
  Added in v.1.56


CVSweb interface <joel.bertrand@systella.fr>