Diff for /rpl/src/daemon.c between versions 1.22 and 1.45

version 1.22, 2011/06/20 17:54:14 version 1.45, 2012/10/01 11:04:59
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.1.0.prerelease.1    RPL/2 (R) version 4.1.11
   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 59  lancement_daemon(struct_processus *s_eta Line 59  lancement_daemon(struct_processus *s_eta
   
     fflush(NULL);      fflush(NULL);
   
 #   ifdef _BROKEN_SIGINFO  
     destruction_fifos_signaux(s_etat_processus);  
 #   endif  
   
     pid = fork();      pid = fork();
   
 #   ifdef OS2  
     if (pid == 0)  
     {  
         sem_init(&semaphore_liste_threads, 0, 1);  
         sem_init(&semaphore_gestionnaires_signaux, 0, 0);  
         sem_init(&semaphore_gestionnaires_signaux_atomique, 0, 1);  
         sem_init(&((*s_etat_processus).semaphore_fork), 0, 0);  
     }  
 #   endif  
   
     if (pid < 0)      if (pid < 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
Line 84  lancement_daemon(struct_processus *s_eta Line 70  lancement_daemon(struct_processus *s_eta
     if (pid > 0)      if (pid > 0)
     {      {
         // Fin du processus père.          // Fin du processus père.
   
           // À noter : dans le cas où l'on utilise l'émulation des
           // sémaphores anonymes POSIX ou la sémantique SysV, il faut
           // détruire les sémaphores et les recréer dans le processus fils.
   
   #       ifndef SEMAPHORE_NOMMES
           sem_post(&((*s_etat_processus).semaphore_fork));
           sem_destroy(&((*s_etat_processus).semaphore_fork));
   
           sem_post(&semaphore_gestionnaires_signaux);
           sem_destroy(&semaphore_gestionnaires_signaux);
   #       else
           sem_post((*s_etat_processus).semaphore_fork);
           sem_destroy3((*s_etat_processus).semaphore_fork, getpid(),
                   pthread_self(), SEM_FORK);
   
           sem_post(semaphore_gestionnaires_signaux);
           sem_destroy2(semaphore_gestionnaires_signaux, getpid(), SEM_SIGNAUX);
   #       endif
   
           destruction_queue_signaux(s_etat_processus);
         _exit(EXIT_SUCCESS);          _exit(EXIT_SUCCESS);
     }      }
   
Line 112  lancement_daemon(struct_processus *s_eta Line 119  lancement_daemon(struct_processus *s_eta
     fflush(NULL);      fflush(NULL);
     pid = fork();      pid = fork();
   
 #   ifdef _BROKEN_SIGINFO  
     creation_fifos_signaux(s_etat_processus);  
 #   endif  
   
 #   ifdef OS2  
     if (pid == 0)  
     {  
         sem_init(&semaphore_liste_threads, 0, 1);  
         sem_init(&semaphore_gestionnaires_signaux, 0, 0);  
         sem_init(&semaphore_gestionnaires_signaux_atomique, 0, 1);  
         sem_init(&((*s_etat_processus).semaphore_fork), 0, 0);  
     }  
 #   endif  
   
     if (pid < 0)      if (pid < 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
Line 139  lancement_daemon(struct_processus *s_eta Line 132  lancement_daemon(struct_processus *s_eta
     }      }
   
     (*s_etat_processus).pid_processus_pere = getpid();      (*s_etat_processus).pid_processus_pere = getpid();
       creation_queue_signaux(s_etat_processus);
     modification_pid_thread_pere(s_etat_processus);      modification_pid_thread_pere(s_etat_processus);
   
   #   ifndef SEMAPHORES_NOMMES
       sem_init(&semaphore_gestionnaires_signaux, 0, 0);
       sem_init(&((*s_etat_processus).semaphore_fork), 0, 0);
   #   else
       if ((semaphore_gestionnaires_signaux = sem_init2(0, getpid(), SEM_SIGNAUX))
               == SEM_FAILED)
       {
           (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
           return;
       }
   
       if ((sem_init(&((*s_etat_processus).semaphore_fork), 0, 0))
               == SEM_FAILED)
       {
           (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
           return;
       }
   #   endif
   
     return;      return;
 }  }
   

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


CVSweb interface <joel.bertrand@systella.fr>