Diff for /rpl/src/instructions_s10.c between versions 1.57 and 1.58

version 1.57, 2012/04/13 14:12:59 version 1.58, 2012/05/20 17:28:26
Line 1201  instruction_smphrdecr(struct_processus * Line 1201  instruction_smphrdecr(struct_processus *
 void  void
 instruction_smphrtrydecr(struct_processus *s_etat_processus)  instruction_smphrtrydecr(struct_processus *s_etat_processus)
 {  {
     struct_objet                *s_objet_argument;      real8                       partie_entiere;
   
       struct_objet                *s_objet_argument_1;
       struct_objet                *s_objet_argument_2;
     struct_objet                *s_objet_resultat;      struct_objet                *s_objet_resultat;
   
       struct timeval              horodatage;
   
       struct timespec             horodatage_absolu;
   
     unsigned char               *tampon;      unsigned char               *tampon;
   
     (*s_etat_processus).erreur_execution = d_ex;      (*s_etat_processus).erreur_execution = d_ex;
Line 1221  instruction_smphrtrydecr(struct_processu Line 1228  instruction_smphrtrydecr(struct_processu
             printf("(try to decremente semaphore)\n\n");              printf("(try to decremente semaphore)\n\n");
         }          }
   
         printf("    1: %s\n", d_SPH);          printf("    2: %s\n", d_SPH);
           printf("    1: %s, %s\n", d_INT, d_REL);
         printf("->  1: %s\n", d_INT);          printf("->  1: %s\n", d_INT);
         return;          return;
     }      }
Line 1233  instruction_smphrtrydecr(struct_processu Line 1241  instruction_smphrtrydecr(struct_processu
           
     if (test_cfsf(s_etat_processus, 31) == d_vrai)      if (test_cfsf(s_etat_processus, 31) == d_vrai)
     {      {
         if (empilement_pile_last(s_etat_processus, 1) == d_erreur)          if (empilement_pile_last(s_etat_processus, 2) == d_erreur)
         {          {
             return;              return;
         }          }
     }      }
   
     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),      if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
             &s_objet_argument) == d_erreur)              &s_objet_argument_1) == d_erreur)
     {      {
         (*s_etat_processus).erreur_execution = d_ex_manque_argument;          (*s_etat_processus).erreur_execution = d_ex_manque_argument;
         return;          return;
     }      }
   
     if ((*s_objet_argument).type == SPH)      if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
               &s_objet_argument_2) == d_erreur)
     {      {
           (*s_etat_processus).erreur_execution = d_ex_manque_argument;
           return;
       }
   
       if (((*s_objet_argument_2).type == SPH) && (((*s_objet_argument_1).type
               == INT) || ((*s_objet_argument_1).type == REL)))
       {
           gettimeofday(&horodatage, NULL);
   
           if ((*s_objet_argument_1).type == INT)
           {
               if ((*((integer8 *) (*s_objet_argument_1).objet)) < 0)
               {
                   (*s_etat_processus).erreur_execution = d_ex_argument_invalide;
   
                   liberation(s_etat_processus, s_objet_argument_1);
                   liberation(s_etat_processus, s_objet_argument_2);
                   return;
               }
   
               horodatage.tv_sec += (*((integer8 *) (*s_objet_argument_1).objet));
           }
           else
           {
               if ((*((real8 *) (*s_objet_argument_1).objet)) < 0)
               {
                   (*s_etat_processus).erreur_execution = d_ex_argument_invalide;
   
                   liberation(s_etat_processus, s_objet_argument_1);
                   liberation(s_etat_processus, s_objet_argument_2);
                   return;
               }
   
               partie_entiere = floor((*((real8 *) (*s_objet_argument_1).objet)));
               horodatage.tv_sec += partie_entiere;
               horodatage.tv_usec += (*((real8 *) (*s_objet_argument_1).objet))
                       - partie_entiere;
   
               if (horodatage.tv_usec > 1000000)
               {
                   horodatage.tv_usec -= 1000000;
                   horodatage.tv_sec += 1;
               }
           }
   
           horodatage_absolu.tv_sec = horodatage.tv_sec;
           horodatage_absolu.tv_nsec = horodatage.tv_usec * 1000;
   
         if ((s_objet_resultat = allocation(s_etat_processus, INT)) == NULL)          if ((s_objet_resultat = allocation(s_etat_processus, INT)) == NULL)
         {          {
             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;              (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
Line 1256  instruction_smphrtrydecr(struct_processu Line 1313  instruction_smphrtrydecr(struct_processu
   
         if ((*s_etat_processus).profilage == d_vrai)          if ((*s_etat_processus).profilage == d_vrai)
         {          {
             if ((tampon = formateur(s_etat_processus, 0, s_objet_argument))              if ((tampon = formateur(s_etat_processus, 0, s_objet_argument_2))
                     == NULL)                      == NULL)
             {              {
                 (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;                  (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
Line 1287  instruction_smphrtrydecr(struct_processu Line 1344  instruction_smphrtrydecr(struct_processu
             return;              return;
         }          }
   
         (*((integer8 *) (*s_objet_resultat).objet)) = 0;          (*((integer8 *) (*s_objet_resultat).objet)) = -1;
   
         while(sem_trywait((*((struct_semaphore *) (*s_objet_argument).objet))          while(sem_timedwait((*((struct_semaphore *) (*s_objet_argument_2)
                 .semaphore) == -1)                  .objet)).semaphore, &horodatage_absolu) == -1)
         {          {
             switch(errno)              switch(errno)
             {              {
Line 1308  instruction_smphrtrydecr(struct_processu Line 1365  instruction_smphrtrydecr(struct_processu
                         profilage(s_etat_processus, NULL);                          profilage(s_etat_processus, NULL);
                     }                      }
   
                     liberation(s_etat_processus, s_objet_argument);                      liberation(s_etat_processus, s_objet_argument_1);
                       liberation(s_etat_processus, s_objet_argument_2);
                     return;                      return;
                 }                  }
   
                 case EAGAIN :                  case ETIMEDOUT :
                 {                  {
                     (*((integer8 *) (*s_objet_resultat).objet)) = -1;                      (*((integer8 *) (*s_objet_resultat).objet)) = 0;
                     break;                      break;
                 }                  }
             }              }
   
             if ((*((integer8 *) (*s_objet_resultat).objet)) != 0)              if ((*((integer8 *) (*s_objet_resultat).objet)) == 0)
             {              {
                 break;                  break;
             }              }
Line 1348  instruction_smphrtrydecr(struct_processu Line 1406  instruction_smphrtrydecr(struct_processu
             profilage(s_etat_processus, NULL);              profilage(s_etat_processus, NULL);
         }          }
   
         liberation(s_etat_processus, s_objet_argument);          liberation(s_etat_processus, s_objet_argument_1);
           liberation(s_etat_processus, s_objet_argument_2);
     }      }
     else      else
     {      {
         (*s_etat_processus).erreur_execution = d_ex_erreur_type_argument;          (*s_etat_processus).erreur_execution = d_ex_erreur_type_argument;
   
         liberation(s_etat_processus, s_objet_argument);          liberation(s_etat_processus, s_objet_argument_1);
           liberation(s_etat_processus, s_objet_argument_2);
         return;          return;
     }      }
   

Removed from v.1.57  
changed lines
  Added in v.1.58


CVSweb interface <joel.bertrand@systella.fr>