--- rpl/src/daemon.c 2010/07/14 14:19:33 1.11 +++ rpl/src/daemon.c 2011/09/14 17:55:59 1.32 @@ -1,7 +1,7 @@ /* ================================================================================ - RPL/2 (R) version 4.0.18 - Copyright (C) 1989-2010 Dr. BERTRAND Joël + RPL/2 (R) version 4.1.3 + Copyright (C) 1989-2011 Dr. BERTRAND Joël This file is part of RPL/2. @@ -20,7 +20,7 @@ */ -#include "rpl.conv.h" +#include "rpl-conv.h" /* @@ -58,8 +58,19 @@ lancement_daemon(struct_processus *s_eta */ fflush(NULL); + 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) { (*s_etat_processus).erreur_systeme = d_es_processus; @@ -69,6 +80,7 @@ lancement_daemon(struct_processus *s_eta if (pid > 0) { // Fin du processus père. + destruction_queue_signaux(s_etat_processus); _exit(EXIT_SUCCESS); } @@ -97,6 +109,16 @@ lancement_daemon(struct_processus *s_eta fflush(NULL); 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) { (*s_etat_processus).erreur_systeme = d_es_processus; @@ -110,6 +132,7 @@ lancement_daemon(struct_processus *s_eta } (*s_etat_processus).pid_processus_pere = getpid(); + creation_queue_signaux(s_etat_processus); modification_pid_thread_pere(s_etat_processus); return;